[
    {
        "tags": [
            "bash",
            "curl",
            "terraform",
            "jq",
            "digital-ocean"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 90365,
                    "reputation": 240414,
                    "user_id": 248823,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/6605deca5924e84df1a4847f607b87c6?s=256&d=identicon&r=PG",
                    "display_name": "Marcin",
                    "link": "https://stackoverflow.com/users/248823/marcin"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1623630473,
                "post_id": 67951747,
                "comment_id": 120125958,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1627081301,
                "creation_date": 1627081301,
                "answer_id": 68505749,
                "question_id": 67951747,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "There are a couple modules that have been built to handle this situation and make it a lot easier to work with. [This][1] is my preferred one for a shell data source; use it with the `curl` command (forget `jq`), then use `jsondecode` on the `stdout` response and access whichever fields you need.\r\n\r\nAlternatively, instead of using `curl` you can use the [HTTP provider](https://registry.terraform.io/providers/hashicorp/http/latest/docs/data-sources/http) (if there&#39;s a way to get your token from within terraform).\r\n\r\n\r\n  [1]: https://registry.terraform.io/modules/Invicton-Labs/shell-data/external/latest",
                "title": "terraform external data not returning bash output"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1627081301,
        "creation_date": 1623521772,
        "question_id": 67951747,
        "body_markdown": "I, trying to return bash execution through Terraform `data &quot;external&quot;`, but have error:\r\n\r\n    │ jq: error (at &lt;stdin&gt;:0): Cannot iterate over null (null)\r\n    │ \r\n    │ \r\n    │   with data.external.fetchssh,\r\n    │   on dovpccloud.tf line 31, in data &quot;external&quot; &quot;fetchssh&quot;:\r\n    │   31: data &quot;external&quot; &quot;fetchssh&quot; {\r\n\r\nhowever bash script is successfully return ssh-script:\r\n\r\n    #!/bin/bash\r\n    do_token=`echo &quot;var.do-token&quot; | terraform -chdir=/input console`\r\n    curl -X GET -s -H &quot;Authorization: Bearer ${do_token//\\&quot;}&quot; &quot;https://api.digitalocean.com/v2/account/keys?page=1&quot; | jq -r --arg queryname &quot;User&#39;s key&quot; &#39;.ssh_keys[] | select(.name == $queryname).public_key&#39;\r\n\r\nit returns common ssh-rsa.\r\nAfter data &quot;external&quot; I would use this in droplet resource:\r\n\r\n    resource &quot;digitalocean_droplet&quot; &quot;web&quot; {\r\n      image  = &quot;ubuntu-18-04-x64&quot;\r\n      name   = &quot;web-1&quot;\r\n      region = &quot;lon1&quot;\r\n      size   = &quot;s-1vcpu-1gb&quot;\r\n      tags = [digitalocean_tag.devops.id, digitalocean_tag.your_email.id]\r\n      ssh_keys = [digitalocean_ssh_key.user.id, data.external.fetchssh]\r\n    }\r\n\r\n I suspect the problem is in program execution of internal terraform method, but can&#39;t get what.\r\n\r\n",
        "link": "https://stackoverflow.com/questions/67951747/terraform-external-data-not-returning-bash-output",
        "title": "terraform external data not returning bash output"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1623597861,
                "post_id": 67959650,
                "comment_id": 120118900,
                "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": 1623597942,
                "post_id": 67959650,
                "comment_id": 120118936,
                "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": 1623598369,
                "post_id": 67959650,
                "comment_id": 120119060,
                "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": 1623598946,
                "post_id": 67959650,
                "comment_id": 120119226,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1623598907,
                "last_edit_date": 1623598907,
                "creation_date": 1623598189,
                "answer_id": 67959925,
                "question_id": 67959650,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "When you put a `[0]` into your query, you&#39;re throwing away all but the first list entry. Thus, you no longer have a list. Thus, there are no more square brackets.\r\n\r\nIf you want to process _all_ items, not just the first one (and thus to generate a stream of items), and want to put that stream into a list, you might instead want:\r\n\r\n```\r\njq &#39;\r\n  .taskDefinition.containerDefinitions | map(\r\n    ( .environment[] |=\r\n      if .name == &quot;SMT_PORT_3306_TCP_ADDR&quot; then\r\n        .value = &quot;myvalue&quot;\r\n      elif .name == &quot;SERVER_API_TIMEOUT_SUBSCRIPTIONS_CANCEL_REQUEST&quot; then\r\n        .value = &quot;myvalue&quot;\r\n      else . end\r\n    ) |\r\n    .logConfiguration.options.&quot;awslogs-group&quot; = &quot;myvalue&quot;\r\n  )\r\n&#39;  &lt;&lt;&lt;&quot;$TASK_DEFINITIONS&quot; &gt;&quot;${TASK_DEFINITION_PATH}/${SERVICE_NAME}2-task-definition.json&quot;\r\n```\r\n\r\nNote the removal of `[0]`, and the use of `map()` to pass all the list elements through the transforming function.\r\n\r\n---\r\n\r\nAnother approach is to use `jq -n`, and put `inputs` inside of a list:\r\n\r\n```bash\r\njq -n &#39;\r\n  [ inputs |\r\n    .taskDefinition.containerDefinitions[] |\r\n    ( .environment[] |=\r\n      if .name == &quot;SMT_PORT_3306_TCP_ADDR&quot; then\r\n        .value = &quot;myvalue&quot;\r\n      elif .name == &quot;SERVER_API_TIMEOUT_SUBSCRIPTIONS_CANCEL_REQUEST&quot; then\r\n        .value = &quot;myvalue&quot;\r\n      else . end\r\n    ) |\r\n    .logConfiguration.options.&quot;awslogs-group&quot; = &quot;myvalue&quot;\r\n  ]\r\n&#39;  &lt;&lt;&lt;&quot;$TASK_DEFINITIONS&quot; &gt;&quot;${TASK_DEFINITION_PATH}/${SERVICE_NAME}2-task-definition.json&quot;\r\n```\r\n\r\nNote the addition of outer `[` and `]`s, the use of `inputs` inside that block, the use of the `-n` argument to `jq`, and the use of `[]` where `[0]` had been used before.",
                "title": "jq how to retain the parent square bracket while extracting and modifying content in json"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1623608003,
                "creation_date": 1623608003,
                "answer_id": 67961334,
                "question_id": 67959650,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Your jq program adds .logConfiguration whereas the &quot;expected output&quot; does not, but except for that key, the following variation of your jq program retains the `[0]` and produces the &quot;expected output&quot;:\r\n```\r\n[.taskDefinition.containerDefinitions[0]\r\n | ( .environment[] |= if .name | IN(&quot;SMT_PORT_3306_TCP_ADDR&quot;, &quot;SERVER_API_TIMEOUT_SUBSCRIPTIONS_CANCEL_REQUEST&quot;)\r\n                       then .value = &quot;myvalue&quot; else . end)\r\n | .logConfiguration.options.&quot;awslogs-group&quot; = &quot;myvalue&quot;\r\n]\r\n\r\n```\r\n\r\nComments:\r\n\r\n1. Notice how the use of `IN/1` makes the solution much DRYer. \r\n2. If your jq does not have `IN/1`, then now would be a good time to upgrade, but an alternative would be simply to include its `def`, as shown below.\r\n\r\n3. If you opt for a solution that avoids `[0]` (e.g. in favor of `map`), you could still use `IN` to avoid redundancy.\r\n\r\n---\r\n\r\n    def IN(s): first((s == .) // empty) // false;\r\n",
                "title": "jq how to retain the parent square bracket while extracting and modifying content in json"
            }
        ],
        "is_answered": false,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1623608003,
        "creation_date": 1623596545,
        "last_edit_date": 1623597591,
        "question_id": 67959650,
        "body_markdown": "I have the below JSON where I need modify few elements values and also extract only the contents inside containerDefinitions while retaining the square bracket.\r\n\r\nThe below script works in replacing the required value and extract the json inside the square brack inside containerDefinitions but leaves out the square bracket. Is there additinal command that can retain the square brackets. \r\n\r\n    echo $TASK_DEFINITION | jq &#39;.taskDefinition.containerDefinitions[0] | ( .environment[] |= if   .name == &quot;SMT_PORT_3306_TCP_ADDR&quot; then .value = &quot;myvalue&quot; elif .name == &quot;SERVER_API_TIMEOUT_SUBSCRIPTIONS_CANCEL_REQUEST&quot; then .value = &quot;myvalue&quot; else . end) | .logConfiguration.options.&quot;awslogs-group&quot; = &quot;myvalue&quot; &#39; &gt; ${TASK_DEFINITION_PATH}/${SERVICE_NAME}2-task-definition.json\r\n\r\nInput JSON\r\n\r\n    {\r\n       &quot;taskDefinition&quot;:{\r\n          &quot;taskDefinitionArn&quot;:&quot;some value&quot;,\r\n          &quot;containerDefinitions&quot;:[\r\n             {\r\n                &quot;name&quot;:&quot;common-api-img&quot;,\r\n                &quot;environment&quot;:[\r\n                   {\r\n                      &quot;name&quot;:&quot;SERVER_API_TIMEOUT_SUBSCRIPTIONS_CANCEL_REQUEST&quot;,\r\n                      &quot;value&quot;:&quot;false&quot;\r\n                   },\r\n                   {\r\n                      &quot;name&quot;:&quot;SMT_PORT_3306_TCP_ADDR&quot;,\r\n                      &quot;value&quot;:&quot;valueToReplace&quot;\r\n                   }\r\n                ],\r\n                &quot;mountPoints&quot;:[\r\n                   \r\n                ],\r\n                &quot;volumesFrom&quot;:[\r\n                   \r\n                ]\r\n             }\r\n          ],\r\n          &quot;revision&quot;:65,\r\n          &quot;volumes&quot;:[\r\n             \r\n          ],\r\n          &quot;status&quot;:&quot;ACTIVE&quot;\r\n       }\r\n    }\r\nexpected output\r\n\r\n    [\r\n       {\r\n          &quot;name&quot;:&quot;common-api-img&quot;,\r\n          &quot;environment&quot;:[\r\n             {\r\n                &quot;name&quot;:&quot;SERVER_API_TIMEOUT_SUBSCRIPTIONS_CANCEL_REQUEST&quot;,\r\n                &quot;value&quot;:&quot;myvalue&quot;\r\n             },\r\n             {\r\n                &quot;name&quot;:&quot;SMT_PORT_3306_TCP_ADDR&quot;,\r\n                &quot;value&quot;:&quot;myvalue&quot;\r\n             }\r\n          ],\r\n          &quot;mountPoints&quot;:[\r\n             \r\n          ],\r\n          &quot;volumesFrom&quot;:[\r\n             \r\n          ]\r\n       }\r\n    ]\r\n\r\n",
        "link": "https://stackoverflow.com/questions/67959650/jq-how-to-retain-the-parent-square-bracket-while-extracting-and-modifying-conten",
        "title": "jq how to retain the parent square bracket while extracting and modifying content in json"
    },
    {
        "tags": [
            "json",
            "jq",
            "export-to-tsv"
        ],
        "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": 1623661881,
                "post_id": 67964539,
                "comment_id": 120132960,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1623644441,
                "last_edit_date": 1623644441,
                "creation_date": 1623643873,
                "answer_id": 67964700,
                "question_id": 67964539,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Using jq with the -r command-line option:\r\n```\r\n(.events.dividends|map_values(.amount)) as $dividends\r\n| [&quot;timestamp&quot;, &quot;open&quot;, &quot;high&quot;, &quot;dividends&quot;],\r\n  ( [.timestamp, (.indicators.quote[0] | .open, .high),\r\n     [$dividends[.timestamp[]|tostring]]]\r\n    | transpose[])\r\n| @tsv\r\n\r\n```\r\n\r\nNotice how the dividends column is computed using the provided $dividends dictionary:\r\n\r\n    $dividends[.timestamp[]|tostring]\r\n \r\n",
                "title": "Join array and dictionary into TSV in jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -1,
        "last_activity_date": 1654357169,
        "creation_date": 1623641920,
        "last_edit_date": 1654357169,
        "question_id": 67964539,
        "body_markdown": "I have the input JSON data at the bottom.\r\n\r\nI&#39;d like to generate a TSV output like the following. `&lt;TAB&gt;` is the TAB character. How can I do it in jq?\r\n\r\n```\r\ntimestamp&lt;TAB&gt;open&lt;TAB&gt;high&lt;TAB&gt;dividends\r\n1623072600&lt;TAB&gt;4229.33984375&lt;TAB&gt;4232.33984375&lt;TAB&gt;\r\n1623159000&lt;TAB&gt;4233.81005859375&lt;TAB&gt;4236.740234375&lt;TAB&gt;\r\n1623245400&lt;TAB&gt;4232.990234375&lt;TAB&gt;4237.08984375&lt;TAB&gt;0.42\r\n1623331800&lt;TAB&gt;4228.56005859375&lt;TAB&gt;4249.740234375&lt;TAB&gt;\r\n1623418200&lt;TAB&gt;4242.89990234375&lt;TAB&gt;4248.3798828125&lt;TAB&gt;\r\n```\r\n\r\n```\r\n{\r\n  &quot;timestamp&quot;: [\r\n    1623072600,\r\n    1623159000,\r\n    1623245400,\r\n    1623331800,\r\n    1623418200\r\n  ],\r\n  &quot;indicators&quot;: {\r\n    &quot;quote&quot;: [\r\n      {\r\n        &quot;open&quot;: [\r\n          4229.33984375,\r\n          4233.81005859375,\r\n          4232.990234375,\r\n          4228.56005859375,\r\n          4242.89990234375\r\n        ],\r\n        &quot;high&quot;: [\r\n          4232.33984375,\r\n          4236.740234375,\r\n          4237.08984375,\r\n          4249.740234375,\r\n          4248.3798828125\r\n        ]\r\n      }\r\n    ]\r\n  },\r\n  &quot;events&quot;: {\r\n    &quot;dividends&quot;: {\r\n      &quot;1623245400&quot;: {\r\n        &quot;amount&quot;: 0.42,\r\n        &quot;date&quot;: 1623245400\r\n      }\r\n    }\r\n  }\r\n}\r\n```",
        "link": "https://stackoverflow.com/questions/67964539/join-array-and-dictionary-into-tsv-in-jq",
        "title": "Join array and dictionary into TSV in jq"
    },
    {
        "tags": [
            "json",
            "jq",
            "import-from-csv"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1623685468,
                "creation_date": 1623685468,
                "answer_id": 67973361,
                "question_id": 67971376,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "It&#39;d be more intuitive if sid, year, quarter, etc. were to be key names. With `-R/--raw-input` and `-n/--null-input` options on the command line, this will do that:\r\n```\r\nreduce (inputs / &quot;,&quot;)\r\n  as [$sid, $year, $quarter, $type, $obj]\r\n(.; .[$sid][$year][$quarter] += [{$type, $obj}])\r\n```\r\nAnd, to get your expected output you can append these lines to the above program.\r\n```\r\n| .[][] |= (to_entries | map({quarter: .key, customer_type: .value}))\r\n| .[]   |= (to_entries | map({year:    .key, quarters:      .value}))\r\n| .     |= (to_entries | map({sid:     .key, years:         .value}))\r\n```",
                "title": "Import JSON from CSV, grouping by multiple fields"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -3,
        "last_activity_date": 1623685669,
        "creation_date": 1623678164,
        "last_edit_date": 1623685669,
        "question_id": 67971376,
        "body_markdown": "I would like to create a JSON with array of nested objects with a grouping for different fields. \r\nThis is the CSV and Iwould like to group it by sid, year and quarter (first three fields):\r\n\r\n```\r\nS4446B3,2020,202001,2,345.45\r\nS4446B3,2020,202001,4,24.44\r\nS4446B3,2021,202102,5,314.55\r\nS6506LK,2020,202002,3,376.55\r\nS6506LK,2020,202003,3,76.23\r\n```\r\n\r\nAfter splitting the CSV with the following I get an object for each record.\r\n```\r\nsplit(&quot;\\n&quot;) \r\n   | map(split(&quot;,&quot;)) \r\n   | .[0:] \r\n   | map({&quot;sid&quot; : .[0], &quot;year&quot; : .[1], &quot;quarter&quot; : .[2], &quot;customer_type&quot; : .[3], &quot;obj&quot; : .[4]})\r\n```\r\n\r\nBut for each sid I would like to get an array of objects nested like this : \r\n```\r\n[\r\n    {\r\n        &quot;sid&quot; : &quot;S4446B3&quot;,\r\n        &quot;years&quot; : [\r\n            {\r\n                &quot;year&quot; : 2020,\r\n                &quot;quarters&quot; : [\r\n                    {\r\n                        &quot;quarter&quot; : 202001,\r\n                        &quot;customer_type&quot; : [\r\n                            {\r\n                                &quot;type&quot; : 2,\r\n                                &quot;obj&quot; : &quot;345.45&quot;\r\n                            },\r\n                            {\r\n                                &quot;type&quot; : 4,\r\n                                &quot;obj&quot; : &quot;24.44&quot;\r\n                            }\r\n                        ]\r\n                    }\r\n                ]\r\n            },\r\n            {\r\n                &quot;year&quot; : 2021,\r\n                &quot;quarters&quot; : [\r\n                    {\r\n                        &quot;quarter&quot; : 202102,\r\n                        &quot;customer_type&quot; : [\r\n                            {\r\n                                &quot;type&quot; : 5,\r\n                                &quot;obj&quot; : &quot;314.55&quot;\r\n                            }\r\n                        ]\r\n                    }\r\n                ]\r\n            }\r\n        ]\r\n    },\r\n    {\r\n        &quot;sid&quot; : &quot;S6506LK&quot;,\r\n        &quot;years&quot; : [\r\n            {\r\n                &quot;year&quot; : 2020,\r\n                &quot;quarters&quot; : [\r\n                    {\r\n                        &quot;quarter&quot; : 202002,\r\n                        &quot;customer_type&quot; : [\r\n                            {\r\n                                &quot;type&quot; : 3,\r\n                                &quot;obj&quot; : &quot;376.55&quot;\r\n                            }\r\n                        ]\r\n                    },\r\n                    {\r\n                        &quot;quarter&quot; : 202003,\r\n                        &quot;customer_type&quot; : [\r\n                            {\r\n                                &quot;type&quot; : 3,\r\n                                &quot;obj&quot; : &quot;76.23&quot;\r\n                            }\r\n                        ]\r\n                    }\r\n                ]\r\n            }\r\n        ]\r\n    }\r\n]\r\n```",
        "link": "https://stackoverflow.com/questions/67971376/import-json-from-csv-grouping-by-multiple-fields",
        "title": "Import JSON from CSV, grouping by multiple fields"
    },
    {
        "tags": [
            "json",
            "bash",
            "file",
            "jq",
            "git-bash"
        ],
        "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": 1623701310,
                "post_id": 67975407,
                "comment_id": 120148740,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "reply_to_user": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1623705192,
                "post_id": 67975407,
                "comment_id": 120149958,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "reply_to_user": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1623706025,
                "post_id": 67975407,
                "comment_id": 120150176,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "reply_to_user": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1623709779,
                "post_id": 67975407,
                "comment_id": 120151076,
                "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": 1623758728,
                "post_id": 67975407,
                "comment_id": 120164623,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1623708296,
                "last_edit_date": 1623708296,
                "creation_date": 1623701373,
                "answer_id": 67976603,
                "question_id": 67975407,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "This is a job that `xargs` is created to fix -- splitting lists of items into individual command lines that are within the permitted limit.\r\n\r\nBecause running `jq -s` a single time is different from concatenating the results of multiple smaller runs, it&#39;s appropriate to use `xargs` to combine `cat` invocations using the manner described in the linked duplicate.\r\n\r\n```\r\nprintf &#39;%s\\0&#39; inventoryItem_*.json \\\r\n  | xargs -0 cat \\\r\n  | jq -s . \\\r\n  &gt;&quot;inventory_items_result_$(date +&quot;%Y%m%d_%H%M%S&quot;).json&quot;\r\n```",
                "title": "How to merge json objects into single array in bash"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1623758699,
        "creation_date": 1623695174,
        "last_edit_date": 1623709629,
        "question_id": 67975407,
        "body_markdown": "There are more than 6k JSON files, each containing exactly one JSON object. I want to prepare one list of objects from these JSONs. \r\n\r\nWhen I am running below `jq` command I am getting an error.\r\n\r\n```\r\nKedar.Javalkar@KD2806 MINGW64 /c/zz\r\n$ jq -s &#39;.&#39; inventoryItem_*.json &gt; inventory_items_result_$(date +&quot;%Y%m%d_%H%M%S&quot;).json\r\nbash: /usr/bin/jq: Argument list too long\r\n```\r\n\r\nI tried `ulimit -s unlimited` but the same error\r\n\r\nI am using a windows 10 git bash",
        "link": "https://stackoverflow.com/questions/67975407/how-to-merge-json-objects-into-single-array-in-bash",
        "title": "How to merge json objects into single array in bash"
    },
    {
        "tags": [
            "jquery",
            "regex",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 3959308,
                    "reputation": 53394,
                    "user_id": 3266847,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/U0oyt.png?s=256",
                    "display_name": "Benjamin W.",
                    "link": "https://stackoverflow.com/users/3266847/benjamin-w"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1623705881,
                "post_id": 67977314,
                "comment_id": 120150127,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 21901809,
                    "reputation": 1,
                    "user_id": 16187386,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/ea29d52c0c4966a5b6708fda7dcff6f7?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Nva",
                    "link": "https://stackoverflow.com/users/16187386/nva"
                },
                "reply_to_user": {
                    "account_id": 3959308,
                    "reputation": 53394,
                    "user_id": 3266847,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/U0oyt.png?s=256",
                    "display_name": "Benjamin W.",
                    "link": "https://stackoverflow.com/users/3266847/benjamin-w"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1623706025,
                "post_id": 67977314,
                "comment_id": 120150174,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 3959308,
                    "reputation": 53394,
                    "user_id": 3266847,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/U0oyt.png?s=256",
                    "display_name": "Benjamin W.",
                    "link": "https://stackoverflow.com/users/3266847/benjamin-w"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1623707267,
                "post_id": 67977314,
                "comment_id": 120150503,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1623725096,
                "creation_date": 1623725096,
                "answer_id": 67979340,
                "question_id": 67977314,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "\r\n    .doc |= map_values(if has(&quot;cNames&quot;)\r\n                       then .cNames |= [splits(&quot; *[0-9]+ *&quot;)][1:]\r\n                       else . end)",
                "title": "to transform output of JSON based on the no.of names"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": -2,
        "last_activity_date": 1623725096,
        "creation_date": 1623705451,
        "last_edit_date": 1623707264,
        "question_id": 67977314,
        "body_markdown": "Input is data extracted from card.\r\nFinding it difficult to extract especially because the **0.jpg** is dynamically generated based on the name of image\r\n\r\n.doc.0.jpg becomes invalid and so unable to fetch values under 0.jpg\r\n\r\n```\r\n&quot;doc&quot;: {\r\n    &quot;0.jpg&quot;: {\r\n      &quot;cNumber&quot;: &quot;6218961 450 3875&quot;,\r\n      &quot;cNames&quot;: &quot; 1 VEN NUT 2 SIRKA SARTH&quot;,\r\n      &quot;cExpiry&quot;: &quot;09/2025&quot;\r\n    },\r\n    &quot;number&quot;: {\r\n      &quot;nTotal&quot;: 3,\r\n      &quot;nRequires&quot;: 3,\r\n      &quot;nDocuments&quot;: 1\r\n    }\r\n  }\r\n```\r\n\r\nI should be able to extract the names based on the number in cNames\r\n\r\nOutput should be\r\n\r\n```\r\n&quot;doc&quot;: {\r\n    &quot;0.jpg&quot;: {\r\n      &quot;cNumber&quot;: &quot;6218961 450 3875&quot;,\r\n      &quot;cNames&quot;: [ &quot;VEN NUT&quot;,\r\n                  &quot;SIRKA SARTH&quot;],\r\n      &quot;cExpiry&quot;: &quot;09/2025&quot;\r\n    },\r\n    &quot;number&quot;: {\r\n      &quot;nTotal&quot;: 3,\r\n      &quot;nRequires&quot;: 3,\r\n      &quot;nDocuments&quot;: 1\r\n    }\r\n  }\r\n```",
        "link": "https://stackoverflow.com/questions/67977314/to-transform-output-of-json-based-on-the-no-of-names",
        "title": "to transform output of JSON based on the no.of names"
    },
    {
        "tags": [
            "json",
            "tags",
            "export-to-csv",
            "jq",
            "aws-cli"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1623722094,
                "creation_date": 1623722094,
                "answer_id": 67979057,
                "question_id": 67978941,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "To achieve the &quot;expected&quot; output given the &quot;actual&quot; output, you could use the following filter:\r\n\r\n    .ResourceTagMappingList[].Tags\r\n     |= map(select(.Key|IN(&quot;ApplicationName&quot;,&quot;Owner&quot;,&quot;ProjectName&quot;)))\r\n\r\nTo achieve the expected CSV, it would be helpful to know what you expect. ",
                "title": "How to filter json file with specific tag values and get output into csv"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1624118004,
        "creation_date": 1623720988,
        "last_edit_date": 1624118004,
        "question_id": 67978941,
        "body_markdown": "I have created a json file with the output having key values pair. But I would like to filter more   and get only specific tags and get new output in table using excel (csv) format\r\n\r\n\r\n```\r\naws resourcegroupstaggingapi get-resources --tags-per-page 100 --tag-filters Key=ProjectName,Values=Avengers &gt; tag-filter.json\r\n```\r\n\r\nHowever it provides the list of all the tags besides &quot;ProjectName&quot;. I would like to filter the output with 2 more tags with their values but not all of them:\r\n\r\nActual results:\r\n```\r\n{\r\n    &quot;ResourceTagMappingList&quot;: [\r\n        {\r\n            &quot;ResourceARN&quot;: &quot;arn:aws:app:us-east-1:XXXX/mesh/Avenger1&quot;,\r\n            &quot;Tags&quot;: [\r\n                {\r\n                    &quot;Key&quot;: &quot;ApplicationName&quot;,\r\n                    &quot;Value&quot;: &quot;HULK&quot;\r\n                },\r\n                {\r\n                    &quot;Key&quot;: &quot;Owner&quot;,\r\n                    &quot;Value&quot;: &quot;Mark Ruffalo&quot;\r\n                },\r\n                {\r\n                    &quot;Key&quot;: &quot;Costume&quot;,\r\n                    &quot;Value&quot;: &quot;GREEN&quot;\r\n                },\r\n                {\r\n                    &quot;Key&quot;: &quot;Power&quot;,\r\n                    &quot;Value&quot;: &quot;SMASH&quot;\r\n                },\r\n                {\r\n                    &quot;Key&quot;: &quot;ProjectName&quot;,\r\n                    &quot;Value&quot;: &quot;Avengers&quot;\r\n                }\r\n            ]\r\n        },\r\n        {\r\n            &quot;ResourceARN&quot;: &quot;arn:aws:app:us-east-1:XXXX:mesh/Avenger2&quot;,\r\n            &quot;Tags&quot;: [\r\n                {\r\n                    &quot;Key&quot;: &quot;ApplicationName&quot;,\r\n                    &quot;Value&quot;: &quot;IRON-MAN&quot;\r\n                },\r\n                {\r\n                    &quot;Key&quot;: &quot;Owner&quot;,\r\n                    &quot;Value&quot;: &quot;Robert Downey Jr.&quot;\r\n                },\r\n                {\r\n                    &quot;Key&quot;: &quot;Costume&quot;,\r\n                    &quot;Value&quot;: &quot;RED&quot;\r\n                },\r\n                {\r\n                    &quot;Key&quot;: &quot;Power&quot;,\r\n                    &quot;Value&quot;: &quot;SuperSonic&quot;\r\n                },\r\n                {\r\n                    &quot;Key&quot;: &quot;ProjectName&quot;,\r\n                    &quot;Value&quot;: &quot;Avengers&quot;\r\n                }\r\n            ]\r\n        }\r\n\t]\r\n}\t\r\n\r\n```\r\n\r\nExpected Results:\r\n\r\n```\r\n{\r\n    &quot;ResourceTagMappingList&quot;: [\r\n        {\r\n            &quot;ResourceARN&quot;: &quot;arn:aws:app:us-east-1:XXXX/mesh/Avenger1&quot;,\r\n            &quot;Tags&quot;: [\r\n                {\r\n                    &quot;Key&quot;: &quot;ApplicationName&quot;,\r\n                    &quot;Value&quot;: &quot;HULK&quot;\r\n                },\r\n                {\r\n                    &quot;Key&quot;: &quot;Owner&quot;,\r\n                    &quot;Value&quot;: &quot;Mark Ruffalo&quot;\r\n                },\r\n                {\r\n                    &quot;Key&quot;: &quot;ProjectName&quot;,\r\n                    &quot;Value&quot;: &quot;Avengers&quot;\r\n                }\r\n            ]\r\n        },\r\n        {\r\n            &quot;ResourceARN&quot;: &quot;arn:aws:app:us-east-1:XXXX:mesh/Avenger2&quot;,\r\n            &quot;Tags&quot;: [\r\n                {\r\n                    &quot;Key&quot;: &quot;ApplicationName&quot;,\r\n                    &quot;Value&quot;: &quot;IRON-MAN&quot;\r\n                },\r\n                {\r\n                    &quot;Key&quot;: &quot;Owner&quot;,\r\n                    &quot;Value&quot;: &quot;Robert Downey Jr.&quot;\r\n                },\r\n                {\r\n                    &quot;Key&quot;: &quot;ProjectName&quot;,\r\n                    &quot;Value&quot;: &quot;Avengers&quot;\r\n                }\r\n            ]\r\n        }\r\n\t]\r\n}\r\n```",
        "link": "https://stackoverflow.com/questions/67978941/how-to-filter-json-file-with-specific-tag-values-and-get-output-into-csv",
        "title": "How to filter json file with specific tag values and get output into csv"
    },
    {
        "tags": [
            "bash",
            "macos",
            "zsh",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 183306,
                    "reputation": 11207,
                    "user_id": 418599,
                    "user_type": "registered",
                    "accept_rate": 52,
                    "profile_image": "https://i.sstatic.net/QDDnf.jpg?s=256",
                    "display_name": "Antonio Petricca",
                    "link": "https://stackoverflow.com/users/418599/antonio-petricca"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1623737118,
                "post_id": 67980820,
                "comment_id": 120155778,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1623737878,
                "post_id": 67980820,
                "comment_id": 120156052,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2148798,
                    "reputation": 124,
                    "user_id": 1905759,
                    "user_type": "registered",
                    "accept_rate": 25,
                    "profile_image": "https://www.gravatar.com/avatar/fafd0052824c4b5bd048051aa7b11ffd?s=256&d=identicon&r=PG",
                    "display_name": "capa_matrix",
                    "link": "https://stackoverflow.com/users/1905759/capa-matrix"
                },
                "reply_to_user": {
                    "account_id": 183306,
                    "reputation": 11207,
                    "user_id": 418599,
                    "user_type": "registered",
                    "accept_rate": 52,
                    "profile_image": "https://i.sstatic.net/QDDnf.jpg?s=256",
                    "display_name": "Antonio Petricca",
                    "link": "https://stackoverflow.com/users/418599/antonio-petricca"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1623738554,
                "post_id": 67980820,
                "comment_id": 120156316,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1623740058,
                "last_edit_date": 1623740058,
                "creation_date": 1623737616,
                "answer_id": 67980915,
                "question_id": 67980820,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "```\r\njq &#39;.Changes[0].ResourceRecordSet.Name = &quot;word-is-here.domain.com&quot;&#39; file.json\r\n```\r\nQuote the string you are assigning. Or pass it to jq via an argument:\r\n```\r\njq --arg foo &#39;words-here&#39; &#39;.Changes[0].ResourceRecordSet.Name = $foo&#39; file.json\r\n```\r\nFor passing the path to the key you want as an argument, a suggestion from https://github.com/stedolan/jq/issues/1493 might work:\r\n```\r\njq --argjson path &#39;[&quot;Changes&quot;,0,&quot;ResourceRecordSet&quot;,&quot;Name&quot;]&#39; \\\r\n  --arg val &#39;word-is-here.domain.com&#39; \\\r\n  &#39;getpath($path) = $val&#39; file.json\r\n```",
                "title": "jq produces `is not defined at &lt;top-level&gt;` error"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1623746016,
                "last_edit_date": 1623746016,
                "creation_date": 1623737768,
                "answer_id": 67980946,
                "question_id": 67980820,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The problem (or at least the obvious problem) here is evidently the string: `word-is-here.domain.com`, since jq is interpreting the dash (&quot;-&quot;) as an operation (&quot;minus&quot;).\r\n\r\nUnfortunately, since you haven&#39;t given us many clues, it&#39;s not completely clear what specifically needs to be changed, but a reasonable guess is that `word-is-here.domain.com` is intended as a fixed string.  If so, you would have to present it as a JSON string.  So in a bash or bash-like environment, you could write: \r\n```\r\njq &#39;.Changes[0].ResourceRecordSet.Name = &quot;word-is-here.domain.com&quot;&#39; someFile.json\r\n```\r\n\r\n### Specifying the LHS path via a shell variable\r\n\r\nIf the LHS path must be specified by a shell variable, it should if possible be passed in as a JSON array, e.g. using the `--argjson` command-line option; one can then use an expression of the form `setpath($path; $value)` to update the path.  \r\n\r\nIf for some reason a solution allowing the LHS to be specified as a jq path is preferred, then shell string-interpolation could be used, though as with any such interpolation, this should be done with care.\r\n",
                "title": "jq produces `is not defined at &lt;top-level&gt;` error"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": -1,
        "last_activity_date": 1623746016,
        "creation_date": 1623736981,
        "last_edit_date": 1623738445,
        "question_id": 67980820,
        "body_markdown": "I&#39;m seeing a `is not defined at &lt;top-level&gt;` when calling jq like so:\r\n\r\n```\r\njq &quot;.Changes[0].ResourceRecordSet.Name = word-is-here.domain.com&quot; someFile.json\r\n```\r\n\r\nThe error repeats for each word separated by a dash in the second side of the replacement. The full error is like\r\n\r\n```\r\njq: error: word/0 is not defined at &lt;top-level&gt;, line 1:\r\n.Changes[0].ResourceRecordSet.Name = word-is-here.domain.com\r\n```\r\n\r\nI&#39;ve tried escaping quotes in many different ways but that didn&#39;t help. (what I mean by this is doing &quot;&#39;&quot;&#39;&quot; weird stuff, I&#39;m still learning bash so I&#39;m just trowing stuff at the wall until it sticks)\r\n\r\n**EDIT:**\r\nSo I&#39;m trying to run this in a bash script, and both side of the = signs are variables such as `jq --arg value &quot;$value&quot; --arg key &quot;$key&quot; &#39;$key = $value&#39; &quot;$path&quot;` (what I tried after a suggestion) \r\n\r\nand got the error:\r\nInvalid path expression with result &quot;.Changes[0].ResourceRecor...\r\n\r\n\r\nThe json I&#39;m using is as such:\r\n```\r\n{\r\n  &quot;Changes&quot;: [\r\n    {\r\n      &quot;Action&quot;: &quot;do something&quot;,\r\n      &quot;ResourceRecordSet&quot;: {\r\n        &quot;Name&quot;: &quot;some name here to replace&quot;,\r\n         ...\r\n      }\r\n    }\r\n  ]\r\n}\r\n```",
        "link": "https://stackoverflow.com/questions/67980820/jq-produces-is-not-defined-at-top-level-error",
        "title": "jq produces `is not defined at &lt;top-level&gt;` error"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 21925990,
                    "reputation": 71,
                    "user_id": 16208606,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/7e9bd6f11b37fd52c059d82157803246?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "h0llym0lly",
                    "link": "https://stackoverflow.com/users/16208606/h0llym0lly"
                },
                "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": 1623746786,
                "post_id": 67982781,
                "comment_id": 120159487,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1623748757,
                "last_edit_date": 1623748757,
                "creation_date": 1623748491,
                "answer_id": 67983432,
                "question_id": 67982781,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You could and probably should perform the update using jq without complicating things using other programs as well.\r\n\r\nAssuming an invocation of jq using `—-argson tenantname` appropriately, the jq filter would be along these lines:\r\n\r\n    ._source.alertruleindexpattern \r\n    |= $tenantname + &quot;-&quot; + sub(&quot;-?[*]$&quot;;&quot;&quot;)",
                "title": "Concatenate string in JSON field and truncate last characters"
            },
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": -1,
                "last_activity_date": 1623749845,
                "creation_date": 1623749845,
                "answer_id": 67983747,
                "question_id": 67982781,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "This will do it:\r\n\r\n~~~\r\necho &quot;$json&quot; | \r\n  jq --arg prefix tenant-lta- \\\r\n    &#39;{alertruleindexpattern: ($prefix + (._source.alertruleindexpattern | match(&quot;(.*?)(?=-\\\\*$|$)&quot;).captures[0].string))}&#39;\r\n~~~",
                "title": "Concatenate string in JSON field and truncate last characters"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1623749845,
        "creation_date": 1623746045,
        "last_edit_date": 1623746928,
        "question_id": 67982781,
        "body_markdown": "I want to add a string (which is a script argument - in this case &quot;tenant-lta&quot;) in JSON objects to a value in field &quot;alertruleindexpattern&quot; and truncate `-*` or `*` if it is at the end of the string. Could someone help me with this?\r\n\r\n\r\nJSON Object:\r\n\r\n```\r\n{\r\n  &quot;_index&quot;: &quot;.alertrules&quot;,\r\n  &quot;_type&quot;: &quot;_doc&quot;,\r\n  &quot;_id&quot;: &quot;tenant-lta_Windows_Admin_task_as_user&quot;,\r\n  &quot;_score&quot;: 0.07554413,\r\n  &quot;_source&quot;: {\r\n    &quot;alertrulemethoddata&quot;: &quot;&quot;,\r\n    &quot;alertruleimportance&quot;: 50,\r\n    &quot;alertruletype&quot;: &quot;any&quot;,\r\n    &quot;alertrule_any&quot;: &quot;filter:\\n - query_string:\\n     query: \\&quot;event_id:4732 AND NOT user.role:admin\\&quot;&quot;,\r\n    &quot;alertrulemethodusers&quot;: [],\r\n    &quot;alertrulemethod&quot;: &quot;none&quot;,\r\n    &quot;alertruleindexpattern&quot;: &quot;winlogbeat-*&quot;,\r\n    &quot;alertruleplaybooks&quot;: [],\r\n    &quot;alertrulefilename&quot;: &quot;tenant-lta_Windows_Admin_task_as_user&quot;,\r\n    &quot;alertrulename&quot;: &quot;tenant-lta-Windows - Admin task as user&quot;,\r\n    &quot;enable&quot;: &quot;N&quot;,\r\n    &quot;selectedroles&quot;: [\r\n      &quot;tenant-lta&quot;\r\n    ],\r\n    &quot;alertruleriskkeyaggregation&quot;: &quot;MAX&quot;,\r\n    &quot;authenticator&quot;: &quot;index&quot;,\r\n    &quot;alertruleriskkey&quot;: &quot;&quot;,\r\n    &quot;changed&quot;: false\r\n  }\r\n}\r\n\r\n```\r\n\r\nDesired output in field `alertruleindexpattern`:\r\n```\r\n{\r\n    &quot;alertruleindexpattern&quot;: &quot;tenant-lta-winlogbeat&quot;,\r\n    \r\n}\r\n```\r\nMy attempts:\r\n\r\n```\r\nruleindexpattern=`echo &quot;$i&quot; | jq &#39;._source.alertruleindexpattern&#39; | pcregrep -o1 &#39;&quot;(.*?)[-]?\\*&quot;$&#39;`\r\nsed -i &#39;s/\\&quot;alertruleindexpattern\\&quot;:\\&quot;&#39;$ruleindexpattern&#39;\\&quot;/\\&quot;alertruleindexpattern\\&quot;:\\&quot;&#39;$tenantname&#39;-&#39;$ruleindexpattern&#39;\\&quot;/g&#39; $alert_file\r\n```\r\n",
        "link": "https://stackoverflow.com/questions/67982781/concatenate-string-in-json-field-and-truncate-last-characters",
        "title": "Concatenate string in JSON field and truncate last characters"
    },
    {
        "tags": [
            "bash",
            "jq",
            "github-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": 1,
                "creation_date": 1623762367,
                "post_id": 67986766,
                "comment_id": 120166244,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1623771371,
                "last_edit_date": 1623771371,
                "creation_date": 1623770778,
                "answer_id": 67989169,
                "question_id": 67986766,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "GitHub API tells if there are more result pages in the `link` header.\r\n\r\nYou can obtain the last result page by parsing the `link` header for example with `awk` like this:\r\n\r\n*The `per_page=1` is here to force excessive paging of the results for the purpose of demonstrating how to parse GitHub API&#39;s `link` header.*.\r\n\r\n\r\n**DO NOT DO THIS IN PRODUCTION** as it would be very inefficient\r\n\r\n```sh\r\n#!/usr/bin/env bash\r\n\r\nAPI=&#39;https://api.github.com&#39;\r\n\r\n# DO NOT SET IT TO 1 IN PRODUCTION\r\nper_page=1\r\n\r\n# Get the last page\r\nlast_page=$(\r\n  curl \\\r\n    --silent \\\r\n    --head \\\r\n    --header &quot;Accept: application/vnd.github.v3+json&quot; \\\r\n    --url &quot;${API}/repos/jina-ai/jina/pulls?per_page=${per_page}&amp;state=opened&quot; |\r\n      awk -F&#39;,&#39; &#39;\r\n/^link:/{\r\n  for(i=1; i &lt;= NF; i++) {\r\n    if(match($i, &quot;[&amp;?]page=([0-9]+).*rel=\\&quot;last\\&quot;&quot;, a)) print a[1]\r\n  }\r\n}&#39;\r\n)\r\n\r\n# In case there is no paging, we need to set this to 1)\r\nlast_page=${last_page:-1}\r\n\r\nfor ((page=1; page &lt;= last_page; page++)); do\r\n  curl \\\r\n    --silent \\\r\n    --header &quot;Accept: application/vnd.github.v3+json&quot; \\\r\n    --url &quot;${API}/repos/jina-ai/jina/pulls?per_page=${per_page}&amp;page=${page}&amp;state=opened&quot; |\r\n    jq &#39;.[] | (.user.login, .labels)&#39;\r\ndone\r\n```\r\n",
                "title": "JQ filter and github api"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1623771371,
        "creation_date": 1623762007,
        "question_id": 67986766,
        "body_markdown": "I have a simple task to write the script with curl and jq, which will print the number of pull requests of each contributor has created with the labels.\r\nI was able to filter pull requests by contributor:\r\n```\r\ncurl -H &quot;Accept: application/vnd.github.v3+json&quot; https://api.github.com/repos/jina-ai/jina/pulls?state=opened | jq &#39;. [] | .user.login, .labels&#39;\r\n```\r\nBut how to deal next, maybe U can sugest something.\r\n\r\nThanks",
        "link": "https://stackoverflow.com/questions/67986766/jq-filter-and-github-api",
        "title": "JQ filter and github api"
    },
    {
        "tags": [
            "json",
            "bash",
            "shell",
            "export-to-csv",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1623765397,
                "last_edit_date": 1623765397,
                "creation_date": 1623764084,
                "answer_id": 67987322,
                "question_id": 67987088,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "With the [alternative operator `//`][1]:\r\n\r\n```sh\r\njq -r &#39;.[] | (.Actions[].Event // &quot;none&quot;) as $e | [ .Name, $e ] | @csv&#39;\r\n```\r\n\r\nThis assumes that the missing comma on line 20 hast been inserted.\r\n\r\n\r\n  [1]: https://stedolan.github.io/jq/manual/#Alternativeoperator://",
                "title": "Including empty JSON values in jq output"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1623765397,
        "creation_date": 1623763257,
        "last_edit_date": 1623764587,
        "question_id": 67987088,
        "body_markdown": "I&#39;m trying to get a .csv out that includes occasional empty values.\r\n\r\nCalling this API (https://www.campaignmonitor.com/api/subscribers/#getting-subscribers-details) I get the following:\r\n\r\n```\r\n[\r\n    {\r\n        &quot;ID&quot;: &quot;fc0ce7105baeaf97f47c99be31d02a91&quot;,\r\n        &quot;Type&quot;: &quot;Campaign&quot;,\r\n        &quot;Name&quot;: &quot;Campaign One&quot;,\r\n        &quot;Actions&quot;: [\r\n            {\r\n                &quot;Event&quot;: &quot;Open&quot;,\r\n                &quot;Date&quot;: &quot;2010-10-12 13:18:00&quot;,\r\n                &quot;IPAddress&quot;: &quot;192.168.126.87&quot;,\r\n                &quot;Detail&quot;: &quot;&quot;\r\n            },\r\n            {\r\n                &quot;Event&quot;: &quot;Click&quot;,\r\n                &quot;Date&quot;: &quot;2010-10-12 13:16:00&quot;,\r\n                &quot;IPAddress&quot;: &quot;192.168.126.87&quot;,\r\n                &quot;Detail&quot;: &quot;https://example.com/post/12323/&quot;\r\n            }\r\n        ]\r\n    }\r\n    {\r\n        &quot;ID&quot;: &quot;dsadsamdkl9309ujd432&quot;,\r\n        &quot;Type&quot;: &quot;Campaign&quot;,\r\n        &quot;Name&quot;: &quot;Campaign Two&quot;,\r\n        &quot;Actions&quot;: []\r\n    }\r\n]\r\n```\r\n\r\nWhat I want to get as output:\r\n\r\n```\r\n&quot;Campaign One&quot;,&quot;Open&quot;\r\n&quot;Campaign One&quot;,&quot;Click&quot;\r\n&quot;Campaign Two&quot;,&quot;none&quot;\r\n```\r\n\r\nWhat I currently get\r\n\r\n```\r\n&quot;Campaign One&quot;,&quot;Open&quot;\r\n&quot;Campaign One&quot;,&quot;Click&quot;\r\n```\r\n\r\nI can&#39;t seem to find a way to include values when `&quot;Actions&quot; == []`\r\n\r\nWhat I tried so far:\r\n\r\n**Attempt 1:**\r\n\r\n`curl -u &quot;apikey:x&quot; https://api.createsend.com/api/v3.2/subscribers/listID/history.json?email=example@email.com | jq -r &#39;.[] | .Name as $n | .Actions[] | ([$n, .Event | if . == null then &quot;none&quot; else . end]) | @csv&#39;`\r\n\r\n**Attempt 2:**\r\n\r\n`curl -u &quot;apikey:x&quot; https://api.createsend.com/api/v3.2/subscribers/listID/history.json?email=example@email.com | jq -r &#39;.[] | .Name as $n | .Actions[] | ([$n, .Event // &quot;none&quot;]) | @csv&#39;`\r\n\r\n**Attempt 3:**\r\n\r\n`curl -u &quot;apikey:x&quot; https://api.createsend.com/api/v3.2/subscribers/listID/history.json?email=example@email.com | jq -r &#39;.[] | .Name as $n | .Actions[] |.Actions[] | if . == [] then .Actions[].Event = &quot;&quot; else . end | ([$n, .Event]) | @csv&#39;`",
        "link": "https://stackoverflow.com/questions/67987088/including-empty-json-values-in-jq-output",
        "title": "Including empty JSON values in jq output"
    },
    {
        "tags": [
            "arrays",
            "bash",
            "for-loop",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 11716894,
                    "reputation": 801,
                    "user_id": 8577085,
                    "user_type": "registered",
                    "profile_image": "https://lh5.googleusercontent.com/-nhongh2SRgk/AAAAAAAAAAI/AAAAAAAAAJM/2nMWIXl9YJk/s256-rj/photo.jpg",
                    "display_name": "abhishek phukan",
                    "link": "https://stackoverflow.com/users/8577085/abhishek-phukan"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1623766619,
                "post_id": 67987940,
                "comment_id": 120168403,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 11716894,
                    "reputation": 801,
                    "user_id": 8577085,
                    "user_type": "registered",
                    "profile_image": "https://lh5.googleusercontent.com/-nhongh2SRgk/AAAAAAAAAAI/AAAAAAAAAJM/2nMWIXl9YJk/s256-rj/photo.jpg",
                    "display_name": "abhishek phukan",
                    "link": "https://stackoverflow.com/users/8577085/abhishek-phukan"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1623766709,
                "post_id": 67987940,
                "comment_id": 120168452,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 6651761,
                    "reputation": 2880,
                    "user_id": 5133523,
                    "user_type": "registered",
                    "accept_rate": 25,
                    "profile_image": "https://www.gravatar.com/avatar/a3f381a3b37852c260d2daee88d4091a?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "learner",
                    "link": "https://stackoverflow.com/users/5133523/learner"
                },
                "reply_to_user": {
                    "account_id": 11716894,
                    "reputation": 801,
                    "user_id": 8577085,
                    "user_type": "registered",
                    "profile_image": "https://lh5.googleusercontent.com/-nhongh2SRgk/AAAAAAAAAAI/AAAAAAAAAJM/2nMWIXl9YJk/s256-rj/photo.jpg",
                    "display_name": "abhishek phukan",
                    "link": "https://stackoverflow.com/users/8577085/abhishek-phukan"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1623766739,
                "post_id": 67987940,
                "comment_id": 120168467,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 6651761,
                    "reputation": 2880,
                    "user_id": 5133523,
                    "user_type": "registered",
                    "accept_rate": 25,
                    "profile_image": "https://www.gravatar.com/avatar/a3f381a3b37852c260d2daee88d4091a?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "learner",
                    "link": "https://stackoverflow.com/users/5133523/learner"
                },
                "reply_to_user": {
                    "account_id": 11716894,
                    "reputation": 801,
                    "user_id": 8577085,
                    "user_type": "registered",
                    "profile_image": "https://lh5.googleusercontent.com/-nhongh2SRgk/AAAAAAAAAAI/AAAAAAAAAJM/2nMWIXl9YJk/s256-rj/photo.jpg",
                    "display_name": "abhishek phukan",
                    "link": "https://stackoverflow.com/users/8577085/abhishek-phukan"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1623766774,
                "post_id": 67987940,
                "comment_id": 120168485,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 11716894,
                    "reputation": 801,
                    "user_id": 8577085,
                    "user_type": "registered",
                    "profile_image": "https://lh5.googleusercontent.com/-nhongh2SRgk/AAAAAAAAAAI/AAAAAAAAAJM/2nMWIXl9YJk/s256-rj/photo.jpg",
                    "display_name": "abhishek phukan",
                    "link": "https://stackoverflow.com/users/8577085/abhishek-phukan"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1623767007,
                "post_id": 67987940,
                "comment_id": 120168604,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 219835,
                    "reputation": 33519,
                    "user_id": 476951,
                    "user_type": "registered",
                    "accept_rate": 81,
                    "profile_image": "https://www.gravatar.com/avatar/4e1366f240b6e71c43ca4c76c0d0ee70?s=256&d=identicon&r=PG",
                    "display_name": "yunzen",
                    "link": "https://stackoverflow.com/users/476951/yunzen"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1623767500,
                "post_id": 67987940,
                "comment_id": 120168862,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1143565,
                    "reputation": 535973,
                    "user_id": 1126841,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/fa05233b2357f8d11c22ef4cfc7bb85c?s=256&d=identicon&r=PG",
                    "display_name": "chepner",
                    "link": "https://stackoverflow.com/users/1126841/chepner"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1623767883,
                "post_id": 67987940,
                "comment_id": 120169029,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1623767199,
                "creation_date": 1623767199,
                "answer_id": 67988204,
                "question_id": 67987940,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "```\r\nctr=0\r\nfor ptr in &quot;${values[@]}&quot;\r\ndo\r\n    az pipelines variable-group variable update --group-id 1543 --name &quot;${ptr}&quot; --value &quot;${az_create_options[$ctr]}&quot; #First element read and value updated\r\n    az pipelines variable-group variable update --group-id 1543 --name &quot;${ptr}&quot; --value &quot;${az_create_options[$ctr]}&quot; #Second element read and value updated\r\n    ctr=$((ctr+1))\r\ndone\r\n\r\n```",
                "title": "How to read an individual items of an array in bash for loop"
            },
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1623767448,
                "creation_date": 1623767448,
                "answer_id": 67988272,
                "question_id": 67987940,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Iterate over the array _indices_:\r\n```bash\r\nfor ((i = 0; i &lt; ${#values[@]}; i++)); do\r\n  value=${values[i]}\r\n  option=${az_create_options[i]}\r\n\r\n  echo &quot;value =&gt; $value; option =&gt; $option&quot;\r\ndone\r\n```",
                "title": "How to read an individual items of an array in bash for loop"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1623767524,
        "creation_date": 1623766276,
        "last_edit_date": 1623767524,
        "question_id": 67987940,
        "body_markdown": "I have a code snippet below\r\n```\r\nvalues=(addressSearchBaseUrl addressSearchSubscriptionKey cacheUrl calendarApiUrl checkoutBffApiUrl cpCode)\r\n\r\naz_create_options=()\r\n\r\nfor ptr in &quot;${values[@]}&quot;\r\ndo\r\nresult=$(\r\naz pipelines variable-group list --group-name &quot;${Variable Group ${reference_env}&quot; | jq &#39;.[0].variables.&#39;${ptr}&#39;.value&#39;\r\n)\r\n\r\n\r\nif [[ &quot;$ptr&quot; = &quot;calendarApiUrl&quot; ]]\r\nthen\r\necho &quot;INF: Updating $ptr with new value&quot;\r\nresult=&quot;https://noname-api.platform.test.com.au/marketing/calendar/v1/AvailableDates/market1/&quot;\r\ninsertString=&quot;;rev=${target_env}&quot;\r\nlookingfor=&quot;v1&quot;\r\nresult=$(echo $result| sed s/&quot;${lookingfor}&quot;/&quot;${insertString}&quot;/g)\r\necho $result\r\nfi\r\n\r\naz_create_options+=(&quot;$result&quot; )\r\ndone\r\n\r\ndeclare -p az_create_options\r\n\r\nvalues=(addressSearchBaseUrl addressSearchSubscriptionKey cacheUrl calendarApiUrl checkoutBffApiUrl cpCode)\r\n\r\nfor ptr in &quot;${values[@]}&quot;\r\ndo\r\naz pipelines variable-group variable update --group-id 1543 --name &quot;${ptr} --value &quot;${az_create_options[0]}&quot; First element read and value updated\r\naz pipelines variable-group variable update --group-id 1543 --name &quot;${ptr} --value &quot;${az_create_options[0]}&quot; Second element read and value updated\r\ndone\r\n```\r\n\r\nThe last for loop is where I need help as I do not know how to refer an array in bash.I need to point to individual items of az_create_options as they have to go 1:1.\r\n\r\nForgive me for my bash incompetency, but, I am here to learn.",
        "link": "https://stackoverflow.com/questions/67987940/how-to-read-an-individual-items-of-an-array-in-bash-for-loop",
        "title": "How to read an individual items of an array in bash for loop"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1623771873,
                "creation_date": 1623771873,
                "answer_id": 67989458,
                "question_id": 67989350,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can use the `keys` function as in:\r\n```\r\njq keys test.json\r\n[\r\n  &quot;BI_Arch&quot;,\r\n  &quot;Data_Engineers&quot;\r\n]\r\n```\r\npossibly obtaining &quot;raw&quot; output with:\r\n```\r\njq -r keys[] test.json\r\nBI_Arch\r\nData_Engineers\r\n```",
                "title": "Jq get the first main values programatically"
            },
            {
                "up_vote_count": 4,
                "is_accepted": false,
                "score": 4,
                "last_activity_date": 1623771878,
                "creation_date": 1623771878,
                "answer_id": 67989459,
                "question_id": 67989350,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Pipe the object through the `keys` filter, and slice it if you really want the first 2 of more-than-2:\r\n\r\n    % jq &#39;keys[:2]&#39; tmp.json\r\n    [\r\n      &quot;BI_Arch&quot;,\r\n      &quot;Data_Engineers&quot;\r\n    ]",
                "title": "Jq get the first main values programatically"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1623772583,
                "creation_date": 1623772583,
                "answer_id": 67989653,
                "question_id": 67989350,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can use just `jq &#39;[keys]&#39;`\r\n\r\nHere&#39;s an online tool\r\nhttps://jqplay.org/s/csowtIQRaZ",
                "title": "Jq get the first main values programatically"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 0,
        "last_activity_date": 1623772583,
        "creation_date": 1623771487,
        "question_id": 67989350,
        "body_markdown": "Im trying to get the first 2 names in the following example json, without having to call them \r\n\r\ntest.json \r\n```\r\n{\r\n  &quot;BI_Arch&quot;: [{\r\n    &quot;Read&quot;: [&quot;RDS&quot;, &quot;Redshift&quot;, &quot;Athena&quot;],\r\n    &quot;Write&quot;: [&quot;Quicksight&quot;]\r\n  }],\r\n  &quot;Data_Engineers&quot;: [{\r\n    &quot;Write&quot;: [ &quot;S3&quot;, &quot;Glue&quot;,&quot;Lambda&quot;, &quot;Athena&quot;, &quot;EMR&quot;, &quot;Databricks&quot;, &quot;RDS&quot; , &quot;Redshift&quot;, &quot;Kinesis&quot;, &quot;SQS&quot;, &quot;SES&quot;, &quot;SNS&quot;, &quot;AWS SFTP&quot;],\r\n    &quot;Read&quot;: [&quot;KMS&quot;, &quot;Secret_Manager&quot;]\r\n  }]\r\n}\r\n```\r\n\r\nwhat i want to get is ```BI_Arch Data_Engineers``` without having to resort in naming them, something like the opposite response of ```jq .[] test.json``` that writes down only those names, is there a way to get it? \r\n\r\nthis is the ```jq .[] test.json``` for making it simpler\r\n```\r\n[\r\n  {\r\n    &quot;Read&quot;: [\r\n      &quot;RDS&quot;,\r\n      &quot;Redshift&quot;,\r\n      &quot;Athena&quot;\r\n    ],\r\n    &quot;Write&quot;: [\r\n      &quot;Quicksight&quot;\r\n    ]\r\n  }\r\n]\r\n[\r\n  {\r\n    &quot;Write&quot;: [\r\n      &quot;S3&quot;,\r\n      &quot;Glue&quot;,\r\n      &quot;Lambda&quot;,\r\n      &quot;Athena&quot;,\r\n      &quot;EMR&quot;,\r\n      &quot;Databricks&quot;,\r\n      &quot;RDS&quot;,\r\n      &quot;Redshift&quot;,\r\n      &quot;Kinesis&quot;,\r\n      &quot;SQS&quot;,\r\n      &quot;SES&quot;,\r\n      &quot;SNS&quot;,\r\n      &quot;AWS SFTP&quot;\r\n    ],\r\n    &quot;Read&quot;: [\r\n      &quot;KMS&quot;,\r\n      &quot;Secret_Manager&quot;\r\n    ]\r\n  }\r\n]\r\n```\r\nIt prints everything but the names, i want the names without everything else",
        "link": "https://stackoverflow.com/questions/67989350/jq-get-the-first-main-values-programatically",
        "title": "Jq get the first main values programatically"
    },
    {
        "tags": [
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 3,
                "creation_date": 1623793642,
                "post_id": 67993813,
                "comment_id": 120178585,
                "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": 1623793763,
                "post_id": 67993813,
                "comment_id": 120178619,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 3712045,
                    "reputation": 415,
                    "user_id": 3089106,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/e687eb96730813a72b976f435055b11a?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "alec",
                    "link": "https://stackoverflow.com/users/3089106/alec"
                },
                "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": 1623793818,
                "post_id": 67993813,
                "comment_id": 120178643,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 3712045,
                    "reputation": 415,
                    "user_id": 3089106,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/e687eb96730813a72b976f435055b11a?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "alec",
                    "link": "https://stackoverflow.com/users/3089106/alec"
                },
                "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": 1623794072,
                "post_id": 67993813,
                "comment_id": 120178716,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1623794122,
                "post_id": 67993813,
                "comment_id": 120178731,
                "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": 1623812358,
                "post_id": 67993813,
                "comment_id": 120181899,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 5,
                "is_accepted": false,
                "score": 5,
                "last_activity_date": 1623797692,
                "last_edit_date": 1623797692,
                "creation_date": 1623794314,
                "answer_id": 67993977,
                "question_id": 67993813,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If _any_ of your output is going to be raw, you need to pass `-r`; it&#39;ll just be ignored for data items that aren&#39;t strings.\r\n\r\nAnyhow -- if you write `(expr1, expr2)`, then your input will be passed through both expressions. Thus:\r\n\r\n```bash\r\njq -Cr &#39;\r\n  ([.data[]\r\n    | {invoice_id: .id,\r\n       client: .customer_name,\r\n       date: .date | strftime(&quot;%Y-%m-%d&quot;),\r\n       amount: .total,\r\n       status: .status}\r\n    | .amount = &quot;$&quot; + (.amount/100|tostring)\r\n   ] | sort_by(.date)),\r\n  &quot;Total: $\\([.data[] | .total] | add | . / 100)&quot;\r\n&#39;\r\n```\r\n",
                "title": "what&#39;s the simplest way to calculate the sum of values at the end of this jq command?"
            },
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1623796183,
                "last_edit_date": 1623796183,
                "creation_date": 1623794864,
                "answer_id": 67994058,
                "question_id": 67993813,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "In case you decide after all to emit valid JSON, here is a modular answer to the question that makes it easy to formulate alternative approaches, and which postpones the conversion of `.amount` to dollars for efficiency:\r\n```\r\ndef todollar:\r\n  &quot;$&quot; + tostring;\r\n  \r\ndef json:\r\n  [.data[]\r\n   | {invoice_id: .id,\r\n      client: .customer_name,\r\n      date: .date | strftime(&quot;%Y-%m-%d&quot;),\r\n      amount: (.total/100),\r\n      status: .status} ]\r\n  | sort_by(.date) ;\r\n\r\njson\r\n| map_values(.amount |= todollar),\r\n  &quot;Total: &quot; + (map(.amount) | add | todollar)\r\n\r\n```\r\n\r\nAs noted elsewhere, you will probably want to use the -r command-line option.\r\n\r\n",
                "title": "what&#39;s the simplest way to calculate the sum of values at the end of this jq command?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1623797692,
        "creation_date": 1623793205,
        "last_edit_date": 1623797183,
        "question_id": 67993813,
        "body_markdown": "I see that `jq` can calculate addition as simply as `jq &#39;map(.duration) | add&#39;` but I&#39;ve got a more complex command and I can&#39;t figure out how to perform this `add` at the end of it.\r\n\r\nI&#39;m starting with data like this:\r\n\r\n```\r\n{\r\n  &quot;object&quot;: &quot;list&quot;,\r\n  &quot;data&quot;: [\r\n    {\r\n      &quot;id&quot;: &quot;in_1HW85aFGUwFHXzvl8wJbW7V7&quot;,\r\n      &quot;object&quot;: &quot;invoice&quot;,\r\n      &quot;account_country&quot;: &quot;US&quot;,\r\n      &quot;customer_name&quot;: &quot;clientOne&quot;,\r\n      &quot;date&quot;: 1601244686,\r\n      &quot;livemode&quot;: true,\r\n      &quot;metadata&quot;: {},\r\n      &quot;paid&quot;: true,\r\n      &quot;status&quot;: &quot;paid&quot;,\r\n      &quot;total&quot;: 49500\r\n    },\r\n    {\r\n      &quot;id&quot;: &quot;in_1HJlIZFGUwFHXzvlWqhegRkf&quot;,\r\n      &quot;object&quot;: &quot;invoice&quot;,\r\n      &quot;account_country&quot;: &quot;US&quot;,\r\n      &quot;customer_name&quot;: &quot;clientTwo&quot;,\r\n      &quot;date&quot;: 1598297143,\r\n      &quot;livemode&quot;: true,\r\n      &quot;metadata&quot;: {},\r\n      &quot;paid&quot;: true,\r\n      &quot;status&quot;: &quot;paid&quot;,\r\n      &quot;total&quot;: 51000\r\n    },\r\n    {\r\n      &quot;id&quot;: &quot;in_1HJkg5FGUwFHXzvlYp2uC63C&quot;,\r\n      &quot;object&quot;: &quot;invoice&quot;,\r\n      &quot;account_country&quot;: &quot;US&quot;,\r\n      &quot;customer_name&quot;: &quot;clientThree&quot;,\r\n      &quot;date&quot;: 1598294757,\r\n      &quot;livemode&quot;: true,\r\n      &quot;metadata&quot;: {},\r\n      &quot;paid&quot;: true,\r\n      &quot;status&quot;: &quot;paid&quot;,\r\n      &quot;total&quot;: 57000\r\n    },\r\n    {\r\n      &quot;id&quot;: &quot;in_1H8B0pFGUwFHXzvlU6nrOm6I&quot;,\r\n      &quot;object&quot;: &quot;invoice&quot;,\r\n      &quot;account_country&quot;: &quot;US&quot;,\r\n      &quot;customer_name&quot;: &quot;clientThree&quot;,\r\n      &quot;date&quot;: 1595536051,\r\n      &quot;livemode&quot;: true,\r\n      &quot;metadata&quot;: {},\r\n      &quot;paid&quot;: true,\r\n      &quot;status&quot;: &quot;paid&quot;,\r\n      &quot;total&quot;: 20000\r\n    }\r\n  ],\r\n  &quot;has_more&quot;: true,\r\n  &quot;url&quot;: &quot;/v1/invoices&quot;\r\n}\r\n```\r\nand my `jq` command looks like:\r\n```\r\ncat example-data.json | \r\n  jq -C &#39;[.data[] \r\n          | {invoice_id: .id, client: .customer_name, date: .date | strftime(&quot;%Y-%m-%d&quot;), amount: .total, status: .status}\r\n          | .amount = &quot;$&quot; + (.amount/100|tostring)]\r\n         | sort_by(.date)&#39;\r\n```\r\nwhich nicely gives me output like:\r\n\r\n```\r\n[\r\n  {\r\n    &quot;invoice_id&quot;: &quot;in_1H8B0pFGUwFHXzvlU6nrOm6I&quot;,\r\n    &quot;client&quot;: &quot;clientThree&quot;,\r\n    &quot;date&quot;: &quot;2020-07-23&quot;,\r\n    &quot;amount&quot;: &quot;$200&quot;,\r\n    &quot;status&quot;: &quot;paid&quot;\r\n  },\r\n  {\r\n    &quot;invoice_id&quot;: &quot;in_1HJlIZFGUwFHXzvlWqhegRkf&quot;,\r\n    &quot;client&quot;: &quot;clientTwo&quot;,\r\n    &quot;date&quot;: &quot;2020-08-24&quot;,\r\n    &quot;amount&quot;: &quot;$510&quot;,\r\n    &quot;status&quot;: &quot;paid&quot;\r\n  },\r\n  {\r\n    &quot;invoice_id&quot;: &quot;in_1HJkg5FGUwFHXzvlYp2uC63C&quot;,\r\n    &quot;client&quot;: &quot;clientThree&quot;,\r\n    &quot;date&quot;: &quot;2020-08-24&quot;,\r\n    &quot;amount&quot;: &quot;$570&quot;,\r\n    &quot;status&quot;: &quot;paid&quot;\r\n  },\r\n  {\r\n    &quot;invoice_id&quot;: &quot;in_1HW85aFGUwFHXzvl8wJbW7V7&quot;,\r\n    &quot;client&quot;: &quot;clientOne&quot;,\r\n    &quot;date&quot;: &quot;2020-09-27&quot;,\r\n    &quot;amount&quot;: &quot;$495&quot;,\r\n    &quot;status&quot;: &quot;paid&quot;\r\n  }\r\n]\r\n```\r\n\r\nand I want to add a sum/total at the end of that, something like `Total: $1775`, so that the entire output would look like this:\r\n\r\n```\r\n[\r\n  {\r\n    &quot;invoice_id&quot;: &quot;in_1H8B0pFGUwFHXzvlU6nrOm6I&quot;,\r\n    &quot;client&quot;: &quot;clientThree&quot;,\r\n    &quot;date&quot;: &quot;2020-07-23&quot;,\r\n    &quot;amount&quot;: &quot;$200&quot;,\r\n    &quot;status&quot;: &quot;paid&quot;\r\n  },\r\n  {\r\n    &quot;invoice_id&quot;: &quot;in_1HJlIZFGUwFHXzvlWqhegRkf&quot;,\r\n    &quot;client&quot;: &quot;clientTwo&quot;,\r\n    &quot;date&quot;: &quot;2020-08-24&quot;,\r\n    &quot;amount&quot;: &quot;$510&quot;,\r\n    &quot;status&quot;: &quot;paid&quot;\r\n  },\r\n  {\r\n    &quot;invoice_id&quot;: &quot;in_1HJkg5FGUwFHXzvlYp2uC63C&quot;,\r\n    &quot;client&quot;: &quot;clientThree&quot;,\r\n    &quot;date&quot;: &quot;2020-08-24&quot;,\r\n    &quot;amount&quot;: &quot;$570&quot;,\r\n    &quot;status&quot;: &quot;paid&quot;\r\n  },\r\n  {\r\n    &quot;invoice_id&quot;: &quot;in_1HW85aFGUwFHXzvl8wJbW7V7&quot;,\r\n    &quot;client&quot;: &quot;clientOne&quot;,\r\n    &quot;date&quot;: &quot;2020-09-27&quot;,\r\n    &quot;amount&quot;: &quot;$495&quot;,\r\n    &quot;status&quot;: &quot;paid&quot;\r\n  }\r\n]\r\nTotal: $1775\r\n```\r\n\r\nIs there a neat/tidy way to enhance this `jq` command to achieve this?\\\r\nOr even, since I&#39;m invoking this in a shell script, a dirty/ugly way with bash?",
        "link": "https://stackoverflow.com/questions/67993813/whats-the-simplest-way-to-calculate-the-sum-of-values-at-the-end-of-this-jq-com",
        "title": "what&#39;s the simplest way to calculate the sum of values at the end of this jq command?"
    },
    {
        "tags": [
            "shell",
            "curl",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1623802693,
                "post_id": 67994766,
                "comment_id": 120180349,
                "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": 1623802731,
                "post_id": 67994766,
                "comment_id": 120180355,
                "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": 1623802928,
                "post_id": 67994766,
                "comment_id": 120180382,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "is_answered": false,
        "answer_count": 0,
        "score": 0,
        "last_activity_date": 1623831659,
        "creation_date": 1623801557,
        "last_edit_date": 1623831659,
        "question_id": 67994766,
        "body_markdown": "{\r\n\t&quot;count&quot;: 3,\r\n\t&quot;next&quot;: &quot;&quot;,\r\n\t&quot;previous&quot;: &quot;&quot;,\r\n\t&quot;list&quot;: [{\r\n\t\t&quot;id&quot;: &quot;X1&quot;,\r\n\t\t&quot;name&quot;: &quot;STAGING&quot;,\r\n\t\t&quot;description&quot;: null,\r\n\t\t&quot;context&quot;: &quot;STAGING&quot;,\r\n\t\t&quot;version&quot;: &quot;1.0.0&quot;,\r\n\t\t&quot;provider&quot;: &quot;user0&quot;,\r\n\t\t&quot;status&quot;: &quot;PUBLISHED&quot;,\r\n\t\t&quot;thumbnailUri&quot;: null\r\n\t}, {\r\n\t\t&quot;id&quot;: &quot;X2&quot;,\r\n\t\t&quot;name&quot;: &quot;STAGING&quot;,\r\n\t\t&quot;description&quot;: null,\r\n\t\t&quot;context&quot;: &quot;STAGING&quot;,\r\n\t\t&quot;version&quot;: &quot;2.0.0&quot;,\r\n\t\t&quot;provider&quot;: &quot;user1&quot;,\r\n\t\t&quot;status&quot;: &quot;PUBLISHED&quot;,\r\n\t\t&quot;thumbnailUri&quot;: null\r\n\t}, {\r\n\t\t&quot;id&quot;: &quot;X3&quot;,\r\n\t\t&quot;name&quot;: &quot;STAGING&quot;,\r\n\t\t&quot;description&quot;: null,\r\n\t\t&quot;context&quot;: &quot;STAGING&quot;,\r\n\t\t&quot;version&quot;: &quot;3.0.0&quot;,\r\n\t\t&quot;provider&quot;: &quot;user2&quot;,\r\n\t\t&quot;status&quot;: &quot;CREATED&quot;,\r\n\t\t&quot;thumbnailUri&quot;: null\r\n\t}],\r\n\t&quot;pagination&quot;: {\r\n\t\t&quot;total&quot;: 3,\r\n\t\t&quot;offset&quot;: 0,\r\n\t\t&quot;limit&quot;: 25\r\n\t}\r\n}\r\n\r\n\r\nabove is my json - looking for solution where i could loop and get &quot;id&quot; for a given &quot;Version&quot;\r\n\r\nfor suppose the while i pass argument &quot;Version&quot; = 3.0.0 expecting the output to be as &quot;X3&quot;( which is the key value of &quot;id&quot;\r\n\r\nand the json is output from a curl.\r\n\r\n\r\nthis is what i have tried but no error&#39;s \r\n x= curl(); - which gives me above json as output!\r\n\r\n echo &quot;$x&quot; | jq -r &#39;map(select(any(.version[]; contains(&quot;3.0.0&quot;))|not)|.id)[]&#39;\r\n\r\nand i see error below:\r\n\r\njq: error (at &lt;stdin&gt;:1): Cannot index number with string &quot;version&quot;\r\n\r\n",
        "link": "https://stackoverflow.com/questions/67994766/looping-through-json-using-sh-jq",
        "title": "looping through json using sh+ jq"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1623846381,
                "creation_date": 1623846381,
                "answer_id": 68002645,
                "question_id": 68002556,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Not directly. You already know the name you want to use, so either hard code it:\r\n\r\n    jq -n --arg name value &#39;{name: $name}&#39;\r\n\r\nor use a second variable\r\n\r\n    jq -n --arg key name --arg name value &#39;{($key): $name}&#39;\r\n\r\n(I forgot about [@0stone0&#39;s approach](https://stackoverflow.com/a/68002658/1126841); that&#39;s probably what you want to use.)",
                "title": "jq: Can I use the name of an argument in the code itself?"
            },
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1623928073,
                "last_edit_date": 1623928073,
                "creation_date": 1623846433,
                "answer_id": 68002658,
                "question_id": 68002556,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If you remove the `($name):` JQ will use the name as the key fallback:\r\n\r\n```bash\r\n$ jq -n --arg name value &#39;{$name}&#39;\r\n{\r\n  &quot;name&quot;: &quot;value&quot;\r\n}\r\n$\r\n```\r\n\r\n&lt;hr&gt; \r\n\r\nFrom the [tag:JQ] [**Frequently Asked Questions**](https://github.com/stedolan/jq/wiki/FAQ):  \r\n&lt;sup&gt;[Notable Differences between Versions](https://github.com/stedolan/jq/wiki/FAQ#notable-differences-between-versions)&lt;/sup&gt;\r\n&gt;&#119928;: In which version was the abbreviation `{$x}` for `{&quot;x&quot;: $x}` introduced?\r\n&gt;\r\n&gt;Version ***1.5***\r\n&lt;hr&gt;\r\n\r\nFrom the **Object Construction** (`{}`) [documentation][1]:\r\n\r\n&gt;The value can be any expression (although you may need to wrap it in parentheses if, for example, it contains colons), which gets applied to the `{}` expression&#39;s input (remember, all filters have an input and an output).\r\n&gt;\r\n&gt; ```\r\n&gt;{foo: .bar}\r\n&gt;```\r\n&gt;\r\n&gt;will produce the JSON object `{&quot;foo&quot;: 42}` if given the JSON object `{&quot;bar&quot;:42, &quot;baz&quot;:43}` as its input. You can use this to select particular fields of an object: if the input is an object with &quot;user&quot;, &quot;title&quot;, &quot;id&quot;, and &quot;content&quot; fields and you just want &quot;user&quot; and &quot;title&quot;, you can write\r\n&gt;\r\n&gt;```\r\n&gt;{user: .user, title: .title}\r\n&gt;```\r\n&gt;\r\n&gt;**Because that is so common, there&#39;s a shortcut syntax for it**: \r\n&gt;\r\n&gt;```\r\n&gt;{user, title}\r\n&gt;```\r\n\r\n  [1]: https://stedolan.github.io/jq/manual/#TypesandValues",
                "title": "jq: Can I use the name of an argument in the code itself?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 3,
        "last_activity_date": 1623928073,
        "creation_date": 1623846084,
        "question_id": 68002556,
        "body_markdown": "Is there some way to use the name of an argument in the code?\r\n\r\nFor example, this command:\r\n\r\n```\r\njq -n --arg name value &#39;{($name): $name}&#39;\r\n```\r\nhas this output:\r\n```\r\n{\r\n  &quot;value&quot;: &quot;value&quot;\r\n}\r\n```\r\n\r\nIs it possible to get this output?:\r\n```\r\n{\r\n  &quot;name&quot;: &quot;value&quot;\r\n}\r\n```",
        "link": "https://stackoverflow.com/questions/68002556/jq-can-i-use-the-name-of-an-argument-in-the-code-itself",
        "title": "jq: Can I use the name of an argument in the code itself?"
    },
    {
        "tags": [
            "json",
            "dynamic",
            "snowflake-cloud-data-platform",
            "jq",
            "relational"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 16844408,
                    "reputation": 7409,
                    "user_id": 12178980,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/qJzKP.jpg?s=256",
                    "display_name": "Mike Walton",
                    "link": "https://stackoverflow.com/users/12178980/mike-walton"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1623859352,
                "post_id": 68006188,
                "comment_id": 120199907,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 16563186,
                    "reputation": 91,
                    "user_id": 11968591,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/09b58477918ec5219eb694b469537a6d?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "hiphop",
                    "link": "https://stackoverflow.com/users/11968591/hiphop"
                },
                "reply_to_user": {
                    "account_id": 16844408,
                    "reputation": 7409,
                    "user_id": 12178980,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/qJzKP.jpg?s=256",
                    "display_name": "Mike Walton",
                    "link": "https://stackoverflow.com/users/12178980/mike-walton"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1623867552,
                "post_id": 68006188,
                "comment_id": 120203102,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 45023,
                    "reputation": 59633,
                    "user_id": 132438,
                    "user_type": "registered",
                    "accept_rate": 43,
                    "profile_image": "https://i.sstatic.net/QJxe1.jpg?s=256",
                    "display_name": "Felipe Hoffa",
                    "link": "https://stackoverflow.com/users/132438/felipe-hoffa"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1623868956,
                "post_id": 68006188,
                "comment_id": 120203638,
                "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": 1623909439,
                "post_id": 68006188,
                "comment_id": 120212252,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1623884984,
                "creation_date": 1623884984,
                "answer_id": 68011019,
                "question_id": 68006188,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Dynamic JSON can be easily loaded into Snowflake as is.  In your example, with variable length arrays, you can use `FLATTEN()` to explode the single row of JSON into multiple rows in a query.  In this scenario I would suggest you leave it as JSON in your data lake too.\r\n\r\nThe penalty for such things is relatively low since the JSON data isn&#39;t just stored as a long string; instead internally Snowflake analyzes the JSON as its loaded and does things to aid speedy queries, like creating virtual columns for frequent paths like `$.Job_Profile_Reference` and `$.Job_Profile_Reference.ID` in your example.\r\n\r\n```\r\nwith semistructured as (select parse_json(&#39;{&quot;Job_Profile_Reference&quot;: {&quot;ID&quot;: [{&quot;@type&quot;: &quot;WI&quot;,&quot;__text&quot;: &quot;4acf03b2e8e301fab3caeab105020f&quot;},{&quot;@type&quot;: &quot;Job_Profile_ID&quot;,&quot;__text&quot;: &quot;112&quot;}]}}&#39;) json)\r\nselect * from semistructured, lateral flatten(json, recursive=&gt;True) structured;\r\n\r\nJSON\tSEQ\tKEY\tPATH\tINDEX\tVALUE\tTHIS\r\n{    &quot;Job_Profile_Reference&quot;: {      &quot;ID&quot;: [        {          &quot;@type&quot;: &quot;WI&quot;,          &quot;__text&quot;: &quot;4acf03b2e8e301fab3caeab105020f&quot;        },        {          &quot;@type&quot;: &quot;Job_Profile_ID&quot;,          &quot;__text&quot;: &quot;112&quot;        }      ]    }  }\t1\tJob_Profile_Reference\tJob_Profile_Reference\t\t{    &quot;ID&quot;: [      {        &quot;@type&quot;: &quot;WI&quot;,        &quot;__text&quot;: &quot;4acf03b2e8e301fab3caeab105020f&quot;      },      {        &quot;@type&quot;: &quot;Job_Profile_ID&quot;,        &quot;__text&quot;: &quot;112&quot;      }    ]  }\t{    &quot;Job_Profile_Reference&quot;: {      &quot;ID&quot;: [        {          &quot;@type&quot;: &quot;WI&quot;,          &quot;__text&quot;: &quot;4acf03b2e8e301fab3caeab105020f&quot;        },        {          &quot;@type&quot;: &quot;Job_Profile_ID&quot;,          &quot;__text&quot;: &quot;112&quot;        }      ]    }  }\r\n{    &quot;Job_Profile_Reference&quot;: {      &quot;ID&quot;: [        {          &quot;@type&quot;: &quot;WI&quot;,          &quot;__text&quot;: &quot;4acf03b2e8e301fab3caeab105020f&quot;        },        {          &quot;@type&quot;: &quot;Job_Profile_ID&quot;,          &quot;__text&quot;: &quot;112&quot;        }      ]    }  }\t1\tID\tJob_Profile_Reference.ID\t\t[    {      &quot;@type&quot;: &quot;WI&quot;,      &quot;__text&quot;: &quot;4acf03b2e8e301fab3caeab105020f&quot;    },    {      &quot;@type&quot;: &quot;Job_Profile_ID&quot;,      &quot;__text&quot;: &quot;112&quot;    }  ]\t{    &quot;ID&quot;: [      {        &quot;@type&quot;: &quot;WI&quot;,        &quot;__text&quot;: &quot;4acf03b2e8e301fab3caeab105020f&quot;      },      {        &quot;@type&quot;: &quot;Job_Profile_ID&quot;,        &quot;__text&quot;: &quot;112&quot;      }    ]  }\r\n{    &quot;Job_Profile_Reference&quot;: {      &quot;ID&quot;: [        {          &quot;@type&quot;: &quot;WI&quot;,          &quot;__text&quot;: &quot;4acf03b2e8e301fab3caeab105020f&quot;        },        {          &quot;@type&quot;: &quot;Job_Profile_ID&quot;,          &quot;__text&quot;: &quot;112&quot;        }      ]    }  }\t1\t\tJob_Profile_Reference.ID[0]\t0\t{    &quot;@type&quot;: &quot;WI&quot;,    &quot;__text&quot;: &quot;4acf03b2e8e301fab3caeab105020f&quot;  }\t[    {      &quot;@type&quot;: &quot;WI&quot;,      &quot;__text&quot;: &quot;4acf03b2e8e301fab3caeab105020f&quot;    },    {      &quot;@type&quot;: &quot;Job_Profile_ID&quot;,      &quot;__text&quot;: &quot;112&quot;    }  ]\r\n{    &quot;Job_Profile_Reference&quot;: {      &quot;ID&quot;: [        {          &quot;@type&quot;: &quot;WI&quot;,          &quot;__text&quot;: &quot;4acf03b2e8e301fab3caeab105020f&quot;        },        {          &quot;@type&quot;: &quot;Job_Profile_ID&quot;,          &quot;__text&quot;: &quot;112&quot;        }      ]    }  }\t1\t@type\tJob_Profile_Reference.ID[0][&#39;@type&#39;]\t\t&quot;WI&quot;\t{    &quot;@type&quot;: &quot;WI&quot;,    &quot;__text&quot;: &quot;4acf03b2e8e301fab3caeab105020f&quot;  }\r\n{    &quot;Job_Profile_Reference&quot;: {      &quot;ID&quot;: [        {          &quot;@type&quot;: &quot;WI&quot;,          &quot;__text&quot;: &quot;4acf03b2e8e301fab3caeab105020f&quot;        },        {          &quot;@type&quot;: &quot;Job_Profile_ID&quot;,          &quot;__text&quot;: &quot;112&quot;        }      ]    }  }\t1\t__text\tJob_Profile_Reference.ID[0].__text\t\t&quot;4acf03b2e8e301fab3caeab105020f&quot;\t{    &quot;@type&quot;: &quot;WI&quot;,    &quot;__text&quot;: &quot;4acf03b2e8e301fab3caeab105020f&quot;  }\r\n{    &quot;Job_Profile_Reference&quot;: {      &quot;ID&quot;: [        {          &quot;@type&quot;: &quot;WI&quot;,          &quot;__text&quot;: &quot;4acf03b2e8e301fab3caeab105020f&quot;        },        {          &quot;@type&quot;: &quot;Job_Profile_ID&quot;,          &quot;__text&quot;: &quot;112&quot;        }      ]    }  }\t1\t\tJob_Profile_Reference.ID[1]\t1\t{    &quot;@type&quot;: &quot;Job_Profile_ID&quot;,    &quot;__text&quot;: &quot;112&quot;  }\t[    {      &quot;@type&quot;: &quot;WI&quot;,      &quot;__text&quot;: &quot;4acf03b2e8e301fab3caeab105020f&quot;    },    {      &quot;@type&quot;: &quot;Job_Profile_ID&quot;,      &quot;__text&quot;: &quot;112&quot;    }  ]\r\n{    &quot;Job_Profile_Reference&quot;: {      &quot;ID&quot;: [        {          &quot;@type&quot;: &quot;WI&quot;,          &quot;__text&quot;: &quot;4acf03b2e8e301fab3caeab105020f&quot;        },        {          &quot;@type&quot;: &quot;Job_Profile_ID&quot;,          &quot;__text&quot;: &quot;112&quot;        }      ]    }  }\t1\t@type\tJob_Profile_Reference.ID[1][&#39;@type&#39;]\t\t&quot;Job_Profile_ID&quot;\t{    &quot;@type&quot;: &quot;Job_Profile_ID&quot;,    &quot;__text&quot;: &quot;112&quot;  }\r\n{    &quot;Job_Profile_Reference&quot;: {      &quot;ID&quot;: [        {          &quot;@type&quot;: &quot;WI&quot;,          &quot;__text&quot;: &quot;4acf03b2e8e301fab3caeab105020f&quot;        },        {          &quot;@type&quot;: &quot;Job_Profile_ID&quot;,          &quot;__text&quot;: &quot;112&quot;        }      ]    }  }\t1\t__text\tJob_Profile_Reference.ID[1].__text\t\t&quot;112&quot;\t{    &quot;@type&quot;: &quot;Job_Profile_ID&quot;,    &quot;__text&quot;: &quot;112&quot;  }```",
                "title": "Converting dynamic JSON into a format suitable for loading into Snowflake/relational database"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1623884984,
        "creation_date": 1623858992,
        "last_edit_date": 1623876839,
        "question_id": 68006188,
        "body_markdown": "I have limited experience with API data ingestion and we&#39;re running into issues where the API JSON response is dynamic in nature with bunch of arrays within the JSON for multiple elements. How do you handle dynamic JSON where in you&#39;re not aware of elements or even multiple values that you will encounter and then convert into a format that can be easily loaded into Snowflake or any other relational database? We tried converting the entire JSON row into a single row but then we don&#39;t know how to parse multiple columns (ABC0, ABC1) for the same column (ABC).\r\n\r\n```\r\n&quot;Job_Profile_Reference&quot;: {\r\n      &quot;ID&quot;: [\r\n      {\r\n        &quot;@type&quot;: &quot;WI&quot;,\r\n        &quot;__text&quot;: &quot;4acf03b2e8e301fab3caeab105020f&quot;\r\n      },\r\n      {\r\n        &quot;@type&quot;: &quot;Job_Profile_ID&quot;,\r\n        &quot;__text&quot;: &quot;112&quot;\r\n      }\r\n      ]\r\n    }\r\n```\r\n\r\noutput\r\n```\r\nJob_Profile.Job_Profile_Reference.ID.0.@type,Job_Profile.Job_Profile_Reference.ID.0.__text,Job_Profile.Job_Profile_Reference.ID.1.@type,Job_Profile.Job_Profile_Reference.ID.1.__text\r\nWI,4acf03b2e8e301fab3caeab105020f,Job_Profile_ID,112\r\n```",
        "link": "https://stackoverflow.com/questions/68006188/converting-dynamic-json-into-a-format-suitable-for-loading-into-snowflake-relati",
        "title": "Converting dynamic JSON into a format suitable for loading into Snowflake/relational database"
    },
    {
        "tags": [
            "json",
            "shell",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1623861173,
                "creation_date": 1623861173,
                "answer_id": 68006736,
                "question_id": 68006550,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I&#39;m going to assume the contents of `myHosts` is a valid JSON array body.\r\n\r\n```sh\r\njq --argjson hosts &quot;[$myHosts]&quot; &#39;.hosts = $hosts | .adminserver = .hosts[0]&#39; rds.json\r\n```\r\n\r\n[jqplay](https://jqplay.org/s/vfMBeknFGG)",
                "title": "json element value to be replaced with variable in shell script"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -1,
        "last_activity_date": 1623861212,
        "creation_date": 1623860371,
        "last_edit_date": 1623861212,
        "question_id": 68006550,
        "body_markdown": "I have a template json file with list of hosts for an example. The same to be replaced with the dynamic value being generated by shell script.\r\n\r\nSample rds.json\r\n\r\n```json\r\n{\r\n    &quot;lob&quot;: &quot;coaching&quot;,\r\n    &quot;function&quot;: &quot;badminton&quot;,\r\n    &quot;hosts&quot;: [\r\n        &quot;node1.rds.sports.com&quot;,\r\n        &quot;node2.rds.sports.com&quot;,\r\n        &quot;node3.rds.sports.com&quot;\r\n\t\t],\r\n    &quot;adminserver&quot;: &quot;node1.rds.sports.com&quot;,\r\n    &quot;user_name&quot;: &quot;coach&quot;,\r\n    &quot;sudo_type&quot;: &quot;sudo&quot;,\r\n    &quot;group_name&quot;: &quot;admin&quot;\r\n}\r\n```\r\n\r\n`echo $myHosts`:\r\n\r\n`&quot;host1.rds.sports.com&quot;, &quot;host2.rds.sports.com&quot;, &quot;host3.rds.sports.com&quot;, &quot;host4.rds.sports.com&quot;, &quot;host5.rds.sports.com&quot;, &quot;host6.rds.sports.com&quot;, &quot;host7.rds.sports.com&quot;, &quot;host8.rds.sports.com&quot;`\r\n\r\nThe value of $myHosts should get replaced in hosts elements key.\r\n\r\nDesired output:\r\n\r\n```json\r\n{\r\n    &quot;lob&quot;: &quot;coaching&quot;,\r\n    &quot;function&quot;: &quot;badminton&quot;,\r\n    &quot;hosts&quot;: [\r\n        &quot;host1.rds.sports.com&quot;, \r\n\t\t&quot;host2.rds.sports.com&quot;, \r\n\t\t&quot;host3.rds.sports.com&quot;, \r\n\t\t&quot;host4.rds.sports.com&quot;, \r\n\t\t&quot;host5.rds.sports.com&quot;, \r\n\t\t&quot;host6.rds.sports.com&quot;, \r\n\t\t&quot;host7.rds.sports.com&quot;, \r\n\t\t&quot;host8.rds.sports.com&quot;\r\n\t],\r\n    &quot;adminserver&quot;: &quot;hosts1.rds.sports.com&quot;,\r\n    &quot;user_name&quot;: &quot;coach&quot;,\r\n    &quot;sudo_type&quot;: &quot;sudo&quot;,\r\n    &quot;group_name&quot;: &quot;admin&quot;\r\n}\r\n```",
        "link": "https://stackoverflow.com/questions/68006550/json-element-value-to-be-replaced-with-variable-in-shell-script",
        "title": "json element value to be replaced with variable in shell script"
    },
    {
        "tags": [
            "json",
            "bash",
            "curl",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1623867904,
                "last_edit_date": 1623867904,
                "creation_date": 1623865563,
                "answer_id": 68007706,
                "question_id": 68007200,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "It&#39;s not clear to me exactly what you mean by &quot;exporting them as an environment variable&quot;, but you could start by looking at the following variation of your code, though I would not actually recommend `export &quot;$Username=$secret&quot;`:\r\n\r\n```\r\nwhile read -r CredId Username\r\ndo\r\n    secret=$(curl -l -k -X GET -H &quot;Content-Type: application/json&quot; -H &quot;Authorization: ${token}&quot; &quot;$PasswordServerURL/api/v6/rest/credential/$CredId/password&quot;)\r\n    export &quot;$Username=$secret&quot;\r\n    echo &quot;Username:secret=$Username:$secret&quot;\r\ndone &lt; &lt;(jq -r &#39;.[] | &quot;\\(.Id) \\(.Username)&quot;&#39; &lt; so-loop-over-json.json)\r\n\r\n```\r\n\r\nThe above of course depends on the assumption that &quot;Credid&quot; is a single token. If there is any doubt about that, it&#39;s easy enough to adapt the foregoing accordingly.\r\n\r\nWith thanks to @GlennJackman.",
                "title": "Loop over a JSON in bash script"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -1,
        "last_activity_date": 1623867904,
        "creation_date": 1623863045,
        "question_id": 68007200,
        "body_markdown": "The target is to create environment variables from data retrieved from an API in JSON format.\r\n\r\nExample:\r\n```\r\nValueA=pass1\r\nValueB=pass2\r\n...\r\n```\r\n\r\n```\r\nresult=$(curl -l -k -X GET -H &quot;Content-Type: application/json&quot; -H &quot;Authorization: bearer ${token}&quot; &quot;$PasswordServerURL/api/v6/rest/folders/$IdFolder&quot; | jq -r &#39;.Credentials&#39;)\r\n```\r\nBy running the command I get the following output for **$result**:\r\n\r\n```\r\n[\r\n   {\r\n      &quot;CustomUserFields&quot;:{\r\n         \r\n      },\r\n      &quot;CustomApplicationFields&quot;:{\r\n         \r\n      },\r\n      &quot;Attachments&quot;:[\r\n         \r\n      ],\r\n      &quot;Tags&quot;:[\r\n         \r\n      ],\r\n      &quot;HasModifyEntriesAccess&quot;:true,\r\n      &quot;HasViewEntryContentsAccess&quot;:true,\r\n      &quot;HasViewEntryPasswordAccess&quot;:true,\r\n      &quot;CommentPrompts&quot;:{\r\n         &quot;AskForCommentOnViewPassword&quot;:false,\r\n         &quot;AskForCommentOnViewOffline&quot;:false,\r\n         &quot;AskForCommentOnModifyEntries&quot;:false,\r\n         &quot;AskForCommentOnMoveEntries&quot;:false,\r\n         &quot;AskForCommentOnMoveFolders&quot;:false,\r\n         &quot;AskForCommentOnModifyFolders&quot;:false\r\n      },\r\n      &quot;Id&quot;:&quot;34307337-6b90-4b6f-bc1d-3dba50fa9cbd&quot;,\r\n      &quot;Name&quot;:&quot;valueA&quot;,\r\n      &quot;Username&quot;:&quot;valueA&quot;,\r\n      &quot;Password&quot;:null,\r\n      &quot;Url&quot;:&quot;&quot;,\r\n      &quot;Notes&quot;:&quot;&quot;,\r\n      &quot;GroupId&quot;:&quot;cd52d662-0771-4eb6-9309-d12aff60b6bb&quot;,\r\n      &quot;Created&quot;:&quot;2021-06-16T00:07:44+02:00&quot;,\r\n      &quot;Modified&quot;:&quot;2021-06-16T18:52:00+02:00&quot;,\r\n      &quot;Expires&quot;:null\r\n   },\r\n   {\r\n      &quot;CustomUserFields&quot;:{\r\n         \r\n      },\r\n      &quot;CustomApplicationFields&quot;:{\r\n         \r\n      },\r\n      &quot;Attachments&quot;:[\r\n         \r\n      ],\r\n      &quot;Tags&quot;:[\r\n         \r\n      ],\r\n      &quot;HasModifyEntriesAccess&quot;:true,\r\n      &quot;HasViewEntryContentsAccess&quot;:true,\r\n      &quot;HasViewEntryPasswordAccess&quot;:true,\r\n      &quot;CommentPrompts&quot;:{\r\n         &quot;AskForCommentOnViewPassword&quot;:false,\r\n         &quot;AskForCommentOnViewOffline&quot;:false,\r\n         &quot;AskForCommentOnModifyEntries&quot;:false,\r\n         &quot;AskForCommentOnMoveEntries&quot;:false,\r\n         &quot;AskForCommentOnMoveFolders&quot;:false,\r\n         &quot;AskForCommentOnModifyFolders&quot;:false\r\n      },\r\n      &quot;Id&quot;:&quot;c92729e3-1325-4725-ae8e-baba4a0d31b5&quot;,\r\n      &quot;Name&quot;:&quot;ValueB&quot;,\r\n      &quot;Username&quot;:&quot;ValueB&quot;,\r\n      &quot;Password&quot;:null,\r\n      &quot;Url&quot;:&quot;&quot;,\r\n      &quot;Notes&quot;:&quot;&quot;,\r\n      &quot;GroupId&quot;:&quot;cd52d662-0771-4eb6-9309-d12aff60b6bb&quot;,\r\n      &quot;Created&quot;:&quot;2021-06-16T00:08:05+02:00&quot;,\r\n      &quot;Modified&quot;:&quot;2021-06-16T18:51:48+02:00&quot;,\r\n      &quot;Expires&quot;:null\r\n   }\r\n]\r\n```\r\nTo get the password, I get the id of **$result** and I use a loop for with another **curl** :\r\n\r\n```\r\nListeId=$(echo &quot;${result}&quot; | jq -r &quot;.[] | .Id&quot;)\r\nfor CredId in $ListeId\r\ndo\r\nsecret=$(curl -l -k -X GET -H &quot;Content-Type: application/json&quot; -H &quot;Authorization: ${token}&quot; &quot;$PasswordServerURL/api/v6/rest/credential/$CredId/password&quot;)\r\ndone\r\n```\r\nI get &quot;pass1&quot; and &quot;pass2&quot;\r\n\r\nHow to match each username (Value A, ValueB ...) to its password ?\r\nThe second question is how to export them as an environment variable in a bash script?\r\nThanks ",
        "link": "https://stackoverflow.com/questions/68007200/loop-over-a-json-in-bash-script",
        "title": "Loop over a JSON in bash script"
    },
    {
        "tags": [
            "json",
            "bash",
            "environment-variables",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1623881850,
                "creation_date": 1623881850,
                "answer_id": 68010653,
                "question_id": 68010556,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I suggest this to read output from `jq` to an array.\r\n\r\n    mapfile -t idd &lt; &lt;(jq &#39;.id&#39; /Users/f.json)\r\n    declare -p idd\r\n\r\nOutput:\r\n&lt;pre&gt;\r\ndeclare -a idd=([0]=&quot;5679162&quot; [1]=&quot;5679163&quot; [2]=&quot;5679164&quot;)\r\n&lt;/pre&gt;",
                "title": "parse json and put in array"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1623904641,
        "creation_date": 1623881059,
        "last_edit_date": 1623904641,
        "question_id": 68010556,
        "body_markdown": "I am trying to parse a JSON file which looks like this and then trying to store each field in an array, then trying to read it. However, its going in an infinite loop, I think. Anyone knows what I am doing wrong?\r\n    \r\n    #!/bin/bash\r\n    \r\n    test(){\r\n    \tlocal file=&quot;/Users/f.json&quot;\r\n    \tif [ -f &quot;$file&quot; ]; then\r\n    \techo &quot;present&quot;\r\n    \telse\r\n    \t\techo &quot;absent&quot;\r\n    \tfi\r\n    \t\r\n    \t#jq . f.json\r\n    \t\r\n    \twhile read rule; do\r\n        \tlocal idd\r\n    \t\tlocal username\r\n    \r\n        idd=$(jq --raw-output &#39;.id&#39; &lt;&lt;&lt; ${rule})\r\n        username=$(jq --raw-output &#39;.username&#39; &lt;&lt;&lt; ${rule})\r\n        \r\n        #username=$(jq --raw-output &#39;.username&#39;)\r\n   \r\n        done\r\n        \r\n        for (( i=0; i&lt;${#idd[@]}; i++ )); do\r\n        \techo &quot;${idd[i]}&quot;\r\n        done\r\n        \r\n    }\r\n    test\r\n\r\nHere is json:\r\n\r\n    {\r\n          &quot;id&quot;: 5679162,\r\n          &quot;username&quot;: &quot;ryderw1&quot;\r\n        }\r\n        {\r\n          &quot;id&quot;: 5679163,\r\n          &quot;username&quot;: &quot;ryderw3&quot;\r\n        }\r\n        {\r\n          &quot;id&quot;: 5679164,\r\n          &quot;username&quot;: &quot;ryderw4&quot;\r\n        }\r\n\r\nMy desired o/p should be:\r\n\r\n    5679162\r\n    5679163\r\n    5679164",
        "link": "https://stackoverflow.com/questions/68010556/parse-json-and-put-in-array",
        "title": "parse json and put in array"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 3302072,
                    "reputation": 3820,
                    "user_id": 2777988,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/JsFcU.jpg?s=256",
                    "display_name": "Rakesh Gupta",
                    "link": "https://stackoverflow.com/users/2777988/rakesh-gupta"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1623899533,
                "post_id": 68012288,
                "comment_id": 120210250,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 889135,
                    "reputation": 846,
                    "user_id": 1076276,
                    "user_type": "registered",
                    "accept_rate": 70,
                    "profile_image": "https://www.gravatar.com/avatar/20d1eb631a46a8ebfc26abbc31fe8422?s=256&d=identicon&r=PG",
                    "display_name": "unfulvio",
                    "link": "https://stackoverflow.com/users/1076276/unfulvio"
                },
                "reply_to_user": {
                    "account_id": 3302072,
                    "reputation": 3820,
                    "user_id": 2777988,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/JsFcU.jpg?s=256",
                    "display_name": "Rakesh Gupta",
                    "link": "https://stackoverflow.com/users/2777988/rakesh-gupta"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1623899695,
                "post_id": 68012288,
                "comment_id": 120210276,
                "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": 1623902338,
                "post_id": 68012288,
                "comment_id": 120210701,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 889135,
                    "reputation": 846,
                    "user_id": 1076276,
                    "user_type": "registered",
                    "accept_rate": 70,
                    "profile_image": "https://www.gravatar.com/avatar/20d1eb631a46a8ebfc26abbc31fe8422?s=256&d=identicon&r=PG",
                    "display_name": "unfulvio",
                    "link": "https://stackoverflow.com/users/1076276/unfulvio"
                },
                "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": 1623904663,
                "post_id": 68012288,
                "comment_id": 120211169,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1623909008,
                "creation_date": 1623909008,
                "answer_id": 68013638,
                "question_id": 68012288,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "It would be better to avoid calling jq more than once.  Consider, for example:\r\n```\r\nwhile read -r name ; do\r\n    read -r url\r\n    echo &quot;$name&quot; &quot;$url&quot;\r\ndone &lt; &lt;( curl .... | jq -r &#39;.[] | .name, .commit.url&#39; )\r\n```\r\n\r\nwhere `curl ....` signifies the relevant invocation of curl.",
                "title": "How to iterate a JSON array of objects with jq and grab multiple variables from each object in each loop"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1623909008,
        "creation_date": 1623898578,
        "last_edit_date": 1623901208,
        "question_id": 68012288,
        "body_markdown": "I need to grab variables from JSON properties.\r\n\r\nThe JSON array looks like this (GitHub API for repository tags), which I obtain from a curl request.\r\n\r\n    [\r\n        {\r\n            &quot;name&quot;: &quot;my-tag-name&quot;,\r\n            &quot;zipball_url&quot;: &quot;https://api.github.com/repos/path-to-my-tag-name&quot;,\r\n            &quot;tarball_url&quot;: &quot;https://api.github.com/repos/path-to-my-tag-name-tarball&quot;,\r\n            &quot;commit&quot;: {\r\n                &quot;sha&quot;: &quot;commit-sha&quot;,\r\n                &quot;url&quot;: &quot;https://api.github.com/repos/path-to-my-commit-sha&quot;\r\n            },\r\n            &quot;node_id&quot;: &quot;node-id&quot;\r\n        },\r\n        {\r\n            &quot;name&quot;: &quot;another-tag-name&quot;,\r\n            &quot;zipball_url&quot;: &quot;https://api.github.com/repos/path-to-my-tag-name&quot;,\r\n            &quot;tarball_url&quot;: &quot;https://api.github.com/repos/path-to-my-tag-name-tarball&quot;,\r\n            &quot;commit&quot;: {\r\n                &quot;sha&quot;: &quot;commit-sha&quot;,\r\n                &quot;url&quot;: &quot;https://api.github.com/repos/path-to-my-commit-sha&quot;\r\n            },\r\n            &quot;node_id&quot;: &quot;node-id&quot;\r\n        },\r\n    ]\r\n\r\nIn my actual JSON there are 100s of objects like these.\r\n\r\nWhile I loop each one of these I need to grab the name and the commit URL, then perform more operations with these two variables before I get to the next object and repeat.\r\n\r\nI tried (with and without -r)\r\n\r\n    tags=$(curl -s -u &quot;${GITHUB_USERNAME}:${GITHUB_TOKEN}&quot; -H &quot;Accept: application/vnd.github.v3+json&quot; &quot;https://api.github.com/repos/path-to-my-repository/tags?per_page=100&amp;page=${page}&quot;)\r\n    for row in $(jq -r &#39;.[]&#39; &lt;&lt;&lt; &quot;$tags&quot;); do\r\n    \ttag=$(jq -r &#39;.name&#39; &lt;&lt;&lt; &quot;$row&quot;)\r\n        # I have also tried with the syntax:\r\n        url=$(echo &quot;${row}&quot; | jq -r &#39;.commit.url&#39;)\r\n        # do stuff with $tag and $url...\r\n    done\r\n\r\nBut I get errors like:\r\n\r\n&gt; parse error: Unfinished JSON term at EOF at line 2, column 0 jq: error\r\n&gt; (at &lt;stdin&gt;:1): Cannot index string with string &quot;name&quot; } parse error:\r\n&gt; Unmatched &#39;}&#39; at line 1, column 1\r\n\r\n\r\nAnd from the terminal output it appears that it is trying to parse `$row` in a strange way, trying to grab `.name` from every substring? Not sure.\r\n\r\nI am assuming the output from `$(jq &#39;.[]&#39; &lt;&lt;&lt; &quot;$tags&quot;)` could be valid JSON, from which I could again use `jq` to grab the object properties I need, but maybe that is not the case? If I output `${row}` it does look like valid JSON to me, and I tried pasting the results in a JSON validator, everything seems to check out...\r\n\r\nHow do I grab the &quot;.name&quot; and &quot;.commit.url&quot; for each of these object before I move onto the next one?\r\n\r\nThanks",
        "link": "https://stackoverflow.com/questions/68012288/how-to-iterate-a-json-array-of-objects-with-jq-and-grab-multiple-variables-from",
        "title": "How to iterate a JSON array of objects with jq and grab multiple variables from each object in each loop"
    },
    {
        "tags": [
            "json",
            "ansible",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1623918152,
                "creation_date": 1623918152,
                "answer_id": 68015581,
                "question_id": 68014727,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You should process your file `test.json` for example using `jq`\r\n\r\n```\r\njq &#39;map(. |= if .docker.network then . else . + {&quot;docker&quot;:{&quot;network&quot;: .id}} end)&#39; test.json\r\n```\r\n\r\nwill print\r\n\r\n```\r\n[\r\n  {\r\n    &quot;id&quot;: &quot;foo&quot;,\r\n    &quot;docker&quot;: {\r\n      &quot;network&quot;: &quot;baz&quot;\r\n    }\r\n  },\r\n  {\r\n    &quot;id&quot;: &quot;bar&quot;,\r\n    &quot;docker&quot;: {\r\n      &quot;network&quot;: &quot;bar&quot;\r\n    }\r\n  }\r\n]\r\n```\r\n\r\nYou can read more in pages:\r\n\r\nhttps://kaijento.github.io/2017/03/26/json-parsing-jq-simplifying-with-map/\r\nhttps://stedolan.github.io/jq/manual/#Math\r\nhttps://stackoverflow.com/questions/42245288/add-new-element-to-existing-json-array-with-jq\r\n\r\nAnd test your command on page:\r\n\r\nhttps://jqplay.org/",
                "title": "Transforming JSON array"
            },
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1623935526,
                "last_edit_date": 1623935526,
                "creation_date": 1623929219,
                "answer_id": 68018389,
                "question_id": 68014727,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "For example\r\n\r\n```yaml\r\n    - debug:\r\n        msg: &quot;{{ _list }}&quot;\r\n      vars:\r\n        _list: &quot;{{ _list_str|from_yaml }}&quot;\r\n        _list_str: |\r\n          [\r\n          {% for i in daemons %}\r\n          {% if i.docker.network is defined %}\r\n          {{ i.docker.network }},\r\n          {% else %}\r\n          {{ i.id }},\r\n          {% endif %}\r\n          {% endfor %}\r\n          ]\r\n```\r\n\r\ngives\r\n\r\n```yaml\r\n  msg:\r\n  - baz\r\n  - bar\r\n```\r\n",
                "title": "Transforming JSON array"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 2,
        "last_activity_date": 1623935526,
        "creation_date": 1623914757,
        "last_edit_date": 1623918335,
        "question_id": 68014727,
        "body_markdown": "I need to conditionally transform a list of objects defined in a JSON file. The problem with the playbook is that I need the transformation to yield either the value of `docker.network` or `id`. Simply put, I need to figure out some kind of ternary operator for transforming lists. The playbook results in:\r\n\r\n    &quot;msg&quot;: &quot;[&#39;baz&#39;, AnsibleUndefined]&quot;\r\n\r\nI need\r\n\r\n    &quot;msg&quot;: &quot;[&#39;baz&#39;, &#39;bar&#39;]&quot;\r\n\r\n**Playbook:**\r\n\r\n    vars:\r\n      daemons: &quot;{{ lookup(&#39;file&#39;,&#39;./test.json&#39;) | from_json }}&quot;\r\n    \r\n      tasks:\r\n        - name: Transform\r\n          debug:\r\n            msg: &quot;{{ daemons | map(attribute=&#39;docker.network&#39;)  }}&quot;\r\n\r\n**test.json:**\r\n\r\n    [\r\n      {\r\n        &quot;id&quot;: &quot;foo&quot;,\r\n        &quot;docker&quot;: {\r\n          &quot;network&quot;: &quot;baz&quot;\r\n        }\r\n      },\r\n      {\r\n        &quot;id&quot;: &quot;bar&quot;,\r\n        &quot;docker&quot;: {\r\n        }\r\n      }\r\n    ]\r\n\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/68014727/transforming-json-array",
        "title": "Transforming JSON array"
    },
    {
        "tags": [
            "linux",
            "bash",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1623927620,
                "creation_date": 1623927620,
                "answer_id": 68018011,
                "question_id": 68017243,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Sounds like `+=` should to the trick &lt;sup&gt;[\\[docs\\]][1]&lt;/sup&gt;\r\n\r\n* `.Aliases.Quantity += 1` To increment `Quantity` by `1`\r\n* `.Aliases.Items += [ &quot;Example&quot; ]` To add a new index to the `Items` array\r\n\r\nFull command:\r\n```jq\r\njq &#39;.Aliases.Quantity += 1 | .Aliases.Items += [ &quot;Example&quot; ]&#39;\r\n```\r\n\r\n### [Online demo][2]\r\n\r\n```json\r\n{\r\n  &quot;CallerReference&quot;: &quot;terraform-20210518124856158900000001&quot;,\r\n  &quot;Aliases&quot;: {\r\n    &quot;Quantity&quot;: 4,\r\n    &quot;Items&quot;: [\r\n      &quot;consumer-portal.mlb.effi.com.au&quot;,\r\n      &quot;*.mlb.effi.com.au&quot;,\r\n      &quot;coolvalue.mylocalbroker.com.au&quot;,\r\n      &quot;Example&quot;\r\n    ]\r\n  }\r\n}\r\n```\r\n\r\n\r\n  [1]: https://stedolan.github.io/jq/manual/#example97\r\n  [2]: https://jqplay.org/s/jcJt733eKx",
                "title": "How to change json object using jq bash"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1623929832,
        "creation_date": 1623924616,
        "last_edit_date": 1623929832,
        "question_id": 68017243,
        "body_markdown": "I have a `json` object that looks like below:\r\n\r\n```\r\n{\r\n    &quot;CallerReference&quot;: &quot;terraform-20210518124856158900000001&quot;,\r\n    &quot;Aliases&quot;: {\r\n        &quot;Quantity&quot;: 3,\r\n        &quot;Items&quot;: [\r\n            &quot;consumer-portal.mlb.effi.com.au&quot;,\r\n            &quot;*.mlb.effi.com.au&quot;,\r\n            &quot;coolvalue.mylocalbroker.com.au&quot;\r\n        ]\r\n    }\r\n}\r\n```\r\n\r\nAnd I need to;\r\n\r\n1. First get the value of `Quantity`\r\n2. Increment it by 1\r\n3. Then change that value so it looks like `&quot;Quantity&quot;: 4,`\r\n4. And I need to add another entry at the bottom of the `Items` array.\r\n\r\nI am using `jq` and trying to first replace the `&quot;Quantity&quot;` value as below:\r\n\r\n\r\n```\r\nfilename=cf.json\r\nrm $filename\r\naws cloudfront get-distribution-config --id &lt;ID&gt; \\\r\n  --query &#39;DistributionConfig&#39; --output json &gt; $filename\r\n\r\netag=$(aws cloudfront  get-distribution-config --id &lt;ID&gt; |\r\n       jq -r &#39;.ETag&#39;)\r\n\r\naws cloudfront update-distribution \\\r\n  --distribution-config file://$filename --id &lt;ID&gt; --if-match $etag &gt; /dev/null\r\n\r\njq --argjson i &quot;10&quot; &#39;.Aliases.Quantity[$i]&#39; $filename\r\n```\r\n\r\nBut I am getting this error:\r\n\r\n&gt;jq: error (at cf.json:136): Cannot index number with number",
        "link": "https://stackoverflow.com/questions/68017243/how-to-change-json-object-using-jq-bash",
        "title": "How to change json object using jq bash"
    },
    {
        "tags": [
            "arrays",
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1623933030,
                "creation_date": 1623933030,
                "answer_id": 68019400,
                "question_id": 68018808,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Almost there. To construct objects, you need object contructors.\r\n```\r\n  group_by(.fields.issuetype.name)\r\n| map({item: .[0].fields.issuetype.name, size: map(.fields.size) | add})\r\n```\r\n&lt;sup&gt;[Online demo](https://jqplay.org/s/b0bJgoBa7Z)&lt;/sup&gt;",
                "title": "Group stream elements and sum a field using JQ"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1623933142,
        "creation_date": 1623930796,
        "last_edit_date": 1623933142,
        "question_id": 68018808,
        "body_markdown": "I am trying to group several items by their name based on the JSON-Data. Furthermore I want to calculate the sum of the size. Therefore I am using jq to transforming the data. Attached you see the raw data.\r\n```\r\n{\r\n  &quot;fields&quot;: {\r\n    &quot;issuetype&quot;: {\r\n      &quot;name&quot;: &quot;Server&quot;\r\n    },\r\n    &quot;size&quot;: 2\r\n  }\r\n}\r\n{\r\n  &quot;fields&quot;: {\r\n    &quot;issuetype&quot;: {\r\n      &quot;name&quot;: &quot;Server&quot;\r\n    },\r\n    &quot;size&quot;: 2\r\n  }\r\n}\r\n{\r\n  &quot;fields&quot;: {\r\n    &quot;issuetype&quot;: {\r\n      &quot;name&quot;: &quot;Hardware&quot;\r\n    },\r\n    &quot;size&quot;: 0.58\r\n  }\r\n}\r\n```\r\nThe transformed data should be structered like this:\r\n```\r\n[\r\n  {\r\n    &quot;item&quot;: &quot;Hardware&quot;,\r\n    &quot;size&quot;: 0.58\r\n  },\r\n  {\r\n    &quot;item&quot;: &quot;Server&quot;,\r\n    &quot;size&quot;: 4\r\n  }\r\n]\r\n```\r\n\r\nI am using the following code \r\n\r\n    jq -s &lt; input.json &quot;group_by( .fields.issuetype.name ) | .[] | item: .[0].fields.issuetype.name), size:([.[].fields.customfield_1234] | add)&quot; &gt; transformedData.json\r\n\r\n",
        "link": "https://stackoverflow.com/questions/68018808/group-stream-elements-and-sum-a-field-using-jq",
        "title": "Group stream elements and sum a field using JQ"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1623946078,
                "creation_date": 1623946078,
                "answer_id": 68022923,
                "question_id": 68022774,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I just found the solution myself, the trick was to end the array before sending it to the `join` function:\r\n\r\n    echo $MY_JSON | jq &#39;[ .content[].content[] | select(.type | contains(&quot;inlineCard&quot;)) | .attrs.url ] | join(&quot;,&quot;)&#39;",
                "title": "Using jq to concatenate multiple entries into a single string value?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1623946078,
        "creation_date": 1623945504,
        "question_id": 68022774,
        "body_markdown": "I&#39;ve been experimenting for quite a while now and also researched stackoverflow and came across this question which comes closes to what I&#39;m trying to achieve:\r\nhttps://stackoverflow.com/questions/45165303/how-to-combine-an-array-into-a-single-string-value-when-using-csv-output-in-jq\r\n\r\nMy JSON output looks quite a big more complicated though:\r\n\r\n    &quot;content&quot;: [\r\n\t{\r\n\t\t&quot;type&quot;: &quot;paragraph&quot;,\r\n\t\t&quot;content&quot;: [\r\n\t\t\t{\r\n\t\t\t\t&quot;type&quot;: &quot;inlineCard&quot;,\r\n\t\t\t\t&quot;attrs&quot;: {\r\n\t\t\t\t&quot;url&quot;: &quot;https://www.myurl.com&quot;\r\n\t\t\t\t}\r\n\t\t\t},\r\n\t\t\t{\r\n\t\t\t\t&quot;type&quot;: &quot;text&quot;,\r\n\t\t\t\t&quot;text&quot;: &quot; &quot;\r\n\t\t\t}\r\n\t\t]\r\n\t},\r\n\t{\r\n\t\t&quot;type&quot;: &quot;paragraph&quot;,\r\n\t\t&quot;content&quot;: [\r\n\t\t\t{\r\n\t\t\t\t&quot;type&quot;: &quot;inlineCard&quot;,\r\n\t\t\t\t&quot;attrs&quot;: {\r\n\t\t\t\t\t&quot;url&quot;: &quot;https://www.anotherurl.com&quot;\r\n\t\t\t\t}\r\n\t\t\t},\r\n\t\t\t{\r\n\t\t\t\t&quot;type&quot;: &quot;text&quot;,\r\n\t\t\t\t&quot;text&quot;: &quot; &quot;\r\n\t\t\t}\r\n\t\t]\r\n\t},\r\n\t{\r\n\t\t&quot;type&quot;: &quot;paragraph&quot;,\r\n\t\t&quot;content&quot;: [\r\n\t\t\t{\r\n\t\t\t\t&quot;type&quot;: &quot;inlineCard&quot;,\r\n\t\t\t\t&quot;attrs&quot;: {\r\n\t\t\t\t\t&quot;url&quot;: &quot;https://www.andanotherurl.com&quot;\r\n\t\t\t\t}\r\n\t\t\t},\r\n\t\t\t{\r\n\t\t\t\t&quot;type&quot;: &quot;text&quot;,\r\n\t\t\t\t&quot;text&quot;: &quot; &quot;\r\n\t\t\t}\r\n\t\t]\r\n\t}\r\n    ]\r\n\r\nI would now like to get the following result:\r\n\r\n    &quot;https://www.myurl.com, https://www.anotherurl.com, https://www.andanotherurl.com&quot;\r\n\r\nI&#39;ve tried the following:\r\n\r\n    echo $MY_JSON | jq &#39;[ .content[].content[] | select(.type | contains(&quot;inlineCard&quot;)) | .attrs.url | join(&quot;,&quot;) ]&#39;\r\n\r\nbut that tells me\r\n\r\n    jq: error (at &lt;stdin&gt;:0): Cannot iterate over string (&quot;http://ww...)\r\n\r\nCan anyone help me? Thank you!",
        "link": "https://stackoverflow.com/questions/68022774/using-jq-to-concatenate-multiple-entries-into-a-single-string-value",
        "title": "Using jq to concatenate multiple entries into a single string value?"
    },
    {
        "tags": [
            "go",
            "terminal",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 1259930,
                    "reputation": 22555,
                    "user_id": 1218512,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f40bbe64fcdaa806d999fe25dffc0690?s=256&d=identicon&r=PG",
                    "display_name": "colm.anseo",
                    "link": "https://stackoverflow.com/users/1218512/colm-anseo"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1623948703,
                "post_id": 68023503,
                "comment_id": 120229397,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 15526,
                    "reputation": 109726,
                    "user_id": 32880,
                    "user_type": "registered",
                    "accept_rate": 75,
                    "profile_image": "https://www.gravatar.com/avatar/7728fc825d24a338b763bfa32b2aea9f?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Mr_Pink",
                    "link": "https://stackoverflow.com/users/32880/mr-pink"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1623948730,
                "post_id": 68023503,
                "comment_id": 120229406,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1259930,
                    "reputation": 22555,
                    "user_id": 1218512,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f40bbe64fcdaa806d999fe25dffc0690?s=256&d=identicon&r=PG",
                    "display_name": "colm.anseo",
                    "link": "https://stackoverflow.com/users/1218512/colm-anseo"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1623949105,
                "post_id": 68023503,
                "comment_id": 120229597,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1332780,
                    "reputation": 1198,
                    "user_id": 1440786,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/e59d2183135d8072365bc4f12b0dd311?s=256&d=identicon&r=PG",
                    "display_name": "Bracken",
                    "link": "https://stackoverflow.com/users/1440786/bracken"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1623949198,
                "post_id": 68023503,
                "comment_id": 120229644,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "is_answered": false,
        "answer_count": 0,
        "score": 0,
        "last_activity_date": 1623949147,
        "creation_date": 1623948557,
        "question_id": 68023503,
        "body_markdown": "I&#39;m trying to pass a json data to `jq` command and replace a value like `sed`. But it&#39;s just printing the command and not executing it. \r\n\r\n    jsonStr, _ := json.Marshal(p.Values)\r\n    op, _ := exec.Command(&quot;echo&quot;, string(jsonStr), &quot;| jq &#39;.aws=1&#39;&quot;).CombinedOutput()\r\n    fmt.Println(string(op))\r\n\r\n\r\nIt&#39;s just printing the `value of p.Values` which is a json and `| jq &#39;.aws=1&#39;` instead of replacing the `aws` key in `p.Values` and printing it.\r\n\r\nThe output is something like this.\r\n\r\n`{&quot;name&quot;: &quot;n1&quot;} | jq &#39;.aws=1&#39;`\r\n\r\nBut if I execute the same command from terminal, it&#39;s working fine and replacing the text in json.\r\n\r\n ",
        "link": "https://stackoverflow.com/questions/68023503/unable-to-execute-jq-command-in-golang",
        "title": "Unable to execute jq command in golang"
    },
    {
        "tags": [
            "json",
            "command-line",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 5,
                "is_accepted": false,
                "score": 5,
                "last_activity_date": 1623952747,
                "last_edit_date": 1623952747,
                "creation_date": 1623951897,
                "answer_id": 68024219,
                "question_id": 68023759,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The parentheses just change the precedence. It&#39;s documented in `man jq`:\r\n\r\n&gt;Parenthesis work as a grouping operator just as in any  typical  programming  language.\r\n&gt;```\r\n&gt;       jq &#180;(. + 2) * 5&#180;\r\n&gt;          1\r\n&gt;       =&gt; 15\r\n&gt;```\r\nLet&#39;s have a simpler example:\r\n```\r\necho &#39;[{&quot;a&quot;:1}, {&quot;a&quot;:2}]&#39; | jq &#39;.[] | .a |= .+1&#39;\r\n```\r\nIt outputs\r\n```\r\n{\r\n  &quot;a&quot;: 2\r\n}\r\n{\r\n  &quot;a&quot;: 3\r\n}\r\n```\r\nbecause it&#39;s interpreted as\r\n\r\n```\r\n                                      ↓         ↓\r\necho &#39;[{&quot;a&quot;:1}, {&quot;a&quot;:2}]&#39; | jq &#39;.[] | (.a |= .+1)&#39;\r\n```\r\nThe first filter `.[]` outputs the elements as separated objects, they are then modified by the second filter.\r\n\r\nPlacing the parentheses after the first two elements changes the precedence:\r\n```\r\n                                ↓        ↓\r\necho &#39;[{&quot;a&quot;:1}, {&quot;a&quot;:2}]&#39; | jq &#39;(.[] | .a) |= .+1&#39;\r\n```\r\nand produces a different otuput:\r\n```\r\n[\r\n  {\r\n    &quot;a&quot;: 2\r\n  },\r\n  {\r\n    &quot;a&quot;: 3\r\n  }\r\n]\r\n```\r\nBTW, this is the same output as from\r\n```\r\necho &#39;[{&quot;a&quot;:1}, {&quot;a&quot;:2}]&#39; | jq &#39;.[].a |= .+1&#39;\r\n```\r\nIt changes the value associated with the `&quot;a&quot;` key in the array.",
                "title": "Why is adding parentheses to a filter in &#39;jq&#39; producing valid JSON and without parentheses, multiple outputs of objects?"
            },
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1624023692,
                "last_edit_date": 1624023692,
                "creation_date": 1623953205,
                "answer_id": 68024479,
                "question_id": 68023759,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Let&#39;s compare the two.\r\n\r\n     .notifications[] | select(...).time = &quot;NEWTIME&quot;\r\n\r\n    (.notifications[] | select(...).time) = &quot;NEWTIME&quot;\r\n\r\n\r\nIn the first one, the top-level filter is defined by `|`. The input is an object, and the output is the result of applying `select(...).time = &quot;NEWTIME&quot;` to each value produced by `.notifications[]`. In essence, the original object is &quot;lost&quot;.\r\n\r\nIn the second one, the top-level filter is defined by `=`. `x = y` returns its input as output, but with a side effect produced by\r\n\r\n  1. Determining what the *path expression* `x` refers to in the input,\r\n  2. Evaluating the *filter* `y` on the input, (Even an expression like `&quot;NEWTIME&quot;` is just a filter: one that ignores its input and returns the string `&quot;NEWTIME&quot;`)\r\n  3. Assigning the result of `y` to the thing addressed by `x`.",
                "title": "Why is adding parentheses to a filter in &#39;jq&#39; producing valid JSON and without parentheses, multiple outputs of objects?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1624023692,
        "creation_date": 1623949645,
        "question_id": 68023759,
        "body_markdown": "With [jq][1], I would like to set a property within JSON data and let [jq][1] output the original JSON with the updated value. I found, more or less due to trial and error, a solution, and want to understand why and how it works.\r\n\r\nI have the following JSON data:\r\n\r\n```json\r\n{\r\n    &quot;notifications&quot;: [\r\n    {\r\n      &quot;source&quot;: &quot;observer01&quot;,\r\n      &quot;channel&quot;: &quot;error&quot;,\r\n      &quot;time&quot;: &quot;2021-01-01 01:01:01&quot;\r\n    },\r\n    {\r\n      &quot;source&quot;: &quot;observer01&quot;,\r\n      &quot;channel&quot;: &quot;info&quot;,\r\n      &quot;time&quot;: &quot;2021-02-02 02:02:02&quot;\r\n    }\r\n  ]\r\n}\r\n```\r\n\r\nMy goal is to update the `time` property of an object with a specific `source` and `channel` (the original JSON is way longer with lots of objects in the `notifications` array of the same format).\r\n\r\n(In the following example, I want to update the `time` property of `observer01` with channel `info`, so the second object in the example data above.)\r\n\r\nMy first try, not producing the desired output, was the following `jq` command:\r\n\r\n```\r\njq &#39;.notifications[] | select(.source == &quot;observer01&quot; and .channel == &quot;info&quot;).time = &quot;NEWTIME&quot;&#39; data.json\r\n```\r\n\r\nThat produces the following output:\r\n\r\n```json\r\n{\r\n  &quot;source&quot;: &quot;observer01&quot;,\r\n  &quot;channel&quot;: &quot;error&quot;,\r\n  &quot;time&quot;: &quot;2021-01-01 01:01:01&quot;\r\n},\r\n{\r\n  &quot;source&quot;: &quot;observer01&quot;,\r\n  &quot;channel&quot;: &quot;info&quot;,\r\n  &quot;time&quot;: &quot;NEWTIME&quot;\r\n}\r\n```\r\n\r\nWhich is just a list of the JSON objects within the `notifications` array. I understand that this can be useful, for example piping the objects to other command line tools.\r\n\r\nNow let&#39;s try the following `jq` command, which is the same as above plus one pair of parentheses:\r\n\r\n```\r\njq &#39;(.notifications[] | select(.source == &quot;observer01&quot; and .channel == &quot;info&quot;).time) = &quot;NEWTIME&quot;&#39; data.json\r\n```\r\n\r\nThis produces the desired output, the original valid JSON with the updated `time` property:\r\n\r\n```json\r\n{\r\n    &quot;notifications&quot;: [\r\n    {\r\n      &quot;source&quot;: &quot;observer01&quot;,\r\n      &quot;channel&quot;: &quot;error&quot;,\r\n      &quot;time&quot;: &quot;2021-01-01 01:01:01&quot;\r\n    },\r\n    {\r\n      &quot;source&quot;: &quot;observer01&quot;,\r\n      &quot;channel&quot;: &quot;info&quot;,\r\n      &quot;time&quot;: &quot;NEWTIME&quot;\r\n    }\r\n  ]\r\n}\r\n```\r\n\r\nWhy is adding the parentheses to the `jq` filter in the case above producing a different output?\r\n\r\n\r\n  [1]: https://stedolan.github.io/jq/",
        "link": "https://stackoverflow.com/questions/68023759/why-is-adding-parentheses-to-a-filter-in-jq-producing-valid-json-and-without-p",
        "title": "Why is adding parentheses to a filter in &#39;jq&#39; producing valid JSON and without parentheses, multiple outputs of objects?"
    },
    {
        "tags": [
            "regex",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 5,
                "is_accepted": true,
                "score": 5,
                "last_activity_date": 1710998072,
                "last_edit_date": 1710998072,
                "creation_date": 1623954448,
                "answer_id": 68024741,
                "question_id": 68024571,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "In JQ we use [named capture groups](https://www.pcre.org/current/doc/html/pcre2pattern.html#SEC16) for that.\r\n```\r\nsub(&quot;.*T(?&lt;x&gt;.*)\\\\..*&quot;; .x)\r\n```",
                "title": "Using backreference as replacement string in JQ"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1623954693,
                "creation_date": 1623954693,
                "answer_id": 68024791,
                "question_id": 68024571,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "In this case, you may remove all up to `T` and all the text starting with (and including) a dot with `.*T|\\.[^.]*$` regex:\r\n```bash\r\ns=&#39;{&quot;node&quot;:&quot;2021-06-10T10:42:30.016+0200&quot;}&#39;\r\njq &#39;.node |= gsub(&quot;.*T|\\\\.[^.]*$&quot;; &quot;&quot;)&#39; &lt;&lt;&lt; &quot;$s&quot;\r\n```\r\nOutput:\r\n```\r\n{\r\n  &quot;node&quot;: &quot;10:42:30&quot;\r\n}\r\n```\r\n*Pattern details*:\r\n\r\n - `.*T` - any text and then `T`\r\n - `|` - or \r\n - `\\.` - a dot\r\n - `[^.]*` - zero or more chars other than a `.`\r\n - `$` - end of string.",
                "title": "Using backreference as replacement string in JQ"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 4,
        "last_activity_date": 1710998072,
        "creation_date": 1623953617,
        "last_edit_date": 1623954722,
        "question_id": 68024571,
        "body_markdown": "Assuming I want to extract the time part of a date/time string on the shell I can do something like:\r\n\r\n    echo &quot;2021-06-10T10:42:30.016+0200&quot; | sed &#39;s|.*T\\(.*\\)\\..*|\\1|g&#39;\r\n\r\nThis returns\r\n\r\n    10:42:30\r\n\r\nHow can I achieve the same with `jq` and `sub()`?\r\nI&#39;m missing the right syntax. I was not able to find any good examples. E.g. I&#39;ve been trying:\r\n\r\n    jq &#39;&lt;myid&gt; | sub(&quot;.*T(.*)\\\\..*&quot;; &quot;\\1&quot;)&#39;\r\n    jq &#39;&lt;myid&gt; | sub(&quot;.*T(.*)\\\\..*&quot;; &quot;$1&quot;)&#39;\r\n    jq &#39;&lt;myid&gt; | sub(&quot;.*T\\\\(.*\\\\)\\\\..*&quot;; &quot;\\1&quot;)&#39;\r\n\r\nBut none of this returns back what I want?",
        "link": "https://stackoverflow.com/questions/68024571/using-backreference-as-replacement-string-in-jq",
        "title": "Using backreference as replacement string in JQ"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 4663062,
                    "reputation": 89888,
                    "user_id": 3776858,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/Cagbk.jpg?s=256",
                    "display_name": "Cyrus",
                    "link": "https://stackoverflow.com/users/3776858/cyrus"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1623955996,
                "post_id": 68025031,
                "comment_id": 120232157,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1623958819,
                "last_edit_date": 1623958819,
                "creation_date": 1623956637,
                "answer_id": 68025193,
                "question_id": 68025031,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can use `jq` to add a new key-value pair to the object in `config.json`, then write the new object back to disk.\r\n\r\n    jq &#39;.proxies = {\r\n        &quot;default&quot;: {\r\n            &quot;httpProxy&quot;: &quot;http://proxy.xyz.com:123&quot;,\r\n            &quot;httpsProxy&quot;: &quot;http://proxy.xyz.com:123&quot;,\r\n            &quot;noProxy&quot;: &quot;127.0.0.1,localhost&quot;\r\n        }\r\n    }&#39;  ~/.docker/config.json &gt; tmp &amp;&amp; mv tmp ~/.docker/config.json\r\n\r\n---\r\n\r\nEverything in `jq` is a filter: they take a stream of JSON values as inputs, and return a stream of JSON values as output. Assignment is no different.\r\n\r\nIn the filter `x = y`, `x` is a path expression and `y` is an ordinary filter. `x` is evaluated using the input to determine the &quot;target&quot; for the assignment. `y` is applied to the input, and its output is assigned to the target specific by `x`.\r\n\r\nIn this case, the input is the entire contents of `config.json`. `.proxies` specifies a key in an object, and the `{...}` expression is a filter that ignores the input and produces a JSON object. That JSON object is that added to the input under the `proxies` key, and the modified object is returned as the output, which `jq` then writes to standard output.\r\n\r\nThe result is written to a new file so that we don&#39;t overwrite `config.json` before we can read it. Assuming `jq` succeeds, we can then replace the old `config.json` with the new file `tmp`.\r\n\r\n`jq` itself cannot write to a file, only standard output. It can read JSON values either from standard input or from files named as arguments.",
                "title": "Insert a JSON object at the end of a JSON file using shell script in linux"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -1,
        "last_activity_date": 1623990894,
        "creation_date": 1623955861,
        "last_edit_date": 1623990894,
        "question_id": 68025031,
        "body_markdown": "I&#39;ve a file ~/.docker/config.json as follows.\r\n\r\n    {\r\n            &quot;auths&quot;: {\r\n                    &quot;https://index.docker.io/v1/&quot;: {\r\n                            &quot;auth&quot;: &quot;bmFnZGVlcGdrOk5hZzEzNDFkb2NrZXJA&quot;\r\n                    }\r\n            }\r\n    }\r\n\r\nI want to append the following JSON object to it using shell script (*.sh) in  my ubuntu 18.04.\r\nHow can I achieve this ?\r\n\r\n    &quot;proxies&quot;: {\r\n    \t\t&quot;default&quot;: {\r\n    \t\t\t&quot;httpProxy&quot;: &quot;http://proxy.xyz.com:123&quot;,\r\n    \t\t\t&quot;httpsProxy&quot;: &quot;http://proxy.xyz.com:123&quot;,\r\n    \t\t\t&quot;noProxy&quot;: &quot;127.0.0.1,localhost&quot;\r\n    \t\t}\r\n    \t}\r\n\r\nSo the final file ~/.docker/config.json should look like this:\r\n\r\n    {\r\n                &quot;auths&quot;: {\r\n                        &quot;https://index.docker.io/v1/&quot;: {\r\n                                &quot;auth&quot;: &quot;bmFnZGVlcGdrOk5hZzEzNDFkb2NrZXJA&quot;\r\n                        }\r\n                },\r\n                &quot;proxies&quot;: {\r\n        \t\t&quot;default&quot;: {\r\n        \t\t\t&quot;httpProxy&quot;: &quot;http://proxy.xyz.com:123&quot;,\r\n        \t\t\t&quot;httpsProxy&quot;: &quot;http://proxy.xyz.com:123&quot;,\r\n        \t\t\t&quot;noProxy&quot;: &quot;127.0.0.1,localhost&quot;\r\n        \t\t}\r\n        \t}\r\n    }\r\n\r\nHow to achieve this appending JSON object to the end of a JSON file using shell scripting.",
        "link": "https://stackoverflow.com/questions/68025031/insert-a-json-object-at-the-end-of-a-json-file-using-shell-script-in-linux",
        "title": "Insert a JSON object at the end of a JSON file using shell script in linux"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1623956379,
                "creation_date": 1623956379,
                "answer_id": 68025143,
                "question_id": 68025092,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I suggest:\r\n\r\n    echo &quot;$verses&quot; | jq -r &#39;.verse[1].text&#39;\r\n\r\nOutput:\r\n&lt;pre&gt;\r\nHeld me at the golden door.\r\n&lt;/pre&gt;",
                "title": "jq: Combining 3 filters into one"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1623957314,
        "creation_date": 1623956128,
        "last_edit_date": 1623957314,
        "question_id": 68025092,
        "body_markdown": "Website https://sites.research.google/versebyverse/ can generate poems automatically.  \r\nI want to get them to Linux console.  \r\nI have inspected this website with Firefox and found, that it uses GET and POST and JSON.\r\n  \r\nI have selected such parameters:\r\n\r\n* Edgar Allan Poe\r\n* Qutrain\r\n* The number of syllables for each line of verse: 7\r\n* The letters indicate which lines of the poem rhyme: ABCB\r\n\r\nI have made curl request and saved it to variable:\r\n\r\n    verses=$(curl -k &#39;https://sites.research.google/versebyverse/api/PoemFrontendService/GenerateVerses&#39; --compressed -H &#39;Content-Type: application/json&#39; -H &#39;Origin: https://sites.research.google&#39; -H &#39;Connection: keep-alive&#39; -H &#39;Referer: https://sites.research.google/versebyverse/&#39; --data-raw &#39;{&quot;dependency&quot;:&quot;The sheer wall&quot;,&quot;numberOfVerses&quot;:5,&quot;poetKey&quot;:[&quot;edgar_allan_poe&quot;],&quot;samplingSize&quot;:10,&quot;syllableCount&quot;:&quot;7&quot;}&#39; )\r\n\r\nNow I want to parse it with jq. But I have no ided how to do it with one command.  \r\nI came only to this:\r\n\r\n    echo &quot;$verses&quot; | jq .verse | jq &#39;[.[]|select(.text)][0]&#39; | jq -r .text\r\n\r\nAnd that gave me:\r\n\r\n    Held me at my many home—\r\n\r\nThat&#39;s fine but I need to have only one jq for better code. Please help me to make this with just one jq.  \r\nI need to select the result of **text** and only the first one. Or random one if it&#39;s possible.",
        "link": "https://stackoverflow.com/questions/68025092/jq-combining-3-filters-into-one",
        "title": "jq: Combining 3 filters into one"
    },
    {
        "tags": [
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 1526413,
                    "reputation": 13993,
                    "user_id": 1424739,
                    "user_type": "registered",
                    "accept_rate": 17,
                    "profile_image": "https://www.gravatar.com/avatar/19d3c927744b5ad3b94afbf88e1c3844?s=256&d=identicon&r=PG",
                    "display_name": "user1424739",
                    "link": "https://stackoverflow.com/users/1424739/user1424739"
                },
                "reply_to_user": {
                    "account_id": 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": 1623994431,
                "post_id": 68029752,
                "comment_id": 120240447,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1623995830,
                "last_edit_date": 1623995830,
                "creation_date": 1623995217,
                "answer_id": 68029939,
                "question_id": 68029752,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "jq programs are always filters. The maxim “No input, no output.” properly understood, always holds, though you might be able to achieve whatever it is you really want by using the -n option, e.g. using `inputs`:\r\n\r\n    jq -n &#39;(inputs | if ... end) // &quot;xxxx&quot;&#39;\r\n\r\n Note: the -n option in effect provides the JSON value `null` as the input to the jq program. It does not mean “provide no input”.",
                "title": "How to reach else in if?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -2,
        "last_activity_date": 1623995830,
        "creation_date": 1623994015,
        "last_edit_date": 1623994421,
        "question_id": 68029752,
        "body_markdown": "```\r\nif has(&quot;data&quot;) then\r\n.data\r\nelse\r\n&quot;xxxx&quot;\r\nend\r\n```\r\n\r\nThe second command below does not have any output. But I&#39;d expect to see &quot;xxxx&quot;. Could anybody show me how to fix the jq code that the else branch can be used? Thanks.\r\n\r\n```\r\n$ jq -r -f x.jq &lt;&lt;&lt; &#39;{&quot;data&quot;: 42}&#39;\r\n42\r\n$ jq -r -f x.jq &lt; /dev/null\r\n```",
        "link": "https://stackoverflow.com/questions/68029752/how-to-reach-else-in-if",
        "title": "How to reach else in if?"
    },
    {
        "tags": [
            "json",
            "bash",
            "shell",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "user_type": "does_not_exist",
                    "display_name": "user2849202"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1624211631,
                "post_id": 68031453,
                "comment_id": 120290654,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1624210918,
                "last_edit_date": 1624210918,
                "creation_date": 1624023976,
                "answer_id": 68036292,
                "question_id": 68031453,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "```\r\nexport USER_PROXY= &quot;proxy.zyz.com:122&quot;\r\n```\r\n\r\n1. You can&#39;t have a space here. This sets `USER_PROXY` to an empty string and tries to export a non-existant variable &#39;proxy.zyz.com:122&#39;. You probably want\r\n\r\n```\r\nexport USER_PROXY=&quot;proxy.zyz.com:122&quot;\r\n```\r\n\r\n```\r\njq -r --arg UPROXY ${USER_PROXY} &#39;.proxies = {\r\n            &quot;default&quot;: {\r\n            &quot;httpProxy&quot;: &quot;http://$UPROXY\\&quot;,\r\n            &quot;httpsProxy&quot;: &quot;http://$UPROXY\\&quot;,\r\n            &quot;noProxy&quot;: &quot;127.0.0.1,localhost&quot;\r\n            }\r\n            }&#39;  ~/.docker/config.json &gt; tmp &amp;&amp; mv tmp ~/.docker/config.json\r\n```\r\n2. You need quotes around `${USER_PROXY}` otherwise any whitespace in it will break it. Instead use `--arg UPROXY &quot;${USER_PROXY}&quot;`.\r\n3. This isn&#39;t the syntax for using variables inside a string in jq. Instead of `&quot;...$UPROXY...&quot;` you need `&quot;...\\($UPROXY)...&quot;`\r\n4. You are escaping the `&quot;` at the end of the string by putting a `\\` before it. I am not sure what you mean here. I think you perhaps meant to use a forward slash instead?\r\n\r\nThis last issue is the immediate cause of the error message you&#39;re saying. It says `&quot;syntax error, unexpected IDENT, expecting &#39;}&#39; at line 4&quot;` and then shows you what it found on line 4: `&quot;httpsProxy&quot;: ...`. It parsed the string from line 3, which looks like: `&quot;http://$UPROXY\\&quot;\\n            &quot;` because the escaped double quote doesn&#39;t end the string. After finding the end of the string on line 4, jq expects to find a `}` to close the object, or a `,` for the next key-value-pair, but it finds `httpsProxy`, which looks like an _identifier_. So that&#39;s what the error message is saying. It found an IDENTifier when it was expecting a `}` (or a `,` but it doesn&#39;t mention that).",
                "title": "Use variables in JQ queries"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -2,
        "last_activity_date": 1624210918,
        "creation_date": 1624002982,
        "question_id": 68031453,
        "body_markdown": "\r\nI want to use the value of a variable USER_PROXY in the JQ query statement.\r\n\r\n    export USER_PROXY= &quot;proxy.zyz.com:122&quot;\r\n\r\nBY refering the SO answer no:1 from [HERE][1] , and also the [LINK][2], I made the following shell script. \r\n\r\n    jq -r --arg UPROXY ${USER_PROXY} &#39;.proxies = {\r\n                &quot;default&quot;: {\r\n                &quot;httpProxy&quot;: &quot;http://$UPROXY\\&quot;,\r\n                &quot;httpsProxy&quot;: &quot;http://$UPROXY\\&quot;,\r\n                &quot;noProxy&quot;: &quot;127.0.0.1,localhost&quot;\r\n                }\r\n                }&#39;  ~/.docker/config.json &gt; tmp &amp;&amp; mv tmp ~/.docker/config.json\r\n\r\nHowever, I see I get the bash error as below. What is it that is missing here. Why is JQ variable UPROXY not getting the value from USER_PROXY bash variable.\r\n\r\n[![enter image description here][3]][3]\r\n\r\n\r\n  [1]: https://stackoverflow.com/questions/40027395/passing-bash-variable-to-jq\r\n  [2]: https://phpfog.com/using-variables-in-jq-command-line-json-parser/\r\n  [3]: https://i.sstatic.net/SsIzW.png",
        "link": "https://stackoverflow.com/questions/68031453/use-variables-in-jq-queries",
        "title": "Use variables in JQ queries"
    },
    {
        "tags": [
            "json",
            "jq",
            "jmespath"
        ],
        "answers": [
            {
                "up_vote_count": 18,
                "is_accepted": false,
                "score": 16,
                "last_activity_date": 1624047190,
                "creation_date": 1624047190,
                "answer_id": 68040961,
                "question_id": 68039947,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "It&#39;s not so much about the difference between JMESPath and `jq` as the different ways they are *used*.\r\n\r\nSuppose you are querying a remote resource, the result is going to number in the millions of records, but you only care about a specific, much smaller subset of the records. You have two choices:\r\n\r\n  1. Have every record transmitted to you over the network, then pick out the ones you want locally\r\n  2. Send your filter to the remote resource, and have *it* do the filtering, only sending you the response.\r\n\r\n`jq` is typically used for the former, JMESPath for the latter. There&#39;s no reason why the remote service couldn&#39;t accept a `jq` filter, or that you couldn&#39;t use a JMESPath-based executable.",
                "title": "How to search with case insensitive regex using JMESPath"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 22,
        "last_activity_date": 1683578826,
        "creation_date": 1624040956,
        "last_edit_date": 1683578826,
        "question_id": 68039947,
        "body_markdown": "I need to work with some systems that use JMESPath to search JSON. How can I search for strings with pattern (like [this](https://stackoverflow.com/questions/66677527/how-to-match-a-regex-on-an-array-name-itself-in-jmespath-json-element-string-re)). How do I do this with a regular expression in case-insensitive mode?\r\n\r\nP.S.: Not sure why AWS S3 CLI, and Ansible use JMESPath instead of jq to query JSON. It seems to be missing these features and the proposal to add split function has been frozen since 2017 (like [this](https://github.com/jmespath/jmespath.site/issues/35) and [this](https://github.com/jmespath/jmespath.py/issues/159)). These features are all available to jq. What are the strengths of JMESPath that make it appealing? ",
        "link": "https://stackoverflow.com/questions/68039947/how-to-search-with-case-insensitive-regex-using-jmespath",
        "title": "How to search with case insensitive regex using JMESPath"
    },
    {
        "tags": [
            "json",
            "csv",
            "null",
            "export-to-csv",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 1693,
                    "reputation": 18059,
                    "user_id": 2283,
                    "user_type": "registered",
                    "accept_rate": 79,
                    "profile_image": "https://www.gravatar.com/avatar/3ac5db3768c09788ed9fe03c5f4ff171?s=256&d=identicon&r=PG",
                    "display_name": "Weeble",
                    "link": "https://stackoverflow.com/users/2283/weeble"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1624223186,
                "post_id": 68042332,
                "comment_id": 120293212,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1624059522,
                "creation_date": 1624059522,
                "answer_id": 68042445,
                "question_id": 68042332,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Use `//` as alternative operator for your cell value:\r\n\r\n`jq -r &#39;(map(keys) | add | unique) as $cols | map(. as $row | $cols | map($row[.] // &quot;null&quot;)) as $rows | $cols, $rows[] | @csv&#39; &lt; test.json`\r\n\r\n(The whole string is pretty good explained here: https://stackoverflow.com/a/32965227/16174836)",
                "title": "jq - converting json to cvs - how to treat &quot;null&quot; as string?"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1624131376,
                "last_edit_date": 1624131376,
                "creation_date": 1624067287,
                "answer_id": 68042958,
                "question_id": 68042332,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can &quot;stringify&quot; the value using [`tostring`](https://stedolan.github.io/jq/manual/#tostring) by changing `map($row[.])` into `map($row[.]|tostring)`:\r\n\r\n    $ cat so2332.json\r\n    {\r\n      &quot;id&quot;: 1,\r\n      &quot;date&quot;: &quot;2014-05-05T19:07:48.577&quot;\r\n    }\r\n    {\r\n      &quot;id&quot;: 2,\r\n      &quot;date&quot;: null\r\n    }\r\n    \r\n    $ jq --slurp --raw-output &#39;(map(keys) | add | unique) as $cols | map(. as $row | $cols | map($row[.]|tostring)) as $rows | $cols, $rows[] | @csv&#39; so2332.json\r\n    &quot;date&quot;,&quot;id&quot;\r\n    &quot;2014-05-05T19:07:48.577&quot;,&quot;1&quot;\r\n    &quot;null&quot;,&quot;2&quot;\r\n\r\nNote that the use of `tostring` will cause the numbers to be converted to strings.",
                "title": "jq - converting json to cvs - how to treat &quot;null&quot; as string?"
            },
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1624124756,
                "last_edit_date": 1624124756,
                "creation_date": 1624069420,
                "answer_id": 68043093,
                "question_id": 68042332,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I&#39;d go with:\r\n```\r\n(map(keys_unsorted) | add | unique) as $cols\r\n| $cols,\r\n  (.[] | [.[$cols[]]] | map(. // &quot;null&quot;) )\r\n| @csv\r\n```\r\nFirst, using `keys_unsorted` avoids useless sorting.\r\n\r\nSecond, `[.[$cols[]]]` is an important, recurrent and idiomatic pattern, used to ensure an array is constructed in the correct order without resorting to the `reduce` sledge-hammer.\r\n\r\nThird, although `map(. // &quot;null&quot;)` seems to be appropriate here, it should be noted that this expression will also replace `false` with `&quot;null&quot;`, so, it would not be appropriate in general. Instead, to preserve `false`, one could write `map(if . == null then &quot;null&quot; else . end)`.\r\n\r\nFourth, it should be noted that using `map(. // &quot;null&quot;)` as above will also mask missing values of any of the keys, so if one wants some other behavior (e.g., raising an error if `id` is missing), then an alternative approach would be warranted. \r\n\r\n---\r\nThe above assumes the stream of JSON objects shown in the question is &quot;slurped&quot;, e.g. using jq&#39;s -s command-line option.",
                "title": "jq - converting json to cvs - how to treat &quot;null&quot; as string?"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 2,
        "last_activity_date": 1624936299,
        "creation_date": 1624058204,
        "last_edit_date": 1624936299,
        "question_id": 68042332,
        "body_markdown": "I have the following json file which I would like to convert to csv:\r\n\r\n    {\r\n      &quot;id&quot;: 1,\r\n      &quot;date&quot;: &quot;2014-05-05T19:07:48.577&quot;\r\n    }\r\n    {\r\n      &quot;id&quot;: 2,\r\n      &quot;date&quot;: null\r\n    }\r\n\r\n\r\nConverting it to csv with the following jq produces:\r\n\r\n    $ jq -sr &#39;(map(keys) | add | unique) as $cols | map(. as $row | $cols | map($row[.])) as $rows | $cols, $rows[] | @csv&#39; &lt; test.json\r\n    &quot;date&quot;,&quot;id&quot;\r\n    &quot;2014-05-05T19:07:48.577&quot;,1\r\n    ,2\r\n\r\nUnfortunately, for the line with &quot;id&quot; equal to &quot;2&quot;, the date column was not set to &quot;null&quot; - instead, it was empty. This in turn makes MySQL error on import if it&#39;s a datetime column (it expects a literal &quot;null&quot; if we don&#39;t have a date, and errors on &quot;&quot;).\r\n\r\nHow can I make jq print the literal &quot;null&quot;, and not &quot;&quot;?\r\n",
        "link": "https://stackoverflow.com/questions/68042332/jq-converting-json-to-cvs-how-to-treat-null-as-string",
        "title": "jq - converting json to cvs - how to treat &quot;null&quot; as string?"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 5,
                "is_accepted": true,
                "score": 5,
                "last_activity_date": 1624159491,
                "last_edit_date": 1624159491,
                "creation_date": 1624154327,
                "answer_id": 68052085,
                "question_id": 68051269,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "There are several reasonable approaches to solving the problem using jq, but all have in common that jq is only called once.  Since `bash` is one of the tags, then provided the &quot;destination&quot; file names are legal, you could do worse than:\r\n\r\n```\r\nwhile IFS= read -r destination; do\r\n    IFS= read -r file\r\n    printf &quot;%s&quot; &quot;$file&quot; &gt; &quot;$destination&quot;\r\ndone &lt; &lt;(jq -r &#39;.[] | .destination,.file&#39; input.json )\r\n```\r\n\r\nHowever, this also assumes that the contents of the fields do not contain &quot;newline&quot; or NUL characters.  If either might contain literal newlines, then see below.\r\n\r\nAlso, it would almost surely be better to check the validity of the filenames and/or to handle errors arising from failed attempts to write to the specified filenames.\r\nSee for example https://stackoverflow.com/questions/1976007/what-characters-are-forbidden-in-windows-and-linux-directory-names\r\n\r\n### Handling newlines\r\nAssuming the key values do not contain NUL characters:\r\n\r\n```\r\nwhile IFS= read -r -d &#39;&#39; destination; do\r\n    IFS= read -r -d &#39;&#39; file\r\n    printf &quot;%s&quot; &quot;$file&quot; &gt; &quot;$destination&quot;\r\ndone &lt; &lt;(jq -rj &#39;.[] | map_values(tostring+&quot;\\u0000&quot;) | .destination,.file&#39; input.json )\r\n```\r\n\r\n\r\n",
                "title": "Parsing JSON to array using jq - bash"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1624185028,
        "creation_date": 1624142342,
        "last_edit_date": 1624185028,
        "question_id": 68051269,
        "body_markdown": "I have JSON looking like that:\r\n```json\r\n[\r\n  {\r\n    &quot;file&quot;: &quot;aaa.txt&quot;,\r\n    &quot;destination&quot;: 1\r\n  },\r\n  {\r\n    &quot;file&quot;: &quot;bbb.txt&quot;,\r\n    &quot;destination&quot;: 2\r\n  },\r\n  {\r\n    &quot;file&quot;: &quot;ccc.txt&quot;,\r\n    &quot;destination&quot;: 3\r\n  },\r\n  {\r\n    &quot;file&quot;: &quot;ddd.txt&quot;,\r\n    &quot;destination&quot;: 4\r\n  },\r\n  {\r\n    &quot;file&quot;: &quot;eee.txt&quot;,\r\n    &quot;destination&quot;: 9\r\n  }\r\n]\r\n```\r\nI&#39;m trying to build a script in bash using command jq to get the number of items in JSON and use the vaules of file, destination in second command. To achieve the first one I use \r\n\r\n    count=$(curl &#39;http://mypage/json&#39; | jq length)\r\n\r\nI&#39;m getting the number (count) of this elements (5 in this case). Next I  want to build **while loop** from 5 to 1 to put *file* value into (nomen omen) file (script in the loop should create file called *[destination]* with *[file]* as content (example: for firstone file should by called 1 with aaa.txt as a content). And... this is my question - how can I put my JSON into array (or something)? I tried to use \r\n\r\n    arr=$(curl &#39;http://mypage/json&#39; | jq&#39;.[]&#39;)\r\nbut it puts whole json as one. \r\nCan you help me please?",
        "link": "https://stackoverflow.com/questions/68051269/parsing-json-to-array-using-jq-bash",
        "title": "Parsing JSON to array using jq - bash"
    },
    {
        "tags": [
            "json",
            "windows",
            "cmd",
            "jq",
            "cmder"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 8423,
                    "reputation": 757671,
                    "user_id": 15168,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/WtEI9.png?s=256",
                    "display_name": "Jonathan Leffler",
                    "link": "https://stackoverflow.com/users/15168/jonathan-leffler"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1624254854,
                "post_id": 68062772,
                "comment_id": 120297921,
                "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": 1624341719,
                "post_id": 68062772,
                "comment_id": 120324901,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1665501545,
                "last_edit_date": 1665501545,
                "creation_date": 1624299223,
                "answer_id": 68072822,
                "question_id": 68062772,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You are getting permission denied because you provided a directory where a path to an ordinary file is expected.\r\n\r\n---\r\n\r\nI&#39;m going to start with the &quot;unix&quot; approach because jq has unix roots. The following is the command you want to use:\r\n\r\n```sh\r\njq --slurp &#39;map(.[])&#39; bill/a.json bill/b.json bill/c.json ...\r\n```\r\n\r\nThe shell will expand the following command into the above:\r\n\r\n```sh\r\njq --slurp &#39;map(.[])&#39; bill/*.json\r\n```\r\n\r\nThe problem  is that this can easily result in a command that&#39;s too long. So you really want one the following:\r\n\r\n```sh\r\n# A\r\n(\r\n   jq &#39;.[]&#39; bill/a.json\r\n   jq &#39;.[]&#39; bill/b.json\r\n   jq &#39;.[]&#39; bill/c.json\r\n   jq &#39;.[]&#39; bill/d.json\r\n   jq &#39;.[]&#39; bill/e.json\r\n   jq &#39;.[]&#39; bill/f.json\r\n) | jq --slurp .\r\n```\r\n\r\n```sh\r\n# B\r\n(\r\n   cat bill/a.json\r\n   cat bill/b.json\r\n   cat bill/c.json\r\n   cat bill/d.json\r\n   cat bill/e.json\r\n   cat bill/f.json\r\n) | jq --slurp &#39;map(.[])&#39;\r\n```\r\n\r\n```sh\r\n# C\r\n(\r\n   jq &#39;.[]&#39; bill/a.json bill/b.json bill/c.json\r\n   jq &#39;.[]&#39; bill/d.json bill/e.json bill/f.json\r\n) | jq --slurp .\r\n```\r\n\r\n```sh\r\n# D\r\n(\r\n   cat bill/a.json bill/b.json bill/c.json\r\n   cat bill/d.json bill/e.json bill/f.json\r\n) | jq --slurp &#39;map(.[])&#39;\r\n```\r\n\r\nSomething equivalent can be achieved using any of the following:\r\n\r\n```sh\r\n# Portable. Equivalent to A\r\nfind bill -mindepth 1 -maxdepth 1 -name &#39;*.json&#39; -exec jq &#39;.[]&#39; {} \\; | jq --slurp .\r\n```\r\n\r\n```sh\r\n# Portable. Equivalent to B\r\nfind bill -mindepth 1 -maxdepth 1 -name &#39;*.json&#39; -exec cat {} \\; | jq --slurp &#39;map(.[])&#39;\r\n```\r\n\r\n```sh\r\n# Possibly portable with tweaks. Similar to &quot;C&quot;\r\nfind bill -mindepth 1 -maxdepth 1 -name &#39;*.json&#39; -print0 |\r\n   xargs -r0 jq &#39;.[]&#39; |\r\n      jq --slurp .\r\n```\r\n\r\n```sh\r\n# Possibly portable with tweaks. Similar to &quot;D&quot;\r\nfind bill -mindepth 1 -maxdepth 1 -name &#39;*.json&#39; -print0 |\r\n   xargs -r0 cat |\r\n      jq --slurp .\r\n```\r\n\r\n```sh\r\n# GNU-specific. Equivalent to &quot;C&quot;\r\nfind bill -mindepth 1 -maxdepth 1 -name &#39;*.json&#39; -exec jq &#39;.[]&#39; {} + | jq --slurp .\r\n```\r\n\r\n```sh\r\n# GNU-specific. Equivalent to &quot;D&quot;\r\nfind bill -mindepth 1 -maxdepth 1 -name &#39;*.json&#39; -exec cat {} + | jq --slurp &#39;map(.[])&#39;\r\n```\r\n\r\n\r\n---\r\n\r\nBut you asked about Windows. In the Windows world it&#39;s up to programs to perform their own wildcard expansion. So you&#39;d expect to be able to do\r\n\r\n```sh\r\njq --slurp &#39;map(.[])&#39; bill\\*.json\r\n```\r\n\r\nHowever, `jq` wasn&#39;t properly ported.\r\n\r\n```lang-none\r\nAssertion failed!\r\n\r\nProgram: c:\\bin\\jq.exe\r\nFile: src/main.c, Line 256\r\n\r\nExpression: wargc == argc\r\n```\r\n\r\nSo like in unix, you have to pass all the files you want to process to `jq` as separate arguments.\r\n\r\nUsing `cmd`, you could use either of the following:\r\n\r\n```cmd\r\n:: Not efficient\r\ncopy /y nul bill.jsonl\r\nfor %q in (bill\\*.json) do jq &quot;.[]&quot; %q &gt;&gt;bill.jsonl\r\njq --slurp . bill.jsonl\r\ndel bill.jsonl\r\n```\r\n\r\n```cmd\r\n:: More efficient\r\ncopy /y nul+bill\\*.json bill.jsonl\r\njq --slurp &quot;map(.[])&quot; bill.jsonl\r\ndel bill.jsonl\r\n```\r\n\r\n---\r\n\r\nPowerShell is a far more advanced shell than `cmd`. With PowerShell, you could use\r\n\r\n```powershell\r\njq --slurp &#39;map(.[])&#39; ( Get-Item bill\\*.json )\r\n```\r\n\r\nBut just like the simple unix version, the above can easily result in a command line that&#39;s too long. To avoid that, we can use the following:\r\n\r\n```powershell\r\n# Not efficient\r\nGet-Item bill\\*.json | %{ jq &#39;.[]&#39; $_ } | jq --slurp .\r\n```\r\n\r\n```\r\n# More efficient\r\n%{ Get-Content bill\\*.json } | jq --slurp &#39;map(.[])&#39;\r\n```\r\n\r\n(`%{...}` is a shorthand for `ForEach-Object {...}`.)\r\n\r\n---\r\n\r\nFinally, I&#39;m not familiar with Cmder.\r\n\r\n\r\n\r\n",
                "title": "How do I merge thousands of json files with jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1665501545,
        "creation_date": 1624253739,
        "last_edit_date": 1624271983,
        "question_id": 68062772,
        "body_markdown": "I have thousands of individually named `json` files in a single windows directory. I&#39;m trying to use `jq` to merge them all into a single file I can then import into a jupyter notebook.\r\n\r\nI keep getting a permissioned denied error when I try and run the following command:\r\n\r\n`jq --slurp &#39;map(.[])&#39; bill`\r\n\r\nI&#39;ve tried editing the directory (bill) permissions. My file path looks like this:\r\n\r\n`\\downloadedJSONfiles\\AK\\2019-2020_31st_Legislature\\bill`\r\n\r\nI downloaded `jq` through `chocolately`. I&#39;m using `cmder`",
        "link": "https://stackoverflow.com/questions/68062772/how-do-i-merge-thousands-of-json-files-with-jq",
        "title": "How do I merge thousands of json files with jq?"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 1020072,
                    "reputation": 243994,
                    "user_id": 1030675,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/957956ce51706d03f19a4dc85a767bb1?s=256&d=identicon&r=PG",
                    "display_name": "choroba",
                    "link": "https://stackoverflow.com/users/1030675/choroba"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1624266276,
                "post_id": 68064881,
                "comment_id": 120301851,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 11683079,
                    "reputation": 23,
                    "user_id": 8554003,
                    "user_type": "registered",
                    "profile_image": "https://lh6.googleusercontent.com/-gOSDz54cOl8/AAAAAAAAAAI/AAAAAAAAKYQ/mt0VsmkSwgU/s256-rj/photo.jpg",
                    "display_name": "Hugo Fournier",
                    "link": "https://stackoverflow.com/users/8554003/hugo-fournier"
                },
                "reply_to_user": {
                    "account_id": 1020072,
                    "reputation": 243994,
                    "user_id": 1030675,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/957956ce51706d03f19a4dc85a767bb1?s=256&d=identicon&r=PG",
                    "display_name": "choroba",
                    "link": "https://stackoverflow.com/users/1030675/choroba"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1624281277,
                "post_id": 68064881,
                "comment_id": 120308125,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1624267514,
                "creation_date": 1624267514,
                "answer_id": 68065500,
                "question_id": 68064881,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "```\r\njq -s &#39;[.[]\r\n        | { title : .title,\r\n            description : .description,\r\n            message : .message,\r\n            data: [{region: [.region], resource: [.resource]}]\r\n          }\r\n       ]\r\n       | group_by(.title, .descripiton, .message)\r\n       | .[]\r\n       | { title: .[0].title,\r\n           description: .[0].description,\r\n           message: .[0].message,\r\n           data:{\r\n               region: [.[].data[].region | add],\r\n               resource: [.[].data[].resource | add]\r\n           }}&#39;",
                "title": "jq create unique keys from json duplicates"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1624294219,
                "creation_date": 1624294219,
                "answer_id": 68071817,
                "question_id": 68064881,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The following is a succinct variant of @choroba&#39;s program that may be of interest as it will preserve all keys of the JSON objects apart from the two that are to be consolidated:\r\n\r\n```\r\nmap( . + {data: [{region: [.region], resource: [.resource]}]}\r\n     | del(.region, .resource) )\r\n| group_by(.title, .description, .message)[]\r\n| .[0] +\r\n    { data: {\r\n        region:   [.[].data[].region   | add],\r\n        resource: [.[].data[].resource | add]\r\n      }\r\n    }\r\n```\r\n\r\nIt should of course also be used with the -s command-line option.",
                "title": "jq create unique keys from json duplicates"
            }
        ],
        "is_answered": false,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1624294219,
        "creation_date": 1624264690,
        "last_edit_date": 1624281110,
        "question_id": 68064881,
        "body_markdown": "I am trying to transform a json file, it looks like this so far after extracting what I need:\r\n\r\n```\r\n{\r\n  &quot;title&quot;: &quot;title 1&quot;,\r\n  &quot;description&quot;: &quot;desc 1&quot;,\r\n  &quot;message&quot;: &quot;msg 1&quot;,\r\n  &quot;region&quot;: &quot;region 1&quot;,\r\n  &quot;resource&quot;: &quot;resource 1&quot;\r\n}\r\n{\r\n  &quot;title&quot;: &quot;title 1&quot;,\r\n  &quot;description&quot;: &quot;desc 1&quot;,\r\n  &quot;message&quot;: &quot;msg 1&quot;,\r\n  &quot;region&quot;: &quot;region 2&quot;,\r\n  &quot;resource&quot;: &quot;resource 2&quot;\r\n}\r\n```\r\n\r\nI would like to transform it into\r\n```\r\n{\r\n  &quot;title&quot;: &quot;title 1&quot;,\r\n  &quot;description&quot;: &quot;desc 1&quot;,\r\n  &quot;message&quot;: &quot;msg 1&quot;,\r\n  &quot;data&quot;: [\r\n           {&quot;region 1&quot;:&quot;resource 1&quot;},\r\n           {&quot;region 2&quot;:&quot;resource 2&quot;}\r\n          ]\r\n}\r\n```\r\n\r\nMy idea would be to transform the json and make title, description, message that are repeating unique (thus removing the duplicate) while keeping the changing region and resources into a data object.\r\n\r\nI tried group_by(.title) it gives me an error &quot;Cannot index string with string &quot;title&quot;, I wanted to do group_by(.title,.description,.message).\r\n\r\nI tried unique_by also getting errors.\r\n\r\nMy current query is\r\n```\r\njq &#39;.[] | {title : .title, description : .description, message : .message, data: [{region: .region, resource: .resource}] } | group_by(.title,.description,.message)&#39;\r\n```",
        "link": "https://stackoverflow.com/questions/68064881/jq-create-unique-keys-from-json-duplicates",
        "title": "jq create unique keys from json duplicates"
    },
    {
        "tags": [
            "docker",
            "jq",
            "apache-zeppelin"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1624296939,
                "creation_date": 1624296939,
                "answer_id": 68072358,
                "question_id": 68071969,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If you look at the zeppelin Dockerfile [here][1], you can see that there&#39;s a `USER 1000` statement near the end.\r\n\r\nWhen you try to build upon this image, your build steps are run as that user which isn&#39;t allowed to install anything.\r\n\r\nTo fix it, you need to switch to the root user before installing and then back to user 1000 after you&#39;re done. Like this\r\n\r\n    FROM apache/zeppelin:0.9.0\r\n    USER root\r\n    RUN apt-get update &amp;&amp; apt-get install -y jq\r\n    USER 1000\r\n\r\n\r\n  [1]: https://hub.docker.com/r/apache/zeppelin/dockerfile",
                "title": "Cannot install packages inside Docker image based of apache/zeppelin:0.9.0"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1624296939,
        "creation_date": 1624294988,
        "question_id": 68071969,
        "body_markdown": "I have created a Dockerfile from the `apache/zeppelin:0.9.0` base image that installs `jq` inside my docker image:\r\n\r\n```\r\nFROM apache/zeppelin:0.9.0\r\n\r\nRUN apt-get update &amp;&amp; apt-get install -y jq\r\n```\r\n\r\nWhen I build this image using `docker build .` I get the following error message:\r\n\r\n                                                                                                                                                                                                                          \r\n&gt; [2/2] RUN apt-get update &amp;&amp; apt-get install -y jq:\r\n&gt; \r\n&gt; #5 0.257 Reading package lists...\r\n&gt; \r\n&gt; #5 0.272 E: Could not open lock file /var/lib/apt/lists/lock - open (13: Permission denied)\r\n&gt; \r\n&gt; #5 0.272 E: Unable to lock directory /var/lib/apt/lists/\r\n\r\nWhen using `RUN sudo apt-get update &amp;&amp; sudo apt-get install -y jq` in my Dockerfile, I run into another error, saying sudo is missing:\r\n\r\n&gt; [2/2] RUN sudo apt-get update &amp;&amp; sudo apt-get install -y jq:\r\n&gt; \r\n&gt; #5 0.249 /bin/sh: 1: sudo: not found\r\n\r\nMy question is, how can I run `apt-get` when using the above Docker base image?\r\n",
        "link": "https://stackoverflow.com/questions/68071969/cannot-install-packages-inside-docker-image-based-of-apache-zeppelin0-9-0",
        "title": "Cannot install packages inside Docker image based of apache/zeppelin:0.9.0"
    },
    {
        "tags": [
            "json",
            "jq",
            "amazon-cloudfront",
            "aws-cli",
            "edit"
        ],
        "answers": [
            {
                "up_vote_count": 7,
                "is_accepted": false,
                "score": 7,
                "last_activity_date": 1624309081,
                "last_edit_date": 1624309081,
                "creation_date": 1624307816,
                "answer_id": 68074394,
                "question_id": 68074046,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The basic way to accomplish edits such as these is using the syntax:\r\n\r\n    PATHSPEC = VALUE\r\n\r\nor if the value depends on PATHSPEC in a certain way:\r\n\r\n    PATHSPEC |= VALUE\r\n\r\nwhere PATHSPEC is a jq path specification.\r\n\r\nUsing this principle, in your case, you could write:\r\n```\r\n.ETag = &quot;&quot;\r\n| .DistributionConfig.Origins.Items[1].OriginPath = &quot;myvalue&quot;\r\n```\r\n\r\nor, if you want to base the second update on .Id:\r\n```\r\n.ETag = &quot;&quot;\r\n| .DistributionConfig.Origins.Items[] |=\r\n   if .Id == &quot;redacted-2&quot; then .OriginPath = &quot;myvalue&quot; else . end\r\n```\r\n\r\nThe example immediately above can be seen in action at https://jqplay.org/s/u5xbhbSs4l \r\n\r\n### Variations\r\nThere are of course numerous variations.  For example, you could use .Quantity as the index of the item to be updated:\r\n\r\n```\r\n.ETag = &quot;&quot;\r\n| .DistributionConfig.Origins.Quantity as $ix\r\n| .DistributionConfig.Origins.Items[$ix - 1].OriginPath = &quot;myvalue&quot;\r\n```\r\n\r\nor more DRYly:\r\n\r\n```\r\n.ETag = &quot;&quot;\r\n| .DistributionConfig.Origins |=\r\n    (.Items[.Quantity  - 1].OriginPath = &quot;myvalue&quot;)\r\n\r\n```\r\n \r\n \r\n\r\n\r\n",
                "title": "How can I output the whole document in jq while replacing an item based on a field&#39;s value?"
            },
            {
                "up_vote_count": 5,
                "is_accepted": true,
                "score": 5,
                "last_activity_date": 1624309780,
                "last_edit_date": 1624309780,
                "creation_date": 1624308552,
                "answer_id": 68074534,
                "question_id": 68074046,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Just a minor variation on @peak&#39;s answer, using `select` to choose which item(s) to update:\r\n\r\n    .ETag = &quot;&quot;\r\n    | (.DistributionConfig.Origins.Items[] | \r\n          select(.Id == &quot;redacted-2&quot;)\r\n      ).OriginPath = &quot;foo&quot;\r\n\r\nThe second assignment receives the entire original input as its input, so produces it as its output. The parenthesized filter, though, selects only the appropriate element(s) of `Items` whose `OriginPath` key you want to update.",
                "title": "How can I output the whole document in jq while replacing an item based on a field&#39;s value?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 5,
        "last_activity_date": 1624317785,
        "creation_date": 1624305775,
        "last_edit_date": 1624317785,
        "question_id": 68074046,
        "body_markdown": "I am attempting to use jq to parse a AWS CloudFront configuration JSON file and change a few values so that I can then issue an update statement with that configuration.\r\n\r\n## The Document\r\n\r\nThe document format snippet that matters, with redacted values, is: \r\n\r\n```json\r\n{\r\n    &quot;ETag&quot;: &quot;REDACTED&quot;,\r\n    &quot;DistributionConfig&quot;: {\r\n        &quot;Origins&quot;: {\r\n            &quot;Quantity&quot;: 2,\r\n            &quot;Items&quot;: [\r\n                {\r\n                    &quot;Id&quot;: &quot;redacted-1&quot;,\r\n                    &quot;DomainName&quot;: &quot;redacted1.us-east-1.amazonaws.com&quot;,\r\n                    &quot;OriginPath&quot;: &quot;/redacted&quot;\r\n\t\t\t\t},\r\n                {\r\n                    &quot;Id&quot;: &quot;redacted-2&quot;,\r\n                    &quot;DomainName&quot;: &quot;redacted2.s3.amazonaws.com&quot;,\r\n                    &quot;OriginPath&quot;: &quot;&quot;\r\n                }\r\n            ]\r\n        }\r\n    }    \r\n}\r\n```\r\n\r\n## What I&#39;m trying to do\r\n\r\nI want to output the entire document, but:\r\n\r\n* I want to set the `ETag` value to `&quot;&quot;`\r\n* On the 2nd item in the items array, I want to set the `OriginPath` to a value of my choosing\r\n\r\n(this is to support our CI/CD process being able to point the CloudFront distribution to a new folder of just-deployed code within an S3 bucket. I want to modify the existing configuration in those specific ways but leave the rest in-tact.) \r\n\r\n## Something that works...sort of\r\n\r\nA jq filter of `. | (.DistributionConfig.Origins.Items[1].OriginPath = &quot;Hello&quot;) | .ETag = &quot;&quot;` does what I need it to do, resulting in:\r\n\r\n```json\r\n{\r\n  &quot;ETag&quot;: &quot;&quot;, // correctly updated\r\n  &quot;DistributionConfig&quot;: {\r\n    &quot;Origins&quot;: {\r\n      &quot;Quantity&quot;: 2, // correctly retained\r\n      &quot;Items&quot;: [\r\n        {\r\n          &quot;Id&quot;: &quot;redacted-1&quot;,\r\n          &quot;DomainName&quot;: &quot;redacted1.us-east-1.amazonaws.com&quot;,\r\n          &quot;OriginPath&quot;: &quot;/redacted&quot;\r\n        },\r\n        {\r\n          &quot;Id&quot;: &quot;redacted-2&quot;,\r\n          &quot;DomainName&quot;: &quot;redacted2.s3.amazonaws.com&quot;,\r\n          &quot;OriginPath&quot;: &quot;Hello&quot; // correctly updated\r\n        }\r\n      ]\r\n    }\r\n  }\r\n}\r\n```\r\n\r\n## Where I&#39;m having trouble\r\n\r\nThe solution above works...as long as I&#39;m referring to the 2nd item in the array. But I&#39;m not always sure it *will be* the second item in the array. \r\n\r\nSo instead, I&#39;d like to match based on the `Id` property.\r\n\r\nAny solutions I&#39;ve been able to find that do this seem to filter the document to that section of JSON, rather than matching and updating the value as part of outputting the document.\r\n\r\n## Question\r\n\r\nHow can I filter an array for a field that has a certain value, and still output the whole document?\r\n\r\nOr put another way -- given the document above, how can I change:\r\n\r\n    . | (.DistributionConfig.Origins.Items[1].OriginPath = &quot;Hello&quot;) | .ETag = &quot;&quot;\r\n\r\nTo something that lets me refer to `.Id=&quot;redaacted-2&quot;` rather than `Items[1]`?\r\n\r\n## A link to a demo\r\n\r\nDemo of the script at &lt;https://jqplay.org/s/ZQ7XcM5-BY&gt; in case anyone wants to try an answer.",
        "link": "https://stackoverflow.com/questions/68074046/how-can-i-output-the-whole-document-in-jq-while-replacing-an-item-based-on-a-fie",
        "title": "How can I output the whole document in jq while replacing an item based on a field&#39;s value?"
    },
    {
        "tags": [
            "string",
            "variables",
            "parameter-passing",
            "jq",
            "string-interpolation"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1624312763,
                "last_edit_date": 1624312763,
                "creation_date": 1624311473,
                "answer_id": 68075019,
                "question_id": 68074909,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Instead of passing 2 arguments to JQ, why don&#39;t we combine those on to just 1 on the bash-level like so:\r\n\r\n```bash\r\njq -r --arg travis_search &quot;$TRAVIS_BRANCH-$TRAVIS_BUILD_NUMBER&quot; &#39;.imageIds[] | select(.imageTag == $travis_search) | .imageDigest&#39;\r\n```\r\n\r\n&lt;hr&gt;\r\n\r\n#### [JqPlay Demo](https://jqplay.org/s/2e0pjbgM6B)\r\n&lt;hr&gt;\r\n\r\nExample on my local machine:\r\n```none\r\n$\r\n$ jq &#39;.&#39; test.json\r\n{\r\n  &quot;imageIds&quot;: [\r\n    {\r\n      &quot;imageDigest&quot;: &quot;sha256:ec2ad330fadaf1ef05e30b8ba1ee5a92efb8b39c8d51bbcfb706b1b1a1981020&quot;,\r\n      &quot;imageTag&quot;: &quot;latest&quot;\r\n    },\r\n    {\r\n      &quot;imageDigest&quot;: &quot;sha256:9377451ac4ea941e49d3176457b3d285d6418fec883a9a8fee87a491b79ac06a&quot;\r\n    },\r\n    {\r\n      &quot;imageDigest&quot;: &quot;sha256:1fb63f185c11a3300d394f83f8152d391b5f37ee3b17b73702296e979fb42576&quot;\r\n    },\r\n    {\r\n      &quot;imageDigest&quot;: &quot;sha256:4fc44daf69561482c9b00858b1a60e6590444703b75d49fed7d46c025520ddac&quot;\r\n    },\r\n    {\r\n      &quot;imageDigest&quot;: &quot;sha256:ce109ba9df0e566a4bd9d0a8311596b61def59d51c1b42455170dcb41451f4b0&quot;,\r\n      &quot;imageTag&quot;: &quot;main-48&quot;\r\n    },\r\n    {\r\n      &quot;imageDigest&quot;: &quot;sha256:928950d4cab36d434f99e65bb75e65e4a6218760b1a32a08ac7212b2b6b9b9b0&quot;,\r\n      &quot;imageTag&quot;: &quot;main-49&quot;\r\n    },\r\n    {\r\n      &quot;imageDigest&quot;: &quot;sha256:30a7f57f1a8aea4b00a441fff139806662342f0b584651231ed99738bf9d00b8&quot;\r\n    },\r\n    {\r\n      &quot;imageDigest&quot;: &quot;sha256:2319a7b3d5a030cc22efc06be780d6789cbf575822dd96bffbb550e3d20faefd&quot;\r\n    }\r\n  ]\r\n}\r\n$\r\n$ TRAVIS_BUILD_NUMBER=49\r\n$ TRAVIS_BRANCH=main\r\n$\r\n$ jq -r --arg travis_search &quot;$TRAVIS_BRANCH-$TRAVIS_BUILD_NUMBER&quot; &#39;.imageIds[] | select(.imageTag == $travis_search) | .imageDigest&#39; test.json\r\nsha256:928950d4cab36d434f99e65bb75e65e4a6218760b1a32a08ac7212b2b6b9b9b0\r\n$\r\n$\r\n```",
                "title": "Unable to catch imageDigest where the tag contains a numeric argument using jq, but why?"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1624461692,
                "creation_date": 1624461692,
                "answer_id": 68102709,
                "question_id": 68074909,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Using the form of invocation in the original question (`jq -r --arg travis_branch ${TRAVIS_BRANCH} --arg travis_build_number ${TRAVIS_BUILD_NUMBER} ...`), an appropriate jq program could look like this:\r\n\r\n\r\n     .imageIds[] \r\n     | select(.imageTag == &quot;\\($travis_branch)-\\($travis_build_number)&quot;)\r\n     | .imageDigest",
                "title": "Unable to catch imageDigest where the tag contains a numeric argument using jq, but why?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1624461816,
        "creation_date": 1624310698,
        "last_edit_date": 1624461816,
        "question_id": 68074909,
        "body_markdown": "Trying to extract ecr image digest using the imageTag.\r\n\r\n    base ❯ aws ecr list-images --repository-name itaig\r\n    {\r\n        &quot;imageIds&quot;: [\r\n            {\r\n                &quot;imageDigest&quot;: &quot;sha256:ec2ad330fadaf1ef05e30b8ba1ee5a92efb8b39c8d51bbcfb706b1b1a1981020&quot;,\r\n                &quot;imageTag&quot;: &quot;latest&quot;\r\n            },\r\n            {\r\n                &quot;imageDigest&quot;: &quot;sha256:9377451ac4ea941e49d3176457b3d285d6418fec883a9a8fee87a491b79ac06a&quot;\r\n            },\r\n            {\r\n                &quot;imageDigest&quot;: &quot;sha256:1fb63f185c11a3300d394f83f8152d391b5f37ee3b17b73702296e979fb42576&quot;\r\n            },\r\n            {\r\n                &quot;imageDigest&quot;: &quot;sha256:4fc44daf69561482c9b00858b1a60e6590444703b75d49fed7d46c025520ddac&quot;\r\n            },\r\n            {\r\n                &quot;imageDigest&quot;: &quot;sha256:ce109ba9df0e566a4bd9d0a8311596b61def59d51c1b42455170dcb41451f4b0&quot;,\r\n                &quot;imageTag&quot;: &quot;main-48&quot;\r\n            },\r\n            {\r\n                &quot;imageDigest&quot;: &quot;sha256:928950d4cab36d434f99e65bb75e65e4a6218760b1a32a08ac7212b2b6b9b9b0&quot;,\r\n                &quot;imageTag&quot;: &quot;main-49&quot;\r\n            },\r\n            {\r\n                &quot;imageDigest&quot;: &quot;sha256:30a7f57f1a8aea4b00a441fff139806662342f0b584651231ed99738bf9d00b8&quot;\r\n            },\r\n            {\r\n                &quot;imageDigest&quot;: &quot;sha256:2319a7b3d5a030cc22efc06be780d6789cbf575822dd96bffbb550e3d20faefd&quot;\r\n            }\r\n        ]\r\n    }\r\n    \r\n    ~/src/personal/aws-s3-lambda main ⇣\r\n    base ❯ TRAVIS_BUILD_NUMBER=49\r\n    \r\n    ~/src/personal/aws-s3-lambda main ⇣\r\n    base ❯ TRAVIS_BRANCH=main\r\n    \r\n    ~/src/personal/aws-s3-lambda main ⇣\r\n    base ❯ aws ecr list-images --repository-name itaig | jq -r --arg travis_branch ${TRAVIS_BRANCH} --arg travis_build_number ${TRAVIS_BUILD_NUMBER}  &#39;.imageIds[] | select(.imageTag==&quot;$travis_branch-$travis_build_number&quot;) .imageDigest&#39;\r\n\r\nIf I don&#39;t use args, it works like a charm:\r\n\r\n    base ❯ aws ecr list-images --repository-name itaig | jq -r &#39;.imageIds[] | select(.imageTag==&quot;main-49&quot;) .imageDigest&#39;\r\n    sha256:928950d4cab36d434f99e65bb75e65e4a6218760b1a32a08ac7212b2b6b9b9b0\r\n\r\nBut the relevant imageDigest isn&#39;t caught by jq.\r\n\r\nI suspect it has something to with the travis_build_number, I think I need to use &quot;tonumber&quot; but I&#39;m not sure where to place it in my query.\r\n\r\nAny idea how to do it?",
        "link": "https://stackoverflow.com/questions/68074909/unable-to-catch-imagedigest-where-the-tag-contains-a-numeric-argument-using-jq",
        "title": "Unable to catch imageDigest where the tag contains a numeric argument using jq, but why?"
    },
    {
        "tags": [
            "json",
            "select",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1624313142,
                "last_edit_date": 1624313142,
                "creation_date": 1624313111,
                "answer_id": 68075260,
                "question_id": 68075040,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Just figured out my solution:\r\n\r\n```jq\r\ndel(.[] | select(.Case == null))\r\n```",
                "title": "Delete an element when a key of element is not found by jq"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1624317933,
                "last_edit_date": 1624317933,
                "creation_date": 1624313347,
                "answer_id": 68075300,
                "question_id": 68075040,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "This can be achieved by keeping the elements that have `.Case` defined.\r\n\r\n```jq\r\nmap(select(.Case != null))\r\n```\r\n\r\n[jqplay](https://jqplay.org/s/fTN3KrtsG4)\r\n\r\nIf `.Case == false` won&#39;t be encountered, the above simplifies to\r\n\r\n```jq\r\nmap(select(.Case))\r\n```\r\n\r\n[jqplay](https://jqplay.org/s/3HUFjEifxT)\r\n",
                "title": "Delete an element when a key of element is not found by jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 4,
        "last_activity_date": 1624318022,
        "creation_date": 1624311603,
        "last_edit_date": 1624318022,
        "question_id": 68075040,
        "body_markdown": "I want to delete some elements when a specific key is not found using jq.  In below json file, I need to delete the first and second items as they don&#39;t have the key &quot;Case&quot;.\r\n\r\n```\r\n[\r\n  {\r\n    &quot;label&quot;: &quot;US : USA : English&quot;,\r\n    &quot;Country&quot;: &quot;USA&quot;,\r\n    &quot;region&quot;: &quot;US&quot;,\r\n    &quot;Language&quot;: &quot;English&quot;,\r\n    &quot;locale&quot;: &quot;en&quot;,\r\n    &quot;currency&quot;: &quot;USD&quot;,\r\n    &quot;number&quot;: &quot;USD&quot;\r\n  },\r\n  {\r\n    &quot;label&quot;: &quot;AU : Australia : English&quot;,\r\n    &quot;Country&quot;: &quot;Australia&quot;,\r\n    &quot;region&quot;: &quot;AU&quot;,\r\n    &quot;Language&quot;: &quot;English&quot;,\r\n    &quot;locale&quot;: &quot;en&quot;,\r\n    &quot;currency&quot;: &quot;AUD&quot;,\r\n    &quot;number&quot;: &quot;AUD&quot;\r\n  },\r\n  {\r\n    &quot;Case&quot;: &quot;1&quot;,\r\n    &quot;label&quot;: &quot;CA : Canada : English&quot;,\r\n    &quot;Country&quot;: &quot;Canada&quot;,\r\n    &quot;region&quot;: &quot;CA&quot;,\r\n    &quot;Language&quot;: &quot;English&quot;,\r\n    &quot;locale&quot;: &quot;en&quot;,\r\n    &quot;currency&quot;: &quot;CAD&quot;,\r\n    &quot;number&quot;: &quot;CAD&quot;\r\n  }\r\n]\r\n```\r\n\r\nAnd the output would be:\r\n```\r\n[\r\n  {\r\n    &quot;Case&quot;: &quot;1&quot;,\r\n    &quot;label&quot;: &quot;CA : Canada : English&quot;,\r\n    &quot;Country&quot;: &quot;Canada&quot;,\r\n    &quot;region&quot;: &quot;CA&quot;,\r\n    &quot;Language&quot;: &quot;English&quot;,\r\n    &quot;locale&quot;: &quot;en&quot;,\r\n    &quot;currency&quot;: &quot;CAD&quot;,\r\n    &quot;number&quot;: &quot;CAD&quot;\r\n  }\r\n]",
        "link": "https://stackoverflow.com/questions/68075040/delete-an-element-when-a-key-of-element-is-not-found-by-jq",
        "title": "Delete an element when a key of element is not found by jq"
    },
    {
        "tags": [
            "json",
            "select",
            "jq",
            "edit"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1624325587,
                "creation_date": 1624325587,
                "answer_id": 68076460,
                "question_id": 68075978,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Pipe the output of `.steps[][]` into a `select` call that chooses the objects with the desired `name` and `state` values, then set the `state` value on the result.\r\n\r\n    $ jq &#39;(.steps[][] | select(.name == &quot;Foo&quot; and .state == &quot;wait&quot;)).state = &quot;ready&quot;&#39; tmp.json\r\n    {\r\n      &quot;state&quot;: &quot;wait&quot;,\r\n      &quot;steps&quot;: {\r\n        &quot;step1&quot;: [\r\n          {\r\n            &quot;name&quot;: &quot;Foo&quot;,\r\n            &quot;state&quot;: &quot;ready&quot;\r\n          },\r\n          {\r\n            &quot;name&quot;: &quot;Bar&quot;,\r\n            &quot;state&quot;: &quot;wait&quot;\r\n          }\r\n        ],\r\n        &quot;step2&quot;: [\r\n          {\r\n            &quot;name&quot;: &quot;Foo&quot;,\r\n            &quot;state&quot;: &quot;ready&quot;\r\n          },\r\n          {\r\n            &quot;name&quot;: &quot;Zoinks&quot;,\r\n            &quot;state&quot;: &quot;ready&quot;\r\n          }\r\n        ],\r\n        &quot;step3&quot;: [\r\n          {\r\n            &quot;name&quot;: &quot;Foo&quot;,\r\n            &quot;state&quot;: &quot;cancel&quot;\r\n          }\r\n        ]\r\n      }\r\n    }\r\n\r\nYou can help confirm this using `diff` (the first `jq` just normalizes the formatting so that only the changes made by the second one show up in the diff):\r\n\r\n    $ diff &lt;(jq . tmp.json) &lt;(jq &#39;...&#39; tmp.json)\r\n    7c7\r\n    &lt;         &quot;state&quot;: &quot;wait&quot;\r\n    ---\r\n    &gt;         &quot;state&quot;: &quot;ready&quot;\r\n    17c17\r\n    &lt;         &quot;state&quot;: &quot;wait&quot;\r\n    ---\r\n    &gt;         &quot;state&quot;: &quot;ready&quot;",
                "title": "jq update json document to alter an array element"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1702629064,
                "creation_date": 1702629064,
                "answer_id": 77665073,
                "question_id": 68075978,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "the way I did this for a complex document was following \r\n```yaml\r\nkeya: AAA\r\nkeyb: BBB\r\nkeyc:\r\n  arrayc:\r\n  - name: item1\r\n    someparam1: i1p1\r\n    someparam2: i1p2\r\n  - name: item2\r\n    someparam1: i2p1\r\n    someparam2: i2p2\r\n```\r\n\r\n```bash\r\nyq &#39;.keyc.arrayc = (.keyc.arrayc|map((select(.name == &quot;item2&quot;)|.someparam2) |= &quot;modified&quot;))&#39;\r\n```\r\n\r\nresults in \r\n\r\n```yaml\r\nkeya: AAA\r\nkeyb: BBB\r\nkeyc:\r\n  arrayc:\r\n    - name: item1\r\n      someparam1: i1p1\r\n      someparam2: i1p2\r\n    - name: item2\r\n      someparam1: i2p1\r\n      someparam2: modified\r\n```",
                "title": "jq update json document to alter an array element"
            }
        ],
        "is_answered": false,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1702629064,
        "creation_date": 1624319856,
        "last_edit_date": 1624328369,
        "question_id": 68075978,
        "body_markdown": "I know this has to be simple, but for some reason it&#39;s eluding me how to find an element given a condition and modify one of its fields.  The doc should be fully output (`sed` style) with the edit made.   \r\n\r\n```\r\n{\r\n  &quot;state&quot;: &quot;wait&quot;,\r\n  &quot;steps&quot;: { \r\n    &quot;step1&quot;: [\r\n      { &quot;name&quot;:&quot;Foo&quot;,    &quot;state&quot;:&quot;wait&quot; },\r\n      { &quot;name&quot;:&quot;Bar&quot;,    &quot;state&quot;:&quot;wait&quot; }\r\n    ],\r\n    &quot;step2&quot;: [\r\n      { &quot;name&quot;:&quot;Foo&quot;,    &quot;state&quot;:&quot;wait&quot; },\r\n      { &quot;name&quot;:&quot;Zoinks&quot;, &quot;state&quot;:&quot;ready&quot; }\r\n    ],\r\n    &quot;step3&quot;: [\r\n      { &quot;name&quot;:&quot;Foo&quot;,    &quot;state&quot;:&quot;cancel&quot; }\r\n    ]\r\n  }\r\n}\r\n```\r\n\r\nI&#39;m expecting something like this should be workable.\r\n\r\n```jq &#39;. | (select(.steps[][].name==&quot;Foo&quot; and .steps[][].state==&quot;wait&quot;) |= . + {.state:&quot;Ready&quot;}&#39; ```\r\n\r\nor \r\n\r\n```jq &#39;. | (select(.steps[][]) | if (.name==&quot;Foo&quot; and .state==&quot;wait&quot;) then (.state=&quot;Ready&quot;) else . end)```\r\n\r\nThe desired output, of course, would be \r\n\r\n```\r\n{\r\n  &quot;state&quot;: &quot;wait&quot;,\r\n  &quot;steps&quot;: { \r\n    &quot;step1&quot;: [\r\n      { &quot;name&quot;:&quot;Foo&quot;,    &quot;state&quot;:&quot;ready&quot; },\r\n      { &quot;name&quot;:&quot;Bar&quot;,    &quot;state&quot;:&quot;wait&quot; }\r\n    ],\r\n    &quot;step2&quot;: [\r\n      { &quot;name&quot;:&quot;Foo&quot;,    &quot;state&quot;:&quot;ready&quot; },\r\n      { &quot;name&quot;:&quot;Zoinks&quot;, &quot;state&quot;:&quot;ready&quot; }\r\n    ],\r\n    &quot;step3&quot;: [\r\n      { &quot;name&quot;:&quot;Foo&quot;,    &quot;state&quot;:&quot;cancel&quot; }\r\n    ]\r\n  }\r\n}\r\n```\r\n\r\nInstead, when I&#39;m not getting cryptic errors, I&#39;m either modifying a top-level field in the document or modifying the field for *all* the elements or repeated the entire doc multiple times.  \r\n\r\nAny insights greatly appreciated.  \r\n\r\nThanks. \r\n\r\n\r\np.s. is there a better syntax than [] to wildcard the named-elements under steps?  Or after the pipe to identify the indices discovered by the select?  ",
        "link": "https://stackoverflow.com/questions/68075978/jq-update-json-document-to-alter-an-array-element",
        "title": "jq update json document to alter an array element"
    },
    {
        "tags": [
            "json",
            "file",
            "parameters",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1624333615,
                "creation_date": 1624333615,
                "answer_id": 68077271,
                "question_id": 68076934,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Yeah, just save the first one in a variable.\r\n```\r\nINDEX(.name) as $p | inputs | .features |= map($p[.name] + .)\r\n```\r\n&lt;sup&gt;[Online demo](https://jqplay.org/s/2MiSs1EjGN)&lt;/sup&gt;",
                "title": "Can I use jq for using parameters from a JSON file to filter and modify another JSON file?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1624346270,
        "creation_date": 1624330280,
        "last_edit_date": 1624346270,
        "question_id": 68076934,
        "body_markdown": "Let&#39;s say I have two input JSON files. The first one is:\r\n\r\n    [\r\n        {\r\n            &quot;name&quot;: &quot;one&quot;,\r\n            &quot;keyB&quot;: &quot;2&quot;,\r\n            &quot;keyC&quot;: &quot;3&quot;\r\n        },\r\n    \t{\r\n            &quot;name&quot;: &quot;two&quot;,\r\n            &quot;keyB&quot;: &quot;15&quot;,\r\n            &quot;keyC&quot;: &quot;20&quot;\r\n        }\r\n    ]\r\n\r\n\r\nAnd the second one:\r\n\r\n    {\r\n    \t&quot;name&quot;: &quot;one&quot;,\r\n    \t&quot;type&quot;: &quot;FeatureCollection&quot;,\r\n    \t&quot;features&quot;: [\r\n    \t\t{\r\n    \t\t\t&quot;name&quot;: &quot;one&quot;,\r\n    \t\t\t&quot;valueA&quot;: &quot;0&quot;,\r\n    \t\t\t&quot;valueB&quot; : &quot;0&quot;\r\n    \t\t},  \r\n    \t\t{\r\n    \t\t\t&quot;name&quot;: &quot;two&quot;,\r\n    \t\t\t&quot;valueA&quot;: &quot;11&quot;,\r\n    \t\t\t&quot;valueB&quot;: &quot;21&quot;\r\n    \t\t},\r\n    \t\t{\r\n    \t\t\t&quot;name&quot;: &quot;one&quot;,\r\n    \t\t\t&quot;valueA&quot;: &quot;21&quot;,\r\n    \t\t\t&quot;valueB&quot;: &quot;30&quot;\r\n    \t\t},  \r\n    \t\t{\r\n    \t\t\t&quot;name&quot;: &quot;two&quot;,\r\n    \t\t\t&quot;valueA&quot;: &quot;1&quot;,\r\n    \t\t\t&quot;valueB&quot;: &quot;2&quot;\r\n    \t\t},\r\n    \t\t{\r\n    \t\t\t&quot;name&quot;: &quot;one&quot;,\r\n    \t\t\t&quot;valueA&quot;: &quot;2&quot;,\r\n    \t\t\t&quot;valueB&quot;: &quot;3&quot;\r\n    \t\t},  \r\n    \t\t{\r\n    \t\t\t&quot;name&quot;: &quot;two&quot;,\r\n    \t\t\t&quot;valueA&quot;: &quot;5&quot;,\r\n    \t\t\t&quot;valueB&quot;: &quot;3&quot;\r\n    \t\t}\r\n    \t]\r\n    }\r\n\r\nI&#39;d like to create a logic that when `.[].name` from the first file is equals to `.features[].name` from the second file I concatenate its corresponding keys from the first file on the second file (considering that the value of `.[].name` on the first file is always unique). So the result would be the following:\r\n\r\n    {\r\n    \t&quot;name&quot;: &quot;one&quot;,\r\n    \t&quot;type&quot;: &quot;FeatureCollection&quot;,\r\n    \t&quot;features&quot;: [\r\n    \t\t{\r\n    \t\t\t&quot;name&quot;: &quot;one&quot;,\r\n    \t\t\t&quot;valueA&quot;: &quot;0&quot;,\r\n    \t\t\t&quot;valueB&quot; : &quot;0&quot;,\r\n    \t\t\t&quot;keyB&quot;: &quot;2&quot;,\r\n    \t\t\t&quot;keyC&quot;: &quot;3&quot;\r\n    \t\t},  \r\n    \t\t{\r\n    \t\t\t&quot;name&quot;: &quot;two&quot;,\r\n    \t\t\t&quot;valueA&quot;: &quot;11&quot;,\r\n    \t\t\t&quot;valueB&quot;: &quot;21&quot;,\r\n    \t\t\t&quot;keyB&quot;: &quot;15&quot;,\r\n    \t\t\t&quot;keyC&quot;: &quot;20&quot;\r\n    \t\t},\r\n    \t\t{\r\n    \t\t\t&quot;name&quot;: &quot;one&quot;,\r\n    \t\t\t&quot;valueA&quot;: &quot;21&quot;,\r\n    \t\t\t&quot;valueB&quot;: &quot;30&quot;,\r\n    \t\t\t&quot;keyB&quot;: &quot;2&quot;,\r\n    \t\t\t&quot;keyC&quot;: &quot;3&quot;\r\n    \t\t},  \r\n    \t\t{\r\n    \t\t\t&quot;name&quot;: &quot;two&quot;,\r\n    \t\t\t&quot;valueA&quot;: &quot;1&quot;,\r\n    \t\t\t&quot;valueB&quot;: &quot;2&quot;,\r\n    \t\t\t&quot;keyB&quot;: &quot;15&quot;,\r\n    \t\t\t&quot;keyC&quot;: &quot;20&quot;\r\n    \t\t},\r\n    \t\t{\r\n    \t\t\t&quot;name&quot;: &quot;one&quot;,\r\n    \t\t\t&quot;valueA&quot;: &quot;2&quot;,\r\n    \t\t\t&quot;valueB&quot;: &quot;3&quot;,\r\n    \t\t\t&quot;keyB&quot;: &quot;2&quot;,\r\n    \t\t\t&quot;keyC&quot;: &quot;3&quot;\r\n    \t\t},  \r\n    \t\t{\r\n    \t\t\t&quot;name&quot;: &quot;two&quot;,\r\n    \t\t\t&quot;valueA&quot;: &quot;5&quot;,\r\n    \t\t\t&quot;valueB&quot;: &quot;3&quot;,\r\n    \t\t\t&quot;keyB&quot;: &quot;15&quot;,\r\n    \t\t\t&quot;keyC&quot;: &quot;20&quot;\r\n    \t\t}\r\n    \t]\r\n    }\r\n\r\nIn this output, I just checked where the `name` is equal on both JSON files and then I brought the keys `keyB: &quot;2&quot;, &quot;keyC&quot;: &quot;3&quot;` where `name == &quot;one&quot;` and `keyB: &quot;15&quot;, &quot;keyC&quot;: &quot;20&quot;` where `name == &quot;two&quot;`. Is it possible to do with jq? Can I work with two JSON files in a way that I get parameters from one file to give it to another one?\r\n\r\n\r\n\r\n  [1]: https://stedolan.github.io/jq/tutorial/",
        "link": "https://stackoverflow.com/questions/68076934/can-i-use-jq-for-using-parameters-from-a-json-file-to-filter-and-modify-another",
        "title": "Can I use jq for using parameters from a JSON file to filter and modify another JSON file?"
    },
    {
        "tags": [
            "json",
            "bash",
            "jenkins",
            "groovy",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1624346130,
                "creation_date": 1624346130,
                "answer_id": 68079081,
                "question_id": 68078448,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "One can only use the abbreviated form `.foo` if the key name is alphanumeric, it being understood that _ is counted as an alphabetic character here.\r\n\r\nThe basic form for referring to the value of a key named &quot;KEY&quot; is `.[&quot;KEY&quot;]`, but recent versions of jq also allow `.&quot;KEY&quot;`.\r\n\r\nUsing your first approach and ignoring whatever escapes may be required by jenkins, you could write:\r\n\r\n     &quot;.[\\&quot;BucketARNUpdate=${arn}\\&quot;]&quot;     \r\n\r\nYour second approach, however, is perhaps safer.  Again ignoring whatever escapes may be required by jenkins, the invocation would look like this:\r\n\r\n    jq --arg var &quot;${arn}&quot;  &#39;.[&quot;BucketARNUpdate=&quot; + $var]&#39; .updateApp.json\r\n\r\n",
                "title": "jq fails to set value with colon in jenkins pipeline"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1624396728,
        "creation_date": 1624342623,
        "last_edit_date": 1624396728,
        "question_id": 68078448,
        "body_markdown": "My jenkins pipeline needs to manipulate **.updateApp.json** and set the name of an S3 bucket that contains **colons** as a value to the key `BucketARNUpdate`\r\n\r\nWhat I tried up to now:\r\n\r\n    arn = &quot;arn:aws:s3:::${PROJECT}-${STAGE}&quot;\r\n    sh(script: &#39;jq  &quot;.BucketARNUpdate=${arn}&quot; .updateApp.json&#39;, returnStdout: true)\r\n\r\nbut this gives me\r\n\r\n    jq: error: syntax error, unexpected &#39;:&#39; (Unix shell quoting issues?) at &lt;top-level&gt;, line 1:\r\n\r\nMy second approach was using the --arg argument and I tried\r\n\r\n`sh(script: &#39;jq --arg var \\&quot;${arn}\\&quot;  &quot;.BucketARNUpdate=${var}&quot; .updateApp.json&#39;, returnStdout: true)`\r\n\r\nbut this gives\r\n\r\n    groovy.lang.MissingPropertyException: No such property: var\r\n\r\nI tried it both with and without escaping the `var` value. How do I get this right?",
        "link": "https://stackoverflow.com/questions/68078448/jq-fails-to-set-value-with-colon-in-jenkins-pipeline",
        "title": "jq fails to set value with colon in jenkins pipeline"
    },
    {
        "tags": [
            "json",
            "select",
            "jq",
            "edit"
        ],
        "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": 1624374968,
                "post_id": 68085571,
                "comment_id": 120338999,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1624377824,
                "creation_date": 1624377824,
                "answer_id": 68087037,
                "question_id": 68085571,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Try\r\n\r\n    jq --arg CHECKIN $(uuidgen)  &#39;(.permanentLocation.id = &quot;1d0ec5e4-ba80-4eb9-8b0c-53da40d6335b&quot;)| (.circulationNotes[] |(select(.noteType == &quot;Check in&quot; and .id == null) | .id)) = $CHECKIN&#39;",
                "title": "How do I get jq to set values deep in the hierarchy?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1624394861,
        "creation_date": 1624372652,
        "last_edit_date": 1624394861,
        "question_id": 68085571,
        "body_markdown": "I have a number of documents that look like the following where I need to change the permanentLocation.id and identify all circulationNotes where the id is null and set them to a uuid\r\n\r\n      {\r\n      &quot;circulationNotes&quot;: [\r\n        {\r\n          &quot;id&quot;: null,\r\n          &quot;noteType&quot;: &quot;Check in&quot;,\r\n          &quot;note&quot;: &quot;Original location pmgd1 Gov. Documents - 2nd Fl.&quot;,\r\n          &quot;staffOnly&quot;: true,\r\n          &quot;source&quot;: {\r\n            &quot;id&quot;: &quot;affd2a52-2f04-40e3-8da3-37c2de08e338&quot;,\r\n            &quot;personal&quot;: {\r\n              &quot;lastName&quot;: &quot;Data&quot;,\r\n              &quot;firstName&quot;: &quot;Migration&quot;\r\n            }\r\n          },\r\n          &quot;date&quot;: null\r\n        },\r\n        {\r\n          &quot;id&quot;: null,\r\n          &quot;noteType&quot;: &quot;Check out&quot;,\r\n          &quot;note&quot;: &quot;Original location pmgd1 Gov. Documents - 2nd Fl.&quot;,\r\n          &quot;staffOnly&quot;: true,\r\n          &quot;source&quot;: {\r\n            &quot;id&quot;: &quot;affd2a52-2f04-40e3-8da3-37c2de08e338&quot;,\r\n            &quot;personal&quot;: {\r\n              &quot;lastName&quot;: &quot;Data&quot;,\r\n              &quot;firstName&quot;: &quot;Migration&quot;\r\n            }\r\n          },\r\n          &quot;date&quot;: null\r\n        }\r\n      ],\r\n      &quot;permanentLoanType&quot;: {\r\n        &quot;id&quot;: &quot;cf424b8f-ae2b-4d01-8365-b412c7815ba9&quot;,\r\n        &quot;name&quot;: &quot;PML 1st Fl. - Circulating&quot;\r\n      }\r\n    }\r\n\r\nI can easily set the permanentLocation.id in the document\r\n\r\n    jq  &#39;(.permanentLocation.id = &quot;1d0ec5e4-ba80-4eb9-8b0c-53da40d6335b&quot;)&#39;\r\n\r\nHowever, when I try to set a ids to the circ notes when they&#39;re null \r\n\r\n    jq --arg CHECKIN $(uuidgen)  &#39;\r\n    (.permanentLocation.id = &quot;1d0ec5e4-ba80-4eb9-8b0c-53da40d6335b&quot;)\r\n    | (.circulationNotes[] |(select(.noteType == &quot;Check in&quot; and .id == null) | .id = $CHECKIN ))&#39;\r\n    {\r\n      &quot;id&quot;: &quot;4b1e8cef-c0e7-44b3-9228-553f99019aa4&quot;,\r\n      &quot;noteType&quot;: &quot;Check in&quot;,\r\n      &quot;note&quot;: &quot;Original location pmgd1 Gov. Documents - 2nd Fl.&quot;,\r\n      &quot;staffOnly&quot;: true,\r\n      &quot;source&quot;: {\r\n        &quot;id&quot;: &quot;affd2a52-2f04-40e3-8da3-37c2de08e338&quot;,\r\n        &quot;personal&quot;: {\r\n          &quot;lastName&quot;: &quot;Data&quot;,\r\n          &quot;firstName&quot;: &quot;Migration&quot;\r\n        }\r\n      },\r\n      &quot;date&quot;: null\r\n    }\r\n\r\nI just get the first note matched rather than modifying the value as it did with permanentLocation.id. \r\n\r\nHow do I get it to set .circulationNotes.id a uuid when it is null (or any number of elements) while returning the full document so I get: \r\n\r\n    {\r\n      &quot;circulationNotes&quot;: [\r\n        {\r\n          &quot;id&quot;: bd5379f7-69fc-48f5-8461-8dcc59883ae0,\r\n          &quot;noteType&quot;: &quot;Check in&quot;,\r\n          &quot;note&quot;: &quot;Original location pmgd1 Gov. Documents - 2nd Fl.&quot;,\r\n          &quot;staffOnly&quot;: true,\r\n          &quot;source&quot;: {\r\n            &quot;id&quot;: &quot;affd2a52-2f04-40e3-8da3-37c2de08e338&quot;,\r\n            &quot;personal&quot;: {\r\n              &quot;lastName&quot;: &quot;Data&quot;,\r\n              &quot;firstName&quot;: &quot;Migration&quot;\r\n            }\r\n          },\r\n          &quot;date&quot;: null\r\n        },\r\n        {\r\n          &quot;id&quot;: 33f60901-33a8-43d1-a2ce-e22d8be87d15,\r\n          &quot;noteType&quot;: &quot;Check out&quot;,\r\n          &quot;note&quot;: &quot;Original location pmgd1 Gov. Documents - 2nd Fl.&quot;,\r\n          &quot;staffOnly&quot;: true,\r\n          &quot;source&quot;: {\r\n            &quot;id&quot;: &quot;affd2a52-2f04-40e3-8da3-37c2de08e338&quot;,\r\n            &quot;personal&quot;: {\r\n              &quot;lastName&quot;: &quot;Data&quot;,\r\n              &quot;firstName&quot;: &quot;Migration&quot;\r\n            }\r\n          },\r\n          &quot;date&quot;: null\r\n        }\r\n      ],\r\n      &quot;permanentLoanType&quot;: {\r\n        &quot;id&quot;: &quot;cf424b8f-ae2b-4d01-8365-b412c7815ba9&quot;,\r\n        &quot;name&quot;: &quot;PML 1st Fl. - Circulating&quot;\r\n      },\r\n      &quot;permanentLocation&quot;: {\r\n        &quot;id&quot;: &quot;1d0ec5e4-ba80-4eb9-8b0c-53da40d6335b&quot;\r\n      }\r\n    }",
        "link": "https://stackoverflow.com/questions/68085571/how-do-i-get-jq-to-set-values-deep-in-the-hierarchy",
        "title": "How do I get jq to set values deep in the hierarchy?"
    },
    {
        "tags": [
            "json",
            "awk",
            "sed",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1624385582,
                "last_edit_date": 1624385582,
                "creation_date": 1624385252,
                "answer_id": 68088807,
                "question_id": 68088473,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Since your question was `Could anyone shed any light onto this please?`, here is some light:\r\n\r\nThe file format you&#39;re working with appears to be `JSON` so use a tool that understands `JSON` to edit it, e.g. `jq`.\r\n\r\nFor example, when run on your sample input (after  the `...` line cluttering it up and making it untestable was removed) here is `jq` pretty-printing it:\r\n\r\n    $ cat file\r\n    {&quot;index&quot;:{}}\r\n    {&quot;LAST_MODIFIED_BY&quot;:&quot;john&quot;,&quot;CREATED_BY&quot;:&quot;david&quot;,&quot;LAST_MODIFIED_DATE&quot;:&quot;2018-01-11T06:39:11.000Z&quot;,&quot;CREATION_DATE&quot;:&quot;2018-01-11T06:39:11.000Z&quot;,&quot;INGESTION_DATE&quot;:&quot;2018-01-11T06:39:11.000Z&quot;,&quot;DECISION&quot;:&quot;AGREE&quot;,&quot;BATCH_TAG&quot;:&quot;&quot;,&quot;TASK_TYPE_NAME&quot;:&quot;Test&quot;,&quot;PUBLISHER_ID&quot;:&quot;abc123&quot;,&quot;ID&quot;:&quot;700adca2-c4d4-4245-8174-0479f7123a63&quot;}\r\n    {&quot;index&quot;:{}}\r\n    {&quot;LAST_MODIFIED_BY&quot;:&quot;joe&quot;,&quot;CREATED_BY&quot;:&quot;brian&quot;,&quot;LAST_MODIFIED_DATE&quot;:&quot;2018-01-11T06:39:11.000Z&quot;,&quot;CREATION_DATE&quot;:&quot;2018-01-11T06:39:11.000Z&quot;,&quot;INGESTION_DATE&quot;:&quot;2018-01-11T06:39:11.000Z&quot;,&quot;DECISION&quot;:&quot;AGREE&quot;,&quot;BATCH_TAG&quot;:&quot;&quot;,&quot;TASK_TYPE_NAME&quot;:&quot;Test2&quot;,&quot;PUBLISHER_ID&quot;:&quot;abc123&quot;,&quot;ID&quot;:&quot;700adca2-c4d4-4245-8174-0479f7123a62&quot;}\r\n    {&quot;index&quot;:{}}\r\n    {&quot;LAST_MODIFIED_BY&quot;:&quot;sarah&quot;,&quot;CREATED_BY&quot;:&quot;hannah&quot;,&quot;LAST_MODIFIED_DATE&quot;:&quot;2018-01-11T06:39:11.000Z&quot;,&quot;CREATION_DATE&quot;:&quot;2018-01-11T06:39:11.000Z&quot;,&quot;INGESTION_DATE&quot;:&quot;2018-01-11T06:39:11.000Z&quot;,&quot;DECISION&quot;:&quot;AGREE&quot;,&quot;BATCH_TAG&quot;:&quot;&quot;,&quot;TASK_TYPE_NAME&quot;:&quot;Test8&quot;,&quot;PUBLISHER_ID&quot;:&quot;abc123&quot;,&quot;ID&quot;:&quot;700adca2-c4d4-4245-8174-0479f7123a61&quot;}\r\n\r\n&lt;p&gt;\r\n\r\n    $ jq . &lt; file\r\n    {\r\n      &quot;index&quot;: {}\r\n    }\r\n    {\r\n      &quot;LAST_MODIFIED_BY&quot;: &quot;john&quot;,\r\n      &quot;CREATED_BY&quot;: &quot;david&quot;,\r\n      &quot;LAST_MODIFIED_DATE&quot;: &quot;2018-01-11T06:39:11.000Z&quot;,\r\n      &quot;CREATION_DATE&quot;: &quot;2018-01-11T06:39:11.000Z&quot;,\r\n      &quot;INGESTION_DATE&quot;: &quot;2018-01-11T06:39:11.000Z&quot;,\r\n      &quot;DECISION&quot;: &quot;AGREE&quot;,\r\n      &quot;BATCH_TAG&quot;: &quot;&quot;,\r\n      &quot;TASK_TYPE_NAME&quot;: &quot;Test&quot;,\r\n      &quot;PUBLISHER_ID&quot;: &quot;abc123&quot;,\r\n      &quot;ID&quot;: &quot;700adca2-c4d4-4245-8174-0479f7123a63&quot;\r\n    }\r\n    {\r\n      &quot;index&quot;: {}\r\n    }\r\n    {\r\n      &quot;LAST_MODIFIED_BY&quot;: &quot;joe&quot;,\r\n      &quot;CREATED_BY&quot;: &quot;brian&quot;,\r\n      &quot;LAST_MODIFIED_DATE&quot;: &quot;2018-01-11T06:39:11.000Z&quot;,\r\n      &quot;CREATION_DATE&quot;: &quot;2018-01-11T06:39:11.000Z&quot;,\r\n      &quot;INGESTION_DATE&quot;: &quot;2018-01-11T06:39:11.000Z&quot;,\r\n      &quot;DECISION&quot;: &quot;AGREE&quot;,\r\n      &quot;BATCH_TAG&quot;: &quot;&quot;,\r\n      &quot;TASK_TYPE_NAME&quot;: &quot;Test2&quot;,\r\n      &quot;PUBLISHER_ID&quot;: &quot;abc123&quot;,\r\n      &quot;ID&quot;: &quot;700adca2-c4d4-4245-8174-0479f7123a62&quot;\r\n    }\r\n    {\r\n      &quot;index&quot;: {}\r\n    }\r\n    {\r\n      &quot;LAST_MODIFIED_BY&quot;: &quot;sarah&quot;,\r\n      &quot;CREATED_BY&quot;: &quot;hannah&quot;,\r\n      &quot;LAST_MODIFIED_DATE&quot;: &quot;2018-01-11T06:39:11.000Z&quot;,\r\n      &quot;CREATION_DATE&quot;: &quot;2018-01-11T06:39:11.000Z&quot;,\r\n      &quot;INGESTION_DATE&quot;: &quot;2018-01-11T06:39:11.000Z&quot;,\r\n      &quot;DECISION&quot;: &quot;AGREE&quot;,\r\n      &quot;BATCH_TAG&quot;: &quot;&quot;,\r\n      &quot;TASK_TYPE_NAME&quot;: &quot;Test8&quot;,\r\n      &quot;PUBLISHER_ID&quot;: &quot;abc123&quot;,\r\n      &quot;ID&quot;: &quot;700adca2-c4d4-4245-8174-0479f7123a61&quot;\r\n    }\r\n\r\nand with your desired output:\r\n\r\n    $ cat file2\r\n    {&quot;index&quot;:{}}\r\n    {&quot;LAST_MODIFIED_BY&quot;:&quot;john&quot;,&quot;CREATED_BY&quot;:&quot;david&quot;,&quot;LAST_MODIFIED_DATE&quot;:&quot;2018-01-11T06:39:11.000Z&quot;,&quot;CREATION_DATE&quot;:&quot;2018-01-11T06:39:11.000Z&quot;,&quot;INGESTION_DATE&quot;:&quot;2018-01-11T06:39:11.000Z&quot;,&quot;DECISION&quot;:&quot;AGREE&quot;,&quot;TAGS&quot;:{&quot;BATCH_TAG&quot;:&quot;&quot;,&quot;TASK_TYPE_NAME&quot;:&quot;Test&quot;},&quot;PUBLISHER_ID&quot;:&quot;abc123&quot;,&quot;ID&quot;:&quot;700adca2-c4d4-4245-8174-0479f7123a63&quot;}\r\n    {&quot;index&quot;:{}}\r\n    {&quot;LAST_MODIFIED_BY&quot;:&quot;joe&quot;,&quot;CREATED_BY&quot;:&quot;brian&quot;,&quot;LAST_MODIFIED_DATE&quot;:&quot;2018-01-11T06:39:11.000Z&quot;,&quot;CREATION_DATE&quot;:&quot;2018-01-11T06:39:11.000Z&quot;,&quot;INGESTION_DATE&quot;:&quot;2018-01-11T06:39:11.000Z&quot;,&quot;DECISION&quot;:&quot;AGREE&quot;,&quot;TAGS&quot;:{&quot;BATCH_TAG&quot;:&quot;&quot;,&quot;TASK_TYPE_NAME&quot;:&quot;Test2&quot;},&quot;PUBLISHER_ID&quot;:&quot;abc123&quot;,&quot;ID&quot;:&quot;700adca2-c4d4-4245-8174-0479f7123a62&quot;}\r\n    {&quot;index&quot;:{}}\r\n    {&quot;LAST_MODIFIED_BY&quot;:&quot;joe&quot;,&quot;CREATED_BY&quot;:&quot;brian&quot;,&quot;LAST_MODIFIED_DATE&quot;:&quot;2018-01-11T06:39:11.000Z&quot;,&quot;CREATION_DATE&quot;:&quot;2018-01-11T06:39:11.000Z&quot;,&quot;INGESTION_DATE&quot;:&quot;2018-01-11T06:39:11.000Z&quot;,&quot;DECISION&quot;:&quot;AGREE&quot;,&quot;TAGS&quot;:{&quot;BATCH_TAG&quot;:&quot;&quot;,&quot;TASK_TYPE_NAME&quot;:&quot;Test2&quot;},&quot;PUBLISHER_ID&quot;:&quot;abc123&quot;,&quot;ID&quot;:&quot;700adca2-c4d4-4245-8174-0479f7123a62&quot;}\r\n\r\n\r\n\r\n&lt;p&gt;\r\n\r\n    $ jq . &lt; file2\r\n    {\r\n      &quot;index&quot;: {}\r\n    }\r\n    {\r\n      &quot;LAST_MODIFIED_BY&quot;: &quot;john&quot;,\r\n      &quot;CREATED_BY&quot;: &quot;david&quot;,\r\n      &quot;LAST_MODIFIED_DATE&quot;: &quot;2018-01-11T06:39:11.000Z&quot;,\r\n      &quot;CREATION_DATE&quot;: &quot;2018-01-11T06:39:11.000Z&quot;,\r\n      &quot;INGESTION_DATE&quot;: &quot;2018-01-11T06:39:11.000Z&quot;,\r\n      &quot;DECISION&quot;: &quot;AGREE&quot;,\r\n      &quot;TAGS&quot;: {\r\n        &quot;BATCH_TAG&quot;: &quot;&quot;,\r\n        &quot;TASK_TYPE_NAME&quot;: &quot;Test&quot;\r\n      },\r\n      &quot;PUBLISHER_ID&quot;: &quot;abc123&quot;,\r\n      &quot;ID&quot;: &quot;700adca2-c4d4-4245-8174-0479f7123a63&quot;\r\n    }\r\n    {\r\n      &quot;index&quot;: {}\r\n    }\r\n    {\r\n      &quot;LAST_MODIFIED_BY&quot;: &quot;joe&quot;,\r\n      &quot;CREATED_BY&quot;: &quot;brian&quot;,\r\n      &quot;LAST_MODIFIED_DATE&quot;: &quot;2018-01-11T06:39:11.000Z&quot;,\r\n      &quot;CREATION_DATE&quot;: &quot;2018-01-11T06:39:11.000Z&quot;,\r\n      &quot;INGESTION_DATE&quot;: &quot;2018-01-11T06:39:11.000Z&quot;,\r\n      &quot;DECISION&quot;: &quot;AGREE&quot;,\r\n      &quot;TAGS&quot;: {\r\n        &quot;BATCH_TAG&quot;: &quot;&quot;,\r\n        &quot;TASK_TYPE_NAME&quot;: &quot;Test2&quot;\r\n      },\r\n      &quot;PUBLISHER_ID&quot;: &quot;abc123&quot;,\r\n      &quot;ID&quot;: &quot;700adca2-c4d4-4245-8174-0479f7123a62&quot;\r\n    }\r\n    {\r\n      &quot;index&quot;: {}\r\n    }\r\n    {\r\n      &quot;LAST_MODIFIED_BY&quot;: &quot;joe&quot;,\r\n      &quot;CREATED_BY&quot;: &quot;brian&quot;,\r\n      &quot;LAST_MODIFIED_DATE&quot;: &quot;2018-01-11T06:39:11.000Z&quot;,\r\n      &quot;CREATION_DATE&quot;: &quot;2018-01-11T06:39:11.000Z&quot;,\r\n      &quot;INGESTION_DATE&quot;: &quot;2018-01-11T06:39:11.000Z&quot;,\r\n      &quot;DECISION&quot;: &quot;AGREE&quot;,\r\n      &quot;TAGS&quot;: {\r\n        &quot;BATCH_TAG&quot;: &quot;&quot;,\r\n        &quot;TASK_TYPE_NAME&quot;: &quot;Test2&quot;\r\n      },\r\n      &quot;PUBLISHER_ID&quot;: &quot;abc123&quot;,\r\n      &quot;ID&quot;: &quot;700adca2-c4d4-4245-8174-0479f7123a62&quot;\r\n    }\r\n\r\nRead the `jq` man page and/or google it for more information on how to apply it to your problem.\r\n",
                "title": "Add a string in front of a string and at the end of another string in alternating lines"
            },
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1624394743,
                "last_edit_date": 1624394743,
                "creation_date": 1624394113,
                "answer_id": 68090424,
                "question_id": 68088473,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The tricky bit here is ensuring the new TAGS key is inserted in the desired position.  Using jq, this can be done with `with_entries`:\r\n```\r\nif has(&quot;BATCH_TAG&quot;)\r\nthen .BATCH_TAG = {BATCH_TAG, TASK_TYPE_NAME}\r\n| with_entries(.key |= if . == &quot;BATCH_TAG&quot; \r\n                       then &quot;TAGS&quot;\r\n                       else . end)\r\n| del(.TASK_TYPE_NAME)\r\nelse .\r\nend\r\n```\r\n",
                "title": "Add a string in front of a string and at the end of another string in alternating lines"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1624394743,
        "creation_date": 1624383748,
        "last_edit_date": 1624385381,
        "question_id": 68088473,
        "body_markdown": "Here&#39;s my file format:\r\n```\r\n{&quot;index&quot;:{}}\r\n{&quot;LAST_MODIFIED_BY&quot;:&quot;john&quot;,&quot;CREATED_BY&quot;:&quot;david&quot;,&quot;LAST_MODIFIED_DATE&quot;:&quot;2018-01-11T06:39:11.000Z&quot;,&quot;CREATION_DATE&quot;:&quot;2018-01-11T06:39:11.000Z&quot;,&quot;INGESTION_DATE&quot;:&quot;2018-01-11T06:39:11.000Z&quot;,&quot;DECISION&quot;:&quot;AGREE&quot;,&quot;BATCH_TAG&quot;:&quot;&quot;,&quot;TASK_TYPE_NAME&quot;:&quot;Test&quot;,&quot;PUBLISHER_ID&quot;:&quot;abc123&quot;,&quot;ID&quot;:&quot;700adca2-c4d4-4245-8174-0479f7123a63&quot;}\r\n{&quot;index&quot;:{}}\r\n{&quot;LAST_MODIFIED_BY&quot;:&quot;joe&quot;,&quot;CREATED_BY&quot;:&quot;brian&quot;,&quot;LAST_MODIFIED_DATE&quot;:&quot;2018-01-11T06:39:11.000Z&quot;,&quot;CREATION_DATE&quot;:&quot;2018-01-11T06:39:11.000Z&quot;,&quot;INGESTION_DATE&quot;:&quot;2018-01-11T06:39:11.000Z&quot;,&quot;DECISION&quot;:&quot;AGREE&quot;,&quot;BATCH_TAG&quot;:&quot;&quot;,&quot;TASK_TYPE_NAME&quot;:&quot;Test2&quot;,&quot;PUBLISHER_ID&quot;:&quot;abc123&quot;,&quot;ID&quot;:&quot;700adca2-c4d4-4245-8174-0479f7123a62&quot;}\r\n...\r\n{&quot;index&quot;:{}}\r\n{&quot;LAST_MODIFIED_BY&quot;:&quot;sarah&quot;,&quot;CREATED_BY&quot;:&quot;hannah&quot;,&quot;LAST_MODIFIED_DATE&quot;:&quot;2018-01-11T06:39:11.000Z&quot;,&quot;CREATION_DATE&quot;:&quot;2018-01-11T06:39:11.000Z&quot;,&quot;INGESTION_DATE&quot;:&quot;2018-01-11T06:39:11.000Z&quot;,&quot;DECISION&quot;:&quot;AGREE&quot;,&quot;BATCH_TAG&quot;:&quot;&quot;,&quot;TASK_TYPE_NAME&quot;:&quot;Test8&quot;,&quot;PUBLISHER_ID&quot;:&quot;abc123&quot;,&quot;ID&quot;:&quot;700adca2-c4d4-4245-8174-0479f7123a61&quot;}\r\n```\r\n\r\nI need to add `&quot;TAGS&quot;:{}` to encompass these two fields: `BATCH_TAG` and `TASK_TYPE_NAME`, so the desired output looks like this:\r\n```\r\n{&quot;index&quot;:{}}\r\n{&quot;LAST_MODIFIED_BY&quot;:&quot;john&quot;,&quot;CREATED_BY&quot;:&quot;david&quot;,&quot;LAST_MODIFIED_DATE&quot;:&quot;2018-01-11T06:39:11.000Z&quot;,&quot;CREATION_DATE&quot;:&quot;2018-01-11T06:39:11.000Z&quot;,&quot;INGESTION_DATE&quot;:&quot;2018-01-11T06:39:11.000Z&quot;,&quot;DECISION&quot;:&quot;AGREE&quot;,&quot;TAGS&quot;:{&quot;BATCH_TAG&quot;:&quot;&quot;,&quot;TASK_TYPE_NAME&quot;:&quot;Test&quot;},&quot;PUBLISHER_ID&quot;:&quot;abc123&quot;,&quot;ID&quot;:&quot;700adca2-c4d4-4245-8174-0479f7123a63&quot;}\r\n{&quot;index&quot;:{}}\r\n{&quot;LAST_MODIFIED_BY&quot;:&quot;joe&quot;,&quot;CREATED_BY&quot;:&quot;brian&quot;,&quot;LAST_MODIFIED_DATE&quot;:&quot;2018-01-11T06:39:11.000Z&quot;,&quot;CREATION_DATE&quot;:&quot;2018-01-11T06:39:11.000Z&quot;,&quot;INGESTION_DATE&quot;:&quot;2018-01-11T06:39:11.000Z&quot;,&quot;DECISION&quot;:&quot;AGREE&quot;,&quot;TAGS&quot;:{&quot;BATCH_TAG&quot;:&quot;&quot;,&quot;TASK_TYPE_NAME&quot;:&quot;Test2&quot;},&quot;PUBLISHER_ID&quot;:&quot;abc123&quot;,&quot;ID&quot;:&quot;700adca2-c4d4-4245-8174-0479f7123a62&quot;}\r\n...\r\n{&quot;index&quot;:{}}\r\n{&quot;LAST_MODIFIED_BY&quot;:&quot;sarah&quot;,&quot;CREATED_BY&quot;:&quot;hannah&quot;,&quot;LAST_MODIFIED_DATE&quot;:&quot;2018-01-11T06:39:11.000Z&quot;,&quot;CREATION_DATE&quot;:&quot;2018-01-11T06:39:11.000Z&quot;,&quot;INGESTION_DATE&quot;:&quot;2018-01-11T06:39:11.000Z&quot;,&quot;DECISION&quot;:&quot;AGREE&quot;,&quot;TAGS&quot;:{&quot;BATCH_TAG&quot;:&quot;&quot;,&quot;TASK_TYPE_NAME&quot;:&quot;Test8&quot;},&quot;PUBLISHER_ID&quot;:&quot;abc123&quot;,&quot;ID&quot;:&quot;700adca2-c4d4-4245-8174-0479f7123a61&quot;}\r\n```\r\n\r\nThe closest that I could find is this one: https://stackoverflow.com/q/2099471/4117496 but it adds a string in the front of each line, which is not really what I wanted.\r\n\r\nCould anyone shed any light onto this please?\r\n\r\nThanks!",
        "link": "https://stackoverflow.com/questions/68088473/add-a-string-in-front-of-a-string-and-at-the-end-of-another-string-in-alternatin",
        "title": "Add a string in front of a string and at the end of another string in alternating lines"
    },
    {
        "tags": [
            "json",
            "bash",
            "join",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1624416674,
                "last_edit_date": 1624416674,
                "creation_date": 1624414931,
                "answer_id": 68092769,
                "question_id": 68092167,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Yes.  \r\n\r\nUsing `reduce` avoids the sorting that is entailed by `group_by`.  For example, you could write:\r\n```\r\n. as $one\r\n| input as $two\r\n| ($one[0] + $two[0] | map_values(&quot;&quot;)) as $defaults\r\n| INDEX($one[]; .url) as $one\r\n| INDEX($two[]; .url) as $two\r\n| reduce ($one+$two|keys_unsorted)[] as $k ({}; \r\n    .[$k] = ($defaults + $one[$k] + $two[$k]) )\r\n| [.[]]\r\n```\r\n\r\nNotes:\r\n1. The above assumes an invocation of the form: jq ... file1.json file2.json\r\n2. Notice how jq supports shadowing of &quot;$-variables&quot;.\r\n3. It might be worth considering using `null` rather than `&quot;&quot;` as the value for what you&#39;ve called &quot;empty keys&quot;.\r\n4. Depending on the detailed requirements, you might want to set $defaults along the lines of:\r\n\r\n    `(($one|add) + ($two|add) | map_values(&quot;&quot;))`\r\n\r\n",
                "title": "Merge JSON files but preserve empty keys (preferably with JQ)"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 4,
        "last_activity_date": 1624418073,
        "creation_date": 1624408672,
        "last_edit_date": 1624418073,
        "question_id": 68092167,
        "body_markdown": "Is there a way to merge two JSON files on a key but preserve empty keys, preferably in JQ?\r\n\r\nThe files are merged on `url`.\r\n\r\nFile 1:\r\n```\r\n[\r\n  {\r\n    &quot;url&quot;: &quot;ABC&quot;,\r\n    &quot;name&quot;: &quot;Search&quot;,\r\n    &quot;version&quot;: &quot;2020&quot;,\r\n    &quot;Ocurrences&quot;: &quot;25&quot;\r\n  },\r\n  {\r\n    &quot;url&quot;: &quot;DEF&quot;,\r\n    &quot;name&quot;: &quot;Welcome&quot;,\r\n    &quot;version&quot;: &quot;2021&quot;,\r\n    &quot;Ocurrences&quot;: &quot;10&quot;\r\n  }\r\n]\r\n```\r\n\r\nFile 2:\r\n```\r\n[\r\n  {\r\n    &quot;url&quot;: &quot;DEF&quot;,\r\n    &quot;title&quot;: &quot;Support&quot;\r\n  },\r\n  {\r\n    &quot;url&quot;: &quot;GHI&quot;,\r\n    &quot;title&quot;: &quot;Contact&quot;\r\n  }\r\n]\r\n```\r\n\r\nDesired result:\r\n```\r\n[\r\n  {\r\n    &quot;url&quot;: &quot;ABC&quot;,\r\n    &quot;title&quot;: &quot;&quot;,\r\n    &quot;name&quot;: &quot;Search&quot;,\r\n    &quot;version&quot;: &quot;2020&quot;,\r\n    &quot;Ocurrences&quot;: &quot;25&quot;\r\n  },\r\n  {\r\n    &quot;url&quot;: &quot;DEF&quot;,\r\n    &quot;title&quot;: &quot;Support&quot;,\r\n    &quot;name&quot;: &quot;Welcome&quot;,\r\n    &quot;version&quot;: &quot;2021&quot;,\r\n    &quot;Ocurrences&quot;: &quot;10&quot;\r\n  },\r\n  {\r\n    &quot;url&quot;: &quot;GHI&quot;,\r\n    &quot;title&quot;: &quot;Contact&quot;,\r\n    &quot;name&quot;: &quot;&quot;,\r\n    &quot;version&quot;: &quot;&quot;,\r\n    &quot;Ocurrences&quot;: &quot;&quot;\r\n  }\r\n]\r\n```\r\n\r\nCurrent JQ script:\r\n```\r\njq -M &#39;[group_by(.url)[]|add]&#39; fi1e1.json file2.json &gt; output.json\r\n```\r\n\r\nCurrent result:\r\n```\r\n[\r\n  {\r\n    &quot;url&quot;: &quot;ABC&quot;,\r\n    &quot;name&quot;: &quot;Search&quot;,\r\n    &quot;version&quot;: &quot;2020&quot;,\r\n    &quot;Ocurrences&quot;: &quot;25&quot;\r\n  },\r\n  {\r\n    &quot;url&quot;: &quot;DEF&quot;,\r\n    &quot;title&quot;: &quot;Support&quot;,\r\n    &quot;name&quot;: &quot;Welcome&quot;,\r\n    &quot;version&quot;: &quot;2021&quot;,\r\n    &quot;Ocurrences&quot;: &quot;10&quot;\r\n  },\r\n  {\r\n    &quot;url&quot;: &quot;GHI&quot;,\r\n    &quot;title&quot;: &quot;Contact&quot;\r\n  }\r\n]\r\n```\r\n\r\nThe real files have 100+ objects. Order of keys doesn&#39;t matter. JQ is preferred because I know Bash only.\r\n\r\nThe goal is to merge data extracted from Azure Application Insights with data on a local hard drive.\r\n\r\nThank you for any help or direction.",
        "link": "https://stackoverflow.com/questions/68092167/merge-json-files-but-preserve-empty-keys-preferably-with-jq",
        "title": "Merge JSON files but preserve empty keys (preferably with JQ)"
    },
    {
        "tags": [
            "json",
            "regex",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1624478184,
                "last_edit_date": 1624478184,
                "creation_date": 1624477512,
                "answer_id": 68106247,
                "question_id": 68105261,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The crux of the problem here concerns the regex to use to capture the .c file (or files), so I&#39;ll focus on that.\r\n\r\nIf it&#39;s known there&#39;s at most one .c file, and that it is reasonably named (e.g., no embedded spaces), then it would be simplest to &quot;capture&quot; the filename along these lines:\r\n\r\n    capture(&quot;(^| )(?&lt;c&gt;[^ ]+[.]c)( |$)&quot;)\r\n\r\nHowever, if there might be more than one .c file, then you could iteratively use the following &quot;capture&quot; expression:\r\n\r\n\r\n    capture(&quot;(^| )(?&lt;c&gt;[^ ]+[.]c)( |$)(?&lt;etc&gt;.*)&quot;)\r\n\r\nExamples:\r\n```\r\necho &#39;a.c b.c&#39; |\r\n  jq -R &#39;capture(&quot;(^| )(?&lt;c&gt;[^ ]+[.]c)( |$)(?&lt;etc&gt;.*)&quot;)&#39;\r\n```\r\nproduces:\r\n```\r\n{\r\n  &quot;c&quot;: &quot;a.c&quot;,\r\n  &quot;etc&quot;: &quot;b.c&quot;\r\n}\r\n```\r\n\r\n### Multiple .c files\r\n```\r\necho &quot;a.c b.c&quot; |\r\n  jq -R &#39;\r\n  # emit a stream of filenames ending in .$suffix\r\n  def filenames($suffix):\r\n    def one:\r\n      capture(&quot;(^| )(?&lt;c&gt;[^ ]+[.]&quot;+$suffix+&quot;)( |$) *(?&lt;etc&gt;.*)&quot;);\r\n    def names:\r\n      one | .c, (.etc | names);\r\n    names;\r\n\r\n  filenames(&quot;c&quot;)&#39;\r\n\r\n```\r\nproduces:\r\n```\r\n&quot;a.c&quot;\r\n&quot;b.c&quot;\r\n```\r\n\r\n\r\n",
                "title": "jq inserts .o instead of .c files in the compile_commands.json &quot;file&quot; field"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1624531485,
        "creation_date": 1624472422,
        "last_edit_date": 1624531485,
        "question_id": 68105261,
        "body_markdown": "I manage to create a `CommandsFile.txt` that looks like this:\r\n\r\n      /cygwin/c/Dev/bin/tricore-gcc.exe   -isystem     all_inc     -W     -Wall  (plus a bunch of other flags)  -c     software/ProjectA/src/file1.c     -o     _objs/ccLib/file1.o\r\n      /cygwin/c/Dev/bin/tricore-gcc.exe   -isystem     all_inc     -W     -Wall  (plus a bunch of other flags)  -c     software/ProjectA/src/file2.c     -o     _objs/ccLib/file2.o\r\n    ...\r\n\r\nand I exploited `jq` for generating the `compile_commands.json` file in the following script\r\n\r\n    #!/bin/bash\r\n    \r\n    cat CommandsFile.txt \\\r\n    | grep -wE &#39;gcc|g\\+\\+&#39; \\\r\n    | grep -w &#39;\\-c&#39; \\\r\n    | ./jq-win64 -nR &#39;[inputs|{directory:&quot;.&quot;, command:., file: match(&quot; [^ ]+$&quot;).string[1:]}]&#39; \\\r\n     &gt; compile_commands.json \r\n\r\n  \r\n\r\nand it works like a charm, but the script fills the field `&quot;file&quot;` with `.o` instead of `.c` files: \r\n\r\n    ...\r\n      {\r\n        &quot;directory&quot;: &quot;.&quot;,\r\n        &quot;command&quot;: &quot;  /cygwin/c/Dev/bin/tricore-gcc.exe   -isystem     all_inc     -W     -Wall  (plus a bunch of other flags)  -c     software/ProjectA/src/file1.c     -o     _objs/ccLib/file1.o,\r\n        &quot;file&quot;: &quot;_objs/ccLib/file1.o&quot;\r\n      },\r\n      {\r\n        &quot;directory&quot;: &quot;.&quot;,\r\n        &quot;command&quot;: &quot;  /cygwin/c/Dev/bin/tricore-gcc.exe   -isystem     all_inc     -W     -Wall  (plus a bunch of other flags)  -c     software/ProjectA/src/file2.c     -o     _objs/ccLib/file2.o,\r\n        &quot;file&quot;: &quot;_objs/ccLib/file2.o&quot;  },\r\n    ...\r\n\r\nHow shall I modified the script for having the `.c` files instead of the `.o` files in the field `&quot;file&quot;`?",
        "link": "https://stackoverflow.com/questions/68105261/jq-inserts-o-instead-of-c-files-in-the-compile-commands-json-file-field",
        "title": "jq inserts .o instead of .c files in the compile_commands.json &quot;file&quot; field"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1624478706,
                "creation_date": 1624478706,
                "answer_id": 68106449,
                "question_id": 68105706,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Presumably you meant:\r\n\r\n    jq &#39;.test[] | [.deviceName]&#39;\r\n\r\nor perhaps:\r\n\r\n    jq &#39;.[][] | [.deviceName]&#39;\r\n\r\nbut without knowing your requirements, it&#39;s hard to say.  That&#39;s one of the reasons why the http://stackoverflow.com/help/mcve guidelines were formulated.\r\n\r\n",
                "title": "Trying to get the correct output from JQ"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -2,
        "last_activity_date": 1624478706,
        "creation_date": 1624474737,
        "last_edit_date": 1624474807,
        "question_id": 68105706,
        "body_markdown": "I&#39;m trying to get this output the device name &quot;test&quot;\r\n\r\nMy filter is `.[] | [.deviceName]` and it&#39;s returning error: (at &lt;stdin&gt;:7): `Cannot index array with string &quot;deviceName&quot;`\r\n\r\n    {\r\n        &quot;test&quot;: [\r\n            {\r\n                &quot;deviceName&quot;: &quot;test&quot;,\r\n                &quot;monitoringServer&quot;: &quot;server1&quot;\r\n            }\r\n        ] \r\n    }\r\n\r\n",
        "link": "https://stackoverflow.com/questions/68105706/trying-to-get-the-correct-output-from-jq",
        "title": "Trying to get the correct output from JQ"
    },
    {
        "tags": [
            "json",
            "select",
            "path",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1624503926,
                "last_edit_date": 1624503926,
                "creation_date": 1624503516,
                "answer_id": 68109079,
                "question_id": 68109003,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Something like this should do that.\r\n``` shell\r\njq --stream &#39;select(.[0][-1] == &quot;id&quot; and (.[1] | strings)) | .[0]&#39; file\r\n```\r\n\r\nAnd by the way, your first *ugly solution* can be simplified to this:\r\n```\r\njq &#39;path(.. .id? | strings)&#39; file\r\n```",
                "title": "Output paths to all keys named &quot;id&quot; where the type of value is &quot;string&quot;"
            },
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1624517979,
                "last_edit_date": 1624517979,
                "creation_date": 1624503729,
                "answer_id": 68109100,
                "question_id": 68109003,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Stream the input in as you started with your second solution, but add some filtering. You do _not_ want want to read the entire contents into memory. And also... UUOC.\r\n\r\n```bash\r\n$ jq --stream &#39;\r\nselect(.[0][-1] == &quot;id&quot; and (.[1]|type) == &quot;string&quot;)[0]\r\n  | join(&quot;.&quot;)\r\n&#39; huge.json\r\n```\r\n",
                "title": "Output paths to all keys named &quot;id&quot; where the type of value is &quot;string&quot;"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1624515924,
                "creation_date": 1624515924,
                "answer_id": 68110572,
                "question_id": 68109003,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Thank you both oguz and Jeff! Beautiful! This runs in 6.5 minutes (on my old laptop), never uses more than 21MB of RAM, and gives me exactly what I need. &lt;3\r\n\r\n```\r\n$ jq --stream -c &#39;select(.[0][-1] == &quot;id&quot; and (.[1]|type) == &quot;string&quot;)&#39; huge.json\r\n```",
                "title": "Output paths to all keys named &quot;id&quot; where the type of value is &quot;string&quot;"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 2,
        "last_activity_date": 1624592768,
        "creation_date": 1624502473,
        "last_edit_date": 1624592768,
        "question_id": 68109003,
        "body_markdown": "Given a huge (15GB) deeply nested (12+ object layers) JSON file how can I find the paths to all the keys named `id` whose values are type `string`? \r\n\r\nA massively simplified example file:\r\n```\r\n{\r\n  &quot;a&quot;: [\r\n    {\r\n      &quot;id&quot;: 3,\r\n      &quot;foo&quot;: &quot;red&quot;\r\n    }\r\n  ],\r\n  &quot;b&quot;: [\r\n    {\r\n      &quot;id&quot;: &quot;7&quot;,\r\n      &quot;bar&quot;: &quot;orange&quot;,\r\n      &quot;baz&quot;: {\r\n        &quot;id&quot;: 13\r\n      },\r\n      &quot;bax&quot;: {\r\n        &quot;id&quot;: &quot;12&quot;\r\n      }\r\n    }\r\n  ]\r\n}\r\n```\r\nLooking for a less ugly solution where I don&#39;t run out of RAM and have to punt to grep at the end (sigh). (I failed to figure out how to chain `to_entries` into this usefully. If that&#39;s even something I should be trying to do.)\r\n\r\nUgly solution 1:\r\n```\r\n$ cat huge.json | jq &#39;path(..|select(type==&quot;string&quot;)) | join(&quot;.&quot;)&#39; | grep -E &#39;\\.id&quot;$&#39;\r\n&quot;b.0.id&quot;\r\n&quot;b.0.bax.id&quot;\r\n```\r\n\r\nUgly solution 2:\r\n```\r\n$ cat huge.json | jq --stream -c | grep -E &#39;&quot;id&quot;],&quot;&#39;\r\n[[&quot;b&quot;,0,&quot;id&quot;],&quot;7&quot;]\r\n[[&quot;b&quot;,0,&quot;bax&quot;,&quot;id&quot;],&quot;12&quot;]\r\n```",
        "link": "https://stackoverflow.com/questions/68109003/output-paths-to-all-keys-named-id-where-the-type-of-value-is-string",
        "title": "Output paths to all keys named &quot;id&quot; where the type of value is &quot;string&quot;"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1624541762,
                "creation_date": 1624541762,
                "answer_id": 68116853,
                "question_id": 68111789,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "This is because you produce the JSON object line by line in a bash read loop. I think the fastest way to achieve your goal is dealing with the output file (`variables_projects.json`).\r\n\r\n```\r\njq -s . variables_projects.json | sponge variables_projects.json\r\n```\r\n\r\nOutput\r\n```\r\n[\r\n  {\r\n    &quot;id&quot;: &quot;200&quot;,\r\n    &quot;project_name&quot;: &quot;spring-boot-remove&quot;,\r\n    &quot;project_path&quot;: &quot;agpm / templates / ansible / spring-boot-remove&quot;,\r\n    &quot;project_variables&quot;: &quot;[]&quot;\r\n  },\r\n  {\r\n    &quot;id&quot;: &quot;199&quot;,\r\n    &quot;project_name&quot;: &quot;agpm-gitleaks&quot;,\r\n    &quot;project_path&quot;: &quot;DevSecOps / agpm-gitleaks&quot;,\r\n    &quot;project_variables&quot;: &quot;[]&quot;\r\n  },\r\n  {\r\n    &quot;id&quot;: &quot;198&quot;,\r\n    &quot;project_name&quot;: &quot;haproxy&quot;,\r\n    &quot;project_path&quot;: &quot;Infra / Projets / nexo / haproxy&quot;,\r\n    &quot;project_variables&quot;: &quot;[]&quot;\r\n  }\r\n]\r\n```\r\n\r\nFor a compact output, add the `-c` option:\r\n```\r\njq -cs . variables_projects.json | sponge variables_projects.json\r\n```\r\n\r\nOutput:\r\n```\r\n[{&quot;id&quot;:&quot;200&quot;,&quot;project_name&quot;:&quot;spring-boot-remove&quot;,&quot;project_path&quot;:&quot;agpm / templates / ansible / spring-boot-remove&quot;,&quot;project_variables&quot;:&quot;[]&quot;},{&quot;id&quot;:&quot;199&quot;,&quot;project_name&quot;:&quot;agpm-gitleaks&quot;,&quot;project_path&quot;:&quot;DevSecOps / agpm-gitleaks&quot;,&quot;project_variables&quot;:&quot;[]&quot;},{&quot;id&quot;:&quot;198&quot;,&quot;project_name&quot;:&quot;haproxy&quot;,&quot;project_path&quot;:&quot;Infra / Projets / nexo / haproxy&quot;,&quot;project_variables&quot;:&quot;[]&quot;}]\r\n```\r\n\r\nFrom the doc:\r\n\r\n&gt;     --slurp/-s:\r\n&gt;           Instead  of running the filter for each JSON object in the input, read the entire input stream into a large array and run the filter just once.\r\n&gt;     --compact-output / -c:\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.",
                "title": "Build a json in bash with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1624542134,
        "creation_date": 1624521681,
        "last_edit_date": 1624542134,
        "question_id": 68111789,
        "body_markdown": "I want to create a new json file from the variables which are fetched from another json. I am a beginner with jq.\r\n\r\n```\r\nwhile read -r id name name_with_namespace\r\ndo\r\n   echo &quot;$id : $name&quot;\r\n   vivariables=$(curl --progress-bar -X GET --header &quot;Content-Type: application/json&quot; --header &quot;Authorization: bearer ${token}&quot; &quot;$GitlabServerURL/api/v4/projects/$id/variables&quot;)\r\n   JSON_STRING=$( jq -n \\\r\n                  --arg id &quot;$id&quot; \\\r\n                  --arg project_name &quot;$name&quot; \\\r\n                  --arg project_path &quot;$name_with_namespace&quot; \\\r\n                  --arg project_variables &quot;$variables&quot; \\\r\n                  &#39;{id: $id, project_name: $project_name, project_path: $project_path, project_variables: $project_variables}&#39; )\r\n   echo $JSON_STRING &gt;&gt; variables_projects.json\r\ndone &lt; &lt;(jq -r &#39;.[] | &quot;\\(.id) \\(.name) \\(.name_with_namespace) &quot;&#39; &lt; projects.json)\r\n\r\n```\r\nExample of part of the data that I recover with my script : \r\n\r\n```\r\n{ &quot;id&quot;: &quot;200&quot;, &quot;project_name&quot;: &quot;spring-boot-remove&quot;, &quot;project_path&quot;: &quot;agpm / templates / ansible / spring-boot-remove&quot;, &quot;project_variables&quot;: &quot;[]&quot; }\r\n{ &quot;id&quot;: &quot;199&quot;, &quot;project_name&quot;: &quot;agpm-gitleaks&quot;, &quot;project_path&quot;: &quot;DevSecOps / agpm-gitleaks&quot;, &quot;project_variables&quot;: &quot;[]&quot; }\r\n{ &quot;id&quot;: &quot;198&quot;, &quot;project_name&quot;: &quot;haproxy&quot;, &quot;project_path&quot;: &quot;Infra / Projets / nexo / haproxy&quot;, &quot;project_variables&quot;: &quot;[]&quot; }\r\n\r\n```\r\nWhat I hope to get : \r\n\r\n```\r\n[{ &quot;id&quot;: &quot;200&quot;, &quot;project_name&quot;: &quot;spring-boot-remove&quot;, &quot;project_path&quot;: &quot;agpm / templates / ansible / spring-boot-remove&quot;, &quot;project_variables&quot;: &quot;[]&quot; },\r\n{ &quot;id&quot;: &quot;199&quot;, &quot;project_name&quot;: &quot;agpm-gitleaks&quot;, &quot;project_path&quot;: &quot;DevSecOps / agpm-gitleaks&quot;, &quot;project_variables&quot;: &quot;[]&quot; },\r\n{ &quot;id&quot;: &quot;198&quot;, &quot;project_name&quot;: &quot;haproxy&quot;, &quot;project_path&quot;: &quot;Infra / Projets / nexo / haproxy&quot;, &quot;project_variables&quot;: &quot;[]&quot; }]\r\n```",
        "link": "https://stackoverflow.com/questions/68111789/build-a-json-in-bash-with-jq",
        "title": "Build a json in bash with jq"
    },
    {
        "tags": [
            "json",
            "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": 0,
                "creation_date": 1624528580,
                "post_id": 68112580,
                "comment_id": 120385965,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 9368912,
                    "reputation": 47,
                    "user_id": 7355559,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f4aa6accf987e6c7e05690bb29b23e15?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Sanchu Varkey",
                    "link": "https://stackoverflow.com/users/7355559/sanchu-varkey"
                },
                "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": 1624528655,
                "post_id": 68112580,
                "comment_id": 120385994,
                "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": 1624530000,
                "post_id": 68112580,
                "comment_id": 120386555,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 9368912,
                    "reputation": 47,
                    "user_id": 7355559,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f4aa6accf987e6c7e05690bb29b23e15?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Sanchu Varkey",
                    "link": "https://stackoverflow.com/users/7355559/sanchu-varkey"
                },
                "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": 1624530006,
                "post_id": 68112580,
                "comment_id": 120386557,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 9368912,
                    "reputation": 47,
                    "user_id": 7355559,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f4aa6accf987e6c7e05690bb29b23e15?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Sanchu Varkey",
                    "link": "https://stackoverflow.com/users/7355559/sanchu-varkey"
                },
                "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": 1624530059,
                "post_id": 68112580,
                "comment_id": 120386590,
                "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": 1624530953,
                "post_id": 68112580,
                "comment_id": 120386934,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 9368912,
                    "reputation": 47,
                    "user_id": 7355559,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f4aa6accf987e6c7e05690bb29b23e15?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Sanchu Varkey",
                    "link": "https://stackoverflow.com/users/7355559/sanchu-varkey"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1624603315,
                "post_id": 68112580,
                "comment_id": 120408140,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1624532628,
                "last_edit_date": 1624532628,
                "creation_date": 1624529244,
                "answer_id": 68113709,
                "question_id": 68112580,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here is one way:\r\n```\r\n. as [$V, $K]\r\n| reduce ($K | keys_unsorted)[] as $k ({};\r\n  . + {($K[$k]): $V[$k]}\r\n)\r\n```\r\nThis iterates over the second object&#39;s keys, retrieves values associated with each key in both objects, and pairs them in a new one. And can be adapted for your second example by changing\r\n```\r\n. as [$V, $K]\r\n```\r\nto\r\n```\r\n. as {data: $V, metadata: {annotations: $K}}\r\n```\r\n \r\n&lt;sup&gt;[Online demo](https://jqplay.org/s/e-DZOWmrTj)&lt;/sup&gt;",
                "title": "JQ combine array of json maps based on keys"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1624609203,
                "last_edit_date": 1624609203,
                "creation_date": 1624569373,
                "answer_id": 68122829,
                "question_id": 68112580,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s a reduce-free solution to the first problem that hopefully also elucidates the general approach:\r\n```\r\n.[0] as $dict\r\n| .[1]\r\n| with_entries( {value: $dict[.key], key: (.value|tostring) } )\r\n```\r\n\r\n## Solution to second problem\r\nUsing the above approach, we have only to tweak the first two lines:\r\n```\r\n.data as $dict\r\n| .metadata.annotations\r\n| with_entries( {value: $dict[.key], key: (.value|tostring) } )\r\n```",
                "title": "JQ combine array of json maps based on keys"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 2,
        "last_activity_date": 1624609203,
        "creation_date": 1624524826,
        "last_edit_date": 1624559008,
        "question_id": 68112580,
        "body_markdown": "My json looks like the following \r\n```\r\n[\r\n  {\r\n    &quot;100&quot;: &quot;ONE&quot;,\r\n    &quot;200&quot;: &quot;TWO&quot;\r\n  },\r\n  {\r\n    &quot;100&quot;: &quot;1&quot;,\r\n    &quot;200&quot;: &quot;2&quot;\r\n  }\r\n]\r\n```\r\n\r\nand I am expecting the following output\r\n\r\n```\r\n{\r\n  &quot;1&quot;: &quot;ONE&quot;,\r\n  &quot;2&quot;: &quot;TWO&quot;\r\n} \r\n```\r\n\r\nI found few answers here but all have static keys but in my case keys are dynamic\r\n\r\nAnother example\r\n```\r\n{\r\n  &quot;apiVersion&quot;: &quot;v1&quot;,\r\n  &quot;data&quot;: {\r\n    &quot;bac6f56f-101c-26da-edfa-c08e6622a337&quot;: &quot;1&quot;\r\n  },\r\n  &quot;kind&quot;: &quot;ConfigMap&quot;,\r\n  &quot;metadata&quot;: {\r\n    &quot;annotations&quot;: {\r\n      &quot;bac6f56f-101c-26da-edfa-c08e6622a337&quot;: &quot;restart&quot;\r\n    },\r\n    &quot;creationTimestamp&quot;: &quot;2020-06-25T14:53:06Z&quot;,\r\n    &quot;uid&quot;: &quot;7b1dfc3a-1357-400e-b750-a1ff98a204b9&quot;\r\n  }\r\n} \r\n```\r\n\r\nand the expected output is \r\n\r\n```\r\n{&quot;restart&quot;:&quot;1&quot;}\r\n```",
        "link": "https://stackoverflow.com/questions/68112580/jq-combine-array-of-json-maps-based-on-keys",
        "title": "JQ combine array of json maps based on keys"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1624560252,
                "post_id": 68121082,
                "comment_id": 120399254,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1624560281,
                "post_id": 68121082,
                "comment_id": 120399263,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1624560372,
                "post_id": 68121082,
                "comment_id": 120399298,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 43,
                "is_accepted": false,
                "score": 43,
                "last_activity_date": 1624561456,
                "last_edit_date": 1624561456,
                "creation_date": 1624560424,
                "answer_id": 68121251,
                "question_id": 68121082,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "    echo &quot;$REPOS&quot; | jq &#39;.[].repositoryName&#39; | while read -r repo; do echo &quot;do something with $repo&quot;; done\r\nOutput:\r\n&lt;pre&gt;\r\ndo something with &quot;repo_a&quot;\r\ndo something with &quot;repo_b&quot;\r\ndo something with &quot;repo_c&quot;\r\ndo something with &quot;repo_d&quot;\r\n&lt;/pre&gt;\r\n\r\nOr without quotes:\r\n\r\n    echo &quot;$REPOS&quot; | jq -r &#39;.[].repositoryName&#39; | while read -r repo; do echo &quot;do something with $repo&quot;; done\r\nOutput:\r\n&lt;pre&gt;\r\ndo something with repo_a\r\ndo something with repo_b\r\ndo something with repo_c\r\ndo something with repo_d\r\n&lt;/pre&gt;",
                "title": "How to iterate over JSON array with jq?"
            },
            {
                "up_vote_count": 7,
                "is_accepted": false,
                "score": 7,
                "last_activity_date": 1733526688,
                "last_edit_date": 1733526688,
                "creation_date": 1624561454,
                "answer_id": 68121470,
                "question_id": 68121082,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I found the problem..... this command:\r\n\r\n``` \r\nREPOS=$(aws codecommit list-repositories)\r\n```\r\n\r\nReturns a json like this:\r\n``` \r\n{\r\n  &quot;repositories&quot;: [\r\n  {\r\n    &quot;repositoryName&quot;: &quot;repo_a&quot;,\r\n    &quot;repositoryId&quot;: &quot;XXXXXX&quot;\r\n  },\r\n  {\r\n    &quot;repositoryName&quot;: &quot;repo_b&quot;,\r\n    &quot;repositoryId&quot;: &quot;XXXXXX&quot;\r\n  },\r\n  {\r\n    &quot;repositoryName&quot;: &quot;repo_c&quot;,\r\n    &quot;repositoryId&quot;: &quot;XXXXXX&quot;\r\n  },\r\n  {\r\n    &quot;repositoryName&quot;: &quot;repo_d&quot;,\r\n    &quot;repositoryId&quot;: &quot;XXXXXX&quot;\r\n  }\r\n]\r\n}\r\n``` \r\n\r\nI wasn&#39;t considering the &#39;repositories&#39; field in jq.....\r\n\r\nThis script works fine now:\r\n\r\n``` \r\nREPOS=$(aws codecommit list-repositories)\r\n\r\necho $REPOS | jq -r &#39;.repositories[].repositoryName&#39; | while read name ; do\r\n    git clone ssh://git-codecommit.us-east-1.amazonaws.com/v1/repos/$name\r\ndone\r\n``` \r\n\r\nThank you for support.\r\nHave a good day :)\r\n\r\n\r\n\r\n",
                "title": "How to iterate over JSON array with jq?"
            },
            {
                "up_vote_count": 15,
                "is_accepted": false,
                "score": 15,
                "last_activity_date": 1686603639,
                "creation_date": 1686603639,
                "answer_id": 76460303,
                "question_id": 68121082,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If you want to iterate over JSON values instead of a single field value, you can use the `-c` option so you end up with one JSON element per line:\r\n```\r\nrepositories=&#39;{\r\n  &quot;repositories&quot;: [\r\n  {\r\n    &quot;repositoryName&quot;: &quot;repo_a&quot;,\r\n    &quot;repositoryId&quot;: &quot;XXXXXX&quot;\r\n  },\r\n  {\r\n    &quot;repositoryName&quot;: &quot;repo_b&quot;,\r\n    &quot;repositoryId&quot;: &quot;XXXXXX&quot;\r\n  },\r\n  {\r\n    &quot;repositoryName&quot;: &quot;repo_c&quot;,\r\n    &quot;repositoryId&quot;: &quot;XXXXXX&quot;\r\n  },\r\n  {\r\n    &quot;repositoryName&quot;: &quot;repo_d&quot;,\r\n    &quot;repositoryId&quot;: &quot;XXXXXX&quot;\r\n  }\r\n]\r\n}&#39;\r\n```\r\n\r\n```bash\r\nwhile read repository\r\ndo\r\n  name=$(echo &quot;$repository&quot; | jq -r .repositoryName)\r\n  id=$(echo &quot;$repository&quot; | jq -r .repositoryId)\r\n\r\n  echo &quot;${id}=${name}&quot;\r\ndone &lt; &lt;(echo &quot;$repositories&quot; | jq -c &#39;.repositories[]&#39;)\r\n```",
                "title": "How to iterate over JSON array with jq?"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1695136878,
                "creation_date": 1695136878,
                "answer_id": 77135895,
                "question_id": 68121082,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If you don&#39;t want to convert to scalar values:\r\n\r\n```\r\n#!/bin/bash\r\n\r\nD=&#39;[\r\n{ &quot;name&quot;: &quot;first&quot;, &quot;is_disabled&quot;: false, &quot;scheme&quot;: &quot;https&quot;, &quot;value&quot;: 30 },\r\n{ &quot;name&quot;: &quot;second&quot;, &quot;is_disabled&quot;: true, &quot;scheme&quot;: &quot;https&quot;, &quot;value&quot;: 118 },\r\n{ &quot;name&quot;: &quot;third&quot;, &quot;is_disabled&quot;: false, &quot;scheme&quot;: &quot;https&quot;, &quot;value&quot;: 93 }\r\n]&#39;\r\n\r\nLEN=$( echo &quot;$D&quot; | jq &#39;. | length&#39; )\r\n\r\necho &quot;got $LEN elements&quot;\r\nfor (( i=0; i&lt;$LEN; i++ )) ; do\r\n        echo &quot;Element $i:&quot;\r\n        echo &quot;$D&quot; | jq &quot;.[$i]&quot;\r\ndone\r\n```\r\nBut it&#39;s not very efficient.\r\n\r\nA quick google turned up [this solution][1]:\r\n```\r\nsample=&#39;[{&quot;name&quot;:&quot;foo&quot;},{&quot;name&quot;:&quot;bar&quot;}]&#39;\r\nfor row in $(echo &quot;${sample}&quot; | jq -r &#39;.[] | @base64&#39;); do\r\n    _jq() {\r\n     echo ${row} | base64 --decode | jq -r ${1}\r\n    }\r\n   echo $(_jq &#39;.&#39;)\r\ndone\r\n```\r\n\r\n\r\n  [1]: https://www.starkandwayne.com/blog/bash-for-loop-over-json-array-using-jq/index.html",
                "title": "How to iterate over JSON array with jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 4,
        "score": 39,
        "last_activity_date": 1733526688,
        "creation_date": 1624559559,
        "last_edit_date": 1733526665,
        "question_id": 68121082,
        "body_markdown": "I&#39;m building a script to download all CodeCommit repositories at once.\r\n\r\n```bash\r\nREPOS=$(aws codecommit list-repositories)\r\n\r\necho $REPOS | jq -r &#39;.[]&#39; | while read name ; do\r\n    git clone XXX\r\ndone\r\n```\r\n\r\nIn first line I get all repos JSON like this:\r\n\r\n```json\r\n[\r\n  {\r\n    &quot;repositoryName&quot;: &quot;repo_a&quot;,\r\n    &quot;repositoryId&quot;: &quot;XXXXXX&quot;\r\n  },\r\n  {\r\n    &quot;repositoryName&quot;: &quot;repo_b&quot;,\r\n    &quot;repositoryId&quot;: &quot;XXXXXX&quot;\r\n  },\r\n  {\r\n    &quot;repositoryName&quot;: &quot;repo_c&quot;,\r\n    &quot;repositoryId&quot;: &quot;XXXXXX&quot;\r\n  },\r\n  {\r\n    &quot;repositoryName&quot;: &quot;repo_d&quot;,\r\n    &quot;repositoryId&quot;: &quot;XXXXXX&quot;\r\n  }\r\n]\r\n```\r\n\r\nI need simple iterate this json, to get attributes repositoryName and execute git clone for each repository.\r\n\r\nBut in this example the command `jq -r &#39;.[]&#39;` don&#39;t works.... This return the entire json on each repeat.",
        "link": "https://stackoverflow.com/questions/68121082/how-to-iterate-over-json-array-with-jq",
        "title": "How to iterate over JSON array with jq?"
    },
    {
        "tags": [
            "bash",
            "macos",
            "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": 1624639824,
                "post_id": 68134398,
                "comment_id": 120422613,
                "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": 1624639840,
                "post_id": 68134398,
                "comment_id": 120422621,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": -1,
                "last_activity_date": 1624639601,
                "creation_date": 1624639601,
                "answer_id": 68134537,
                "question_id": 68134398,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I found a workaround, I don&#39;t like it but it does the job:\r\n```\r\nregion=us-west-2\r\njq &quot;.regions.\\&quot;$region\\&quot;&#39; ids.json \r\n```",
                "title": "jq search with args returns null, works fine with hard coded string"
            },
            {
                "up_vote_count": 8,
                "is_accepted": true,
                "score": 8,
                "last_activity_date": 1624639788,
                "creation_date": 1624639788,
                "answer_id": 68134582,
                "question_id": 68134398,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Use the index notation instead of the dot notation:\r\n```bash\r\njq --arg region &quot;us-east-1&quot; &#39;.regions[$region]&#39; ids.json\r\n```",
                "title": "jq search with args returns null, works fine with hard coded string"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1624639788,
        "creation_date": 1624638970,
        "question_id": 68134398,
        "body_markdown": "I have a line to get the variable from a json using jq which works fine when I use a string that&#39;s hard coded but when I pass in an `--arg` then it returns null\r\n\r\nThe working code which outputs the value at the specified key\r\n```\r\njq &#39;.regions.&quot;us-west-2&quot;&#39; ids.json \r\n```\r\n\r\nThe code that&#39;s outputting `null`\r\n```\r\njq --arg region &quot;us-east-1&quot; &#39;.regions.&quot;$region&quot;&#39; ids.json\r\n```\r\nAny help would be appreciated",
        "link": "https://stackoverflow.com/questions/68134398/jq-search-with-args-returns-null-works-fine-with-hard-coded-string",
        "title": "jq search with args returns null, works fine with hard coded string"
    },
    {
        "tags": [
            "windows",
            "batch-file",
            "jq",
            "overwrite",
            "io-redirection"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1624649000,
                "last_edit_date": 1624649000,
                "creation_date": 1624647483,
                "answer_id": 68135948,
                "question_id": 68135435,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Even if it works or seem to work, blindly overwriting an input file using output redirection is usually a bad idea, or worse.\r\n\r\nIn an environment in which the (well-known)\r\n[sponge][1]  utility is available, it can be used, but it looks like you might not have that luxury, so you might want to consider a more mundane approach using a temporary file.\r\n\r\nPowerShell users can use SetContent:\r\nhttps://learn.microsoft.com/en-us/powershell/module/microsoft.powershell.management/set-content?view=powershell-5.1\r\n\r\n\r\n  [1]: https://unix.stackexchange.com/questions/207919/sponge-from-moreutils-whats-the-difference-to-shell-redirect-useful-examples",
                "title": "Output Redirection produces empty file ONLY with jq"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1624651903,
                "creation_date": 1624651903,
                "answer_id": 68136589,
                "question_id": 68135435,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can&#39;t overwrite the file you are reading from, because the first action will be the (re)creation of the file by the redirection, then `jq` will read from an empty file.\r\n\r\nJust redirect to a temporary file and replace the original file after finishing.",
                "title": "Output Redirection produces empty file ONLY with jq"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1662564869,
                "creation_date": 1662564869,
                "answer_id": 73638177,
                "question_id": 68135435,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The `jq` repo has a FAQ about this, [here](https://github.com/stedolan/jq/wiki/FAQ), under\r\n\r\n&gt; &#119928;: How can &quot;in-place&quot; editing of a JSON file be accomplished?\r\n\r\nThis says\r\n\r\n&gt; ...using tee or output redirection (&gt;) to overwrite the input file is not recommended, even if it seems to work.\r\n\r\nOne easy fix suggested there is using `sponge` from [`moreutils`](https://joeyh.name/code/moreutils/). On macOS, one could do\r\n```\r\n$ brew install jq sponge\r\n```\r\n`apt` and `npm` can be used similarly.\r\n\r\nWith `sponge`, an in-place format of a json file would be\r\n```\r\n$ jq . my.json | sponge my.json\r\n```\r\n",
                "title": "Output Redirection produces empty file ONLY with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 3,
        "last_activity_date": 1662564869,
        "creation_date": 1624644502,
        "last_edit_date": 1624665523,
        "question_id": 68135435,
        "body_markdown": "I&#39;m having an interesting issue. I&#39;m using jq to minify JSON from a batch script, and I want it to replace the file it reads from. While there is probably a better solution, this, while it *should* work on paper, it does ***not*** work in practice.\r\n\r\n### Works:\r\n```\r\nfor /R %%f in (*.json) do (\r\n    ECHO Minifying JSON file &quot;%%f&quot;\r\n    (ECHO Hello) 1&gt; &quot;%%f&quot;\r\n)\r\n```\r\n**Output Files:**\r\n```\r\nHello\r\n\r\n```\r\n\r\n---\r\n### Shows that the redirect works\r\n```\r\nfor /R %%f in (*.json) do (\r\n    ECHO Minifying JSON file &quot;%%f&quot;\r\n    (&quot;path\\to\\jq&quot; . --unbuffered --compact-output &quot;%%f&quot; &amp;&amp; ECHO Hello) 1&gt; &quot;%%f&quot;\r\n)\r\n```\r\n**Output Files:**\r\n```\r\nHello\r\n\r\n```\r\n\r\n---\r\n### Shows that jq produces output\r\n```\r\nfor /R %%f in (*.json) do (\r\n    ECHO Minifying JSON file &quot;%%f&quot;\r\n    &quot;path\\to\\jq&quot; . --unbuffered --compact-output &quot;%%f&quot;\r\n)\r\n```\r\n**Output in CMD Window:** Contents of each JSON file, minified (just like I want it)\r\n\r\n---\r\n### What I&#39;m *trying* to do\r\n```\r\nfor /R %%f in (*.json) do (\r\n    ECHO Minifying JSON file &quot;%%f&quot;\r\n    (&quot;path\\to\\jq&quot; . --unbuffered --compact-output &quot;%%f&quot;) 1&gt; &quot;%%f&quot;\r\n)\r\n```\r\n**Output Files:**\r\n```\r\n```\r\nAs you can see, there is no JSON present, minified or otherwise.\r\n\r\n---\r\n# On the answer\r\n[@peak][1] gave [a workaround using PowerShell][2]. In my situation, I came out with the following:\r\n```\r\nfor /R %%f in (*.json) do (\r\n    ECHO Minifying JSON file &quot;%%f&quot;\r\n    powershell -Command &quot;&amp; {.\\..\\info\\jq . --unbuffered --compact-output \\&quot;%%f\\&quot;|Set-Content \\&quot;%%f\\&quot;}&quot;\r\n)\r\n```\r\nThis outputs the correct, minified JSON.\r\nWhat I&#39;m doing here is invoking PowerShell to handle the minification, and using the Set-Content cmdlet.\r\n\r\n\r\n  [1]: https://stackoverflow.com/users/997358/peak\r\n  [2]: https://stackoverflow.com/a/68135948/13076790",
        "link": "https://stackoverflow.com/questions/68135435/output-redirection-produces-empty-file-only-with-jq",
        "title": "Output Redirection produces empty file ONLY with jq"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 2339925,
                    "reputation": 16193,
                    "user_id": 2051454,
                    "user_type": "registered",
                    "accept_rate": 60,
                    "profile_image": "https://i.sstatic.net/sZBFW.jpg?s=256",
                    "display_name": "Software Engineer",
                    "link": "https://stackoverflow.com/users/2051454/software-engineer"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1624716294,
                "post_id": 68142795,
                "comment_id": 120436710,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 492726,
                    "reputation": 11,
                    "user_id": 14230017,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/684e0902c3ea701f4ad2271732d75e47?s=256&d=identicon&r=PG",
                    "display_name": "Sivaguru Nathan",
                    "link": "https://stackoverflow.com/users/14230017/sivaguru-nathan"
                },
                "reply_to_user": {
                    "account_id": 2339925,
                    "reputation": 16193,
                    "user_id": 2051454,
                    "user_type": "registered",
                    "accept_rate": 60,
                    "profile_image": "https://i.sstatic.net/sZBFW.jpg?s=256",
                    "display_name": "Software Engineer",
                    "link": "https://stackoverflow.com/users/2051454/software-engineer"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1624717082,
                "post_id": 68142795,
                "comment_id": 120436908,
                "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": 1624776898,
                "post_id": 68142795,
                "comment_id": 120446174,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1625085161,
                "creation_date": 1625085161,
                "answer_id": 68201303,
                "question_id": 68142795,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "After making your input json valid, I could correct your update statement for `slug` in `fromRef` and `toRef`:\r\n\r\n```bash \r\n#!/bin/bash\r\n\r\nJSON=&#39;\r\n{\r\n  &quot;title&quot;: &quot;test comment&quot;,\r\n  &quot;description&quot;: &quot;testing&quot;,\r\n  &quot;fromRef&quot;: {\r\n    &quot;id&quot;: &quot;refs/heads/testbranch&quot;,\r\n    &quot;repository&quot;: {\r\n      &quot;slug&quot;: &quot;dummyrepo1&quot;,\r\n      &quot;project&quot;: {\r\n        &quot;key&quot;: &quot;TEST&quot;\r\n      }\r\n    }\r\n  },\r\n  &quot;toRef&quot;: {\r\n    &quot;id&quot;: &quot;refs/heads/master&quot;,\r\n    &quot;repository&quot;: {\r\n      &quot;slug&quot;: &quot;dummyrepo1&quot;,\r\n      &quot;project&quot;: {\r\n        &quot;key&quot;: &quot;TEST&quot;\r\n      }\r\n    }\r\n  }\r\n}\r\n&#39;\r\n\r\njq --arg update_slug &#39;dummyrepo2&#39; &#39;\r\n  .fromRef.repository.slug |= $update_slug\r\n  | .toRef.repository.slug |= $update_slug\r\n&#39; &lt;&lt;&lt; &quot;$JSON&quot;\r\n``` \r\n\r\n## output\r\n```json\r\n{\r\n  &quot;title&quot;: &quot;test comment&quot;,\r\n  &quot;description&quot;: &quot;testing&quot;,\r\n  &quot;fromRef&quot;: {\r\n    &quot;id&quot;: &quot;refs/heads/testbranch&quot;,\r\n    &quot;repository&quot;: {\r\n      &quot;slug&quot;: &quot;dummyrepo2&quot;,\r\n      &quot;project&quot;: {\r\n        &quot;key&quot;: &quot;TEST&quot;\r\n      }\r\n    }\r\n  },\r\n  &quot;toRef&quot;: {\r\n    &quot;id&quot;: &quot;refs/heads/master&quot;,\r\n    &quot;repository&quot;: {\r\n      &quot;slug&quot;: &quot;dummyrepo2&quot;,\r\n      &quot;project&quot;: {\r\n        &quot;key&quot;: &quot;TEST&quot;\r\n      }\r\n    }\r\n  }\r\n}\r\n``` \r\n",
                "title": "issue in replacing multiple values using jq in json file"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": -1,
        "last_activity_date": 1625085161,
        "creation_date": 1624713762,
        "last_edit_date": 1624716275,
        "question_id": 68142795,
        "body_markdown": "\r\nAm trying to replace the slug entries in &quot;fromRef&quot; &amp; &quot;toRef&quot;  from dummyrepo1 to dummyrepo2 using the below code \r\n\r\n&lt;!-- begin snippet: js hide: false console: true babel: false --&gt;\r\n\r\n&lt;!-- language: bash --&gt;\r\n\r\n    #!/bin/bash\r\n    function template {\r\n       cat &lt;&lt; EOF \r\n    {\r\n      &quot;title&quot;: &quot;test comment&quot;\r\n      &quot;description: &quot;testing&quot;\r\n      &quot;fromRef&quot;: {\r\n         &quot;id&quot;: &quot;refs/heads/testbranch&quot;\r\n          &quot;repository&quot; : {\r\n            &quot;slug&quot;: &quot;dummyrepo1&quot;\r\n            &quot;project&quot;: {\r\n                 &quot;key&quot;: &quot;TEST&quot;\r\n              }\r\n             }\r\n          },\r\n       &quot;toRef&quot;:{\r\n          &quot;id&quot;: &quot;refs/heads/master&quot;\r\n           &quot;repository&quot; : {\r\n           &quot;slug&quot; : &quot;dummyrepo1&quot;\r\n           &quot;project&quot;: {\r\n                &quot;key&quot;: &quot;TEST&quot;\r\n             }\r\n           }\r\n         }\r\n    }\r\n    EOF\r\n    }\r\n\r\n    function modify_json() {\r\n       template | \r\n            jq --arg update_slug &quot;${1}&quot; \\\r\n            &#39;.fromRef.repository\r\n            |= (.slug |= $update_slug) |\r\n             .toRef.repository\r\n            |= (.slug |= $update_slug)\r\n            &#39;\r\n    }\r\n\r\n    updated_JSON=$modify_json dummyrepo2)\r\n    echo &quot;$updated_JSON&quot;\r\n\r\n\r\n\r\n&lt;!-- end snippet --&gt;\r\n\r\nAm expecting the output  as  \r\n\r\n    {\r\n          &quot;title&quot;: &quot;test comment&quot;\r\n          &quot;description: &quot;testing&quot;\r\n          &quot;fromRef&quot;: {\r\n             &quot;id&quot;: &quot;refs/heads/testbranch&quot;\r\n              &quot;repository&quot; : {\r\n                &quot;slug&quot;: &quot;dummyrepo2&quot;\r\n                &quot;project&quot;: {\r\n                     &quot;key&quot;: &quot;TEST&quot;\r\n                  }\r\n                 }\r\n              },\r\n           &quot;toRef&quot;:{\r\n              &quot;id&quot;: &quot;refs/heads/master&quot;\r\n               &quot;repository&quot; : {\r\n               &quot;slug&quot; : &quot;dummyrepo2&quot;\r\n               &quot;project&quot;: {\r\n                    &quot;key&quot;: &quot;TEST&quot;\r\n                 }\r\n               }\r\n             }\r\n        }\r\n\r\n\r\n\r\nBut getting output like this, may i know where am doing mistake \r\n\r\n\r\n    {\r\n              &quot;title&quot;: &quot;test comment&quot;\r\n              &quot;description: &quot;testing&quot;\r\n              &quot;fromRef&quot;: {\r\n                 &quot;id&quot;: &quot;refs/heads/testbranch&quot;\r\n                  &quot;repository&quot; : {\r\n                    &quot;slug&quot;: &quot;dummyrepo2&quot;\r\n                    &quot;project&quot;: {\r\n                         &quot;key&quot;: &quot;TEST&quot;\r\n                      }\r\n                     }\r\n                  },\r\n               &quot;toRef&quot;:{\r\n                  &quot;id&quot;: &quot;refs/heads/master&quot;\r\n                   &quot;repository&quot; : {\r\n                   &quot;slug&quot; : &quot;dummyrepo1&quot;\r\n                   &quot;project&quot;: {\r\n                        &quot;key&quot;: &quot;TEST&quot;\r\n                     }\r\n                   }\r\n                 },\r\n                &quot;toRef&quot;:{\r\n                   &quot;repository&quot; : {\r\n                   &quot;slug&quot; : &quot;dummyrepo2&quot;\r\n                   }\r\n                }\r\n             }\r\n\r\n\r\nMeans, instead of replacing the &quot;dummyrepo2&quot; in toRef  the script is amending the newentry in the output ",
        "link": "https://stackoverflow.com/questions/68142795/issue-in-replacing-multiple-values-using-jq-in-json-file",
        "title": "issue in replacing multiple values using jq in json file"
    },
    {
        "tags": [
            "sql",
            "json",
            "postgresql",
            "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": 1624781731,
                "post_id": 68146903,
                "comment_id": 120447038,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "user_type": "does_not_exist",
                    "display_name": "user330315"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1624785789,
                "post_id": 68146903,
                "comment_id": 120447771,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "user_type": "does_not_exist",
                    "display_name": "user330315"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1624786049,
                "post_id": 68146903,
                "comment_id": 120447821,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 20537601,
                    "reputation": 118,
                    "user_id": 15898550,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/fee8a2a52de3989a3aa77e27feab3514?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "jenszo",
                    "link": "https://stackoverflow.com/users/15898550/jenszo"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1624787901,
                "post_id": 68146903,
                "comment_id": 120448195,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1624787383,
                "last_edit_date": 1624787383,
                "creation_date": 1624749308,
                "answer_id": 68146904,
                "question_id": 68146903,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "*I&#39;m going to answer my own question here with what I&#39;ve learned from people on #jq on LiberaChat since I think it might be well worth documenting for a broader audience.*\r\n\r\n\r\n**Solution**\r\n\r\nEssentially, I&#39;ve found two solutions. \r\n\r\nThe first &quot;elegant&quot; one incorporates a two-fold `join`. This will work with a smaller amount of data but performance will take a hit due to it&#39;s non-linear, two-pass join. 500.000 events take several minutes.\r\n\r\nThe second one results in linear, almost sequential processing but is a lot less jq-like. 500.000 events take a couple of seconds on my machine.\r\n\r\na) The elegant way\r\n\r\n```\r\njq -r &#39;\r\n(&quot;INSERT INTO events (date,node,sensor,prop1,prop2,prop3,prop4) VALUES &quot;),\r\n([ &quot;(\\(.date as $date | .events[] | [.node, .sensor] as $d | .intervals[] | [$date, $d[], values[]] | join(&quot;,&quot;)))&quot;] | join(&quot;,\\n&quot;)),\r\n(&quot;ON CONFLICT DO NOTHING;&quot;)\r\n&#39;\r\n```\r\n\r\nwith the `jq` result as:\r\n```\r\nINSERT INTO events (date,node,sensor,prop1,prop2,prop3,prop4) VALUES \r\n(2020-09-10,4170,1,0,-1,0,0),\r\n(2020-09-10,4170,1,0,-1,300,0),\r\n(2020-09-10,8888,2,0,-1,0,0)\r\nON CONFLICT DO NOTHING;\r\n```\r\n\r\nJQ Play: https://jqplay.org/s/oU8mZUHHTm\r\n\r\nb) The sequential but less elegant way\r\n\r\n```\r\njq -r &#39;\r\n(&quot;INSERT INTO events (date,node,sensor,prop1,prop2,prop3,prop4) VALUES &quot;),\r\n([.date as $date | .events[] | [.node, .sensor] as $d | .intervals[] | [ $date, $d[], values[] ]] | ( .[:-1][] | &quot;(&quot; + join(&quot;,&quot;) + &quot;),&quot;), (last | &quot;(&quot; + join(&quot;,&quot;) + &quot;)&quot;)),\r\n(&quot;ON CONFLICT DO NOTHING;&quot;)\r\n&#39;\r\n```\r\nJQ Play: https://jqplay.org/s/pkVxWbBwC3\r\n\r\nBoth suggested solutions go the long way to avoid the excessive `,` at the end of the values list for SQL.\r\n\r\nWhy `jq`? \r\n- It is written in C yielding a very small footprint while offering quite advanced and well proven capabilities for filtering and restructuring JSON\r\n- It works stream based, so I&#39;m expecting mostly sequential reads and writes (?)\r\n- The output can be adapted to the RDMS used and the application itself which makes this fairly portable\r\n\r\n[JQ Github Page](https://github.com/stedolan/jq)\r\n\r\n**Alternative Solutions (Discussion)**\r\n\r\n1) If the RDMS supports JSON natively (e.g. PostgreSQL) import directly.\r\n\r\nVariations of this approach are described here on SO: (https://stackoverflow.com/questions/39224382/how-can-i-import-a-json-file-into-postgresql)\r\n\r\nWhile Postgres&#39; JSON parser is arguably well proven and quite efficient, this approach is not suitable for millions of rows at a time imho. Without having conducted performance experiments, I&#39;d argue that this might perform a little less efficient as the JSON BLOB is not indexed and the postgres query planner will end up performing random seeks thereon (I may be wrong) and there is an additional copy involved.\r\n\r\n2) Create CSV from JSON and COPY into RDBMS\r\n\r\nMost likely this already involves `jq` to create the CSV file. Maybe Python&#39;s `pandas` module is of any help here. \r\n\r\nWhile this adds another layer of conversion to the matter, importing the CSV into the RDBMs is blazingly fast as it is merely a raw `COPY` of the rows with the index built on the fly. This may be good choice, yet, as opposed to the previous approaches, a `COPY` does not honour any TRIGGER that would act only on INSERTS/UPDATE if configured for an existing table.\r\n\r\nIf you were to filter out duplicates in a time series during import using `... ON CONFLICT DO NOTHING`, this is not supported by `COPY` without an intermediate copy of the dataset: https://stackoverflow.com/questions/48019381/how-postgresql-copy-to-stdin-with-csv-do-on-conflic-do-update ",
                "title": "Importing multi level JSON arrays into RDMS by using jq to create SQL INSERT statements"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1624787788,
        "creation_date": 1624749308,
        "last_edit_date": 1624787788,
        "question_id": 68146903,
        "body_markdown": "**Problem**\r\n\r\nI am looking at a some 2-5 million events of a time series, batch-queried daily from a REST API to feed into rows of a PostgreSQL database. I use a RDMS because I want to have the time series pre-structured for faster analysis and exploration later on and he input schema does not change, really. So Cassandra or MongoDB are not an option although they would happily accept JSON as is.\r\n\r\nThe database is running on a cloud infrastructure. PostgreSQL is accessible through the network. Maybe the database itself residing on a network-attached file system, so I/O is suffering from the respective latency and limited bandwidth. \r\n\r\nAlso, if running the crawler/importer as a serverless function, any solution on top of the JVM or python has a significant overhead.\r\n\r\n**Objective**\r\n\r\nAs the task itself is rather simple and linear, I was looking for a very small footprint solution - at best without the dependency of any runtime or interpreter in the first place.\r\n\r\nSo building on a small bash script cascading `httpie` / `curl`, `jq` and the native `psql` client like so sound promising:\r\n\r\n```\r\n#!/bin/bash\r\n\r\nDATE=`date +%Y-%m-%d`\r\n\r\nhttp POST https://example.net/my/api/v2 date=$DATE | \\\r\njq -r &#39;&lt;jq json filter&gt;&#39; | \\\r\npsql -U myuser -d mydb`\r\n```\r\n\r\n**Question**\r\n\r\nTo do just that, how to convert a multi-level JSON including arrays to a prepared SQL STATEMENT using just `jq`?\r\n\r\nExpected SQL statement:\r\n\r\n```\r\nINSERT INTO events (date,node,sensor,prop1,prop2,prop3,prop4) VALUES \r\n(2020-09-10,4170,1,0,-1,0,0),\r\n(2020-09-10,4170,1,0,-1,300,0),\r\n....\r\n(2020-09-10,8888,2,0,-1,0,0)\r\n```\r\n\r\nJSON input:\r\n\r\n```\r\n{\r\n  &quot;date&quot;: &quot;2020-09-10&quot;,\r\n  &quot;events&quot;: [\r\n    {\r\n      &quot;sensor&quot;: 1,\r\n      &quot;intervals&quot;: [\r\n        {\r\n          &quot;prop1&quot;: 0,\r\n          &quot;prop2&quot;: -1,\r\n          &quot;prop3&quot;: 0,\r\n          &quot;prop4&quot;: 0\r\n        },\r\n        {\r\n          &quot;prop1&quot;: 0,\r\n          &quot;prop2&quot;: -1,\r\n          &quot;prop3&quot;: 300,\r\n          &quot;prop4&quot;: 0\r\n        }],\r\n      &quot;node&quot;: 4170\r\n    },\r\n    {\r\n      &quot;sensor&quot;: 2,\r\n      &quot;intervals&quot;: [\r\n        {\r\n          &quot;prop1&quot;: 0,\r\n          &quot;prop2&quot;: -1,\r\n          &quot;prop3&quot;: 0,\r\n          &quot;prop4&quot;: 0\r\n        }],\r\n      &quot;node&quot;: 8888\r\n    }]\r\n}\r\n```\r\n\r\n",
        "link": "https://stackoverflow.com/questions/68146903/importing-multi-level-json-arrays-into-rdms-by-using-jq-to-create-sql-insert-sta",
        "title": "Importing multi level JSON arrays into RDMS by using jq to create SQL INSERT statements"
    },
    {
        "tags": [
            "bash",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1624805968,
                "creation_date": 1624805968,
                "answer_id": 68152408,
                "question_id": 68147007,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "&gt;     jq -C &#39;(.Channels[] | select(.name==&quot;TFX&quot;).category=&quot;test&quot;)&#39;\r\n\r\nYou were so close - just one misplaced parenthesis:\r\n\r\n    jq &#39;(.Channels[] | select(.name==&quot;TFX&quot;)) .category=&quot;test&quot;&#39;",
                "title": "jq and Bash: How to get value of key from value of object? (How to build/update a json?)"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1624810554,
        "creation_date": 1624751053,
        "last_edit_date": 1624810554,
        "question_id": 68147007,
        "body_markdown": "First of all, sorry for my English, I&#39;m French.\r\n\r\nI&#39;m working on a script, which retrieves tags and links from M3U files to store them into variables.\r\nM3U:\r\n\r\n    #EXTM3U\r\n    #EXTINF:-1 tvg-id=&quot;TFX.fr&quot; tvg-name=&quot;TFX&quot; tvg-country=&quot;FR;AD;BE;LU;MC;CH&quot; tvg-language=&quot;French&quot; tvg-logo=&quot;http://www.exemple.com/image.jpg&quot; group-title=&quot;&quot;,TFX (720p)\r\n    https://tfx-hls-live-ssl.tf1.fr/tfx/1/hls/live_2328.m3u8\r\n\r\n\r\nscript:\r\n\r\n    #!/bin/bash\r\n    \r\n    tags=&#39;#EXTINF:-1 tvg-id=&quot;TFX.fr&quot; tvg-name=&quot;TFX&quot; tvg-country=&quot;FR;AD;BE;LU;MC;CH&quot; tvg-language=&quot;French&quot; tvg-logo=&quot;http://www.exemple.com/image.jpg&quot; group-title=&quot;Fiction&quot;,TFX (720p)&#39;\r\n    \r\n    get_chno=&quot;$(echo &quot;$tags&quot; | grep -o &#39;tvg-chno=&quot;[^&quot;]*&#39; | cut -d &#39;&quot;&#39;  -f2)&quot;\r\n    get_id=&quot;$(echo &quot;$tags&quot; | grep -o &#39;tvg-id=&quot;[^&quot;]*&#39; | cut -d &#39;&quot;&#39;  -f2)&quot;\r\n    get_logo=&quot;$(echo &quot;$tags&quot; | grep -o &#39;tvg-logo=&quot;[^&quot;]*&#39; | cut -d &#39;&quot;&#39;  -f2)&quot;\r\n    get_grp_title=&quot;$(echo &quot;$tags&quot; | grep -o &#39;group-title=&quot;[^&quot;]*&#39; | cut -d &#39;&quot;&#39;  -f2)&quot;\r\n    get_title=&quot;$(echo &quot;$tags&quot; | grep -o &#39;,[^*]*&#39; | cut -d &#39;,&#39;  -f2)&quot;\r\n    get_name=&quot;$(echo &quot;$tags&quot; | grep -o &#39;tvg-name=&quot;[^&quot;]*&#39; | cut -d &#39;&quot;&#39;  -f2)&quot;\r\n    get_country=&quot;$(echo &quot;$tags&quot; | grep -o &#39;tvg-country=&quot;[^&quot;]*&#39; | cut -d &#39;&quot;&#39;  -f2)&quot;\r\n    get_language=&quot;$(echo &quot;$tags&quot; | grep -o &#39;tvg-language=&quot;[^&quot;]*&#39; | cut -d &#39;&quot;&#39;  -f2)&quot;\r\n    \r\n    echo -e &quot;chno:\\n $get_chno&quot;\r\n    echo -e &quot;id:\\n $get_id&quot;\r\n    echo -e &quot;logo:\\n $get_logo&quot;\r\n    echo -e &quot;grp 1:\\n $get_grp_title&quot;\r\n    echo -e &quot;title:\\n $get_title&quot;\r\n    echo -e &quot;name:\\n $get_name&quot;\r\n    echo -e &quot;country:\\n $get_country&quot;\r\n    echo -e &quot;lang:\\n $get_language&quot;\r\n\r\nI would like to store these variables in a json file.\r\nThis json will be used to rebuild another playlist.\r\n\r\n        #EXTM3U\r\n        #EXTINF:-1 tvg-id=&quot;TFX.fr&quot; tvg-name=&quot;TFX&quot; tvg-country=&quot;FR;AD;BE;LU;MC;CH&quot; tvg-language=&quot;French&quot; tvg-logo=&quot;http://www.exemple.com/image.jpg&quot; group-title=&quot;&quot;,TFX (720p)\r\n        https://tfx-hls-live-ssl.tf1.fr/tfx/1/hls/live_2328.m3u8\r\n        #EXTINF:-1 tvg-id=&quot;TFX.fr&quot; tvg-name=&quot;TFX&quot; tvg-country=&quot;FR;AD;BE;LU;MC;CH&quot; tvg-language=&quot;French&quot; tvg-logo=&quot;http://127.0.0.1/img/image.jpg&quot; group-title=&quot;&quot;,TFX (local)\r\n        http://127.0.0.1:1234/tfx/live.m3u8\r\n\r\n\r\nThe file which contains multiple arrays and multiple objects.\r\n\r\nLike this :\r\n\r\n    {\r\n      &quot;Channels&quot;: [\r\n        {\r\n          &quot;name&quot;: &quot;TFX&quot;,\r\n          &quot;old_name&quot;: &quot;NT1&quot;,\r\n          &quot;logo&quot;: &quot;http://www.exemple.com/image.jpg&quot;,\r\n          &quot;category&quot;: &quot;Fiction&quot;,\r\n          &quot;urls&quot;: {\r\n            &quot;Official&quot;: [\r\n              {\r\n                &quot;server_name&quot;: &quot;TF1&quot;,\r\n                &quot;IP_address&quot;: &quot;8.8.8.8&quot;,\r\n                &quot;url&quot;: &quot;tfx-hls-live-ssl.tf1.fr&quot;,\r\n                &quot;port&quot;: &quot;&quot;,\r\n                &quot;https_port&quot;: &quot;443&quot;,\r\n                &quot;path&quot;: &quot;tfx/1/hls/&quot;,\r\n                &quot;file_name&quot;: &quot;live_2328&quot;,\r\n                &quot;extension&quot;: &quot;.m3u8&quot;,\r\n                &quot;full_url&quot;: &quot;https://tfx-hls-live-ssl.tf1.fr/tfx/1/hls/live_2328.m3u8&quot;\r\n              }\r\n            ],\r\n            &quot;Xtream_Servers&quot;: [\r\n              {\r\n                &quot;server_name&quot;: &quot;local&quot;,\r\n                &quot;user_name&quot;: &quot;rickey&quot;,\r\n                &quot;stream_id&quot;: &quot;11&quot;,\r\n                &quot;category_name&quot;: &quot;Fiction&quot;,\r\n                &quot;category_id&quot;: &quot;12&quot;\r\n              }\r\n            ]\r\n          },\r\n          &quot;languages&quot;: [\r\n            {\r\n              &quot;code&quot;: &quot;fr&quot;,\r\n              &quot;name&quot;: &quot;Fran&#231;ais&quot;\r\n            }\r\n          ],\r\n          &quot;countries&quot;: [\r\n            {\r\n              &quot;code&quot;: &quot;fr&quot;,\r\n              &quot;name&quot;: &quot;France&quot;\r\n            },\r\n            {\r\n              &quot;code&quot;: &quot;be&quot;,\r\n              &quot;name&quot;: &quot;Belgium&quot;\r\n            }\r\n          ],\r\n          &quot;tvg&quot;: {\r\n            &quot;id&quot;: &quot;TFX.fr&quot;,\r\n            &quot;name&quot;: &quot;TFX&quot;,\r\n            &quot;url&quot;: &quot;&quot;\r\n          }\r\n        },\r\n        {\r\n          &quot;name&quot;: &quot;France 2&quot;,\r\n          &quot;old_name&quot;: &quot;&quot;,\r\n          &quot;logo&quot;: &quot;http://www.exemple.com/image.jpg&quot;,\r\n          &quot;category&quot;: &quot;G&#233;n&#233;ral&quot;,\r\n          &quot;urls&quot;: {\r\n            &quot;Official&quot;: [\r\n              {\r\n                &quot;server_name&quot;: &quot;France TV&quot;,\r\n                &quot;IP_address&quot;: &quot;8.8.8.8&quot;,\r\n                &quot;url&quot;: &quot;france2.fr&quot;,\r\n                &quot;port&quot;: &quot;&quot;,\r\n                &quot;https_port&quot;: &quot;443&quot;,\r\n                &quot;path&quot;: &quot;live/&quot;,\r\n                &quot;file_name&quot;: &quot;Playlist&quot;,\r\n                &quot;extension&quot;: &quot;.m3u8&quot;,\r\n                &quot;full_url&quot;: &quot;https://france2.fr/live/Playlist.m3u8&quot;\r\n              }\r\n            ],\r\n            &quot;Xtream_Servers&quot;: [\r\n              {\r\n                &quot;server_name&quot;: &quot;localhost&quot;,\r\n                &quot;user_name&quot;: &quot;rickey&quot;,\r\n                &quot;stream_id&quot;: &quot;2&quot;,\r\n                &quot;category_name&quot;: &quot;G&#233;n&#233;ral&quot;,\r\n                &quot;category_id&quot;: &quot;10&quot;\r\n              }\r\n            ]\r\n          },\r\n          &quot;languages&quot;: [\r\n            {\r\n              &quot;code&quot;: &quot;fr&quot;,\r\n              &quot;name&quot;: &quot;Fran&#231;ais&quot;\r\n            }\r\n          ],\r\n          &quot;countries&quot;: [\r\n            {\r\n              &quot;code&quot;: &quot;fr&quot;,\r\n              &quot;name&quot;: &quot;France&quot;\r\n            },\r\n            {\r\n              &quot;code&quot;: &quot;be&quot;,\r\n              &quot;name&quot;: &quot;Belgique&quot;\r\n            }\r\n          ],\r\n          &quot;tvg&quot;: {\r\n            &quot;id&quot;: &quot;France2.fr&quot;,\r\n            &quot;name&quot;: &quot;France 2&quot;,\r\n            &quot;url&quot;: &quot;&quot;\r\n          }\r\n        },\r\n        {\r\n          &quot;name&quot;: &quot;M6&quot;,\r\n          &quot;old_name&quot;: &quot;&quot;,\r\n          &quot;logo&quot;: &quot;http://www.exemple.com/image.jpg&quot;,\r\n          &quot;category&quot;: &quot;G&#233;n&#233;ral&quot;,\r\n          &quot;urls&quot;: {\r\n            &quot;Official&quot;: [\r\n              {\r\n                &quot;server_name&quot;: &quot;6Play&quot;,\r\n                &quot;IP_address&quot;: &quot;8.8.8.8&quot;,\r\n                &quot;url&quot;: &quot;6play.fr&quot;,\r\n                &quot;port&quot;: &quot;&quot;,\r\n                &quot;https_port&quot;: &quot;443&quot;,\r\n                &quot;path&quot;: &quot;live/&quot;,\r\n                &quot;file_name&quot;: &quot;Playlist&quot;,\r\n                &quot;extension&quot;: &quot;.m3u8&quot;,\r\n                &quot;full_url&quot;: &quot;https://6play.fr/M6/live/Playlist.m3u8&quot;\r\n              }\r\n            ],\r\n            &quot;Xtream_Servers&quot;: [\r\n              {\r\n                &quot;server_name&quot;: &quot;localhost&quot;,\r\n                &quot;user_name&quot;: &quot;rickey&quot;,\r\n                &quot;stream_id&quot;: &quot;6&quot;,\r\n                &quot;category_name&quot;: &quot;G&#233;n&#233;ral&quot;,\r\n                &quot;category_id&quot;: &quot;10&quot;\r\n              }\r\n            ]\r\n          },\r\n          &quot;languages&quot;: [\r\n            {\r\n              &quot;code&quot;: &quot;fr&quot;,\r\n              &quot;name&quot;: &quot;Fran&#231;ais&quot;\r\n            }\r\n          ],\r\n          &quot;countries&quot;: [\r\n            {\r\n              &quot;code&quot;: &quot;fr&quot;,\r\n              &quot;name&quot;: &quot;France&quot;\r\n            },\r\n            {\r\n              &quot;code&quot;: &quot;be&quot;,\r\n              &quot;name&quot;: &quot;Belgique&quot;\r\n            }\r\n          ],\r\n          &quot;tvg&quot;: {\r\n            &quot;id&quot;: &quot;France2.fr&quot;,\r\n            &quot;name&quot;: &quot;France 2&quot;,\r\n            &quot;url&quot;: &quot;&quot;\r\n          }\r\n        }\r\n      ],\r\n      &quot;Third_Party&quot;: {\r\n        &quot;Xtream_Servers&quot;: [\r\n          {\r\n            &quot;server_name&quot;: &quot;local&quot;,\r\n            &quot;url&quot;: &quot;192.168.1.100&quot;,\r\n            &quot;port&quot;: &quot;8080&quot;,\r\n            &quot;https_port&quot;: &quot;8082&quot;,\r\n            &quot;server_protocol&quot;: &quot;http&quot;,\r\n            &quot;rtmp_port&quot;: &quot;12345&quot;,\r\n            &quot;Users_list&quot;: [\r\n              {\r\n                &quot;username&quot;: &quot;rickey&quot;,\r\n                &quot;password&quot;: &quot;azerty01&quot;,\r\n                &quot;created_at&quot;: &quot;&quot;,\r\n                &quot;exp_date&quot;: &quot;&quot;,\r\n                &quot;is_trial&quot;: &quot;0&quot;,\r\n                &quot;last_check&quot;: &quot;&quot;,\r\n                &quot;max_connections&quot;: &quot;3&quot;,\r\n                &quot;allowed_output_formats&quot;: [\r\n                  &quot;m3u8&quot;,\r\n                  &quot;ts&quot;,\r\n                  &quot;rtmp&quot;\r\n                ]\r\n              }\r\n            ]\r\n          },\r\n          {\r\n            &quot;server_name&quot;: &quot;localhost&quot;,\r\n            &quot;url&quot;: &quot;127.0.0.1&quot;,\r\n            &quot;port&quot;: &quot;8080&quot;,\r\n            &quot;https_port&quot;: &quot;8082&quot;,\r\n            &quot;server_protocol&quot;: &quot;http&quot;,\r\n            &quot;rtmp_port&quot;: &quot;12345&quot;,\r\n            &quot;Users_list&quot;: [\r\n              {\r\n                &quot;username&quot;: &quot;rickey123&quot;,\r\n                &quot;password&quot;: &quot;azerty321&quot;,\r\n                &quot;created_at&quot;: &quot;&quot;,\r\n                &quot;exp_date&quot;: &quot;&quot;,\r\n                &quot;is_trial&quot;: &quot;0&quot;,\r\n                &quot;last_check&quot;: &quot;&quot;,\r\n                &quot;max_connections&quot;: &quot;3&quot;,\r\n                &quot;allowed_output_formats&quot;: [\r\n                  &quot;m3u8&quot;,\r\n                  &quot;ts&quot;,\r\n                  &quot;rtmp&quot;\r\n                ]\r\n              },\r\n              {\r\n                &quot;username&quot;: &quot;guest&quot;,\r\n                &quot;password&quot;: &quot;guest01&quot;,\r\n                &quot;created_at&quot;: &quot;&quot;,\r\n                &quot;exp_date&quot;: &quot;&quot;,\r\n                &quot;is_trial&quot;: &quot;1&quot;,\r\n                &quot;last_check&quot;: &quot;&quot;,\r\n                &quot;max_connections&quot;: &quot;1&quot;,\r\n                &quot;allowed_output_formats&quot;: [\r\n                  &quot;ts&quot;\r\n                ]\r\n              }\r\n            ]\r\n          }\r\n        ]\r\n      }\r\n    }\r\n\r\nFirst question: Is it a crappy json?\r\n\r\nTo add or modify this file, the script must have the entry number (I think, if you have any other ideas, I&#39;m interested...)\r\n\r\n    cat File.json  | jq &#39;.Channels | to_entries[]&#39;\r\n\r\noutput: \r\n\r\n    {\r\n      &quot;key&quot;: 0,\r\n      &quot;value&quot;: {\r\n        &quot;name&quot;: &quot;TFX&quot;,\r\n        &quot;old_name&quot;: &quot;NT1&quot;,\r\n        \r\n2nd question:\r\nHow to get value key (0 is this case) with the value of &quot;name&quot;, for store into variable after ? (to avoid duplicates)\r\n\r\n    key_=&quot;$(cat file.json | jq ????????? search=&quot;name&quot;: &quot;$get_name&quot; ???? .key)&quot;\r\n    echo $key_\r\n    &quot;0&quot;\r\n    key_2=&quot;$(cat file.json | jq ????????? search=&quot;name&quot;: &quot;$get_url&quot; ???? .key)&quot;\r\n    echo $key_2\r\n    &quot;0&quot;\r\n    \r\n    if [[ $key_ == $key_2 ]]; then\r\n  \r\n    Chan_Name=&quot;$(cat $1 | jq &#39;.Channels[$key_].name)&quot;\r\n    Echo $Chan_Name\r\n    &quot;TFX&quot;\r\n    jq  &#39;.[] ????? += {???? , ??? }&#39; file.json | sponge file.json\r\n\r\n    fi\r\n\r\nlast question (most important):\r\nHow to find and modify these f*** objects, when the script does not know any values of the keys of the objects / arrays ?!\r\n\r\nI&#39;ve been looking for 2 days, my brain is liquid.\r\n\r\n\r\nThank you. :)\r\n\r\n**Edit 1 :**\r\n\r\nI&#39;ve found a partial solution to replace value:\r\n\r\n    {\r\n          &quot;name&quot;: &quot;TFX&quot;,\r\n          &quot;old_name&quot;: &quot;NT1&quot;,\r\n          &quot;logo&quot;: &quot;http://www.exemple.com/image.jpg&quot;,\r\n          &quot;category&quot;: &quot;Fiction&quot;,\r\n\r\n\r\n   \r\n\r\nwith:\r\n\r\n     cat file.json | jq -C &#39;(.Channels[] | select(.name==&quot;TFX&quot;).category=&quot;test&quot;)&#39;\r\n\r\noutput:\r\n\r\n    {\r\n      &quot;name&quot;: &quot;TFX&quot;,\r\n      &quot;old_name&quot;: &quot;NT1&quot;,\r\n      &quot;logo&quot;: &quot;http://www.exemple.com/image.jpg&quot;,\r\n      &quot;category&quot;: &quot;test&quot;,\r\n      &quot;urls&quot;: {\r\n\r\nbut &quot;{&quot;Channels&quot;: [&quot; is missing. :/",
        "link": "https://stackoverflow.com/questions/68147007/jq-and-bash-how-to-get-value-of-key-from-value-of-object-how-to-build-update",
        "title": "jq and Bash: How to get value of key from value of object? (How to build/update a json?)"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1624788108,
                "last_edit_date": 1624788108,
                "creation_date": 1624786953,
                "answer_id": 68149833,
                "question_id": 68149782,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can use [`first/1`](https://stedolan.github.io/jq/manual/#first(expr),last(expr),nth(n;expr)) in conjunction with **-n**/**--null-input** flag.\r\n```\r\njq -n &#39;first(inputs.name)&#39;\r\n```\r\n&lt;sup&gt;[Online demo](https://jqplay.org/s/-MPl4kHmpw)&lt;/sup&gt;",
                "title": "How to fetch first element from a stream of JSON objects?"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1689265495,
                "creation_date": 1689265495,
                "answer_id": 76681521,
                "question_id": 68149782,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "There&#39;s also [`input`](https://jqlang.github.io/jq/manual/#input) (whithout &quot;s&quot;) which in combination with the `--null-input` (or `-n`) flag emits just the first item:\r\n```sh\r\njq -n &#39;input.name&#39;\r\n```\r\n[Demo](https://jqplay.org/s/NRky2LR2PXE)",
                "title": "How to fetch first element from a stream of JSON objects?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 3,
        "last_activity_date": 1689265495,
        "creation_date": 1624786452,
        "last_edit_date": 1624786994,
        "question_id": 68149782,
        "body_markdown": "Example \r\n```\r\n{\r\n  &quot;name&quot;: &quot;bar&quot;,\r\n  &quot;thing&quot;: true,\r\n  &quot;new_key&quot;: 0\r\n}\r\n{\r\n  &quot;name&quot;: &quot;baz&quot;,\r\n  &quot;thing&quot;: false,\r\n  &quot;new_key&quot;: 0\r\n}\r\n```\r\nIf I run `.name` I get output as \r\n\r\n```\r\nbar\r\nbaz\r\n```\r\nI want only `bar`\r\n\r\n",
        "link": "https://stackoverflow.com/questions/68149782/how-to-fetch-first-element-from-a-stream-of-json-objects",
        "title": "How to fetch first element from a stream of JSON objects?"
    },
    {
        "tags": [
            "arrays",
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1624795120,
                "creation_date": 1624795120,
                "answer_id": 68150928,
                "question_id": 68150808,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Found the answer \r\n```\r\nif .name  | contains(&quot;random&quot;) then . |= . + {&quot;Contains&quot;: 1} else . |= . + {&quot;Contains&quot;: 0} end \r\n```",
                "title": "JQ add key to json if condition satisfies"
            },
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1624797205,
                "creation_date": 1624797205,
                "answer_id": 68151206,
                "question_id": 68150808,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Keeping it short and sweet:\r\n\r\n    .Contains = (if .name | contains(&quot;random&quot;)\r\n                 then 1 else 0 end)",
                "title": "JQ add key to json if condition satisfies"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1624797205,
        "creation_date": 1624794261,
        "question_id": 68150808,
        "body_markdown": "There are many solutions but sadly none of them worked out for me, so here is my problem\r\nExample\r\n```\r\n{\r\n  &quot;name&quot;: &quot;bar some random string&quot;,\r\n  &quot;thing&quot;: true,\r\n  &quot;new_key&quot;: 0\r\n}\r\n{\r\n  &quot;name&quot;: &quot;biz again another length words&quot;,\r\n  &quot;thing&quot;: true,\r\n  &quot;new_key&quot;: 0\r\n}\r\n\r\n```\r\nSo, my problem was if name contains &quot;random&quot; add key value &quot;Contains&quot; : 1 else &quot;contains&quot; : 0\r\n\r\nSolution I tried was\r\n```\r\nif .name == &quot;random&quot; then . |= . + {&quot;Contains&quot;: 1} else . |= . + {&quot;Contains&quot;: 0} end \r\n```\r\nWhat I need is \r\n\r\n```\r\n{\r\n  &quot;name&quot;: &quot;bar some random string&quot;,\r\n  &quot;thing&quot;: true,\r\n  &quot;new_key&quot;: 0\r\n  &quot;Contains&quot;: 1\r\n}\r\n{\r\n  &quot;name&quot;: &quot;biz again another length words&quot;,\r\n  &quot;thing&quot;: true,\r\n  &quot;new_key&quot;: 0\r\n  &quot;Contains&quot;: 0\r\n}\r\n```\r\n\r\n",
        "link": "https://stackoverflow.com/questions/68150808/jq-add-key-to-json-if-condition-satisfies",
        "title": "JQ add key to json if condition satisfies"
    },
    {
        "tags": [
            "bash",
            "shell",
            "escaping",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": -2,
                "last_activity_date": 1624800613,
                "creation_date": 1624800613,
                "answer_id": 68151688,
                "question_id": 68151639,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Nevermind got it,\r\n```\r\njq &#39;if .tweet | contains(&#39;\\&quot;$p\\&quot;&#39;) then . |= . + {&#39;$p&#39;: 1} else . |= . + {&#39;$p&#39;: 0} end&#39; newfirst.json\r\n",
                "title": "How to wrap double quotes around a variable"
            },
            {
                "up_vote_count": 6,
                "is_accepted": false,
                "score": 6,
                "last_activity_date": 1624827377,
                "last_edit_date": 1624827377,
                "creation_date": 1624806126,
                "answer_id": 68152430,
                "question_id": 68151639,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "&gt; How to wrap double quotes around a variable [for use within jq script]\r\n\r\nWrite your own escaping function that follows the json specification and properly passes escaped string. Writing such function is nontrivial - study jq documentation and source code on how it interprets arguments and json documentation about what characters are allowed in fields and how to escape them.\r\n\r\n---\r\n\r\nWriting such a function would be cumbersome, instead pass the variable to jq and let jq figure it out. Research jq documentation and quoting in shell.\r\n\r\n    jq --arg p &quot;$p&quot; &#39;if .tweet | contains($p) then . |= . + {$p: 1} else . |= . + {$p: 0} end&#39; newfirst.json",
                "title": "How to wrap double quotes around a variable"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": -3,
        "last_activity_date": 1624827377,
        "creation_date": 1624800288,
        "last_edit_date": 1624801144,
        "question_id": 68151639,
        "body_markdown": "So Idk I got the half right but other half I am missing so,\r\n\r\nInput is\r\n```\r\necho $p\r\njq &#39;if .tweet | contains(&#39;\\&quot;$p\\&#39;) then . |= . + {&#39;$p&#39;: 1} else . |= . + {&#39;$p&#39;: 0} end&#39; newfirst.json\r\n```\r\nThe output I am getting is\r\n```\r\nif .tweet | contains(&quot;accelerite) then . |= . + {accelerite: 1} else . |= . + {accelerite: 0} end\r\n```\r\n\r\nThe Output I want is\r\n```\r\nif .tweet | contains(&quot;accelerite&quot;) then . |= . + {&quot;accelerite&quot;: 1} else . |= . + {&quot;accelerite&quot;: 0} end\r\n```\r\n\r\nWhat am I missing?",
        "link": "https://stackoverflow.com/questions/68151639/how-to-wrap-double-quotes-around-a-variable",
        "title": "How to wrap double quotes around a variable"
    },
    {
        "tags": [
            "json",
            "bash",
            "awk",
            "sed",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 1022874,
                    "reputation": 35264,
                    "user_id": 1032785,
                    "user_type": "registered",
                    "accept_rate": 50,
                    "profile_image": "https://www.gravatar.com/avatar/30816b3d787c2bd9d6f036318304f225?s=256&d=identicon&r=PG",
                    "display_name": "jordanm",
                    "link": "https://stackoverflow.com/users/1032785/jordanm"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1624811679,
                "post_id": 68153214,
                "comment_id": 120453815,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 20523406,
                    "reputation": 67,
                    "user_id": 15062453,
                    "user_type": "registered",
                    "profile_image": "https://lh4.googleusercontent.com/-GVAuYBKRiFw/AAAAAAAAAAI/AAAAAAAAAAA/AMZuucmLMatehEf9dp8ch8cahoIqmf7POA/s96-c/s256-rj/photo.jpg",
                    "display_name": "&#193;d&#225;m Heged&#252;s",
                    "link": "https://stackoverflow.com/users/15062453/%c3%81d%c3%a1m-heged%c3%bcs"
                },
                "reply_to_user": {
                    "account_id": 1022874,
                    "reputation": 35264,
                    "user_id": 1032785,
                    "user_type": "registered",
                    "accept_rate": 50,
                    "profile_image": "https://www.gravatar.com/avatar/30816b3d787c2bd9d6f036318304f225?s=256&d=identicon&r=PG",
                    "display_name": "jordanm",
                    "link": "https://stackoverflow.com/users/1032785/jordanm"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1624812153,
                "post_id": 68153214,
                "comment_id": 120453953,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1938048,
                    "reputation": 207858,
                    "user_id": 1745001,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/99a3ebae89496eb16afe453aae97f5be?s=256&d=identicon&r=PG",
                    "display_name": "Ed Morton",
                    "link": "https://stackoverflow.com/users/1745001/ed-morton"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1624812626,
                "post_id": 68153214,
                "comment_id": 120454071,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 20523406,
                    "reputation": 67,
                    "user_id": 15062453,
                    "user_type": "registered",
                    "profile_image": "https://lh4.googleusercontent.com/-GVAuYBKRiFw/AAAAAAAAAAI/AAAAAAAAAAA/AMZuucmLMatehEf9dp8ch8cahoIqmf7POA/s96-c/s256-rj/photo.jpg",
                    "display_name": "&#193;d&#225;m Heged&#252;s",
                    "link": "https://stackoverflow.com/users/15062453/%c3%81d%c3%a1m-heged%c3%bcs"
                },
                "reply_to_user": {
                    "account_id": 1938048,
                    "reputation": 207858,
                    "user_id": 1745001,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/99a3ebae89496eb16afe453aae97f5be?s=256&d=identicon&r=PG",
                    "display_name": "Ed Morton",
                    "link": "https://stackoverflow.com/users/1745001/ed-morton"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1624812769,
                "post_id": 68153214,
                "comment_id": 120454115,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 3754081,
                    "reputation": 5693,
                    "user_id": 3120884,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/4d2ce9b8645183855fd1d237ed348a95?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "stevesliva",
                    "link": "https://stackoverflow.com/users/3120884/stevesliva"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1624812772,
                "post_id": 68153214,
                "comment_id": 120454116,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1624813625,
                "last_edit_date": 1624813625,
                "creation_date": 1624812710,
                "answer_id": 68153406,
                "question_id": 68153214,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "One `awk` idea:\r\n\r\n    awk &#39;\r\n    FNR==1 {print;next}          # print line 1 as is\r\n           {printf &quot;%02d&quot;,$1}    # print all other lines on 2nd line (notice no &quot;\\n&quot;),\r\n                                 # left padding numbers with &quot;0&quot; to 2 digits\r\n    END    {printf &quot;\\n&quot;}         # print EOL\r\n    &#39; file\r\n\r\nAssuming the 3 samples of data are in files `file{1..3}`:\r\n\r\n    for f in file{1..3}\r\n    do\r\n        echo &quot;+++++++++++ ${f}&quot;\r\n        awk &#39;FNR==1 {print;next} {printf &quot;%02d&quot;,$1} END {printf &quot;\\n&quot;}&#39; &quot;${f}&quot;\r\n    done\r\n\r\nThis generates:\r\n\r\n    +++++++++++ file1\r\n    plugin://plugin.video.youtube/play/?video_id=rhMTZB2WJWA\r\n    020305\r\n    +++++++++++ file2\r\n    plugin://plugin.video.youtube/play/?video_id=rhMTZB2WJWA\r\n    001122\r\n    +++++++++++ file3\r\n    plugin://plugin.video.youtube/play/?video_id=rhMTZB2WJWA\r\n    005509\r\n\r\n",
                "title": "Json get fitting the numbers in a row and add a 0 in front of every 1-9 number"
            },
            {
                "up_vote_count": 4,
                "is_accepted": false,
                "score": 4,
                "last_activity_date": 1624874434,
                "last_edit_date": 1624874434,
                "creation_date": 1624818060,
                "answer_id": 68154115,
                "question_id": 68153214,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Do it with `jq` entirely:\r\n\r\n```sh\r\njq --raw-output &#39;[.[].result] | add | .item.file, ( .time | .hours * 3600 + .minutes * 60 + .seconds | strftime(&quot;%H%M%S&quot;) )&#39;\r\n```\r\n\r\nThe `jq` script with comments:\r\n\r\n`jqscript`:\r\n```jq\r\n#!/usr/bin/env -S jq -fr\r\n\r\n# Merge all result entries into a single object\r\n[.[].result] | add |\r\n\r\n# Output the file url\r\n  .item.file,\r\n\r\n# Output a formatted time\r\n  (\r\n    # Using the time object\r\n    .time |\r\n      # Compute a timestamp in seconds\r\n      .hours * 3600 + .minutes * 60 + .seconds |\r\n        # Format the timestamp to requirement\r\n        strftime(&quot;%H%M%S&quot;)\r\n  )\r\n```\r\n\r\n`input.json`\r\n```json\r\n[\r\n  {\r\n    &quot;id&quot;: 17,\r\n    &quot;jsonrpc&quot;: &quot;2.0&quot;,\r\n    &quot;result&quot;: {\r\n      &quot;time&quot;: {\r\n        &quot;hours&quot;: 2,\r\n        &quot;milliseconds&quot;: 200,\r\n        &quot;minutes&quot;: 3,\r\n        &quot;seconds&quot;: 5\r\n      }\r\n    }\r\n  },\r\n  {\r\n    &quot;id&quot;: 18,\r\n    &quot;jsonrpc&quot;: &quot;2.0&quot;,\r\n    &quot;result&quot;: {\r\n      &quot;item&quot;: {\r\n        &quot;file&quot;: &quot;plugin://plugin.video.youtube/play/?video_id=rhMTZB2WJWA&quot;,\r\n        &quot;label&quot;: &quot;FULL SHOW - Burton US Open Men&#39;s Slopestyle Semi-Finals&quot;,\r\n        &quot;type&quot;: &quot;unknown&quot;\r\n      }\r\n    }\r\n  }\r\n]\r\n```\r\n\r\nRunning:\r\n```sh\r\n./jqscript input.json\r\n```\r\n\r\nOutput:\r\n```none\r\nplugin://plugin.video.youtube/play/?video_id=rhMTZB2WJWA\r\n020305\r\n```\r\n",
                "title": "Json get fitting the numbers in a row and add a 0 in front of every 1-9 number"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1624874434,
        "creation_date": 1624811460,
        "question_id": 68153214,
        "body_markdown": "In bash i want to make the .txt file to have the link in line 1. and the numbers in line 2.\r\n\r\n\r\n    curl -s &quot;http://kodi:kodi@192.168.1.10:8080/jsonrpc?Base&quot; -H &#39;Content-Type: application/json&#39; --data &#39;[{&quot;jsonrpc&quot;:&quot;2.0&quot;,&quot;method&quot;:&quot;Player.GetProperties&quot;,&quot;params&quot;:[1,[&quot;time&quot;]],&quot;id&quot;:17},{&quot;jsonrpc&quot;:&quot;2.0&quot;,&quot;method&quot;:&quot;Player.GetItem&quot;,&quot;params&quot;:[1,[&quot;file&quot;]],&quot;id&quot;:18}]&#39; | jq\r\n\r\njson file format with jq\r\n\r\n&gt;     [\r\n&gt;       {\r\n&gt;         &quot;id&quot;: 17,\r\n&gt;         &quot;jsonrpc&quot;: &quot;2.0&quot;,\r\n&gt;         &quot;result&quot;: {\r\n&gt;           &quot;time&quot;: {\r\n&gt;             &quot;hours&quot;: 2,\r\n&gt;             &quot;milliseconds&quot;: 200,\r\n&gt;             &quot;minutes&quot;: 3,\r\n&gt;             &quot;seconds&quot;: 5\r\n&gt;           }\r\n&gt;         }\r\n&gt;       },\r\n&gt;       {\r\n&gt;         &quot;id&quot;: 18,\r\n&gt;         &quot;jsonrpc&quot;: &quot;2.0&quot;,\r\n&gt;         &quot;result&quot;: {\r\n&gt;           &quot;item&quot;: {\r\n&gt;             &quot;file&quot;: &quot;plugin://plugin.video.youtube/play/?video_id=rhMTZB2WJWA&quot;,\r\n&gt;             &quot;label&quot;: &quot;FULL SHOW - Burton US Open Men&#39;s Slopestyle Semi-Finals&quot;,\r\n&gt;             &quot;type&quot;: &quot;unknown&quot;\r\n&gt;           }\r\n&gt;         }\r\n&gt;       }\r\n&gt;     ]\r\n\r\n    \r\n\r\n    curl -s &quot;http://kodi:kodi@192.168.1.10:8080/jsonrpc?Base&quot; -H &#39;Content-Type: application/json&#39; --data &#39;[{&quot;jsonrpc&quot;:&quot;2.0&quot;,&quot;method&quot;:&quot;Player.GetProperties&quot;,&quot;params&quot;:[1,[&quot;time&quot;]],&quot;id&quot;:17},{&quot;jsonrpc&quot;:&quot;2.0&quot;,&quot;method&quot;:&quot;Player.GetItem&quot;,&quot;params&quot;:[1,[&quot;file&quot;]],&quot;id&quot;:18}]&#39; | jq --raw-output &#39;.[].result.item.file, .[].result.time.hours, .[].result.time.minutes, .[].result.time.seconds | select(. != null)&#39; &gt; &quot;c:\\kodi\\info.txt&quot;\r\n\r\nwith this i can get this format in the info.txt file\r\n\r\n\r\n\r\ninfo.txt\r\n\r\n&gt;     plugin://plugin.video.youtube/play/?video_id=rhMTZB2WJWA\r\n&gt;     2\r\n&gt;     3\r\n&gt;     5\r\n\r\n\r\nexample 2.\r\n\r\n&gt;     plugin://plugin.video.youtube/play/?video_id=rhMTZB2WJWA\r\n&gt;     0\r\n&gt;     11\r\n&gt;     22\r\n\r\nexample 3. \r\n\r\n&gt;     plugin://plugin.video.youtube/play/?video_id=rhMTZB2WJWA\r\n&gt;     0\r\n&gt;     55\r\n&gt;     9\r\n\r\n\r\n\r\n\r\n[online jq play link][1]\r\n\r\n**how could it be done with jq, awk, paste, sed or something similar to make it look like this and put a 0 in front of every 1-9?**\r\n\r\n\r\n    example 1.\r\n    plugin://plugin.video.youtube/play/?video_id=rhMTZB2WJWA\r\n    020305\r\n        \r\n    example 2.\r\n    plugin://plugin.video.youtube/play/?video_id=rhMTZB2WJWA\r\n    001122\r\n    \r\n    example 3. \r\n    plugin://plugin.video.youtube/play/?video_id=rhMTZB2WJWA\r\n    005509\r\n\r\n\r\n  [1]: https://jqplay.org/s/xTHa1D-5jI\r\n\r\nThanks in advance for any help!",
        "link": "https://stackoverflow.com/questions/68153214/json-get-fitting-the-numbers-in-a-row-and-add-a-0-in-front-of-every-1-9-number",
        "title": "Json get fitting the numbers in a row and add a 0 in front of every 1-9 number"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 1143565,
                    "reputation": 535973,
                    "user_id": 1126841,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/fa05233b2357f8d11c22ef4cfc7bb85c?s=256&d=identicon&r=PG",
                    "display_name": "chepner",
                    "link": "https://stackoverflow.com/users/1126841/chepner"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1624817334,
                "post_id": 68153993,
                "comment_id": 120455227,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 492726,
                    "reputation": 11,
                    "user_id": 14230017,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/684e0902c3ea701f4ad2271732d75e47?s=256&d=identicon&r=PG",
                    "display_name": "Sivaguru Nathan",
                    "link": "https://stackoverflow.com/users/14230017/sivaguru-nathan"
                },
                "reply_to_user": {
                    "account_id": 1143565,
                    "reputation": 535973,
                    "user_id": 1126841,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/fa05233b2357f8d11c22ef4cfc7bb85c?s=256&d=identicon&r=PG",
                    "display_name": "chepner",
                    "link": "https://stackoverflow.com/users/1126841/chepner"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1624822084,
                "post_id": 68153993,
                "comment_id": 120456286,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1624834353,
                "creation_date": 1624834353,
                "answer_id": 68155893,
                "question_id": 68153993,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You could (for example) simply prepend the following to the jq filter:\r\n\r\n    .anomalyDetection.loadingTimeThresholds.enabled = true |",
                "title": "dynamically changing values in multiple objects in json using jq"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1624836984,
        "creation_date": 1624817182,
        "last_edit_date": 1624836984,
        "question_id": 68153993,
        "body_markdown": "The following file is taken from https://stackoverflow.com/questions/64646374/dynamically-modify-json-file-in-bash-script-with-jq-use-heredocs-or-key-assign\r\n\r\n&lt;!-- language: bash --&gt;\r\n\r\n    #!/usr/bin/env bash\r\n\r\n    function template {\r\n        cat&lt;&lt;EOF\r\n    {\r\n        &quot;anomalyDetection&quot;: {\r\n            &quot;loadingTimeThresholds&quot;: {\r\n                &quot;enabled&quot;: false,\r\n                &quot;thresholds&quot;: []\r\n            },\r\n            &quot;outageHandling&quot;: {\r\n                &quot;globalOutage&quot;: true,\r\n                &quot;localOutage&quot;: true,\r\n                &quot;localOutagePolicy&quot;: {\r\n                    &quot;affectedLocations&quot;: 1,\r\n                    &quot;consecutiveRuns&quot;: 2\r\n                }\r\n            }\r\n        }\r\n    }\r\n    EOF\r\n    }\r\n\r\n    function modify_json() {\r\n        template |  \r\n        jq --argjson update_affectedLocations &quot;${1:-1}&quot; \\\r\n           --argjson update_consecutiveRuns &quot;${2:-2}&quot; &#39;\r\n           .anomalyDetection.outageHandling.localOutagePolicy\r\n             |= (.affectedLocations |= $update_affectedLocations\r\n                 | .consecutiveRuns |= $update_consecutiveRuns )\r\n        &#39;\r\n    }\r\n\r\n    updated_JSON=$(modify_json 42 666)\r\n    echo &quot;$updated_JSON&quot;\r\n\r\nIn this , in addition to above changes in .anomalyDetection.outageHandling.localOutagePolicy Object , How to change the .enabled.key in &quot; .anomalyDetection.loadingTimeThresholds&quot; Object dynamically using the jq in the same modify_json function. \r\n\r\nActual output of the above script is below \r\n\r\n&lt;!-- language: json --&gt;\r\n\r\n    {\r\n      &quot;anomalyDetection&quot;: {\r\n        &quot;loadingTimeThresholds&quot;: {\r\n          &quot;enabled&quot;: false,\r\n          &quot;thresholds&quot;: []\r\n        },\r\n        &quot;outageHandling&quot;: {\r\n          &quot;globalOutage&quot;: true,\r\n          &quot;localOutage&quot;: true,\r\n          &quot;localOutagePolicy&quot;: {\r\n            &quot;affectedLocations&quot;: 42,\r\n            &quot;consecutiveRuns&quot;: 666\r\n          }\r\n        }\r\n      }\r\n    }\r\n\r\n\r\nAm Expecting output like this, existing value anomalyDetection.loadingTimeThresholds.enabled also to be replaced by true in addition to above\r\n\r\n&lt;!-- language: json --&gt;\r\n\r\n    {\r\n      &quot;anomalyDetection&quot;: {\r\n        &quot;loadingTimeThresholds&quot;: {\r\n          &quot;enabled&quot;: true,\r\n          &quot;thresholds&quot;: []\r\n        },\r\n        &quot;outageHandling&quot;: {\r\n          &quot;globalOutage&quot;: true,\r\n          &quot;localOutage&quot;: true,\r\n          &quot;localOutagePolicy&quot;: {\r\n            &quot;affectedLocations&quot;: 42,\r\n            &quot;consecutiveRuns&quot;: 666\r\n          }\r\n        }\r\n      }\r\n    }\r\n",
        "link": "https://stackoverflow.com/questions/68153993/dynamically-changing-values-in-multiple-objects-in-json-using-jq",
        "title": "dynamically changing values in multiple objects in json using jq"
    },
    {
        "tags": [
            "python",
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 5038484,
                    "reputation": 14333,
                    "user_id": 4046632,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/72b9c35f299ebe0cd4353431d2f8eb8b?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "buran",
                    "link": "https://stackoverflow.com/users/4046632/buran"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1624857957,
                "post_id": 68157950,
                "comment_id": 120461639,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": -1,
                "last_activity_date": 1624858119,
                "creation_date": 1624858119,
                "answer_id": 68157992,
                "question_id": 68157950,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "    import json\r\n    \r\n    array = &#39;{ &quot;id&quot;: &quot;1335735520073232385&quot;, &quot;created_at&quot;: &quot;2020-12-07 05:28:59 IST&quot;, &quot;username&quot;: &quot;kristinaforest&quot;,  &quot;tweet&quot;: &quot;@iamsandyhall It’s the look of surprise on her face and the vulnerability on his &#128151;&quot;,&quot;vendor&quot;: &quot;null&quot;}&#39;\r\n    data  = json.loads(array)\r\n    print(data[&#39;id&#39;], data[&#39;created_at&#39;])\r\n    [out]: 335735520073232385 2020-12-07 05:28:59 IST",
                "title": "How to restructure json?"
            },
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1624858362,
                "creation_date": 1624858362,
                "answer_id": 68158014,
                "question_id": 68157950,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can try `itertools.groupby`. But it has the extra overhead of sorting the lost first because if a list is like [1,1,2,2,1,3,3] then `groupby` will work as [(1,1), (2,2), (1), (3,3)], that is why sorting is required, obviously, you can do without groupby, but it makes the code simpler and can use if you do not care about time complexity.\r\n\r\n```python\r\nfrom itertools import groupby\r\n\r\nl = [{\r\n  &quot;id&quot;: &quot;1335735520073232385&quot;,\r\n  &quot;created_at&quot;: &quot;2020-12-07 05:28:59 IST&quot;,\r\n  &quot;username&quot;: &quot;kristinaforest&quot;,\r\n  &quot;tweet&quot;: &quot;@iamsandyhall It’s the look of surprise on her face and the vulnerability on his &#128151;&quot;,\r\n  &quot;vendor&quot;: &quot;null&quot;\r\n},\r\n{\r\n  &quot;id&quot;: &quot;1335735456223399937&quot;,\r\n  &quot;created_at&quot;: &quot;2020-12-07 05:28:44 IST&quot;,\r\n  &quot;username&quot;: &quot;openbugbounty&quot;,\r\n  &quot;tweet&quot;: &quot;@lyrsense please notify your IT security team about a security vulnerability OBB-1583432 on your website  &quot;,\r\n  &quot;vendor&quot;: &quot;openbugbounty&quot;\r\n},\r\n{\r\n  &quot;id&quot;: &quot;1335735446496817152&quot;,\r\n  &quot;created_at&quot;: &quot;2020-12-07 05:28:41 IST&quot;,\r\n  &quot;username&quot;: &quot;openbugbounty&quot;,\r\n  &quot;tweet&quot;: &quot;@arstechnica please notify your IT security team about a security vulnerability OBB-1583440 on your website  &quot;,\r\n  &quot;vendor&quot;: &quot;openbugbounty&quot;\r\n},\r\n{\r\n  &quot;id&quot;: &quot;1335735260957564929&quot;,\r\n  &quot;created_at&quot;: &quot;2020-12-07 05:27:57 IST&quot;,\r\n  &quot;username&quot;: &quot;tpwk_falls&quot;,\r\n  &quot;tweet&quot;: &quot;2 years into a song of vulnerability - a catchy melody embedded with honest lyrics opening up about a difficult time. Thank u for sharing with us  @zaynmalik I’m so proud of how far you’ve come and continue to go. Forever supporting ur journey #2yearsofgoodyears   PROUD OF ZAYN &quot;,\r\n  &quot;vendor&quot;: &quot;zayn malik&quot;\r\n}]\r\n\r\nsorted_l = sorted(l, key=lambda x: x[&#39;vendor&#39;])\r\ngrouped = groupby(sorted_l, key=lambda x: x[&#39;vendor&#39;])\r\n\r\noutput = []\r\n\r\nfor key, group in grouped:\r\n    output.append({\r\n        &#39;vendor&#39;: key,\r\n        &#39;tweets&#39;: [{j:i[j] for j in i if j != &#39;vendor&#39;} for i in group]\r\n    })\r\n    \r\nprint(output)\r\n```\r\n\r\n```\r\n[{&#39;vendor&#39;: &#39;null&#39;,\r\n  &#39;tweets&#39;: [{&#39;id&#39;: &#39;1335735520073232385&#39;,\r\n    &#39;created_at&#39;: &#39;2020-12-07 05:28:59 IST&#39;,\r\n    &#39;username&#39;: &#39;kristinaforest&#39;,\r\n    &#39;tweet&#39;: &#39;@iamsandyhall It’s the look of surprise on her face and the vulnerability on his &#128151;&#39;}]},\r\n {&#39;vendor&#39;: &#39;openbugbounty&#39;,\r\n  &#39;tweets&#39;: [{&#39;id&#39;: &#39;1335735456223399937&#39;,\r\n    &#39;created_at&#39;: &#39;2020-12-07 05:28:44 IST&#39;,\r\n    &#39;username&#39;: &#39;openbugbounty&#39;,\r\n    &#39;tweet&#39;: &#39;@lyrsense please notify your IT security team about a security vulnerability OBB-1583432 on your website  &#39;},\r\n   {&#39;id&#39;: &#39;1335735446496817152&#39;,\r\n    &#39;created_at&#39;: &#39;2020-12-07 05:28:41 IST&#39;,\r\n    &#39;username&#39;: &#39;openbugbounty&#39;,\r\n    &#39;tweet&#39;: &#39;@arstechnica please notify your IT security team about a security vulnerability OBB-1583440 on your website  &#39;}]},\r\n {&#39;vendor&#39;: &#39;zayn malik&#39;,\r\n  &#39;tweets&#39;: [{&#39;id&#39;: &#39;1335735260957564929&#39;,\r\n    &#39;created_at&#39;: &#39;2020-12-07 05:27:57 IST&#39;,\r\n    &#39;username&#39;: &#39;tpwk_falls&#39;,\r\n    &#39;tweet&#39;: &#39;2 years into a song of vulnerability - a catchy melody embedded with honest lyrics opening up about a difficult time. Thank u for sharing with us  @zaynmalik I’m so proud of how far you’ve come and continue to go. Forever supporting ur journey #2yearsofgoodyears   PROUD OF ZAYN &#39;}]}]\r\n```",
                "title": "How to restructure json?"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1624859318,
                "creation_date": 1624859318,
                "answer_id": 68158129,
                "question_id": 68157950,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can achieve this via collections defaultdict and iteration through your json\r\n    \r\n    from collections import defaultdict\r\n\r\n    flat_json = [{\r\n        &quot;id&quot;: &quot;1335735520073232385&quot;,\r\n        &quot;created_at&quot;: &quot;2020-12-07 05:28:59 IST&quot;,\r\n        &quot;username&quot;: &quot;kristinaforest&quot;,\r\n        &quot;tweet&quot;: &quot;@iamsandyhall It’s the look of surprise on her face and the vulnerability on his &#128151;&quot;,\r\n        &quot;vendor&quot;: &quot;null&quot;\r\n    },\r\n    {\r\n        &quot;id&quot;: &quot;1335735456223399937&quot;,\r\n        &quot;created_at&quot;: &quot;2020-12-07 05:28:44 IST&quot;,\r\n        &quot;username&quot;: &quot;openbugbounty&quot;,\r\n        &quot;tweet&quot;: &quot;@lyrsense please notify your IT security team about a security vulnerability OBB-1583432 on your website  &quot;,\r\n        &quot;vendor&quot;: &quot;openbugbounty&quot;\r\n    },\r\n    {\r\n        &quot;id&quot;: &quot;1335735446496817152&quot;,\r\n        &quot;created_at&quot;: &quot;2020-12-07 05:28:41 IST&quot;,\r\n        &quot;username&quot;: &quot;openbugbounty&quot;,\r\n        &quot;tweet&quot;: &quot;@arstechnica please notify your IT security team about a security vulnerability OBB-1583440 on your website  &quot;,\r\n        &quot;vendor&quot;: &quot;openbugbounty&quot;\r\n    },\r\n    {\r\n        &quot;id&quot;: &quot;1335735260957564929&quot;,\r\n        &quot;created_at&quot;: &quot;2020-12-07 05:27:57 IST&quot;,\r\n        &quot;username&quot;: &quot;tpwk_falls&quot;,\r\n        &quot;tweet&quot;: &quot;2 years into a song of vulnerability - a catchy melody embedded with honest lyrics opening up about a difficult time. Thank u for sharing with us  @zaynmalik I’m so proud of how far you’ve come and continue to go. Forever supporting ur journey #2yearsofgoodyears   PROUD OF ZAYN &quot;,\r\n        &quot;vendor&quot;: &quot;zayn malik&quot;\r\n    }]\r\n\r\n    d = defaultdict(list)\r\n\r\n    for item in flat_json:\r\n        vendor = item.pop(&#39;vendor&#39;)\r\n        d[vendor].append(item)\r\n\r\n    result = [{&#39;vendor&#39;: k, &#39;tweets&#39;: v} for k, v in d.items()]",
                "title": "How to restructure json?"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": -2,
        "last_activity_date": 1625393074,
        "creation_date": 1624857750,
        "last_edit_date": 1625393074,
        "question_id": 68157950,
        "body_markdown": "So I have this json,I want to restructure it so far it&#39;s in a single array. Now I want to sort it according to the vendors. \r\nRight now the structure is \r\nkey1\r\nkey2\r\nkey3\r\n\r\nkey1\r\nkey2\r\nkey3\r\n\r\n\r\n```\r\n{\r\n  &quot;id&quot;: &quot;1335735520073232385&quot;,\r\n  &quot;created_at&quot;: &quot;2020-12-07 05:28:59 IST&quot;,\r\n  &quot;username&quot;: &quot;kristinaforest&quot;,\r\n  &quot;tweet&quot;: &quot;@iamsandyhall It’s the look of surprise on her face and the vulnerability on his &#128151;&quot;\r\n  &quot;vendor&quot;: &quot;null&quot;\r\n}\r\n{\r\n  &quot;id&quot;: &quot;1335735456223399937&quot;,\r\n  &quot;created_at&quot;: &quot;2020-12-07 05:28:44 IST&quot;,\r\n  &quot;username&quot;: &quot;openbugbounty&quot;,\r\n  &quot;tweet&quot;: &quot;@lyrsense please notify your IT security team about a security vulnerability OBB-1583432 on your website  &quot;\r\n  &quot;vendor&quot;: &quot;openbugbounty&quot;\r\n}\r\n{\r\n  &quot;id&quot;: &quot;1335735446496817152&quot;,\r\n  &quot;created_at&quot;: &quot;2020-12-07 05:28:41 IST&quot;,\r\n  &quot;username&quot;: &quot;openbugbounty&quot;,\r\n  &quot;tweet&quot;: &quot;@arstechnica please notify your IT security team about a security vulnerability OBB-1583440 on your website  &quot;\r\n  &quot;vendor&quot;: &quot;openbugbounty&quot;\r\n}\r\n{\r\n  &quot;id&quot;: &quot;1335735260957564929&quot;,\r\n  &quot;created_at&quot;: &quot;2020-12-07 05:27:57 IST&quot;,\r\n  &quot;username&quot;: &quot;tpwk_falls&quot;,\r\n  &quot;tweet&quot;: &quot;2 years into a song of vulnerability - a catchy melody embedded with honest lyrics opening up about a difficult time. Thank u for sharing with us  @zaynmalik I’m so proud of how far you’ve come and continue to go. Forever supporting ur journey #2yearsofgoodyears   PROUD OF ZAYN &quot;\r\n  &quot;vendor&quot;: &quot;zayn malik&quot;\r\n}\r\n```\r\n\r\nHow do I restructure it to\r\n```\r\n[\r\n  {\r\n    &quot;vendor&quot;: &quot;openbugbounty&quot;,\r\n    &quot;tweets&quot;: [\r\n        {\r\n       &quot;id&quot;: &quot;1335735260957564929&quot;,\r\n       &quot;created_at&quot;: &quot;2020-12-07 05:27:57 IST&quot;,\r\n       &quot;username&quot;: &quot;tpwk_falls&quot;,\r\n       &quot;tweet&quot;: &quot;2 years into a song of vulnerability - a catchy melody embedded with            \r\n        honest lyrics opening up about a difficult time. Thank u for sharing with us    \r\n        @zaynmalik I’m so proud of how far you’ve come and continue to go. Forever  \r\n        supporting ur journey #2yearsofgoodyears   PROUD OF ZAYN&quot;\r\n        },\r\n       {\r\n       &quot;id&quot;: &quot;1335735260957564929&quot;,\r\n       &quot;created_at&quot;: &quot;2020-12-07 05:27:57 IST&quot;,\r\n       &quot;username&quot;: &quot;tpwk_falls&quot;,\r\n       &quot;tweet&quot;: &quot;2 years into a song of vulnerability - a catchy melody embedded with            \r\n        honest lyrics opening up about a difficult time. Thank u for sharing with us    \r\n        @zaynmalik I’m so proud of how far you’ve come and continue to go. Forever  \r\n        supporting ur journey #2yearsofgoodyears   PROUD OF ZAYN  &quot;\r\n        }\r\n     ]\r\n   },\r\n .....\r\n```",
        "link": "https://stackoverflow.com/questions/68157950/how-to-restructure-json",
        "title": "How to restructure json?"
    },
    {
        "tags": [
            "jq",
            "yq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1624865518,
                "last_edit_date": 1624865518,
                "creation_date": 1624863655,
                "answer_id": 68158899,
                "question_id": 68158827,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The problem is `abc` is not interpreted as a _literal_ string, when the double quotes are expanded by the shell. The underlying `jq` wrapper tries to match with `abc` as a standard built-in or a user-defined function which it was not able to resolve to, hence the error.\r\n\r\nA JSON string (needed for `jq`) type needs to be quoted with `&quot;..&quot;` to be consistent with the JSON grammar. One way would be to pass the arg via command line with the `--arg` support\r\n\r\n```bash\r\nyq -y -i --arg t &quot;$token&quot; --arg a &quot;$alias&quot; &#39;.tokens += { ($a): { value: $t } }&#39; /root/.github.yml\r\n```\r\n\r\nOr have a quoting mess like below, which I don&#39;t recommend at all\r\n\r\n```bash\r\nyq -y -i &#39;.tokens += { &quot;&#39;&quot;$alias&quot;&#39;&quot;: { value: &quot;&#39;&quot;$token&quot;&#39;&quot; }}&#39; /root/.github.yml\r\n```",
                "title": "Using kislyuk/yq returns syntax error, unexpected INVALID_CHARACTER with additional /0 at the end"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1624865518,
        "creation_date": 1624863319,
        "last_edit_date": 1624864025,
        "question_id": 68158827,
        "body_markdown": "I am using kislyuk/yq - The more often talked about version, which is a wrapper over jq, written in Python using the PyYAML library for YAML parsing\r\n\r\nThe version is yq 2.12.2\r\n\r\nMy jq is jq-1.6\r\n\r\nI&#39;m using ubuntu and bash scripts to do my parsing.\r\n\r\nI wrote this as bash\r\n```\r\nalias=alias1\r\ntoken=abc\r\n\r\nyq -y -i  &quot;.tokens += { $alias: { value: $token }}&quot; /root/.github.yml\r\n```\r\n\r\nI get the following error\r\n\r\n```\r\njq: error: abc/0 is not defined at &lt;top-level&gt;, line 1:\r\n.tokens += { alias1: { value: abc }}\r\n```\r\n\r\nI don&#39;t get it. Why would there be a /0 at the end?\r\n\r\n",
        "link": "https://stackoverflow.com/questions/68158827/using-kislyuk-yq-returns-syntax-error-unexpected-invalid-character-with-additio",
        "title": "Using kislyuk/yq returns syntax error, unexpected INVALID_CHARACTER with additional /0 at the end"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "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": 1627494590,
                "post_id": 68159673,
                "comment_id": 121174119,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 8,
                "is_accepted": false,
                "score": 8,
                "last_activity_date": 1624873284,
                "last_edit_date": 1624873284,
                "creation_date": 1624870973,
                "answer_id": 68160498,
                "question_id": 68159673,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If you&#39;re ok with providing a regular expression, you can use `test`.\r\n\r\n```jq\r\n.user | test(&quot;thinking&quot;; &quot;i&quot;)\r\n```\r\n\r\n[jqplay](https://jqplay.org/s/VeSwVQ4i4Y)\r\n\r\n---\r\n\r\nComments made by the OP lead me to believe they might want to find *words*. For a simple definition of word, you could use the following:\r\n\r\n```jq\r\n.user | test(&quot;\\\\bthinking\\\\b&quot;; &quot;i&quot;)\r\n```\r\n\r\n[jqplay](https://jqplay.org/s/guD2GFiM8W)",
                "title": "jq case insensitive contains"
            },
            {
                "up_vote_count": 22,
                "is_accepted": true,
                "score": 22,
                "last_activity_date": 1624893158,
                "last_edit_date": 1624893158,
                "creation_date": 1624872150,
                "answer_id": 68160770,
                "question_id": 68159673,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "It often suffices to convert both strings to the same typographical case using `ascii_upcase` or `ascii_downcase`, as in your case:\r\n\r\n\r\n    .user | ascii_downcase | contains(&quot;thinking&quot;)\r\n\r\nIf you want to test for equality of strings, ignoring (ASCII) case, you would write something along the lines of:\r\n\r\n    (S|ascii_upcase) == (T|ascii_upcase)\r\n\r\n\r\nIf you wanted to test for equality ignoring case more generally, then you should consider anchoring the regex, e.g.\r\n\r\n    .user | test(&quot;^thinking$&quot;; &quot;i&quot;)\r\n\r\nFinally, in light of some of the comments, please also note that `S | contains(T)` does a substring match when S and T are both strings.\r\n\r\n",
                "title": "jq case insensitive contains"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 4,
        "last_activity_date": 1695372892,
        "creation_date": 1624867298,
        "last_edit_date": 1627494561,
        "question_id": 68159673,
        "body_markdown": "Does jq contains support case insensitive matching?\r\n\r\nGiven this filter:\r\n\r\n```\r\n.user | contains(&quot;thinking&quot;)\r\n```\r\n\r\nand the JSON:\r\n\r\n```\r\n{\r\n  &quot;id&quot;: &quot;1338268256814161923&quot;,\r\n  &quot;user&quot;: &quot;Thinking of going through the Venmo transactions on my feed and liking all of them just to create a little sense of vulnerability&quot;\r\n}\r\n```\r\n\r\nOutput is &quot;false&quot;, but I&#39;d like to get &quot;true&quot;.\r\n\r\njq has an `i` flag for `test` and `match`. Is there anything similar for `contains`?",
        "link": "https://stackoverflow.com/questions/68159673/jq-case-insensitive-contains",
        "title": "jq case insensitive contains"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1666503112,
                "last_edit_date": 1666503112,
                "creation_date": 1624872758,
                "answer_id": 68160909,
                "question_id": 68160740,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "This is [a bug](https://github.com/stedolan/jq/issues/2140) in jq 1.6. In this case you can use try-catch instead.\r\n```\r\ndef numberify($x): $x | try tonumber catch 0;\r\n```\r\nBut I don&#39;t know if there is a generic way to walk around this issue. ",
                "title": "Update operator yields empty object in JQ"
            },
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1624894804,
                "last_edit_date": 1624894804,
                "creation_date": 1624873152,
                "answer_id": 68161026,
                "question_id": 68160740,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "This is a bug in jq 1.6.  One option would be to use an earlier version of jq (e.g. jq 1.5).  \r\n\r\nAnother would be to avoid `|=` by using `=` instead, along the lines of:\r\n\r\n    .a = (.a | ...)\r\n\r\nor if the RHS does not actually depend on the LHS (as in your original examples), simply replacing `|=` by `=`.  \r\n",
                "title": "Update operator yields empty object in JQ"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 2,
        "last_activity_date": 1666503112,
        "creation_date": 1624872054,
        "last_edit_date": 1624897603,
        "question_id": 68160740,
        "body_markdown": "I cannot understand the behaviour of the update operator of jq (version 1.6) shown in the following examples.\r\n\r\nWhy does example 1 return an updated object, but example 2 and 3 return an empty object or a wrong result?\r\n\r\nThe difference between the examples is only the calling order of the function to convert a string into a number.\r\n\r\n```\r\n#!/bin/bash\r\n#\r\n# strange behaviour jq\r\n\r\n# example 1 - works as expected\r\njq -n &#39;\r\n  def numberify($x): $x | tonumber? // 0;\r\n\r\n  &quot;1&quot; as $stringValue\r\n  | numberify($stringValue) as $intValue\r\n# | { }                                     # version 1: a.b does not exist yet\r\n  | { a: { b: 1 } }                         # version 2: a.b exists already\r\n  | .[&quot;a&quot;] |= { b: (.b + $intValue) }\r\n&#39;\r\n# result example 1, version 1 - expected\r\n#   {\r\n#     &quot;a&quot;: {\r\n#       &quot;b&quot;: 1\r\n#     }\r\n#   }\r\n\r\n# result example 1, version 2 - expected\r\n#   {\r\n#     &quot;a&quot;: {\r\n#       &quot;b&quot;: 2\r\n#     }\r\n#   }\r\n\r\n\r\n# example 2 - erroneous result\r\njq -n &#39;\r\n  def numberify($x): $x | tonumber? // 0;\r\n\r\n  &quot;1&quot; as $stringValue\r\n# | { }                           # version 1: a.b does not exist yet\r\n  | { a: { b: 1 } }               # version 2: a.b exists already\r\n  | .[&quot;a&quot;] |= { b: (.b + numberify($stringValue)) }\r\n&#39;\r\n# result example 2, version 1 - unexpected\r\n#   {}\r\n\r\n# result example 2, version 2 - unexpected\r\n#   {}\r\n\r\n\r\n# example 3 - erroneous result\r\njq -n &#39;\r\n  def numberify($x): $x | try tonumber catch 0;\r\n\r\n  &quot;1&quot; as $stringValue\r\n# | { }                           # version 1: a.b does not exist yet\r\n  | { a: { b: 1 } }               # version 2: a.b exists already\r\n  | .[&quot;a&quot;] |= { b: (.b + numberify($stringValue)) }\r\n&#39;\r\n# result example 3, version 1 - unexpected\r\n#   {\r\n#     &quot;a&quot;: {\r\n#       &quot;b&quot;: 0\r\n#     }\r\n#   }\r\n\r\n# result example 3, version 2 - unexpected\r\n#   {\r\n#     &quot;a&quot;: {\r\n#       &quot;b&quot;: 1\r\n#     }\r\n#   }\r\n```\r\n\r\n&lt;hr/&gt;\r\n\r\n@oguzismail That&#39;s a good idea to use &#39;+=&#39; instead of &#39;|=&#39;. \r\nI hadn&#39;t thought of it before.\r\nCurrently, my code with the workaround for the bug looks like this:\r\n\r\n```\r\n  def numberify($x): $x | tonumber? // 0;\r\n\r\n  &quot;1&quot; as $sumReqSize\r\n  | &quot;10&quot; as $sumResSize\r\n  | { statistics: { count: 1, sumReqSize: 2, sumResSize: 20 } }\r\n  | [numberify($sumReqSize), numberify($sumResSize)] as $sizes     # workaround for bug\r\n  | .statistics |= {\r\n                     count: (.count + 1),\r\n                     sumReqSize: (.sumReqSize + $sizes[0]),\r\n                     sumResSize: (.sumResSize + $sizes[1])\r\n                   }\r\n&#39;\r\n```\r\n\r\n\r\nFollowing your suggestion it will be more concise and doesn&#39;t need the ugly workaround:\r\n```\r\n  def numberify($x): $x | tonumber? // 0;\r\n\r\n  &quot;1&quot; as $sumReqSize\r\n  | &quot;10&quot; as $sumResSize\r\n  | { statistics: { count: 1, sumReqSize: 2, sumResSize: 20 } }\r\n  | .statistics.count += 1\r\n  | .statistics.sumReqSize += numberify($sumReqSize)\r\n  | .statistics.sumResSize += numberify($sumResSize)\r\n```\r\n",
        "link": "https://stackoverflow.com/questions/68160740/update-operator-yields-empty-object-in-jq",
        "title": "Update operator yields empty object in JQ"
    },
    {
        "tags": [
            "json",
            "jq",
            "string-matching",
            "case-insensitive"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1624874971,
                "last_edit_date": 1624874971,
                "creation_date": 1624873963,
                "answer_id": 68161239,
                "question_id": 68160918,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "As pointed out by @OguzIsmail, if your jq&#39;s regex engine supports ```\\\\Q...\\\\E```, you can use that.  However, not all versions of oniguruma (and therefore not all published versions of jq) provide such support; in any case, the following jq def for &quot;de-regexing&quot; a string can help reduce the &quot;noise&quot;:\r\n```\r\ndef deregex:\r\n  reduce (&quot;\\\\\\\\&quot;, &quot;\\\\*&quot;, &quot;\\\\^&quot;, &quot;\\\\?&quot;, &quot;\\\\+&quot;, &quot;\\\\.&quot;, &quot;\\\\!&quot;, &quot;\\\\{&quot;, &quot;\\\\}&quot;, &quot;\\\\[&quot;, &quot;\\\\]&quot;, &quot;\\\\$&quot;, &quot;\\\\|&quot; ) as $c\r\n    (.; gsub( $c; $c));\r\n```\r\n\r\n## Example\r\nWith the above def, the following:\r\n```\r\n&quot;A*b&quot; |  test( &quot;a*b&quot;| deregex | debug; &quot;i&quot;)\r\n```\r\n\r\nproduces:\r\n\r\n```\r\n[&quot;DEBUG:&quot;,&quot;a\\\\*b&quot;]\r\ntrue\r\n\r\n```\r\n",
                "title": "Match fixed strings case-insensitively in JQ"
            },
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1624880495,
                "last_edit_date": 1624880495,
                "creation_date": 1624874140,
                "answer_id": 68161294,
                "question_id": 68160918,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "`test` **can** do literal string matching.\r\n```\r\ntest(&quot;\\\\Qstring\\\\E&quot;; &quot;i&quot;)\r\n```\r\n&lt;sup&gt;[Online demo](https://jqplay.org/s/2IJTvnIzLS)&lt;/sup&gt;",
                "title": "Match fixed strings case-insensitively in JQ"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1624876606,
                "creation_date": 1624876606,
                "answer_id": 68161872,
                "question_id": 68160918,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can also use ascii_downcase :\r\n\r\n```\r\n#!/bin/bash\r\nfilename=&#39;v.txt&#39;\r\n\r\nwhile read p; do \r\n    jq --arg p &quot;$p&quot; &#39;\r\ndef contains_i($C; $c):\r\n    $C | ascii_downcase | contains($c|ascii_downcase);\r\n\r\nif contains_i(.tweet; $p)\r\nthen . |= . + {vendor: $p}\r\nelse empty end&#39; sfilter.json\r\ndone &lt; $filename\r\n```",
                "title": "Match fixed strings case-insensitively in JQ"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 1,
        "last_activity_date": 1624880495,
        "creation_date": 1624872776,
        "last_edit_date": 1624880358,
        "question_id": 68160918,
        "body_markdown": "Problem:\r\n.contains does not work with case insensitive; where as test and match creates lots of noise cause it is not string matching.\r\n\r\nMy script\r\n```\r\n#!/bin/bash\r\nfilename=&#39;v.txt&#39;\r\n\r\nwhile read p; do \r\n    jq &#39;if .tweet | contains(&#39;\\&quot;$p\\&quot;&#39;) then . |= . + {vendor: &#39;\\&quot;$p\\&quot;&#39;} else empty end&#39; sfilter.json\r\ndone &lt; $filename\r\n```\r\n\r\nThis was working perfectly; but incase of insensitive content it didn&#39;t work | Alternative, test and match also did not pan out cause they did not do the job of string matching. ",
        "link": "https://stackoverflow.com/questions/68160918/match-fixed-strings-case-insensitively-in-jq",
        "title": "Match fixed strings case-insensitively in JQ"
    },
    {
        "tags": [
            "intellij-idea",
            "jq",
            "intellij-plugin"
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1624923564,
                "last_edit_date": 1624923564,
                "creation_date": 1624923007,
                "answer_id": 68171000,
                "question_id": 68169827,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Any modern code editor should be sufficient for the basic functionality you mention. There&#39;s a listing at\r\nhttps://www.softwaretestinghelp.com/best-code-editor; I&#39;d add Emacs/Aquamacs.\r\n\r\nYou might also like to try one or more of these &quot;jq&quot; add-ons:\r\n\r\n* Sublime https://packagecontrol.io/packages/JQ%20Syntax\r\n* Emacs https://melpa.org/#/jq-mode\r\n* Vim https://github.com/vito-c/jq.vim\r\n* Atom https://atom.io/packages/language-jq\r\n* Visual Studio Code https://marketplace.visualstudio.com/items?itemName=davidnussio.vscode-jq-playground",
                "title": "Which IDEs support development in jq?"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1717671601,
                "creation_date": 1717671601,
                "answer_id": 78586134,
                "question_id": 68169827,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "For IntelliJ (and WebStorm, PhpStorm, etc.), there is a plugin called `jqExpress` that allows you to write complex `jq` filters interactively.\r\n\r\nhttps://plugins.jetbrains.com/plugin/23360-jqexpress\r\n\r\n[![jqExpress jq plugin for IntelliJ WebStorm PhpStorm][1]][1]\r\n\r\nBy default it uses a Java implementation of `jq`, but having `jq` installed locally on your machine you can also instruct it to use the native `jq` binary instead:\r\n\r\n[![jqExpress jq plugin for IntelliJ WebStorm PhpStorm configure jq binary][2]][2]\r\n\r\n\r\n  [1]: https://i.sstatic.net/eAyBJnTv.png\r\n  [2]: https://i.sstatic.net/19RTR0z3.png",
                "title": "Which IDEs support development in jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 3,
        "last_activity_date": 1717671601,
        "creation_date": 1624913209,
        "last_edit_date": 1668172791,
        "question_id": 68169827,
        "body_markdown": "I am using IntelliJ as an IDE.\r\nUnfortunately, IntelliJ does not support jq.\r\nLanguage injection is not offered and I can&#39;t find a suitable plugin.\r\nI searched for &quot;IDE support for jq&quot; or similar many times and surprisingly this brings up nothing useful.\r\n\r\nSometimes I write jq programs that are not just oneliners.\r\nI always struggle with getting the syntax right, for example adding the right amount of brackets in the right place and manually refactoring code into functions is painstaking.\r\n\r\nIntelliJ at least offers a hotkey to jump to the matching bracket (Shift-Ctrl-M), which works in any text file and displays the block enclosed by a pair of brackets in colour in the editor.\r\n\r\n**Are there any special IDE features that make editing jq programs easier?**\r\nFor example, a folding of code blocks based on matching brackets \r\nor a bracket selection feature similar to Ctrl-W for selection in Java would be very helpful. Also, it is important for me to indent the jq code properly to make it more understandable. **Is there any generic support for formatting code?**\r\n\r\nI don&#39;t expect complete refactorings, but any advice on useful editor features that make life easier as a jq programmer is highly welcome. ",
        "link": "https://stackoverflow.com/questions/68169827/which-ides-support-development-in-jq",
        "title": "Which IDEs support development in jq?"
    },
    {
        "tags": [
            "json",
            "csv",
            "export-to-csv",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1624942867,
                "last_edit_date": 1624942867,
                "creation_date": 1624935534,
                "answer_id": 68172080,
                "question_id": 68171713,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The key (ha!) is\r\n\r\n```jq\r\n[ .[ $keys[] ] ]\r\n```\r\n\r\nHad you looked at other answers to questions relating to CSV, you might have noticed the first step taken is to get the list of keys. This is often done by collecting the keys of the input objects. ([Example](https://stackoverflow.com/a/68043093/589924)) In your case, you have a hard-coded list, so it&#39;s even simpler.\r\n\r\n---\r\n\r\nIf you wanted actual CSV, you could use\r\n\r\n```sh\r\njq -sr &#39;\r\n   [ &quot;Name&quot;, &quot;ID&quot;, &quot;Creator&quot;, &quot;Manager&quot;, &quot;User&quot; ] as $keys |\r\n   (\r\n      $keys,\r\n      ( .[].Tags | from_entries | [ .[ $keys[] ] ] )\r\n   ) |\r\n   @csv\r\n&#39; role*.json\r\n```\r\n\r\nThis produces \r\n\r\n```csv\r\n&quot;Name&quot;,&quot;ID&quot;,&quot;Creator&quot;,&quot;Manager&quot;,&quot;User&quot;\r\n&quot;Role1Name&quot;,&quot;Role1ID&quot;,,&quot;Role1Manager&quot;,&quot;Role1User&quot;\r\n&quot;Role2Name&quot;,&quot;Role2ID&quot;,&quot;Role2Creator&quot;,,&quot;Role2User&quot;\r\n&quot;Role3Name&quot;,&quot;Role3ID&quot;,&quot;Role3Creator&quot;,&quot;Role3Manager&quot;,&quot;Role3User&quot;\r\n```\r\n\r\n[jqplay](https://jqplay.org/s/uRVe24KPt1)\r\n\r\nWithout a header:\r\n\r\n```sh\r\njq -r &#39;.Tags | from_entries | [ .[&quot;Name&quot;,&quot;ID&quot;,&quot;Creator&quot;,&quot;Manager&quot;,&quot;User&quot;] ] | @csv&#39; role*.json\r\n```\r\n\r\n[jqplay](https://jqplay.org/s/5Li2gdZrAa)\r\n\r\n---\r\n\r\nTo get the specific output you posted (which isn&#39;t CSV), you could use\r\n\r\n```sh\r\njq -sr &#39;\r\n   [ &quot;Name&quot;, &quot;ID&quot;, &quot;Creator&quot;, &quot;Manager&quot;, &quot;User&quot; ] as $keys |\r\n   (\r\n      $keys,\r\n      ( .[].Tags | from_entries | [ .[ $keys[] ] | . // &quot;null&quot; ] )\r\n   ) |\r\n   join(&quot;, &quot;)\r\n&#39; role*.json\r\n```\r\n\r\nThis produces \r\n\r\n```lang-none\r\nName, ID, Creator, Manager, User\r\nRole1Name, Role1ID, null, Role1Manager, Role1User\r\nRole2Name, Role2ID, Role2Creator, null, Role2User\r\nRole3Name, Role3ID, Role3Creator, Role3Manager, Role3User\r\n```\r\n\r\n[jqplay](https://jqplay.org/s/MCcHV7Q1Yx)\r\n\r\nWithout a header:\r\n\r\n```sh\r\njq -r &#39;.Tags | from_entries | [ .[&quot;Name&quot;,&quot;ID&quot;,&quot;Creator&quot;,&quot;Manager&quot;,&quot;User&quot;] | . // &quot;null&quot; ] | join(&quot;, &quot;)&#39; role*.json\r\n```\r\n\r\n[jqplay](https://jqplay.org/s/TjmhrSvYes)\r\n",
                "title": "jq - select objects and print null for missing"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1624938911,
                "creation_date": 1624938911,
                "answer_id": 68172425,
                "question_id": 68171713,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Got an answer from another forum, might be useful for others\r\n\r\n```\r\n$jq -rc  &#39;.Tags | from_entries | [.Name, .ID, .Creator, .Manager, .User]&#39; role*.json\r\n[&quot;Role1Name&quot;,&quot;Role1ID&quot;,null,&quot;Role1Manager&quot;,&quot;Role1User&quot;]\r\n[&quot;Role2Name&quot;,&quot;Role2ID&quot;,&quot;Role2Creator&quot;,null,&quot;Role2User&quot;]\r\n[&quot;Role3Name&quot;,&quot;Role3ID&quot;,&quot;Role3Creator&quot;,&quot;Role3Manager&quot;,&quot;Role3User&quot;]\r\n```",
                "title": "jq - select objects and print null for missing"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1624944752,
        "creation_date": 1624931849,
        "last_edit_date": 1624944752,
        "question_id": 68171713,
        "body_markdown": "I&#39;m trying to generate a CSV of sort from json file, the files are as below\r\n```\r\ncat role1.json\r\n{\r\n  &quot;Tags&quot;: [\r\n    {\r\n      &quot;Key&quot;: &quot;Name&quot;,\r\n      &quot;Value&quot;: &quot;Role1Name&quot;\r\n    },\r\n    {\r\n      &quot;Key&quot;: &quot;ID&quot;,\r\n      &quot;Value&quot;: &quot;Role1ID&quot;\r\n    },\r\n    {\r\n      &quot;Key&quot;: &quot;Manager&quot;,\r\n      &quot;Value&quot;: &quot;Role1Manager&quot;\r\n    },\r\n    {\r\n      &quot;Key&quot;: &quot;User&quot;,\r\n      &quot;Value&quot;: &quot;Role1User&quot;\r\n    },\r\n    {\r\n      &quot;Key&quot;: &quot;Country&quot;,\r\n      &quot;Value&quot;: &quot;USA&quot;\r\n    }\r\n  ]\r\n}\r\n\r\ncat role2.json\r\n{\r\n  &quot;Tags&quot;: [\r\n    {\r\n      &quot;Key&quot;: &quot;Name&quot;,\r\n      &quot;Value&quot;: &quot;Role2Name&quot;\r\n    },\r\n    {\r\n      &quot;Key&quot;: &quot;ID&quot;,\r\n      &quot;Value&quot;: &quot;Role2ID&quot;\r\n    },\r\n    {\r\n      &quot;Key&quot;: &quot;City&quot;,\r\n      &quot;Value&quot;: &quot;NewYork&quot;\r\n    },\r\n    {\r\n      &quot;Key&quot;: &quot;Creator&quot;,\r\n      &quot;Value&quot;: &quot;Role2Creator&quot;\r\n    },\r\n    {\r\n      &quot;Key&quot;: &quot;User&quot;,\r\n      &quot;Value&quot;: &quot;Role2User&quot;\r\n    }\r\n  ]\r\n}\r\n\r\ncat role3.json\r\n{\r\n  &quot;Tags&quot;: [\r\n    {\r\n      &quot;Key&quot;: &quot;Name&quot;,\r\n      &quot;Value&quot;: &quot;Role3Name&quot;\r\n    },\r\n    {\r\n      &quot;Key&quot;: &quot;ID&quot;,\r\n      &quot;Value&quot;: &quot;Role3ID&quot;\r\n    },\r\n    {\r\n      &quot;Key&quot;: &quot;Creator&quot;,\r\n      &quot;Value&quot;: &quot;Role3Creator&quot;\r\n    },\r\n    {\r\n      &quot;Key&quot;: &quot;ZIP&quot;,\r\n      &quot;Value&quot;: 82378\r\n    },\r\n    {\r\n      &quot;Key&quot;: &quot;Manager&quot;,\r\n      &quot;Value&quot;: &quot;Role3Manager&quot;\r\n    },\r\n    {\r\n      &quot;Key&quot;: &quot;User&quot;,\r\n      &quot;Value&quot;: &quot;Role3User&quot;\r\n    }\r\n  ]\r\n}\r\n```\r\n\r\nI want to generate lines from each of these to be later used as CSV, something like:\r\n\r\n```\r\nRole1Name, Role1ID, null, Role1Manager, Role1User\r\nRole2Name, Role2ID, Role2Creator, null, Role2User\r\nRole3Name, Role3ID, Role3Creator, Role3Manager, Role3User\r\n```\r\n\r\nFor the header line\r\nName, ID, Creator, Manager, User\r\n\r\nI&#39;m able to get all the &quot;Value&quot; but not able to print null for missing &quot;Key&quot;\r\n```\r\n$cat role1.json | jq -rc  &#39;[.Tags[] | select(.Key == (&quot;Name&quot;,&quot;ID&quot;,&quot;Creator&quot;,&quot;Manager&quot;,&quot;User&quot;)) | .Value]&#39;\r\n[&quot;Role1Name&quot;,&quot;Role1ID&quot;,&quot;Role1Manager&quot;,&quot;Role1User&quot;]\r\n\r\n$cat role2.json | jq -rc  &#39;[.Tags[] | select(.Key == (&quot;Name&quot;,&quot;ID&quot;,&quot;Creator&quot;,&quot;Manager&quot;,&quot;User&quot;)) | .Value]&#39;\r\n[&quot;Role2Name&quot;,&quot;Role2ID&quot;,&quot;Role2Creator&quot;,&quot;Role2User&quot;]\r\n\r\n$cat role3.json | jq -rc  &#39;[.Tags[] | select(.Key == (&quot;Name&quot;,&quot;ID&quot;,&quot;Creator&quot;,&quot;Manager&quot;,&quot;User&quot;)) | .Value]&#39;\r\n[&quot;Role3Name&quot;,&quot;Role3ID&quot;,&quot;Role3Creator&quot;,&quot;Role3Manager&quot;,&quot;Role3User&quot;]\r\n```\r\nCan someone share with me how this can be done using jq.\r\n\r\nAlso, how can we enforce the order.\r\n\r\nThanks!\r\n\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/68171713/jq-select-objects-and-print-null-for-missing",
        "title": "jq - select objects and print null for missing"
    },
    {
        "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": 0,
                "creation_date": 1624962741,
                "post_id": 68176925,
                "comment_id": 120494825,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 5681576,
                    "reputation": 55,
                    "user_id": 4492590,
                    "user_type": "registered",
                    "accept_rate": 20,
                    "profile_image": "https://www.gravatar.com/avatar/7ff78c93a829b2e2b4e78da783fcbee4?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Alexdharma",
                    "link": "https://stackoverflow.com/users/4492590/alexdharma"
                },
                "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": 1624963573,
                "post_id": 68176925,
                "comment_id": 120495151,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1624965768,
                "creation_date": 1624965768,
                "answer_id": 68177722,
                "question_id": 68176925,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "To get the following filter where:\r\n\r\n* `.type == &quot;person&quot;` --&gt; We use keys: `inn` and `reqId`\r\n* `.type != &quot;person&quot;` --&gt; We use keys: `cuid` and `reqId`\r\n\r\nWe can use:\r\n```\r\nif .type == &quot;person&quot; then { inn } else { cuid } end + { reqId }\r\n```\r\n\r\nThe differences I&#39;ve made:\r\n\r\n* Added the last part: `+ { reqId }`. Here we add the `reqId` to the object created by the `if` statement.\r\n\r\n* I&#39;ve removed the `.inn as $inn` part this we can just use the key for this.\r\n\r\n#### [JqPlay Demo](https://jqplay.org/s/SDAOLxPehi)",
                "title": "jq: create new json basing on existing json with usage if else"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1624965810,
                "creation_date": 1624965810,
                "answer_id": 68177730,
                "question_id": 68176925,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can solve your problem easily with one ```if then else end``` expression:\r\n\r\n``` \r\njq &#39;if .type == &quot;person&quot;\r\n    then {inn, reqId}\r\n    else {cuid, reqId}\r\n    end&#39; &lt;&lt;&lt; &#39;{ &quot;inn&quot; : &quot;qwerty&quot;, &quot;cuid&quot; : &quot;1234&quot;, &quot;type&quot; : &quot;legal&quot;, &quot;reqId&quot; : &quot;asdfg&quot; }&#39;\r\n\r\n# result\r\n# {\r\n#   &quot;cuid&quot;: &quot;1234&quot;,\r\n#   &quot;reqId&quot;: &quot;asdfg&quot;\r\n# }\r\n\r\njq &#39;if .type == &quot;person&quot;\r\n    then {inn, reqId}\r\n    else {cuid, reqId}\r\n    end&#39; &lt;&lt;&lt; &#39;{ &quot;inn&quot; : &quot;qwerty&quot;, &quot;cuid&quot; : &quot;1234&quot;, &quot;type&quot; : &quot;person&quot;, &quot;reqId&quot; : &quot;asdfg&quot; }&#39;\r\n\r\n# result\r\n# {\r\n#   &quot;inn&quot;: &quot;qwerty&quot;,\r\n#   &quot;reqId&quot;: &quot;asdfg&quot;\r\n# }\r\n``` \r\n",
                "title": "jq: create new json basing on existing json with usage if else"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1624965810,
        "creation_date": 1624962381,
        "last_edit_date": 1624963525,
        "question_id": 68176925,
        "body_markdown": "now I have following problem. \r\n\r\nthere is such input json\r\n```\r\n{\r\n“inn” : “qwerty”,\r\n“cuid” : “1234”,\r\n“type” : &quot;legal&quot;,\r\n“reqId” : “asdfg”\r\n}\r\n\r\n```\r\n\r\nIt should be transformed into \r\n\r\n```\r\n{\r\n“inn” : “qwerty”,\r\n“reqId” : “asdfg”\r\n}\r\n\r\n```\r\n\r\nor into \r\n\r\n```\r\n{\r\n“cuid” : “1234”,\r\n“reqId” : “asdfg”\r\n}\r\n\r\n```\r\n\r\nit depends on a value of &quot;type&quot; field. How can I do that with JQ?\r\n\r\nMy attempts were failed, it all was about trying such way\r\n\r\n.inn as $inn | .cuid as  $cuid | {if .type == &quot;person&quot; then $inn else $cuid end}\r\n\r\nbut it gave such result \r\n&gt; jq: error: syntax error, unexpected FIELD, expecting &#39;:&#39; (Unix shell quoting issues?) at &lt;top-level&gt;, line 1:\r\n.inn as $inn | .cuid as  $cuid | {if .type == &quot;person&quot; then $inn else $cuid end}                                     \r\njq: 1 compile error\r\nexit status 3",
        "link": "https://stackoverflow.com/questions/68176925/jq-create-new-json-basing-on-existing-json-with-usage-if-else",
        "title": "jq: create new json basing on existing json with usage if else"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 6313442,
                    "reputation": 45115,
                    "user_id": 5625547,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/oqCND.jpg?s=256",
                    "display_name": "0stone0",
                    "link": "https://stackoverflow.com/users/5625547/0stone0"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1624966897,
                "post_id": 68177864,
                "comment_id": 120496482,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 22064255,
                    "reputation": 133,
                    "user_id": 16326391,
                    "user_type": "registered",
                    "profile_image": "https://lh3.googleusercontent.com/a-/AOh14Gj1ZtS3KT_kVkEqM5_SW1ryeKDaBEvoqLmHzExW=k-s256",
                    "display_name": "Fight Daily",
                    "link": "https://stackoverflow.com/users/16326391/fight-daily"
                },
                "reply_to_user": {
                    "account_id": 6313442,
                    "reputation": 45115,
                    "user_id": 5625547,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/oqCND.jpg?s=256",
                    "display_name": "0stone0",
                    "link": "https://stackoverflow.com/users/5625547/0stone0"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1624967088,
                "post_id": 68177864,
                "comment_id": 120496572,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1624967569,
                "last_edit_date": 1624967569,
                "creation_date": 1624967034,
                "answer_id": 68178041,
                "question_id": 68177864,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "pass the value of ```p``` to your jq program like this:\r\n\r\n```\r\nwhile read p; do\r\n    jq --arg p &quot;$p&quot; &#39;if .tweet | test($p; &quot;i&quot;) then . |= . + {vendor: $p} else empty end&#39; sfilter.json\r\ndone &lt; $filename\r\n```\r\n\r\nThe shell error occurs because you concatenated the string incorrectly.\r\nTry this:\r\n\r\n```\r\np=value\r\nJQ_program=&#39;if .tweet | test(&quot;&#39;&quot;$p&quot;&#39;&quot;; &quot;i&quot;) then . |= . + {vendor: &quot;&#39;&quot;$p&quot;&#39;&quot;} else empty end&#39;\r\necho &quot;$JQ_program&quot;\r\n\r\n# result\r\n# if .tweet | test(&quot;value&quot;; &quot;i&quot;) then . |= . + {vendor: &quot;value&quot;} else empty end\r\n```\r\n",
                "title": "What is wrong with this bash script"
            },
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1624967042,
                "creation_date": 1624967042,
                "answer_id": 68178044,
                "question_id": 68177864,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Don&#39;t generate a dynamic `jq` filter using string interpolation. Pass the value via the `--arg` option.\r\n\r\n    #!/bin/bash\r\n    filename=&#39;delete&#39;\r\n    \r\n    while IFS= read -r p; do \r\n        jq --arg p &quot;$p&quot; &#39;if .tweet | test($p; &quot;i&quot;) then . |= . + {vendor: $p} else empty end&#39; sfilter.json\r\n    done &lt; &quot;$filename&quot;",
                "title": "What is wrong with this bash script"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": -1,
        "last_activity_date": 1624967569,
        "creation_date": 1624966313,
        "last_edit_date": 1624967022,
        "question_id": 68177864,
        "body_markdown": "```\r\n#!/bin/bash\r\nfilename=&#39;delete&#39;\r\n\r\nwhile read p; do \r\n    jq &#39;if .tweet | test(&#39;\\&quot;$p\\&quot;&#39;; &quot;i&quot;) then . |= . + {vendor: &#39;\\&quot;$p\\&quot;&#39;} else empty end&#39; sfilter.json\r\ndone &lt; $filename\r\n```\r\nI keep getting this error, when I use variable = &quot;hello world&quot; but not &quot;hello&quot;\r\nInshort whenever there is a space in letter it causes this error.\r\n\r\nBut while executing directly on shell there seems to be no error.\r\n```\r\njq: error: syntax error, unexpected $end, expecting QQSTRING_TEXT or QQSTRING_INTERP_START or QQSTRING_END (Unix shell quoting issues?) at &lt;top-level&gt;, line 1:\r\nif .tweet | test(&quot;sdas                  \r\njq: 1 compile error\r\n\r\n```\r\nBut when I run the command on shell it works perfectly. Any ideas?\r\n\r\nEdit:\r\nInput delete file\r\n\r\nsdas adssad\r\n",
        "link": "https://stackoverflow.com/questions/68177864/what-is-wrong-with-this-bash-script",
        "title": "What is wrong with this bash script"
    },
    {
        "tags": [
            "json",
            "linux",
            "bigdata",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 51201,
                    "reputation": 243376,
                    "user_id": 152948,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/194ef8f807c34a9d7aab0e11a8674768?s=256&d=identicon&r=PG",
                    "display_name": "hobbs",
                    "link": "https://stackoverflow.com/users/152948/hobbs"
                },
                "edited": false,
                "score": 5,
                "creation_date": 1624976241,
                "post_id": 68180419,
                "comment_id": 120500823,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 11699316,
                    "reputation": 7967,
                    "user_id": 8564999,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/bWepU.jpg?s=256",
                    "display_name": "Alexey S. Larionov",
                    "link": "https://stackoverflow.com/users/8564999/alexey-s-larionov"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1624976466,
                "post_id": 68180419,
                "comment_id": 120500927,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 51201,
                    "reputation": 243376,
                    "user_id": 152948,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/194ef8f807c34a9d7aab0e11a8674768?s=256&d=identicon&r=PG",
                    "display_name": "hobbs",
                    "link": "https://stackoverflow.com/users/152948/hobbs"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1624983778,
                "post_id": 68180419,
                "comment_id": 120504151,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 5301,
                    "reputation": 94077,
                    "user_id": 8454,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/2NlHs.png?s=256",
                    "display_name": "Andy Lester",
                    "link": "https://stackoverflow.com/users/8454/andy-lester"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1625004652,
                "post_id": 68180419,
                "comment_id": 120510632,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1092869,
                    "reputation": 21464,
                    "user_id": 1087119,
                    "user_type": "registered",
                    "accept_rate": 50,
                    "profile_image": "https://i.sstatic.net/CMEVE.png?s=256",
                    "display_name": "Christian Fritz",
                    "link": "https://stackoverflow.com/users/1087119/christian-fritz"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1625008172,
                "post_id": 68180419,
                "comment_id": 120511264,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2984910,
                    "reputation": 3782,
                    "user_id": 2533998,
                    "user_type": "registered",
                    "accept_rate": 69,
                    "profile_image": "https://www.gravatar.com/avatar/2af169e786f598773c4b708dff7d5b7f?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Dhanushka Amarakoon",
                    "link": "https://stackoverflow.com/users/2533998/dhanushka-amarakoon"
                },
                "reply_to_user": {
                    "account_id": 1092869,
                    "reputation": 21464,
                    "user_id": 1087119,
                    "user_type": "registered",
                    "accept_rate": 50,
                    "profile_image": "https://i.sstatic.net/CMEVE.png?s=256",
                    "display_name": "Christian Fritz",
                    "link": "https://stackoverflow.com/users/1087119/christian-fritz"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1625121199,
                "post_id": 68180419,
                "comment_id": 120543766,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1092869,
                    "reputation": 21464,
                    "user_id": 1087119,
                    "user_type": "registered",
                    "accept_rate": 50,
                    "profile_image": "https://i.sstatic.net/CMEVE.png?s=256",
                    "display_name": "Christian Fritz",
                    "link": "https://stackoverflow.com/users/1087119/christian-fritz"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1625154889,
                "post_id": 68180419,
                "comment_id": 120558515,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1625219222,
                "last_edit_date": 1625219222,
                "creation_date": 1625003643,
                "answer_id": 68186100,
                "question_id": 68180419,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Assuming that your large file contains a lot on json objects, you can process them one by one and extract the field `.data[]`.\r\n\r\nThis way, the memory consumption is limited by the size of the largest json from the input and not by the sum of the sizes of all json inputs.\r\n\r\nOr is your problem that a _single_ json object is so large that the memory is insufficient?\r\n\r\n```bash\r\necho &#39;\r\n{ &quot;key&quot;:&quot;A1&quot;, &quot;property&quot;:&quot;A2&quot;, &quot;data&quot;:[1,2,3] }{&quot;key&quot;:&quot;B1&quot;,&quot;property&quot;:&quot;B2&quot;,&quot;data&quot;:[4,5,6]}\r\n{ \r\n   &quot;key&quot;:&quot;C1&quot;, \r\n   &quot;property&quot;:&quot;C2&quot;, \r\n   &quot;data&quot;:[7,8,9] \r\n}&#39; | jq -cr &#39;.data[]&#39;\r\n```\r\n\r\nresult\r\n```\r\n1\r\n2\r\n3\r\n4\r\n5\r\n6\r\n7\r\n8\r\n9\r\n```\r\n",
                "title": "Using jq on a large json file (50GB)"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1673625047,
                "last_edit_date": 1673625047,
                "creation_date": 1673623781,
                "answer_id": 75111225,
                "question_id": 68180419,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "For your example, the following would suffice:\r\n\r\n    jq -cn --stream &#39;fromstream( inputs|(.[0] |= .[2:]) | select(. != [[]]) )&#39;\r\n\r\nIf you only wanted the .data array to be itemized, replace `inputs` in the above by:\r\n\r\n    inputs|select(first|first==&quot;data&quot;)\r\n\r\nFor the record, you could also use gojq (the Go implementation of jq) in exactly the same way.",
                "title": "Using jq on a large json file (50GB)"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1673675797,
                "last_edit_date": 1673675797,
                "creation_date": 1673625573,
                "answer_id": 75111589,
                "question_id": 68180419,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "&gt; what other tool can get the job done?\r\n\r\n[jm][1], a command-line wrapper I wrote for “JSON Machine”, is very easy to use and often more economical than jq’s streaming parser.  In the present case, to itemize .data, you would write:\r\n\r\n    jm —-pointer &#39;/data&#39;\r\n\r\n\r\nOr similarly, using the Python-based script in the same repository:\r\n\r\n    jm.py -i data.item file.json\r\n\r\nAssuming there is just one top-level key, then another alternative in this particular case would be:\r\n\r\n    jstream -d 2 &lt;  file.json\r\n\r\n\r\n  [1]: https://GitHub.com/pkoppstein/jm",
                "title": "Using jq on a large json file (50GB)"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 6,
        "last_activity_date": 1678101472,
        "creation_date": 1624975816,
        "last_edit_date": 1678101472,
        "question_id": 68180419,
        "body_markdown": "I want to use jq on a 50GB file. Needless to say the machines memory can&#39;t handle it. It&#39;s running out of memory.\r\n\r\nI tried several options including --stream but it didn&#39;t help. Can someone tell me what I&#39;m doing wrong ? And how to fix it\r\n\r\n```\r\njq -cn --stream &#39;fromstream(1|truncate_stream(inputs))&#39; file.json |   jq -cr .data[] &gt;&gt; out.json\r\n```\r\n\r\nThe file contains data like this:\r\n\r\n```\r\n{&quot;data&quot;:[{&quot;id&quot;:&quot;id1&quot;,&quot;value&quot;:&quot;value1&quot;},{&quot;id&quot;:&quot;id2&quot;,&quot;value&quot;:&quot;value2&quot;},{&quot;id&quot;:&quot;id3&quot;,&quot;value&quot;:&quot;value3&quot;}...]}\r\n```\r\n\r\ni want to read each value of the array in the data field and put it line by line in another file. such as below\r\n\r\n```\r\n{&quot;id&quot;:&quot;id1&quot;,&quot;value&quot;:&quot;value1&quot;}\r\n{&quot;id&quot;:&quot;id2&quot;,&quot;value&quot;:&quot;value2&quot;}\r\n{&quot;id&quot;:&quot;id3&quot;,&quot;value&quot;:&quot;value3&quot;}\r\n``` \r\n\r\nRight now the command is running out of memory and gets killed. ",
        "link": "https://stackoverflow.com/questions/68180419/using-jq-on-a-large-json-file-50gb",
        "title": "Using jq on a large json file (50GB)"
    },
    {
        "tags": [
            "json",
            "jq",
            "timezone-offset",
            "timestamp-with-timezone"
        ],
        "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": 4,
                "creation_date": 1624978149,
                "post_id": 68180684,
                "comment_id": 120501741,
                "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": 1624979788,
                "post_id": 68180684,
                "comment_id": 120502450,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1624979935,
                "post_id": 68180684,
                "comment_id": 120502518,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1143565,
                    "reputation": 535973,
                    "user_id": 1126841,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/fa05233b2357f8d11c22ef4cfc7bb85c?s=256&d=identicon&r=PG",
                    "display_name": "chepner",
                    "link": "https://stackoverflow.com/users/1126841/chepner"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1624981075,
                "post_id": 68180684,
                "comment_id": 120503026,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1143565,
                    "reputation": 535973,
                    "user_id": 1126841,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/fa05233b2357f8d11c22ef4cfc7bb85c?s=256&d=identicon&r=PG",
                    "display_name": "chepner",
                    "link": "https://stackoverflow.com/users/1126841/chepner"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1624981391,
                "post_id": 68180684,
                "comment_id": 120503168,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1624980620,
                "last_edit_date": 1624980620,
                "creation_date": 1624979524,
                "answer_id": 68181415,
                "question_id": 68180684,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "One way would be to use a custom function to strip off the timezone part and format the date string to a format compatible that `jq` can parse. \r\n\r\nNote that this **only** works when your reference and source strings are in the same timezone offset.\r\n\r\n```bash\r\njq --arg ref &quot;2021-01-01T02:00:00+02:00&quot; &#39;\r\n  def c(str): str | (split(&quot;+&quot;)[0] + &quot;Z&quot;) | fromdate ; \r\n  .MyList | map(select( c(.LastAccessedDate) &gt; c($ref) ))&#39; json\r\n```\r\n\r\nFrom jq Manual\r\n\r\n&gt; The `fromdate` builtin parses datetime strings. Currently `fromdate` only supports **ISO 8601 datetime** strings, but in the future it will attempt to parse datetime strings in more formats.\r\n\r\n",
                "title": "jq fromdate &quot;does not match format &quot;%Y-%m-%dT%H:%M:%SZ&quot;"
            },
            {
                "up_vote_count": 5,
                "is_accepted": false,
                "score": 5,
                "last_activity_date": 1625040613,
                "creation_date": 1625040613,
                "answer_id": 68190839,
                "question_id": 68180684,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here is a jq function for converting certain ISO 8601 timestamps with timezone offsets to seconds since the beginning of the Epoch, thus facilitating comparisons of timestamps with different offsets.\r\n\r\n\r\n```\r\n# Convert a timestamp with a possibly empty timezone offset to seconds since the Epoch.\r\n# Input should be a string of the form \r\n# yyyy-mm-ddThh:mm:ss or yyyy-mm-ddThh:mm:ss&lt;OFFSET&gt;\r\n# where &lt;OFFSET&gt; is Z, or has the form `+hh:mm` or `-hh:mm`.\r\n# If no timezone offset is explicitly given, it is taken to be Z.\r\ndef datetime_to_seconds:\r\n  if test(&quot;[-+]&quot;)\r\n  then capture(&quot;(?&lt;datetime&gt;^.*T[0-9:]+)(?&lt;s&gt;[-+])(?&lt;hh&gt;[0-9]+):?(?&lt;mm&gt;[0-9]*)&quot;)\r\n  | (.datetime +&quot;Z&quot; | fromdateiso8601) as $seconds\r\n  | (if .s == &quot;+&quot; then -1 else 1 end) as $plusminus\r\n  | ([.hh,.mm] | map(tonumber) |.[0] *= 60 | add * 60 * $plusminus) as $offset\r\n  | ($seconds + $offset)\r\n  else . + (if test(&quot;Z&quot;) then &quot;&quot; else &quot;Z&quot; end) | fromdateiso8601\r\n  end;\r\n```\r\n\r\nNote that the interpretation of `+` or `-` in the offset conforms with the principle encapsulated in the example:\r\n&gt; The following times all refer to the same moment: &quot;18:30Z&quot;, &quot;22:30+04&quot;, &quot;1130−0700&quot;, and &quot;15:00−03:30&quot;. \r\n",
                "title": "jq fromdate &quot;does not match format &quot;%Y-%m-%dT%H:%M:%SZ&quot;"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 4,
        "last_activity_date": 1627324188,
        "creation_date": 1624976750,
        "last_edit_date": 1627324188,
        "question_id": 68180684,
        "body_markdown": "I have an example json output below, the `LastAccessedDate` value is as AWS outputs it when running CLI command and thus I have no control over the format of the date.\r\n\r\n```\r\n{\r\n  &quot;MyList&quot;: [\r\n    {\r\n      &quot;Name&quot;: &quot;MyName1&quot;,\r\n      &quot;LastAccessedDate&quot;: &quot;2021-06-29T02:00:00+02:00&quot;\r\n    }\r\n  ]\r\n    \r\n}\r\n```\r\n\r\nWhen trying to run a jq command to select using `fromdate` like this: \r\n\r\n`cat output.json | jq &#39;.[] | .[] | select ( .LastAccessedDate | fromdate &gt; &quot;2021-01-01T02:00:00+02:00&quot;)&#39;` \r\n\r\nthen I get the error message:\r\n`jq: error (at &lt;stdin&gt;:8): date &quot;2021-06-29T02:00:00+02:00&quot; does not match format &quot;%Y-%m-%dT%H:%M:%SZ&quot;\r\n`\r\n\r\nIs there anything I could do to enable me to use jq to filter the output?\r\nWould even appreciate an explanation on what may be wrong so that I can understand for future use cases.",
        "link": "https://stackoverflow.com/questions/68180684/jq-fromdate-does-not-match-format-y-m-dthmsz",
        "title": "jq fromdate &quot;does not match format &quot;%Y-%m-%dT%H:%M:%SZ&quot;"
    },
    {
        "tags": [
            "json",
            "select",
            "match",
            "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": 2,
                "creation_date": 1624989246,
                "post_id": 68183429,
                "comment_id": 120506087,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1624991473,
                "last_edit_date": 1624991473,
                "creation_date": 1624991104,
                "answer_id": 68183893,
                "question_id": 68183429,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You&#39;re missing a pair of parens.  Also, it&#39;s usually much better to pass in variables using `--arg` or `--argjson` or some such.  So, in light of UUOC and other considerations, I&#39;d go with something like this:\r\n```\r\n&lt; file.json jq -r --arg VALUE &quot;$VALUE&quot; &#39;\r\n   .[]\r\n   | select( (.name == $VALUE) or (.guid | contains($VALUE)) )\r\n   | .name&#39;\r\n```\r\n\r\nOr, depending on your requirements, you might prefer to use this `select` clause:\r\n\r\n    select( (.name == $VALUE) or (.guid // &quot;&quot; | contains($VALUE)) )\r\n",
                "title": "JQ selecting multiple conditions where one is substring"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1624991473,
        "creation_date": 1624988763,
        "question_id": 68183429,
        "body_markdown": "I have done quite a bit of searching and most responses I find are close, but not quite what I am looking for.  Parsing a JSON file with this:\r\n\r\n    cat file.json | jq -r &quot;.[] | select(.name == \\&quot;${VALUE}\\&quot; or .guid == \\&quot;${VALUE}\\&quot;) | .name&quot;\r\n\r\nworks as expected, it selects the item where either the .name or .guid equals ${VALUE} and prints out the name.\r\n\r\nHowever, I would like the .guid match to be a substring or regex match.  Trying this does not work:\r\n\r\n    cat file.json | jq -r  &quot;.[] | select(.name == \\&quot;${VALUE}\\&quot; or .guid | contains(\\&quot;${VALUE}\\&quot;)) | .name&quot;\r\n\r\nI think I am fairly close, just missing something being new to jq...",
        "link": "https://stackoverflow.com/questions/68183429/jq-selecting-multiple-conditions-where-one-is-substring",
        "title": "JQ selecting multiple conditions where one is substring"
    },
    {
        "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": 1624993858,
                "post_id": 68184175,
                "comment_id": 120507545,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 14295857,
                    "reputation": 335,
                    "user_id": 10326569,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/33586f2f738af3c01f1455f62196cadc?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "NellaGnute",
                    "link": "https://stackoverflow.com/users/10326569/nellagnute"
                },
                "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": 1624993991,
                "post_id": 68184175,
                "comment_id": 120507598,
                "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": 1624994186,
                "post_id": 68184175,
                "comment_id": 120507661,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 14295857,
                    "reputation": 335,
                    "user_id": 10326569,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/33586f2f738af3c01f1455f62196cadc?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "NellaGnute",
                    "link": "https://stackoverflow.com/users/10326569/nellagnute"
                },
                "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": 1624994454,
                "post_id": 68184175,
                "comment_id": 120507752,
                "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": 1624995907,
                "post_id": 68184175,
                "comment_id": 120508236,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 14295857,
                    "reputation": 335,
                    "user_id": 10326569,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/33586f2f738af3c01f1455f62196cadc?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "NellaGnute",
                    "link": "https://stackoverflow.com/users/10326569/nellagnute"
                },
                "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": 1624997303,
                "post_id": 68184175,
                "comment_id": 120508688,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "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": 1628564587,
                "post_id": 68184175,
                "comment_id": 121448394,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1625037005,
                "last_edit_date": 1625037005,
                "creation_date": 1624998919,
                "answer_id": 68185328,
                "question_id": 68184175,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The following code does what you are looking for.\r\n\r\nThe idea is to collect the values for all keys in arrays in the first step (also for keys that occur only once) and at the end remove duplicates from all arrays and unpack the arrays with only one element.\r\n\r\nThis may be an unperformant solution for a large number of objects.\r\n\r\n```bash\r\n#!/bin/bash     \r\n\r\nobject_a=&#39;\r\n{\r\n    &quot;primaryKey&quot;:&quot;thisValueIsTheSameInAll&quot;,\r\n    &quot;aOnlyField&quot;:&quot;thisIsOnlyInA&quot;,\r\n    &quot;sharedField&quot;:&quot;thisIsInAllWithSameValue&quot;,\r\n    &quot;sharedField2&quot;:&quot;thisIsInAllButDifferentValue-A&quot;,\r\n    &quot;thing&quot;:[&quot;hello&quot;,&quot;hi&quot;]\r\n}&#39;\r\n\r\nobject_b=&#39;\r\n{\r\n    &quot;primaryKey&quot;:&quot;thisValueIsTheSameInAll&quot;,\r\n    &quot;bOnlyField&quot;:&quot;thisIsOnlyInB&quot;,\r\n    &quot;sharedField&quot;:&quot;thisIsInAllWithSameValue&quot;,\r\n    &quot;sharedField2&quot;:&quot;thisIsInAllButDifferentValue-B&quot;,\r\n    &quot;thing&quot;:[&quot;hola&quot;,&quot;bonjour&quot;]\r\n}&#39;\r\n\r\nobject_c=&#39;\r\n{\r\n    &quot;primaryKey&quot;:&quot;thisValueIsTheSameInAll&quot;,\r\n    &quot;sharedField&quot;:&quot;thisIsInAllWithSameValue&quot;,\r\n    &quot;sharedField2&quot;:&quot;thisIsInAllButDifferentValue-C&quot;\r\n}&#39;\r\n\r\necho &quot;$object_a $object_b $object_c&quot; |\r\njq -n &#39;\r\n  reduce inputs as $input\r\n         ({}; reduce ($input | keys_unsorted)[] as $key\r\n                     (.; .[$key] += [$input[$key]])\r\n         )\r\n  | with_entries(.value |= (flatten\r\n                            | unique\r\n                            | if length == 1 then .[0] else . end)         \r\n                )&#39;\r\n```\r\n\r\n\r\nresult:\r\n```json\r\n{\r\n  &quot;primaryKey&quot;: &quot;thisValueIsTheSameInAll&quot;,\r\n  &quot;aOnlyField&quot;: &quot;thisIsOnlyInA&quot;,\r\n  &quot;sharedField&quot;: &quot;thisIsInAllWithSameValue&quot;,\r\n  &quot;sharedField2&quot;: [\r\n    &quot;thisIsInAllButDifferentValue-A&quot;,\r\n    &quot;thisIsInAllButDifferentValue-B&quot;,\r\n    &quot;thisIsInAllButDifferentValue-C&quot;\r\n  ],\r\n  &quot;thing&quot;: [\r\n    &quot;bonjour&quot;,\r\n    &quot;hello&quot;,\r\n    &quot;hi&quot;,\r\n    &quot;hola&quot;\r\n  ],\r\n  &quot;bOnlyField&quot;: &quot;thisIsOnlyInB&quot;\r\n}\r\n```\r\n",
                "title": "How to use | add and preserve duplicate keys with different values, adding them to an array instead"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1625037005,
        "creation_date": 1624992625,
        "last_edit_date": 1624993162,
        "question_id": 68184175,
        "body_markdown": "I am attempting to take two similar JSON objects and combine them because they represent two versions of the same thing.  So far I have a fairly simple solution, by simply using &quot;add.&quot; However, that eliminates duplicate keys that have different values and apparently the values chosen are chosen randomly. My desired outcome is that if the values of a key exist in both places but are different, they should be put into an array and that array would then be the value of that key. Any keys that exist in one but not the other should also be added. Lastly, for any key that exists in both places, where the value is the same, there should only be one key/value for that item. For example:\r\n\r\nObject A:\r\n```\r\n{ \r\n    &quot;primaryKey&quot;:&quot;thisValueIsTheSameInBoth&quot;,\r\n    &quot;aOnlyField&quot;:&quot;thisIsOnlyInA&quot;,\r\n    &quot;sharedField&quot;:&quot;thisIsInBoth-AAA&quot;,\r\n    &quot;sharedField2&quot;:&quot;thisIsInBothAgain-AAA&quot;\r\n}\r\n```\r\n\r\nObject B:\r\n```\r\n{\r\n    &quot;primaryKey&quot;:&quot;thisValueIsTheSameInBoth&quot;,\r\n    &quot;bOnlyField&quot;:&quot;thisIsOnlyInB&quot;,\r\n    &quot;sharedField&quot;:&quot;thisIsInBothButDifferentInB&quot;,\r\n    &quot;sharedField2&quot;:&quot;thisIsInBothAgainButStillDifferentInB&quot;\r\n}\r\n```\r\n\r\nCurrently I am doing this:\r\n\r\n```\r\n&lt;bunch_of_Bash_commands&gt; | jq -n &#39;[inputs] | add&#39;\r\n```\r\n\r\nUnfortunately that results in this:\r\n```\r\n{\r\n    &quot;primaryKey&quot;:&quot;thisValueIsTheSameInBoth&quot;,\r\n    &quot;aOnlyField&quot;:&quot;thisIsOnlyInA&quot;,\r\n    &quot;bOnlyField&quot;:&quot;thisIsOnlyInB&quot;,\r\n    &quot;sharedField&quot;:&quot;thisIsInBoth-AAA&quot;,\r\n    &quot;sharedField2&quot;:&quot;thisIsInBothAgain-AAA&quot;\r\n}\r\n```\r\n\r\nAs you can see, it does a good job of combining fields that don&#39;t exist in both, but arbitrarily decides to pick the value of A for all the shared fields that differ. I&#39;d like to put those differering values in an array instead of a single string. Is there a clean, easy way to do that?\r\n\r\nDesired output:\r\n```\r\n{\r\n    &quot;primaryKey&quot;:&quot;thisValueIsTheSameInBoth&quot;,\r\n    &quot;aOnlyField&quot;:&quot;thisIsOnlyInA&quot;,\r\n    &quot;bOnlyField&quot;:&quot;thisIsOnlyInB&quot;,\r\n    &quot;sharedField&quot; : [ &quot;thisIsInBoth-AAA&quot;, &quot;thisIsInBothButDifferentInB&quot; ],\r\n    &quot;sharedField2&quot; : [ &quot;thisIsInBothAgain-AAA&quot;, &quot;thisIsInBothAgainButStillDifferentInB&quot; ]\r\n}\r\n```",
        "link": "https://stackoverflow.com/questions/68184175/how-to-use-add-and-preserve-duplicate-keys-with-different-values-adding-them",
        "title": "How to use | add and preserve duplicate keys with different values, adding them to an array instead"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1624995941,
                "last_edit_date": 1624995941,
                "creation_date": 1624995639,
                "answer_id": 68184732,
                "question_id": 68184497,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "It is because the objects in your json file does not contain the keys `source`, `cidr`, `ports`.\r\nAccessing non existing keys produces `null`. The filter `join(&quot; &quot;)` then fails.\r\n\r\nA possible solution to fix this would be to provide an empty array as a default wherever it may be missing in the source:\r\n\r\n```\r\nsrc=$(jq --raw-output &#39;.source? // [] | join(&quot; &quot;)&#39; &lt;&lt;&lt; ${rule})\r\ncidr=$(jq --raw-output &#39;.cidr? // [] | join(&quot; &quot;)&#39; &lt;&lt;&lt; ${rule})\r\nports=$(jq --raw-output &#39;.ports? // [] | join(&quot; &quot;)&#39; &lt;&lt;&lt; ${rule})\r\n```",
                "title": "Unable to parse JSON returning NULL"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -1,
        "last_activity_date": 1624995941,
        "creation_date": 1624994340,
        "question_id": 68184497,
        "body_markdown": "I have a small script that reads certain information from JSON and prints it.Running this script throws this error:\r\n\r\njq: error (at &lt;stdin&gt;:1): Cannot iterate over null (null)\r\n\r\nCan someone please let me know what maybe the cause of this returning null:\r\n\r\n    test5(){\r\n    local file=&quot;test.json&quot;\r\n    \twhile read rule; do\r\n        local priority\r\n        local access\r\n        local direction\r\n        local name\r\n        local src\r\n        local protocol\r\n        local ports\r\n        local cidr\r\n        local nsg\r\n        \r\n        \r\n        name=$(jq --raw-output &#39;.name&#39; &lt;&lt;&lt; ${rule})\r\n        direction=$(jq --raw-output &#39;.direction&#39; &lt;&lt;&lt; ${rule})\r\n        protocol=$(jq --raw-output &#39;.protocol&#39; &lt;&lt;&lt; ${rule})\r\n        priority=$(jq --raw-output &#39;.priority&#39; &lt;&lt;&lt; ${rule})\r\n        access=$(jq --raw-output &#39;.access&#39; &lt;&lt;&lt; ${rule})\r\n        nsg=$(jq --raw-output &#39;.nsg&#39; &lt;&lt;&lt; ${rule})\r\n        src=$(jq --raw-output &#39;.source | join(&quot; &quot;)&#39; &lt;&lt;&lt; ${rule})\r\n        cidr=$(jq --raw-output &#39;.cidr | join(&quot; &quot;)&#39; &lt;&lt;&lt; ${rule})\r\n        ports=$(jq --raw-output &#39;.ports | join(&quot; &quot;)&#39; &lt;&lt;&lt; ${rule})\r\n        \r\n        \r\n        \r\n        echo &quot;${priority}&quot;\r\n        done &lt; &lt;(cat ${file} | jq -rc &#39;.[]&#39;)\r\n        \r\n    }\r\n\r\nJSON:\r\n\r\n    [ {\r\n      &quot;name&quot; : &quot;AllowHttpsInBound&quot;,\r\n      &quot;direction&quot; : &quot;Inbound&quot;,\r\n      &quot;protocol&quot; : &quot;tcp&quot;,\r\n      &quot;priority&quot; : 1000,\r\n      &quot;access&quot; : &quot;Allow&quot;,\r\n      &quot;nsgName&quot; : &quot;something&quot;,\r\n      &quot;sourceAddressPrefixes&quot; : [ &quot;something&quot; ],\r\n      &quot;destinationAddressPrefixes&quot; : [ &quot;*&quot; ],\r\n      &quot;destinationPortRanges&quot; : [ &quot;9443&quot; ]\r\n    }, {\r\n      &quot;name&quot; : &quot;AllowInBound&quot;,\r\n      &quot;direction&quot; : &quot;Inbound&quot;,\r\n      &quot;protocol&quot; : &quot;*&quot;,\r\n      &quot;priority&quot; : 1100,\r\n      &quot;access&quot; : &quot;Allow&quot;,\r\n      &quot;nsgName&quot; : &quot;SOMETHING&quot;,\r\n      &quot;sourceAddressPrefixes&quot; : [ &quot;something&quot; ],\r\n      &quot;destinationAddressPrefixes&quot; : [ &quot;*&quot; ],\r\n      &quot;destinationPortRanges&quot; : [ &quot;*&quot; ]\r\n    }\r\n    ]",
        "link": "https://stackoverflow.com/questions/68184497/unable-to-parse-json-returning-null",
        "title": "Unable to parse JSON returning NULL"
    },
    {
        "tags": [
            "json",
            "jq",
            "string-concatenation"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1625016024,
                "creation_date": 1625016024,
                "answer_id": 68187405,
                "question_id": 68187302,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You are really close.  I think you just need some parenthesis:\r\n\r\n    .|.foo as $path1|.bar as $path2|{&quot;path&quot;:($path1 + &quot;/&quot; + $path2)}",
                "title": "jq filter to combine two json values into one with a slash delimiter"
            },
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1625019449,
                "creation_date": 1625019449,
                "answer_id": 68187641,
                "question_id": 68187302,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Or just:\r\n\r\n    {&quot;path&quot;:(.foo + &quot;/&quot; + .bar)}\r\n\r\nor perhaps better (in case conversion to strings is needed):\r\n\r\n    {&quot;path&quot;: &quot;\\(.foo)/\\(.bar)&quot;}\r\n",
                "title": "jq filter to combine two json values into one with a slash delimiter"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1625036277,
        "creation_date": 1625014957,
        "last_edit_date": 1625036277,
        "question_id": 68187302,
        "body_markdown": "I&#39;m trying to use ```jq``` to process a json input:\r\n```\r\n{\r\n&quot;foo&quot;:&quot;xxx&quot;,\r\n&quot;bar&quot;:&quot;yyy&quot;\r\n}\r\n```\r\n\r\nTrying to get the following desired json output:\r\n\r\n```{&quot;path&quot;:&quot;xxx/yyy&quot;}```\r\n\r\nI&#39;ve tried several things for the filter, generally \r\n```\r\n.|.foo as $path1|.bar as $path2|{&quot;path&quot;:?????}\r\n```\r\n```$path1+&quot;/&quot;+$path2``` does not work.\r\n\r\nWhat should I replace ????? with to get desired result?",
        "link": "https://stackoverflow.com/questions/68187302/jq-filter-to-combine-two-json-values-into-one-with-a-slash-delimiter",
        "title": "jq filter to combine two json values into one with a slash delimiter"
    },
    {
        "tags": [
            "json",
            "kubernetes",
            "jq",
            "cartesian-product"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 22071747,
                    "reputation": 2260,
                    "user_id": 16332641,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/0e75ca2c0b0cb923cc89e663ed443d6d?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "jpseng",
                    "link": "https://stackoverflow.com/users/16332641/jpseng"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1625052804,
                "post_id": 68193777,
                "comment_id": 120523520,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 18011515,
                    "reputation": 13,
                    "user_id": 13091053,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/yHyL8.jpg?s=256",
                    "display_name": "Zegal",
                    "link": "https://stackoverflow.com/users/13091053/zegal"
                },
                "reply_to_user": {
                    "account_id": 22071747,
                    "reputation": 2260,
                    "user_id": 16332641,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/0e75ca2c0b0cb923cc89e663ed443d6d?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "jpseng",
                    "link": "https://stackoverflow.com/users/16332641/jpseng"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1625057971,
                "post_id": 68193777,
                "comment_id": 120525783,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 5,
                "is_accepted": true,
                "score": 5,
                "last_activity_date": 1625059425,
                "last_edit_date": 1625059425,
                "creation_date": 1625054999,
                "answer_id": 68194503,
                "question_id": 68193777,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The problem is `&quot;name&quot;: .spec.containers[].name` and `&quot;image&quot;: .spec.containers[].image`:\r\nBoth expressions generate a sequence of each value for `name` and `image` which will than be combined.\r\n\r\nSimplified example of why you get a Cartesian product:\r\n\r\n```jq -c -n &#39;{name: (&quot;A&quot;, &quot;B&quot;), value: (&quot;C&quot;, &quot;D&quot;)}&#39;```\r\n\r\noutputs:\r\n```json\r\n{&quot;name&quot;:&quot;A&quot;,&quot;value&quot;:&quot;C&quot;}\r\n{&quot;name&quot;:&quot;A&quot;,&quot;value&quot;:&quot;D&quot;}\r\n{&quot;name&quot;:&quot;B&quot;,&quot;value&quot;:&quot;C&quot;}\r\n{&quot;name&quot;:&quot;B&quot;,&quot;value&quot;:&quot;D&quot;}\r\n```\r\n\r\n---\r\n\r\nYou get the desired output using this `jq` filter on your input:\r\n\r\n```jq\r\njq &#39;\r\n  .items[]\r\n  | {\r\n      &quot;name&quot;: .metadata.name,\r\n      &quot;containers&quot;: .spec.containers\r\n                    | map({name, image})\r\n    }&#39;\r\n```\r\noutput:\r\n```json\r\n{\r\n  &quot;name&quot;: &quot;pod-1&quot;,\r\n  &quot;containers&quot;: [\r\n    {\r\n      &quot;name&quot;: &quot;container-1&quot;,\r\n      &quot;image&quot;: &quot;image-1&quot;\r\n    },\r\n    {\r\n      &quot;name&quot;: &quot;container-2&quot;,\r\n      &quot;image&quot;: &quot;image-2&quot;\r\n    }\r\n  ]\r\n}\r\n```",
                "title": "Kubernetes + jq - retrieving containers list per pod yields cartesian product"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1625404167,
        "creation_date": 1625051917,
        "last_edit_date": 1625404167,
        "question_id": 68193777,
        "body_markdown": "Im trying to use jq on kubernetes json output, to create new json object containing list of objects - container and image per pod, however im getting cartesian product.\r\n\r\nmy input data (truncated from sensitive info):\r\n```\r\n{\r\n    &quot;apiVersion&quot;: &quot;v1&quot;,\r\n    &quot;items&quot;: [\r\n        {\r\n            &quot;apiVersion&quot;: &quot;v1&quot;,\r\n            &quot;kind&quot;: &quot;Pod&quot;,\r\n            &quot;metadata&quot;: {\r\n                &quot;creationTimestamp&quot;: &quot;2021-06-30T12:45:40Z&quot;,\r\n                &quot;name&quot;: &quot;pod-1&quot;,\r\n                &quot;namespace&quot;: &quot;default&quot;,\r\n                &quot;resourceVersion&quot;: &quot;757679286&quot;,\r\n                &quot;selfLink&quot;: &quot;/api/v1/namespaces/default/pods/pod-1&quot;\r\n            },\r\n            &quot;spec&quot;: {\r\n                &quot;containers&quot;: [\r\n                    {\r\n                        &quot;image&quot;: &quot;image-1&quot;,\r\n                        &quot;imagePullPolicy&quot;: &quot;Always&quot;,\r\n                        &quot;name&quot;: &quot;container-1&quot;,\r\n                        &quot;resources&quot;: {},\r\n                        &quot;terminationMessagePath&quot;: &quot;/dev/termination-log&quot;,\r\n                        &quot;terminationMessagePolicy&quot;: &quot;File&quot;,\r\n                        &quot;volumeMounts&quot;: [\r\n                            {\r\n                                &quot;mountPath&quot;: &quot;/var/run/secrets/kubernetes.io/serviceaccount&quot;,\r\n                                &quot;readOnly&quot;: true\r\n                            }\r\n                        ]\r\n                    },\r\n                    {\r\n                        &quot;image&quot;: &quot;image-2&quot;,\r\n                        &quot;imagePullPolicy&quot;: &quot;Always&quot;,\r\n                        &quot;name&quot;: &quot;container-2&quot;,\r\n                        &quot;resources&quot;: {},\r\n                        &quot;terminationMessagePath&quot;: &quot;/dev/termination-log&quot;,\r\n                        &quot;terminationMessagePolicy&quot;: &quot;File&quot;,\r\n                        &quot;volumeMounts&quot;: [\r\n                            {\r\n                                &quot;mountPath&quot;: &quot;/var/run/secrets/kubernetes.io/serviceaccount&quot;,\r\n                                &quot;readOnly&quot;: true\r\n                            }\r\n                        ]\r\n                    }\r\n                ],\r\n                &quot;dnsPolicy&quot;: &quot;ClusterFirst&quot;,\r\n                &quot;enableServiceLinks&quot;: true,\r\n                &quot;priority&quot;: 0,\r\n                &quot;restartPolicy&quot;: &quot;Always&quot;,\r\n                &quot;schedulerName&quot;: &quot;default-scheduler&quot;,\r\n                &quot;securityContext&quot;: {},\r\n                &quot;serviceAccount&quot;: &quot;default&quot;,\r\n                &quot;serviceAccountName&quot;: &quot;default&quot;,\r\n                &quot;terminationGracePeriodSeconds&quot;: 30,\r\n                &quot;tolerations&quot;: [\r\n                    {\r\n                        &quot;effect&quot;: &quot;NoExecute&quot;,\r\n                        &quot;key&quot;: &quot;node.kubernetes.io/not-ready&quot;,\r\n                        &quot;operator&quot;: &quot;Exists&quot;,\r\n                        &quot;tolerationSeconds&quot;: 300\r\n                    },\r\n                    {\r\n                        &quot;effect&quot;: &quot;NoExecute&quot;,\r\n                        &quot;key&quot;: &quot;node.kubernetes.io/unreachable&quot;,\r\n                        &quot;operator&quot;: &quot;Exists&quot;,\r\n                        &quot;tolerationSeconds&quot;: 300\r\n                    }\r\n                ],\r\n                &quot;volumes&quot;: [\r\n                    {\r\n                        &quot;name&quot;: &quot;default-token-b954f&quot;,\r\n                        &quot;secret&quot;: {\r\n                            &quot;defaultMode&quot;: 420,\r\n                            &quot;secretName&quot;: &quot;default-token-b954f&quot;\r\n                        }\r\n                    }\r\n                ]\r\n            },\r\n            &quot;status&quot;: {\r\n                &quot;conditions&quot;: [\r\n                    {\r\n                        &quot;lastProbeTime&quot;: null,\r\n                        &quot;lastTransitionTime&quot;: &quot;2021-06-30T12:45:40Z&quot;,\r\n                        &quot;status&quot;: &quot;True&quot;,\r\n                        &quot;type&quot;: &quot;Initialized&quot;\r\n                    },\r\n                    {\r\n                        &quot;lastProbeTime&quot;: null,\r\n                        &quot;lastTransitionTime&quot;: &quot;2021-06-30T12:45:40Z&quot;,\r\n                        &quot;message&quot;: &quot;containers with unready status: [container-1 container-2]&quot;,\r\n                        &quot;reason&quot;: &quot;ContainersNotReady&quot;,\r\n                        &quot;status&quot;: &quot;False&quot;,\r\n                        &quot;type&quot;: &quot;Ready&quot;\r\n                    },\r\n                    {\r\n                        &quot;lastProbeTime&quot;: null,\r\n                        &quot;lastTransitionTime&quot;: &quot;2021-06-30T12:45:40Z&quot;,\r\n                        &quot;message&quot;: &quot;containers with unready status: [container-1 container-2]&quot;,\r\n                        &quot;reason&quot;: &quot;ContainersNotReady&quot;,\r\n                        &quot;status&quot;: &quot;False&quot;,\r\n                        &quot;type&quot;: &quot;ContainersReady&quot;\r\n                    },\r\n                    {\r\n                        &quot;lastProbeTime&quot;: null,\r\n                        &quot;lastTransitionTime&quot;: &quot;2021-06-30T12:45:40Z&quot;,\r\n                        &quot;status&quot;: &quot;True&quot;,\r\n                        &quot;type&quot;: &quot;PodScheduled&quot;\r\n                    }\r\n                ],\r\n                &quot;containerStatuses&quot;: [\r\n                    {\r\n                        &quot;image&quot;: &quot;image-1&quot;,\r\n                        &quot;imageID&quot;: &quot;&quot;,\r\n                        &quot;lastState&quot;: {},\r\n                        &quot;name&quot;: &quot;container-1&quot;,\r\n                        &quot;ready&quot;: false,\r\n                        &quot;restartCount&quot;: 0,\r\n                        &quot;started&quot;: false,\r\n                        &quot;state&quot;: {\r\n                            &quot;waiting&quot;: {\r\n                                &quot;message&quot;: &quot;Back-off pulling image \\&quot;image-1\\&quot;&quot;,\r\n                                &quot;reason&quot;: &quot;ImagePullBackOff&quot;\r\n                            }\r\n                        }\r\n                    },\r\n                    {\r\n                        &quot;image&quot;: &quot;image-2&quot;,\r\n                        &quot;imageID&quot;: &quot;&quot;,\r\n                        &quot;lastState&quot;: {},\r\n                        &quot;name&quot;: &quot;container-2&quot;,\r\n                        &quot;ready&quot;: false,\r\n                        &quot;restartCount&quot;: 0,\r\n                        &quot;started&quot;: false,\r\n                        &quot;state&quot;: {\r\n                            &quot;waiting&quot;: {\r\n                                &quot;message&quot;: &quot;Back-off pulling image \\&quot;image-2\\&quot;&quot;,\r\n                                &quot;reason&quot;: &quot;ImagePullBackOff&quot;\r\n                            }\r\n                        }\r\n                    }\r\n                ],\r\n                &quot;qosClass&quot;: &quot;BestEffort&quot;,\r\n                &quot;startTime&quot;: &quot;2021-06-30T12:45:40Z&quot;\r\n            }\r\n        }\r\n    ],\r\n    &quot;kind&quot;: &quot;List&quot;,\r\n    &quot;metadata&quot;: {\r\n        &quot;resourceVersion&quot;: &quot;&quot;,\r\n        &quot;selfLink&quot;: &quot;&quot;\r\n    }\r\n}\r\n```\r\n\r\nmy command: \r\n```\r\njq &#39;.items[] | { &quot;name&quot;: .metadata.name, &quot;containers&quot;: [{ &quot;name&quot;: .spec.containers[].name, &quot;image&quot;: .spec.containers[].image }]} &#39;\r\n```\r\n\r\ndesired output:\r\n```\r\n{\r\n  &quot;name&quot;: &quot;pod_1&quot;,\r\n  &quot;containers&quot;: [\r\n    {\r\n      &quot;name&quot;: &quot;container_1&quot;,\r\n      &quot;image&quot;: &quot;image_1&quot;\r\n    },\r\n    {\r\n      &quot;name&quot;: &quot;container_2&quot;,\r\n      &quot;image&quot;: &quot;image_2&quot;\r\n    }\r\n  ]\r\n}\r\n```\r\n\r\noutput I get:\r\n```\r\n{\r\n  &quot;name&quot;: &quot;pod-1&quot;,\r\n  &quot;containers&quot;: [\r\n    {\r\n      &quot;name&quot;: &quot;container-1&quot;,\r\n      &quot;image&quot;: &quot;image-1&quot;\r\n    },\r\n    {\r\n      &quot;name&quot;: &quot;container-1&quot;,\r\n      &quot;image&quot;: &quot;image-2&quot;\r\n    },\r\n    {\r\n      &quot;name&quot;: &quot;container-2&quot;,\r\n      &quot;image&quot;: &quot;image-1&quot;\r\n    },\r\n    {\r\n      &quot;name&quot;: &quot;container-2&quot;,\r\n      &quot;image&quot;: &quot;image-2&quot;\r\n    }\r\n  ]\r\n}\r\n```\r\n\r\nCould anyone explain what am I doing wrong?\r\n\r\nBest Regards, Piotr.\r\n",
        "link": "https://stackoverflow.com/questions/68193777/kubernetes-jq-retrieving-containers-list-per-pod-yields-cartesian-product",
        "title": "Kubernetes + jq - retrieving containers list per pod yields cartesian product"
    },
    {
        "tags": [
            "json",
            "jq",
            "delete-operator"
        ],
        "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": 1625165215,
                "post_id": 68214943,
                "comment_id": 120562107,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 10660136,
                    "reputation": 1329,
                    "user_id": 7848350,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/87ad61e783196e7b0cc6236f2397d63b?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "hcdocs",
                    "link": "https://stackoverflow.com/users/7848350/hcdocs"
                },
                "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": 1625183106,
                "post_id": 68214943,
                "comment_id": 120566564,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 9,
                "is_accepted": true,
                "score": 9,
                "last_activity_date": 1625173008,
                "last_edit_date": 1625173008,
                "creation_date": 1625171568,
                "answer_id": 68216598,
                "question_id": 68214943,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The following code shows how to solve your task with four examples\r\n\r\n```bash\r\n#!/bin/bash\r\n\r\nFILE=&#39;\r\n[\r\n    {\r\n        &quot;path&quot;: &quot;/path-1/&quot;,\r\n        &quot;guide&quot;: &quot;Guide 1&quot;\r\n    },\r\n    {\r\n        &quot;path&quot;: &quot;/unwanted-path-2/&quot;,\r\n        &quot;guide&quot;: &quot;Guide 2&quot;\r\n    },\r\n    {\r\n        &quot;path&quot;: &quot;/path-3/&quot;,\r\n        &quot;guide&quot;: &quot;Guide 3&quot;,\r\n        &quot;sub&quot;: [\r\n            {\r\n                &quot;path&quot;: &quot;/unwanted-path-4/&quot;,\r\n                &quot;guide&quot;: &quot;Guide 4&quot;\r\n            },\r\n            {\r\n                &quot;path&quot;: &quot;/path-5/&quot;,\r\n                &quot;guide&quot;: &quot;Guide 5&quot;\r\n            },\r\n            [\r\n                {\r\n                    &quot;path&quot;: &quot;/path-6/&quot;,\r\n                    &quot;guide&quot;: &quot;Guide 6&quot;\r\n                },\r\n                {\r\n                    &quot;path&quot;: &quot;/unwanted-path-7/&quot;,\r\n                    &quot;guide&quot;: &quot;Guide 7&quot;\r\n                }\r\n            ]\r\n        ]\r\n    }\r\n]\r\n&#39;\r\n\r\nUNWANTED=&#39;/unwanted-path-2/&#39;\r\necho &quot;example 1: keep only objects in array that does not have the unwanted path &#39;$UNWANTED&#39; (narrow search)&quot;\r\njq --arg unwantedPath &quot;$UNWANTED&quot; \\\r\n   &#39;map(select(.path != $unwantedPath))&#39; &lt;&lt;&lt; &quot;$FILE&quot;\r\n\r\nUNWANTED=&#39;/unwanted-path-7/&#39;\r\necho -e &quot;\\nexample 2: delete objects that have the unwanted path &#39;$UNWANTED&#39; exactly (deep search)&quot;\r\njq --arg unwantedPath &quot;$UNWANTED&quot; \\\r\n   &#39;del(..| objects | select(.path == $unwantedPath)) &#39; &lt;&lt;&lt; &quot;$FILE&quot;\r\n\r\nUNWANTED=&#39;unwanted&#39;\r\necho -e &quot;\\nexample 3: delete objects that have the unwanted path &#39;$UNWANTED&#39; partially (deep search)&quot;\r\njq --arg unwantedPath &quot;$UNWANTED&quot; \\\r\n   &#39;del(..| objects | select(.path | index($unwantedPath) != null)) &#39; &lt;&lt;&lt; &quot;$FILE&quot;\r\n\r\nUNWANTED=&#39;[&quot;/unwanted-path-4/&quot;, &quot;/unwanted-path-7/&quot;]&#39;\r\necho -e &quot;\\nexample 4: delete objects that have one of unwanted paths &#39;$UNWANTED&#39; (deep search)&quot;\r\njq --argjson unwantedPath &quot;$UNWANTED&quot; \\\r\n   &#39;del(..| objects | select(.path | IN($unwantedPath[]))) &#39; &lt;&lt;&lt; &quot;$FILE&quot;\r\n```\r\n\r\n### output example 1: keep only objects in array that does not have the unwanted path &#39;/unwanted-path-2/&#39; (narrow search)\r\n\r\n```json\r\n[\r\n  {\r\n    &quot;path&quot;: &quot;/path-1/&quot;,\r\n    &quot;guide&quot;: &quot;Guide 1&quot;\r\n  },\r\n  {\r\n    &quot;path&quot;: &quot;/path-3/&quot;,\r\n    &quot;guide&quot;: &quot;Guide 3&quot;,\r\n    &quot;sub&quot;: [\r\n      {\r\n        &quot;path&quot;: &quot;/unwanted-path-4/&quot;,\r\n        &quot;guide&quot;: &quot;Guide 4&quot;\r\n      },\r\n      {\r\n        &quot;path&quot;: &quot;/path-5/&quot;,\r\n        &quot;guide&quot;: &quot;Guide 5&quot;\r\n      },\r\n      [\r\n        {\r\n          &quot;path&quot;: &quot;/path-6/&quot;,\r\n          &quot;guide&quot;: &quot;Guide 6&quot;\r\n        },\r\n        {\r\n          &quot;path&quot;: &quot;/unwanted-path-7/&quot;,\r\n          &quot;guide&quot;: &quot;Guide 7&quot;\r\n        }\r\n      ]\r\n    ]\r\n  }\r\n]\r\n```\r\n\r\n### output example 2: delete objects that have the unwanted path &#39;/unwanted-path-7/&#39; exactly (deep search)\r\n\r\n```json\r\n[\r\n  {\r\n    &quot;path&quot;: &quot;/path-1/&quot;,\r\n    &quot;guide&quot;: &quot;Guide 1&quot;\r\n  },\r\n  {\r\n    &quot;path&quot;: &quot;/unwanted-path-2/&quot;,\r\n    &quot;guide&quot;: &quot;Guide 2&quot;\r\n  },\r\n  {\r\n    &quot;path&quot;: &quot;/path-3/&quot;,\r\n    &quot;guide&quot;: &quot;Guide 3&quot;,\r\n    &quot;sub&quot;: [\r\n      {\r\n        &quot;path&quot;: &quot;/unwanted-path-4/&quot;,\r\n        &quot;guide&quot;: &quot;Guide 4&quot;\r\n      },\r\n      {\r\n        &quot;path&quot;: &quot;/path-5/&quot;,\r\n        &quot;guide&quot;: &quot;Guide 5&quot;\r\n      },\r\n      [\r\n        {\r\n          &quot;path&quot;: &quot;/path-6/&quot;,\r\n          &quot;guide&quot;: &quot;Guide 6&quot;\r\n        }\r\n      ]\r\n    ]\r\n  }\r\n]\r\n```\r\n\r\n### output example 3: delete objects that have the unwanted path &#39;unwanted&#39; partially (deep search)\r\n\r\n```json\r\n[\r\n  {\r\n    &quot;path&quot;: &quot;/path-1/&quot;,\r\n    &quot;guide&quot;: &quot;Guide 1&quot;\r\n  },\r\n  {\r\n    &quot;path&quot;: &quot;/path-3/&quot;,\r\n    &quot;guide&quot;: &quot;Guide 3&quot;,\r\n    &quot;sub&quot;: [\r\n      {\r\n        &quot;path&quot;: &quot;/path-5/&quot;,\r\n        &quot;guide&quot;: &quot;Guide 5&quot;\r\n      },\r\n      [\r\n        {\r\n          &quot;path&quot;: &quot;/path-6/&quot;,\r\n          &quot;guide&quot;: &quot;Guide 6&quot;\r\n        }\r\n      ]\r\n    ]\r\n  }\r\n]\r\n```\r\n\r\n### output example 4: delete objects that have one of unwanted paths &#39;[&quot;/unwanted-path-4/&quot;, &quot;/unwanted-path-7/&quot;]&#39; (deep search)\r\n\r\n```json\r\n[\r\n  {\r\n    &quot;path&quot;: &quot;/path-1/&quot;,\r\n    &quot;guide&quot;: &quot;Guide 1&quot;\r\n  },\r\n  {\r\n    &quot;path&quot;: &quot;/unwanted-path-2/&quot;,\r\n    &quot;guide&quot;: &quot;Guide 2&quot;\r\n  },\r\n  {\r\n    &quot;path&quot;: &quot;/path-3/&quot;,\r\n    &quot;guide&quot;: &quot;Guide 3&quot;,\r\n    &quot;sub&quot;: [\r\n      {\r\n        &quot;path&quot;: &quot;/path-5/&quot;,\r\n        &quot;guide&quot;: &quot;Guide 5&quot;\r\n      },\r\n      [\r\n        {\r\n          &quot;path&quot;: &quot;/path-6/&quot;,\r\n          &quot;guide&quot;: &quot;Guide 6&quot;\r\n        }\r\n      ]\r\n    ]\r\n  }\r\n]\r\n```\r\n",
                "title": "Delete a JSON object when a value inside the object matches a designated value (jq)"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1630441336,
        "creation_date": 1625162434,
        "last_edit_date": 1630441336,
        "question_id": 68214943,
        "body_markdown": "The goal is to delete an entire object in a JSON file that contain a key/value pair specified in a JQ script. \r\n\r\nFor example, all objects with `/unwanted-path/` in `path` would be removed:\r\n\r\ninput.json:\r\n```\r\n[\r\n\t{\r\n\t\t&quot;path&quot;: &quot;/path-1/&quot;,\r\n\t\t&quot;guide&quot;: &quot;Guide 1&quot;\r\n\t},\r\n\t{\r\n\t\t&quot;path&quot;: &quot;/path-2/&quot;,\r\n\t\t&quot;guide&quot;: &quot;Guide 2&quot;\r\n\t},\r\n    {\r\n        &quot;path&quot;: &quot;/unwanted-path/&quot;,\r\n        &quot;guide&quot;: &quot;Guide 3&quot;\r\n    }\r\n]\r\n```\r\noutput.json:\r\n```\r\n[\r\n\t{\r\n\t\t&quot;path&quot;: &quot;/path-1/&quot;,\r\n\t\t&quot;guide&quot;: &quot;Guide 1&quot;\r\n\t},\r\n\t{\r\n\t\t&quot;path&quot;: &quot;/path-2/&quot;,\r\n\t\t&quot;guide&quot;: &quot;Guide 2&quot;\r\n\t}\r\n]\r\n```\r\nThis JQ script is the closest I have come to in terms of a potential successful approach, but of course its intent is different and does not accomplish the goal. \r\n\r\n```\r\njq &#39;.[] | walk(if type == &quot;object&quot; then del(.path) else . end)&#39; original.json &gt; modified.json\r\n```\r\n\r\nIs there a way to add logic there that designates a key to go with `path`?\r\n\r\nThe key will always be `path`, but there are several `path` values I will filter against. If there is a way to filter against more than one `path` value a time, that is ideal, but not critical.",
        "link": "https://stackoverflow.com/questions/68214943/delete-a-json-object-when-a-value-inside-the-object-matches-a-designated-value",
        "title": "Delete a JSON object when a value inside the object matches a designated value (jq)"
    },
    {
        "tags": [
            "arrays",
            "json",
            "jq",
            "whitelist"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1625203949,
                "creation_date": 1625203949,
                "answer_id": 68220050,
                "question_id": 68219855,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can use `IN` to see if the value is part of the list and use a much simpler update assignment using select as\r\n\r\n```none\r\njq --arg NEW_VALUE &#39;987-654&#39; --argjson TAGS &#39;[&quot;Tag1&quot;,&quot;Tag2&quot;]&#39; &#39;\r\n   map(select( .Key | IN($TAGS[] ) ).Value |= $NEW_VALUE )&#39; json\r\n```",
                "title": "JQ checking for values in an array given as a parameter"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1625207923,
                "creation_date": 1625207923,
                "answer_id": 68220643,
                "question_id": 68219855,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "## With jq 1.5 or later\r\n```\r\njq --arg NEW_VALUE &#39;987-654&#39; --argjson TAGS &#39;[&quot;Tag1&quot;,&quot;Tag2&quot;]&#39; &#39;\r\n   def IN(s): first((s == .) // empty) // false;\r\n   map(if .Key | IN($TAGS[]) then .Value = $NEW_VALUE else . end)\r\n&#39;\r\n```\r\n\r\n(With jq 1.6, you can obviously leave out the def of `IN/1`.)\r\n\r\n## With jq 1.4 or later\r\n```\r\njq --arg NEW_VALUE &#39;987-654&#39; --arg TAGS &#39;[&quot;Tag1&quot;,&quot;Tag2&quot;]&#39; &#39;\r\n   ($TAGS|fromjson) as $TAGS\r\n   | map(if [.Key == $TAGS[]]|any then .Value = $NEW_VALUE else . end)\r\n&#39; \r\n```\r\n",
                "title": "JQ checking for values in an array given as a parameter"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 3,
        "last_activity_date": 1625214383,
        "creation_date": 1625202353,
        "last_edit_date": 1625214383,
        "question_id": 68219855,
        "body_markdown": "I&#39;ve got a simple JQ filter to update some values in an array based on the &quot;Key&quot;, for example this is my input:\r\n\r\n```json\r\n[\r\n    {\r\n        &quot;Key&quot;: &quot;IDontCare&quot;,\r\n        &quot;Value&quot;: &quot;something&quot;\r\n    },\r\n    {\r\n        &quot;Key&quot;: &quot;Tag1&quot;,\r\n        &quot;Value&quot;: &quot;123-456&quot;\r\n    },\r\n    {\r\n        &quot;Key&quot;: &quot;Tag2&quot;,\r\n        &quot;Value&quot;: &quot;121-717&quot;\r\n    }\r\n]\r\n```\r\nI want to update both tags to a new value (same value for both), so I&#39;ve got this command, that works:\r\n\r\n```\r\njq --arg NEW_VALUE &#39;987-654&#39; \\\r\n    &#39;[.[] |= if(.Key==&quot;Tag1&quot; or .Key==&quot;Tag2&quot;) then (.Value=$NEW_VALUE) else . end]&#39;\r\n```\r\n\r\nHowever I want to update different tags in different runs and would like to pass them as another argument. But not sure how to change the `if()` to look up the tags from the parameter. \r\n\r\nI tried something like this but that&#39;s apparently not the right way:\r\n\r\n```\r\njq --argjson TAGS &#39;[&quot;Tag1&quot;,&quot;Tag2&quot;]&#39; --arg NEW_VALUE &#39;987-654&#39; \\\r\n    &#39;[.[] |= if(.Key|in($TAGS)) then (.Value=$NEW_VALUE) else . end]&#39;\r\n```\r\n\r\nAny ideas?",
        "link": "https://stackoverflow.com/questions/68219855/jq-checking-for-values-in-an-array-given-as-a-parameter",
        "title": "JQ checking for values in an array given as a parameter"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1625251438,
                "last_edit_date": 1625251438,
                "creation_date": 1625217264,
                "answer_id": 68222600,
                "question_id": 68222227,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Your input consists of two separate objects. In order to be able to access the first while processing the second, you could save the first into a variable.\r\n```\r\n. as {$text} | input | if .categories[0].label | test(&quot;/technology&quot;; &quot;i&quot;) then . + {relevant: 1, $text} else . + {relevant: 0} end\r\n```\r\n&lt;sup&gt;[Online demo](https://jqplay.org/s/7uXB959Xjh)&lt;/sup&gt;",
                "title": "Conditionally merging two separate JSON objects in JQ"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1625251438,
        "creation_date": 1625215579,
        "last_edit_date": 1625218911,
        "question_id": 68222227,
        "body_markdown": "This is how my input looks:\r\n```\r\n{\r\n&quot;text&quot; : &quot;Some text here&quot;\r\n}\r\n{\r\n  &quot;usage&quot;: {\r\n    &quot;text_units&quot;: 1,\r\n    &quot;text_characters&quot;: 101,\r\n    &quot;features&quot;: 1\r\n  },\r\n  &quot;language&quot;: &quot;en&quot;,\r\n  &quot;categories&quot;: [\r\n    {\r\n      &quot;score&quot;: 0.655041,\r\n      &quot;label&quot;: &quot;/technology law, govt and politics/espionage and intelligence/surveillance&quot;\r\n    },\r\n    {\r\n      &quot;score&quot;: 0.639809,\r\n      &quot;label&quot;: &quot;/technology and computing/computer security/network security&quot;\r\n    },\r\n    {\r\n      &quot;score&quot;: 0.624533,\r\n      &quot;label&quot;: &quot;/business and industrial/business operations&quot;\r\n    }\r\n  ]\r\n}\r\n```\r\n\r\nUsing JQ, if the first element of array `category` in the second object contains `/technology`, I want to add a new field named `relevant` with `1` as value (which I managed), and copy the `text` field from the first object.\r\n\r\nSo, the expected output is:\r\n```\r\n{\r\n  &quot;usage&quot;: {\r\n    &quot;text_units&quot;: 1,\r\n    &quot;text_characters&quot;: 101,\r\n    &quot;features&quot;: 1\r\n  },\r\n  &quot;language&quot;: &quot;en&quot;,\r\n  &quot;categories&quot;: [\r\n    {\r\n      &quot;score&quot;: 0.655041,\r\n      &quot;label&quot;: &quot;/technology law, govt and politics/espionage and intelligence/surveillance&quot;\r\n    },\r\n    {\r\n      &quot;score&quot;: 0.639809,\r\n      &quot;label&quot;: &quot;/technology and computing/computer security/network security&quot;\r\n    },\r\n    {\r\n      &quot;score&quot;: 0.624533,\r\n      &quot;label&quot;: &quot;/business and industrial/business operations&quot;\r\n    }\r\n  ],\r\n  &quot;relevant&quot;: 1,\r\n  &quot;text&quot;: &quot;Some text here&quot;\r\n}\r\n```\r\n\r\nAnd this is what I have done so far:\r\n```\r\nif .categories[0].label  | test(&quot;/technology&quot;; &quot;i&quot;) then . |=( . + {&quot;relevant&quot;: 1} + {&quot;text&quot;: .text}) else . |= . + {&quot;relevant&quot;: 0} end\r\n```\r\n\r\n* [Link to a demo on jqplay](https://jqplay.org/s/TomoyRY3y_)\r\n",
        "link": "https://stackoverflow.com/questions/68222227/conditionally-merging-two-separate-json-objects-in-jq",
        "title": "Conditionally merging two separate JSON objects in JQ"
    },
    {
        "tags": [
            "arrays",
            "json",
            "conditional-statements",
            "jq"
        ],
        "comments": [
            {
                "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": 1,
                "creation_date": 1625254062,
                "post_id": 68230320,
                "comment_id": 120587872,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 22113503,
                    "reputation": 15,
                    "user_id": 16368004,
                    "user_type": "registered",
                    "profile_image": "https://lh3.googleusercontent.com/a/AATXAJyGJvgQJVA0uagTBVuigZFkOyqomGFnHIF1JgKD=k-s256",
                    "display_name": "user.1234",
                    "link": "https://stackoverflow.com/users/16368004/user-1234"
                },
                "reply_to_user": {
                    "account_id": 3959308,
                    "reputation": 53394,
                    "user_id": 3266847,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/U0oyt.png?s=256",
                    "display_name": "Benjamin W.",
                    "link": "https://stackoverflow.com/users/3266847/benjamin-w"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1625254423,
                "post_id": 68230320,
                "comment_id": 120587983,
                "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": 1625255225,
                "post_id": 68230320,
                "comment_id": 120588221,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 22113503,
                    "reputation": 15,
                    "user_id": 16368004,
                    "user_type": "registered",
                    "profile_image": "https://lh3.googleusercontent.com/a/AATXAJyGJvgQJVA0uagTBVuigZFkOyqomGFnHIF1JgKD=k-s256",
                    "display_name": "user.1234",
                    "link": "https://stackoverflow.com/users/16368004/user-1234"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1625256358,
                "post_id": 68230320,
                "comment_id": 120588515,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1625257096,
                "last_edit_date": 1625257096,
                "creation_date": 1625254535,
                "answer_id": 68230483,
                "question_id": 68230320,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You could do it like this (see [playground][1]):\r\n\r\n```sh\r\njq --raw-output &#39;if (.three | length &gt; 0) then .two else empty end&#39;\r\n```\r\n\r\nand to redirect output to a file:\r\n\r\n```sh\r\njq --raw-output &#39;if (.three | length &gt; 0) then .two else empty end&#39; &gt; outfile\r\n```\r\n\r\nThis assumes valid input, so the playground example uses an array of strings.\r\n\r\n  [1]: https://jqplay.org/s/N0_JBHokOW",
                "title": "jq selection of an attribute value based on another attribute&#39;s length and store that value in a text file"
            },
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1625255762,
                "last_edit_date": 1625255762,
                "creation_date": 1625254910,
                "answer_id": 68230541,
                "question_id": 68230320,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Unfortunately, the input as originally shown in the Q, is not valid JSON, and so some alterations or corrections would have to be made if jq is to be used in a straightforward way.\r\n\r\nAssuming these changes have been made, the following illustrates an efficient approach that avoids &quot;slurping&quot; the input:\r\n\r\n\r\n#### Invocation: jq -rnf program.jq input.json\r\n\r\n```\r\n[inputs | select(.three != []) | .two] | unique[]\r\n```\r\n\r\nThis produces the distinct values, sorted.\r\n\r\n### An alternative\r\n\r\nThe above solution involves collecting all the relevant .two values in an array.  If that is unsatisfactory,\r\none alternative would be to pipe the stream of the relevant .two values to `sort`:\r\n\r\n    &lt; input.json jq -rn &#39;inputs | select(.three != []) | .two&#39; | sort -u &gt; two.txt\r\n\r\n\r\n",
                "title": "jq selection of an attribute value based on another attribute&#39;s length and store that value in a text file"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1625256825,
                "last_edit_date": 1625256825,
                "creation_date": 1625255520,
                "answer_id": 68230614,
                "question_id": 68230320,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If the input file is large, you should process the elements one after the other instead of reading them into an array at once with `--slurp` and processing them together. Otherwise, memory problems may occur.\r\n\r\n### corrected input\r\n```json\r\n{&quot;one&quot;: &quot;Some string&quot;, &quot;two&quot;: &quot;A&quot;, &quot;three&quot;: []}\r\n{&quot;one&quot;: &quot;Some string&quot;, &quot;two&quot;: &quot;B&quot;, &quot;three&quot;: [{&quot;a&quot;: 1},{&quot;b&quot;: 2}]}\r\n{&quot;one&quot;: &quot;Some string&quot;, &quot;two&quot;: &quot;C&quot;, &quot;three&quot;: []}\r\n\r\n``` \r\n\r\n### command\r\n```jq -r &#39;select(.three | length &gt; 0) | .two&#39; &lt; file_in.json &gt; file_out.json```\r\n\r\n### output\r\n```\r\nB \r\n```\r\n\r\n",
                "title": "jq selection of an attribute value based on another attribute&#39;s length and store that value in a text file"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 0,
        "last_activity_date": 1625348941,
        "creation_date": 1625253451,
        "last_edit_date": 1625348941,
        "question_id": 68230320,
        "body_markdown": "I am using jq and want to select the value of an attribute from a large json file based on the condition that an another array is not empty. If that is empty, then we should ignore the value and check the next attribute, and so on. We also would like to store all values that fulfill the non-empty array condition into a text file, one value per line and unquoted. \r\n\r\nFor example, I have a large json file (16+ GB) having **200k** plus entries as below:\r\n\r\n    {&quot;one&quot;: &quot;Some string&quot;, &quot;two&quot;: &quot;A&quot;, &quot;three&quot;: []}\r\n    {&quot;one&quot;: &quot;Some string&quot;, &quot;two&quot;: &quot;B&quot;, &quot;three&quot;: [{&quot;a&quot;: 1,&quot;b&quot;: 2}]}\r\n    {&quot;one&quot;: &quot;Some string&quot;, &quot;two&quot;: &quot;C&quot;, &quot;three&quot;: []}\r\n\r\nSpecifically, I want to select the values of **only those** `&quot;two&quot;` attributes for which the value of array `&quot;three&quot;` is **not empty**. So, in the above example, only the value **&quot;B&quot;** should be returned, and all other values should be **ignored**. I also need to store all such values returned (like **&quot;B&quot;** in the above case) into a text file, one per line and unquoted.\r\n\r\nCan&#39;t seem to figure out how to do it. Your help will be greatly appreciated.",
        "link": "https://stackoverflow.com/questions/68230320/jq-selection-of-an-attribute-value-based-on-another-attributes-length-and-store",
        "title": "jq selection of an attribute value based on another attribute&#39;s length and store that value in a text file"
    },
    {
        "tags": [
            "json",
            "bash",
            "shell",
            "curl",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1625262914,
                "post_id": 68231416,
                "comment_id": 120590169,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "reply_to_user": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1625269894,
                "post_id": 68231416,
                "comment_id": 120591519,
                "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": 1625269997,
                "post_id": 68231416,
                "comment_id": 120591529,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1625262775,
                "last_edit_date": 1625262775,
                "creation_date": 1625261985,
                "answer_id": 68231469,
                "question_id": 68231416,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Try `jq &#39;.items[].Hosts.ip&#39;`. This grabs the `.items` key from the outer object, iterates the items array, then pulls the value from the path `.Hosts.ip` from each object.\r\n\r\n\r\n```\r\nPS &gt; cat a.json\r\n{\r\n  &quot;href&quot; : &quot;http://10.0.0.33:8080/api/v1/hosts?fields=Hosts/host_name,Hosts/ip&quot;,\r\n  &quot;items&quot; : [\r\n    {\r\n      &quot;href&quot; : &quot;http://10.0.0.33:8080/api/v1/hosts/sil.dev.test.com&quot;,\r\n      &quot;Hosts&quot; : {\r\n        &quot;host_name&quot; : &quot;test123.sil.dev.test.com&quot;,\r\n        &quot;ip&quot; : &quot;10.135.3.119&quot;\r\n      }\r\n    },\r\n    {\r\n      &quot;href&quot; : &quot;http://10.0.0.33:8080/api/v1/hosts/test001.sil.dev.test.com&quot;,\r\n      &quot;Hosts&quot; : {\r\n        &quot;cluster_name&quot; : &quot;test_cluster&quot;,\r\n        &quot;host_name&quot; : &quot;test001.sil.dev.test.com&quot;,\r\n        &quot;ip&quot; : &quot;10.0.0.33&quot;\r\n      }\r\n    },\r\n    {\r\n      &quot;href&quot; : &quot;http://10.0.0.33:8080/api/v1/hosts/test002.sil.dev.test.com&quot;,\r\n      &quot;Hosts&quot; : {\r\n        &quot;cluster_name&quot; : &quot;test_cluster&quot;,\r\n        &quot;host_name&quot; : &quot;test002.sil.dev.test.com&quot;,\r\n        &quot;ip&quot; : &quot;10.0.0.34&quot;\r\n      }\r\n    },\r\n    {\r\n      &quot;href&quot; : &quot;http://10.0.0.33:8080/api/v1/hosts/test003.sil.dev.test.com&quot;,\r\n      &quot;Hosts&quot; : {\r\n        &quot;cluster_name&quot; : &quot;test_cluster&quot;,\r\n        &quot;host_name&quot; : &quot;test003.sil.dev.test.com&quot;,\r\n        &quot;ip&quot; : &quot;10.0.0.35&quot;\r\n      }\r\n    }\r\n  ]\r\n}\r\nPS &gt; cat a.json | jq &#39;.items[].Hosts.ip&#39;\r\n&quot;10.135.3.119&quot;\r\n&quot;10.0.0.33&quot;\r\n&quot;10.0.0.34&quot;\r\n&quot;10.0.0.35&quot;\r\nPS &gt; cat a.json | jq -r &#39;.items[].Hosts.ip&#39;\r\n10.135.3.119\r\n10.0.0.33\r\n10.0.0.34\r\n10.0.0.35\r\n```                                                                          ",
                "title": "jq: Unable to retrieve a key/value from Json file using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1625262775,
        "creation_date": 1625261471,
        "last_edit_date": 1625262204,
        "question_id": 68231416,
        "body_markdown": "I have the below JSON from the curl output and I need to retrieve the IP address from it. I tried the below jq query, but I am getting the below error. I tried several other ways of doing it, but no luck\r\n\r\n`curl -sH &quot;X-Requested-By: ambari&quot; -u admin:admin -i http://${AMBARI_IP}:8080/api/v1/hosts?fields=Hosts/host_name,Hosts/ip | jq &#39;.[] | {.items.Hosts.ip}&#39;`\r\n\r\n```\r\njq: error: syntax error, unexpected FIELD (Unix shell quoting issues?) at &lt;top-level&gt;, line 1:\r\n.[] | {.items.Hosts.ip}\r\njq: 1 compile error\r\n(23) Failed writing body\r\n```\r\n\r\nbelow is the output of curl\r\n\r\n```\r\nHTTP/1.1 200 OK\r\nDate: Fri, 02 Jul 2021 21:04:27 GMT\r\nX-Frame-Options: DENY\r\nX-XSS-Protection: 1; mode=block\r\nX-Content-Type-Options: nosniff\r\nCache-Control: no-store\r\nPragma: no-cache\r\nSet-Cookie: AMBARISESSIONID=123344.node0;Path=/;HttpOnly\r\nExpires: Thu, 01 Jan 1970 00:00:00 GMT\r\nUser: admin\r\nContent-Type: text/plain;charset=utf-8\r\nX-Content-Type-Options: nosniff\r\nVary: Accept-Encoding, User-Agent\r\nTransfer-Encoding: chunked\r\n{\r\n  &quot;href&quot; : &quot;http://10.0.0.33:8080/api/v1/hosts?fields=Hosts/host_name,Hosts/ip&quot;,\r\n  &quot;items&quot; : [\r\n    {\r\n      &quot;href&quot; : &quot;http://10.0.0.33:8080/api/v1/hosts/sil.dev.test.com&quot;,\r\n      &quot;Hosts&quot; : {\r\n        &quot;host_name&quot; : &quot;test123.sil.dev.test.com&quot;,\r\n        &quot;ip&quot; : &quot;10.135.3.119&quot;\r\n      }\r\n    },\r\n    {\r\n      &quot;href&quot; : &quot;http://10.0.0.33:8080/api/v1/hosts/test001.sil.dev.test.com&quot;,\r\n      &quot;Hosts&quot; : {\r\n        &quot;cluster_name&quot; : &quot;test_cluster&quot;,\r\n        &quot;host_name&quot; : &quot;test001.sil.dev.test.com&quot;,\r\n        &quot;ip&quot; : &quot;10.0.0.33&quot;\r\n      }\r\n    },\r\n    {\r\n      &quot;href&quot; : &quot;http://10.0.0.33:8080/api/v1/hosts/test002.sil.dev.test.com&quot;,\r\n      &quot;Hosts&quot; : {\r\n        &quot;cluster_name&quot; : &quot;test_cluster&quot;,\r\n        &quot;host_name&quot; : &quot;test002.sil.dev.test.com&quot;,\r\n        &quot;ip&quot; : &quot;10.0.0.34&quot;\r\n      }\r\n    },\r\n    {\r\n      &quot;href&quot; : &quot;http://10.0.0.33:8080/api/v1/hosts/test003.sil.dev.test.com&quot;,\r\n      &quot;Hosts&quot; : {\r\n        &quot;cluster_name&quot; : &quot;test_cluster&quot;,\r\n        &quot;host_name&quot; : &quot;test003.sil.dev.test.com&quot;,\r\n        &quot;ip&quot; : &quot;10.0.0.35&quot;\r\n      }\r\n    },\r\n}",
        "link": "https://stackoverflow.com/questions/68231416/jq-unable-to-retrieve-a-key-value-from-json-file-using-jq",
        "title": "jq: Unable to retrieve a key/value from Json file using jq"
    },
    {
        "tags": [
            "json",
            "select",
            "jq",
            "updates"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1625338497,
                "last_edit_date": 1625338497,
                "creation_date": 1625337203,
                "answer_id": 68239011,
                "question_id": 68238661,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "`walk` to the rescue:\r\n```\r\nwalk(if type == &quot;string&quot;\r\n     then . as $in | try tonumber catch $in \r\n     else . end)\r\n```\r\n\r\nor just:\r\n\r\n```\r\nwalk(if type == &quot;string&quot; then tonumber? // . else . end)\r\n```\r\n\r\n## Enhanced `walk`\r\nIf your jq does not have `walk`, or if you want an enhanced version relative to the (current) built-in version, see the [jq FAQ][1] (search for `def walk`).\r\n\r\n\r\n  [1]: https://github.com/stedolan/jq/wiki/FAQ",
                "title": "workaround for known jq error while updating fields"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1625415977,
                "last_edit_date": 1625415977,
                "creation_date": 1625382442,
                "answer_id": 68242471,
                "question_id": 68238661,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s a walk-free solution for jq 1.5 or greater:\r\n```\r\nreduce paths(strings) as $p (.; \r\n  getpath($p) as $x | setpath($p; $x | tonumber? // $x))\r\n```",
                "title": "workaround for known jq error while updating fields"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 2,
        "last_activity_date": 1625415977,
        "creation_date": 1625334281,
        "last_edit_date": 1625364687,
        "question_id": 68238661,
        "body_markdown": "I want to update each value of type &quot;string&quot; in an entire json to a number if possible.\r\nIf the value cannot be parsed as a number, the string should be kept.\r\n\r\nMy attempt to solve this with jq runs into a known bug of version 1.6.\r\n\r\nI can&#39;t figure out how to workaround this bug.\r\nAny ideas how to solve the task without running into this known bug?\r\n\r\nSee also: [Update operator yields empty object in JQ](https://stackoverflow.com/questions/68160740/update-operator-yields-empty-object-in-jq)\r\n\r\n\r\n### example input\r\n\r\n```json\r\n{\r\n  &quot;outer&quot;: {\r\n    &quot;inner&quot;: [\r\n      {\r\n        &quot;foo&quot;: &quot;foo&quot;,\r\n        &quot;bar&quot;: &quot;11&quot;,\r\n        &quot;count&quot;: 12,\r\n        &quot;data&quot;: [&quot;13&quot;, &quot;14&quot;]\r\n      },\r\n      {\r\n        &quot;foo&quot;: &quot;foo&quot;,\r\n        &quot;bar&quot;: &quot;15&quot;,\r\n        &quot;count&quot;: 16,\r\n        &quot;child&quot;: {\r\n          &quot;otherData&quot;: [&quot;17&quot;, &quot;18&quot;]\r\n        }\r\n      }\r\n    ]\r\n  }\r\n}\r\n```\r\n\r\n### desired output\r\n```json\r\n{\r\n  &quot;outer&quot;: {\r\n    &quot;inner&quot;: [\r\n      {\r\n        &quot;foo&quot;: &quot;foo&quot;,\r\n        &quot;bar&quot;: 11,\r\n        &quot;count&quot;: 12,\r\n        &quot;data&quot;: [13, 14]\r\n      },\r\n      {\r\n        &quot;foo&quot;: &quot;foo&quot;,\r\n        &quot;bar&quot;: 15,\r\n        &quot;count&quot;: 16,\r\n        &quot;child&quot;: {\r\n          &quot;otherData&quot;: [17, 18]\r\n        }\r\n      }\r\n    ]\r\n  }\r\n}\r\n```\r\n\r\n---\r\n\r\n\r\n### attempt 1 to solve - not working\r\n```jq &#39;(..| strings) |= try tonumber catch .&#39;```\r\n\r\noutput\r\n\r\n```json\r\n{\r\n  &quot;outer&quot;: {\r\n    &quot;inner&quot;: [\r\n      {\r\n        &quot;foo&quot;: &quot;Invalid literal at EOF at line 1, column 3 (while parsing &#39;foo&#39;)&quot;,\r\n        &quot;bar&quot;: {\r\n          &quot;__jq&quot;: 1\r\n        },\r\n        &quot;count&quot;: 12,\r\n        &quot;data&quot;: [\r\n          {\r\n            &quot;__jq&quot;: 2\r\n          },\r\n          {\r\n            &quot;__jq&quot;: 3\r\n          }\r\n        ]\r\n      },\r\n      {\r\n        &quot;foo&quot;: &quot;Invalid literal at EOF at line 1, column 3 (while parsing &#39;foo&#39;)&quot;,\r\n        &quot;bar&quot;: {\r\n          &quot;__jq&quot;: 5\r\n        },\r\n        &quot;count&quot;: 16,\r\n        &quot;child&quot;: {\r\n          &quot;otherData&quot;: [\r\n            {\r\n              &quot;__jq&quot;: 6\r\n            },\r\n            {\r\n              &quot;__jq&quot;: 7\r\n            }\r\n          ]\r\n        }\r\n      }\r\n    ]\r\n  }\r\n}\r\n```\r\n\r\n### attempt 2 to solve - even worse\r\n```jq &#39;(..| strings) |= tonumber? // .&#39;```\r\n\r\noutput\r\n```json\r\n{\r\n  &quot;outer&quot;: {\r\n    &quot;inner&quot;: [\r\n      {\r\n        &quot;count&quot;: 12,\r\n        &quot;data&quot;: [\r\n          &quot;14&quot;\r\n        ]\r\n      },\r\n      {\r\n        &quot;count&quot;: 16,\r\n        &quot;child&quot;: {\r\n          &quot;otherData&quot;: [\r\n            &quot;18&quot;\r\n          ]\r\n        }\r\n      }\r\n    ]\r\n  }\r\n}\r\n```\r\n\r\n### working as expected - but does not solve the task\r\nthe bug is related to update operator in combination with try catch expression\r\n\r\n\r\n```jq &#39;(..| strings) |= (. + &quot;___needs_update&quot;)&#39;```\r\n\r\n```json\r\n{\r\n  &quot;outer&quot;: {\r\n    &quot;inner&quot;: [\r\n      {\r\n        &quot;foo&quot;: &quot;foo___needs_update&quot;,\r\n        &quot;bar&quot;: &quot;11___needs_update&quot;,\r\n        &quot;count&quot;: 12,\r\n        &quot;data&quot;: [\r\n          &quot;13___needs_update&quot;,\r\n          &quot;14___needs_update&quot;\r\n        ]\r\n      },\r\n      {\r\n        &quot;foo&quot;: &quot;foo___needs_update&quot;,\r\n        &quot;bar&quot;: &quot;15___needs_update&quot;,\r\n        &quot;count&quot;: 16,\r\n        &quot;child&quot;: {\r\n          &quot;otherData&quot;: [\r\n            &quot;17___needs_update&quot;,\r\n            &quot;18___needs_update&quot;\r\n          ]\r\n        }\r\n      }\r\n    ]\r\n  }\r\n}\r\n```",
        "link": "https://stackoverflow.com/questions/68238661/workaround-for-known-jq-error-while-updating-fields",
        "title": "workaround for known jq error while updating fields"
    },
    {
        "tags": [
            "json",
            "select",
            "key",
            "jq",
            "jsonlines"
        ],
        "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": 1625470055,
                "post_id": 68251963,
                "comment_id": 120626020,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 22127894,
                    "reputation": 63,
                    "user_id": 16379925,
                    "user_type": "registered",
                    "profile_image": "https://lh3.googleusercontent.com/a-/AOh14GhGFRDw9_OhRS0IJh0Ezt9RuYlGaOsZKpU7WkxZ17A=k-s256",
                    "display_name": "Makkenac",
                    "link": "https://stackoverflow.com/users/16379925/makkenac"
                },
                "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": 1625471236,
                "post_id": 68251963,
                "comment_id": 120626461,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 5,
                "is_accepted": true,
                "score": 5,
                "last_activity_date": 1625483481,
                "last_edit_date": 1625483481,
                "creation_date": 1625479569,
                "answer_id": 68254243,
                "question_id": 68251963,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "In accordance with your explanatory comment, it would appear you could achieve what you want using jq &quot;$-variables&quot;:\r\n```\r\njq -c &#39;\r\n.items[]\r\n| .metadata.name as $podname\r\n| .spec.containers[] \r\n| select(.resources.requests == null or \r\n         .resources.limits == null or \r\n         .resources == {})\r\n| [$podname, .name]\r\n&#39;\r\n```\r\n\r\nWith your data, the output produced by the above would be:\r\n```\r\n[&quot;pod02&quot;,&quot;con02_02&quot;]\r\n[&quot;pod03&quot;,&quot;con03_02&quot;]\r\n```\r\n\r\n### Simplification\r\n\r\nThe test for the third condition (.resources == {}) is actually redundant, so the above jq filter is equivalent to:\r\n```\r\n.items[]\r\n| .metadata.name as $podname\r\n| .spec.containers[] \r\n| select(.resources | (.requests == null or .limits == null ))\r\n| [$podname, .name]\r\n\r\n```\r\n\r\n## Existence of a key\r\nTo check for the existence of a key, it is generally appropriate to use `has/1` since `{} | .key` evaluates to `null`. Thus you might wish to replace the `select()` above with:\r\n```\r\nselect( any(.resources | has(&quot;requests&quot;, &quot;limits&quot;); not) )\r\n```\r\n",
                "title": "jq filter for object with target value or key is not exist"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 4,
        "last_activity_date": 1625484461,
        "creation_date": 1625468900,
        "last_edit_date": 1625484461,
        "question_id": 68251963,
        "body_markdown": "I have  jsonlines data which and would like to find 1. value is empty object  or 2. key is not exist . In the following sample, I wonder take the result of items which .items.spec.resource={} or .items.spec.limits|requests which key not exist.\r\n \r\n\r\n    data=&#39;{&quot;items&quot;:[{&quot;metadata&quot;:{&quot;name&quot;:&quot;pod01&quot;},&quot;spec&quot;:{&quot;containers&quot;:[{&quot;name&quot;:&quot;con01_01&quot;,&quot;resources&quot;:{&quot;limits&quot;:{&quot;cpu&quot;:&quot;100m&quot;},&quot;requests&quot;:{&quot;cpu&quot;:&quot;100m&quot;}}},{&quot;name&quot;:&quot;con01_02&quot;,&quot;resources&quot;:{&quot;limits&quot;:{&quot;cpu&quot;:&quot;100m&quot;},&quot;requests&quot;:{&quot;cpu&quot;:&quot;100m&quot;}}}]}},{&quot;metadata&quot;:{&quot;name&quot;:&quot;pod02&quot;},&quot;spec&quot;:{&quot;containers&quot;:[{&quot;name&quot;:&quot;con02_01&quot;,&quot;resources&quot;:{&quot;limits&quot;:{&quot;cpu&quot;:&quot;100m&quot;},&quot;requests&quot;:{&quot;cpu&quot;:&quot;100m&quot;}}},{&quot;name&quot;:&quot;con02_02&quot;,&quot;resources&quot;:{&quot;limits&quot;:{&quot;cpu&quot;:&quot;100m&quot;}}}]}},{&quot;metadata&quot;:{&quot;name&quot;:&quot;pod03&quot;},&quot;spec&quot;:{&quot;containers&quot;:[{&quot;name&quot;:&quot;con03_01&quot;,&quot;resources&quot;:{&quot;limits&quot;:{&quot;cpu&quot;:&quot;100m&quot;},&quot;requests&quot;:{&quot;cpu&quot;:&quot;100m&quot;}}},{&quot;name&quot;:&quot;con03_02&quot;,&quot;resources&quot;:{}}]}}]}&#39;\r\n\r\n```\r\nlist=$(echo $data | jq &#39;.items[] | select(.spec.containers[].resources.requests == null or  .spec.containers[].resources.limits == null or .spec.containers[].resources == {})&#39;)\r\n```\r\n```\r\necho $list \r\n``` \r\nHere comes the result\r\n```\r\n{ \r\n  &quot;metadata&quot;: { &quot;name&quot;: &quot;pod02&quot; }, \r\n  &quot;spec&quot;: { \r\n    &quot;containers&quot;: [ \r\n\t  { &quot;name&quot;: &quot;con02_01&quot;, \r\n\t    &quot;resources&quot;: { \r\n\t\t               &quot;limits&quot;: { &quot;cpu&quot;: &quot;100m&quot; }, \r\n\t\t               &quot;requests&quot;: { &quot;cpu&quot;: &quot;100m&quot; } \r\n\t\t\t\t\t } \r\n\t  }, \r\n\t  { &quot;name&quot;: &quot;con02_02&quot;, \r\n\t    &quot;resources&quot;: { \r\n\t\t               &quot;limits&quot;: { &quot;cpu&quot;: &quot;100m&quot; } \r\n\t\t\t\t\t } \r\n\t  } \r\n\t] \r\n  } \r\n} \r\n{ \r\n  &quot;metadata&quot;: { &quot;name&quot;: &quot;pod03&quot; },\r\n  &quot;spec&quot;: {\r\n    &quot;containers&quot;: [ \r\n\t  { \r\n\t    &quot;name&quot;: &quot;con03_01&quot;, \r\n\t    &quot;resources&quot;: { \r\n\t\t               &quot;limits&quot;: { &quot;cpu&quot;: &quot;100m&quot; }, \r\n\t\t\t\t\t   &quot;requests&quot;: { &quot;cpu&quot;: &quot;100m&quot; } \r\n\t\t\t\t\t } \r\n\t  }, \r\n\t  { &quot;name&quot;: &quot;con03_02&quot;, \r\n\t    &quot;resources&quot;: {} \r\n\t  } \r\n    ] \r\n  } \r\n} \r\n\r\n{ \r\n  &quot;metadata&quot;: { &quot;name&quot;: &quot;pod03&quot; }, \r\n  &quot;spec&quot;: { \r\n    &quot;containers&quot;: [ \r\n\t  { &quot;name&quot;: &quot;con03_01&quot;, \r\n\t    &quot;resources&quot;: { \r\n\t\t                &quot;limits&quot;: { &quot;cpu&quot;: &quot;100m&quot; }, \r\n\t\t                &quot;requests&quot;: { &quot;cpu&quot;: &quot;100m&quot; } \r\n\t\t\t\t\t } \r\n\t  }, \r\n\t  { &quot;name&quot;: &quot;con03_02&quot;, \r\n\t    &quot;resources&quot;: {} \r\n\t  } \r\n\t] \r\n  } \r\n} \r\n  \r\n{ \r\n  &quot;metadata&quot;: { &quot;name&quot;: &quot;pod03&quot; }, \r\n  &quot;spec&quot;: { \r\n    &quot;containers&quot;: [ \r\n\t  { &quot;name&quot;: &quot;con03_01&quot;, \r\n\t    &quot;resources&quot;: { \r\n\t\t                &quot;limits&quot;: { &quot;cpu&quot;: &quot;100m&quot; }, \r\n\t\t\t\t\t\t&quot;requests&quot;: { &quot;cpu&quot;: &quot;100m&quot; } \r\n\t\t\t\t\t  } \r\n\t  }, \r\n\t  { &quot;name&quot;: &quot;con03_02&quot;, \r\n\t    &quot;resources&quot;: {} \r\n\t  } \r\n    ] \r\n  } \r\n}\r\n```\r\nI don&#39;t understand the repeat part, I guess it is because of the conditions,  how can I get the part of above conditions, I would like to filter the part of metadata and spec.containers which meet conditions.\r\n\r\n",
        "link": "https://stackoverflow.com/questions/68251963/jq-filter-for-object-with-target-value-or-key-is-not-exist",
        "title": "jq filter for object with target value or key is not exist"
    },
    {
        "tags": [
            "arrays",
            "shell",
            "curl",
            "environment-variables",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 7,
                "is_accepted": true,
                "score": 7,
                "last_activity_date": 1625489357,
                "last_edit_date": 1625489357,
                "creation_date": 1625488773,
                "answer_id": 68256321,
                "question_id": 68255795,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The simplest way to achieve your goal would be to define `requiredViewers` as a JSON array, and to pass it in using `--argjson` instead of `--arg` (assuming your version of jq supports --argjson):\r\n```\r\nrequiredViewers=&#39;[&quot;joedoe&quot;, &quot;johnsmith&quot;, &quot;johnstiles&quot;]&#39;\r\n\r\necho &quot;$response&quot; |\r\n  jq --argjson items &quot;$requiredViewers&quot; &#39;\r\n    ( map( select( .state==&quot;APPROVED&quot; ) ) \r\n      | map( { user: .user.login, state, submitted_at } )\r\n      | unique_by( .user ) \r\n      | sort_by( .submitted_at )\r\n      | reverse )\r\n    | any( .[].user; \r\n           IN ( $items[] ) ) and length&gt;=2\r\n&#39;\r\n```\r\n### If your jq does not support `--argjson`\r\n\r\nIf you cannot upgrade your jq, then one possibility would be to pass the JSON array in as a string using `--arg`, and to use `fromjson` to convert it to a JSON array.\r\n\r\n### Notes\r\n1. The leading &#39;. |&#39; in constructs such as &#39;. | IN(...)&#39; should be omitted.\r\n2. Don&#39;t forget to quote your shell variables.\r\n3. The jq expression `{foo: .foo}` can be abbreviated to `{foo}`\r\n4. There are some aspects of your jq program that do not seem to make much sense but in the absence of both explicit requirements and sample JSON, I&#39;ve focused on the main question.\r\n5. I&#39;d suggest adopting a style that does not require so much right-indentation; the &quot;pipes-on-the-left&quot; style works for me :-)\r\n\r\n",
                "title": "How to pass an array to jq to filter results"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1625506249,
        "creation_date": 1625486394,
        "last_edit_date": 1625506249,
        "question_id": 68255795,
        "body_markdown": "I am fetching list of PR approvals from Github API using `curl` and `jq` to put a label in each PR if conditions are met. I have a few conditions for that namely; \r\n\r\n - number of approvals must be at least 2 and \r\n - one of approvers must be in a list that I provide.\r\n\r\nIn fact, everything is working well but I wanted to beautify my code for example passing the list as an argument rather than having it hardcoded in code. I tried below but it is not working due to:\r\n\r\n&gt; jq: error (at &lt;stdin&gt;:1): Cannot iterate over string (&quot;joedoe,&quot;)\r\n\r\n    response=$(curl \\\r\n      -H &quot;Accept: application/vnd.github.v3+json&quot; \\\r\n      --request GET \\\r\n      --url https://api.github.com/repos/my-organization/my-repo/pulls/my-pr-number/reviews \\\r\n      --header &quot;Authorization: token ***&quot; \\\r\n      --header &quot;Content-Type: application/json&quot;)\r\n    \r\n    requiredViewers=(&quot;joedoe&quot;, &quot;johnsmith&quot;, &quot;johnstiles&quot;)\r\n    \r\n    echo $response | jq --arg items $requiredViewers &#39;( map( select( .state==&quot;APPROVED&quot; ) ) | \r\n                                                        map( { user: .user.login, state: .state, submitted_at: .submitted_at } ) | \r\n                                                        unique_by( .user ) | \r\n                                                        sort_by( .submitted_at ) | \r\n                                                        reverse ) | \r\n                                                        any( .[].user; . | \r\n                                                        IN ( $items[] --&gt; this is not working ) ) and \r\n                                                        length&gt;=2&#39;\r\n\r\nI had a look at similar posts on SO but couldn&#39;t get it to working unfortunately. My question is that how can I pass a list as an argument and make it working as like hardcoding them?",
        "link": "https://stackoverflow.com/questions/68255795/how-to-pass-an-array-to-jq-to-filter-results",
        "title": "How to pass an array to jq to filter results"
    },
    {
        "tags": [
            "json",
            "key",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1625489680,
                "creation_date": 1625489680,
                "answer_id": 68256517,
                "question_id": 68256334,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Would this work for you?\r\n\r\n```\r\njq -c &#39;to_entries[] | &quot;UserId: &quot; + .key + &quot;  email: &quot; + .value.email &#39;\r\n```",
                "title": "Get value from nested json - Bash"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1625489815,
                "creation_date": 1625489815,
                "answer_id": 68256543,
                "question_id": 68256334,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Another approach:\r\n```\r\n  keys_unsorted[] as $key\r\n  | &quot;UserId: \\($key)  email: \\(.[$key].email)&quot;\r\n```",
                "title": "Get value from nested json - Bash"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1625491658,
        "creation_date": 1625488826,
        "last_edit_date": 1625491658,
        "question_id": 68256334,
        "body_markdown": "I had a look around but I cannot find anything that helped, here my problem, I have a bash script that make a curl query and get a json, that look like that:\r\n\r\n    {\r\n      &quot;user1&quot;: {\r\n        &quot;email&quot;: &quot;email1@email.cccc&quot;,\r\n        &quot;shell&quot;: &quot;/usr/local/bin/bash&quot;,\r\n        &quot;status&quot;: &quot;ACTIVE&quot;,\r\n        &quot;userId&quot;: &quot;user1&quot;,\r\n        &quot;homeDir&quot;: &quot;/home/user1&quot;,\r\n        &quot;unixUid&quot;: 123456,\r\n        &quot;accesses&quot;: [\r\n          &quot;computer1&quot;\r\n        ],\r\n        &quot;personId&quot;: 1234,\r\n        &quot;isPrimary&quot;: true,\r\n        &quot;projectGroupIds&quot;: [\r\n          &quot;bigproj&quot;\r\n        ],\r\n        &quot;primaryProjectGroupId&quot;: &quot;bigproj&quot;\r\n      },\r\n      &quot;user2&quot;: {\r\n        &quot;email&quot;: &quot;email2@email.cccc&quot;,\r\n        &quot;shell&quot;: &quot;/usr/local/bin/bash&quot;,\r\n        &quot;status&quot;: &quot;ACTIVE&quot;,\r\n        &quot;userId&quot;: &quot;user2&quot;,\r\n        &quot;homeDir&quot;: &quot;/home/user2&quot;,\r\n        &quot;unixUid&quot;: 9876564,\r\n        &quot;accesses&quot;: [\r\n          &quot;computer1&quot;\r\n        ],\r\n        &quot;personId&quot;: 5678,\r\n        &quot;isPrimary&quot;: true,\r\n        &quot;projectGroupIds&quot;: [\r\n          &quot;smallporj&quot;\r\n        ],\r\n        &quot;primaryProjectGroupId&quot;: &quot;smallproj&quot;\r\n    ...\r\n\r\nWhat I need to do is to create a list, that contains:\r\n\r\n    UserId: user1  email: email1@email.cccc\r\n    UserId: user2  email: email2@email.cccc\r\n    UserId: user3  email: email3@email.cccc\r\n    ...\r\n\r\nMy problem is that the username key, is basically always changing and it doesn&#39;t have a fix key name. \r\nThe top key types are:\r\n\r\n    jq -c &#39;to_entries[] | [.key, (.value|type)]&#39;\r\n    [&quot;meta&quot;,&quot;object&quot;]\r\n    [&quot;body&quot;,&quot;object&quot;]\r\n\r\nSo what should be the best approach to create a list that I&#39;ll need to compare with another one?\r\nThanks in advance.",
        "link": "https://stackoverflow.com/questions/68256334/get-value-from-nested-json-bash",
        "title": "Get value from nested json - Bash"
    },
    {
        "tags": [
            "json",
            "bash",
            "csv",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 6313442,
                    "reputation": 45115,
                    "user_id": 5625547,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/oqCND.jpg?s=256",
                    "display_name": "0stone0",
                    "link": "https://stackoverflow.com/users/5625547/0stone0"
                },
                "edited": false,
                "score": 3,
                "creation_date": 1625580051,
                "post_id": 68271887,
                "comment_id": 120660680,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1625580363,
                "creation_date": 1625580363,
                "answer_id": 68272068,
                "question_id": 68271887,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Ignoring the duplicate `CDE` key, we can use [this answer](https://stackoverflow.com/questions/43729643/use-jq-to-turn-x-y-pairs-into-key-value-pairs) to convert the `;` splitter string into separate values, then using `add` to create a object:\r\n```\r\n$DOC | split(&quot;;&quot;) | map(split(&quot;=&quot;) | { (.[0]) : .[1] }) | add + { $NEWVAR } + { $NEWVAR2 }\r\n```\r\n\r\nWhere\r\n\r\n* `split(&quot;;&quot;) | map(split(&quot;=&quot;) | { (.[0]) : .[1] })` is from the link above\r\n* `add` created the objecct\r\n* `+ { $NEWVAR }` combine the simple `NEWVAR` to the object\r\n* `+ { $NEWVAR2 }` Add `NEWVAR2`\r\n\r\n&lt;hr&gt;\r\n\r\nFull command with `--arg`:\r\n\r\n```\r\njq --arg DOC &quot;$DOC&quot; --arg NEWVAR &quot;$NEWVAR&quot; --arg NEWVAR2 &quot;$NEWVAR2&quot; &#39;$DOC | split(&quot;;&quot;) | map(split(&quot;=&quot;) | { (.[0]) : .[1] }) | add + { $NEWVAR } + { $NEWVAR2 }&#39; -Rn\r\n```\r\n\r\n&lt;hr&gt;\r\n\r\nExample on my local machine:\r\n```none\r\n$ DOC=&#39;ABC=123;CDE=345;CDE=IOP&#39;\r\nNEWVAR=&#39;101808&#39;\r\nNEWVAR2=&#39;10240404&#39;\r\n$\r\n$ jq --arg DOC &quot;$DOC&quot; --arg NEWVAR &quot;$NEWVAR&quot; --arg NEWVAR2 &quot;$NEWVAR2&quot; &#39;$DOC | split(&quot;;&quot;) | map(split(&quot;=&quot;) | { (.[0]) : .[1] }) | add + { $NEWVAR } + { $NEWVAR2 }&#39; -Rn\r\n{\r\n  &quot;ABC&quot;: &quot;123&quot;,\r\n  &quot;CDE&quot;: &quot;IOP&quot;,\r\n  &quot;NEWVAR&quot;: &quot;101808&quot;,\r\n  &quot;NEWVAR2&quot;: &quot;10240404&quot;\r\n}\r\n$\r\n```",
                "title": "How to convert semicolon separated parameters to json?"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1625593726,
                "creation_date": 1625593726,
                "answer_id": 68275262,
                "question_id": 68271887,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "```bash\r\nDOC=&#39;ABC=123;CDE=345;CDE=IOP&#39;\r\nNEWVAR=&#39;101808&#39;\r\nNEWVAR2=&#39;10240404&#39;\r\nargs=()\r\n\r\n# parse $DOC and add jq --arg options to the array\r\nwhile IFS=&#39;=&#39; read -r -d &#39;;&#39; name value || [[ -n $name &amp;&amp; -n $value ]]; do\r\n    args+=( --arg &quot;$name&quot; &quot;$value&quot; )\r\ndone &lt; &lt;(printf &#39;%s&#39; &quot;$DOC&quot;)\r\n\r\n# add the plain variables to the array\r\nfor var in NEWVAR NEWVAR2; do\r\n    args+=( --arg &quot;$var&quot; &quot;${!var}&quot; )\r\ndone\r\n\r\ndeclare -p args\r\n\r\njq --null-input  &quot;${args[@]}&quot; &#39;$ARGS.named&#39;\r\n```\r\noutputs\r\n```none\r\ndeclare -a args=([0]=&quot;--arg&quot; [1]=&quot;ABC&quot; [2]=&quot;123&quot; [3]=&quot;--arg&quot; [4]=&quot;CDE&quot; [5]=&quot;345&quot; [6]=&quot;--arg&quot; [7]=&quot;CDE&quot; [8]=&quot;IOP&quot; [9]=&quot;--arg&quot; [10]=&quot;NEWVAR&quot; [11]=&quot;101808&quot; [12]=&quot;--arg&quot; [13]=&quot;NEWVAR2&quot; [14]=&quot;10240404&quot;)\r\n{\r\n  &quot;ABC&quot;: &quot;123&quot;,\r\n  &quot;CDE&quot;: &quot;345&quot;,\r\n  &quot;NEWVAR&quot;: &quot;101808&quot;,\r\n  &quot;NEWVAR2&quot;: &quot;10240404&quot;\r\n}\r\n```\r\njq clearly ignores duplicate --arg variables.",
                "title": "How to convert semicolon separated parameters to json?"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1625655572,
                "last_edit_date": 1625655572,
                "creation_date": 1625641572,
                "answer_id": 68281493,
                "question_id": 68271887,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can&#39;t have 2 CDE keys.\r\n\r\nUsing sed and [Miller][1] you can run\r\n\r\n```\r\n&lt;input.csv sed &quot;s/&#39;//g&quot; | \\\r\nmlr --x2n --ips = nest --explode --pairs --across-records -f DOC  --nested-ps =  then \\\r\nunsparsify then \\\r\nreshape -r &quot;[A-Z]&quot; -o i,v then \\\r\nfilter -x -S &#39;$v==&quot;&quot;&#39; then \\\r\nuniq -a\r\n```\r\n\r\nto have \r\n\r\n```\r\nABC 123\r\nNEWVAR 101808\r\nNEWVAR2 10240404\r\nCDE 345\r\nCDE IOP\r\n```\r\n\r\nAnd than you can write a loop to create the wrong JSON you want.\r\n\r\nIf you want a JSON run\r\n\r\n```\r\n&lt;input.csv sed &quot;s/&#39;//g&quot; | \\\r\nmlr --x2j --ips = nest --explode --pairs --across-records -f DOC  --nested-ps =  then \\\r\nunsparsify then \\\r\nreshape -r &quot;[A-Z]&quot; -o i,v then \\\r\nfilter -x -S &#39;$v==&quot;&quot;&#39; then \\\r\nuniq -a then reshape -s i,v\r\n```\r\n\r\nto have\r\n\r\n```\r\n{ &quot;ABC&quot;: 123, &quot;NEWVAR&quot;: 101808, &quot;NEWVAR2&quot;: 10240404, &quot;CDE&quot;: &quot;IOP&quot; }\r\n```\r\n\r\n\r\n  [1]: https://github.com/johnkerl/miller",
                "title": "How to convert semicolon separated parameters to json?"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": -1,
        "last_activity_date": 1625655572,
        "creation_date": 1625579650,
        "question_id": 68271887,
        "body_markdown": "I have these variables in bash.\r\n\r\n```\r\nDOC=&#39;ABC=123;CDE=345;CDE=IOP&#39;\r\nNEWVAR=&#39;101808&#39;\r\nNEWVAR2=&#39;10240404&#39;\r\n```\r\n\r\nI want to combine them and create a json string in bash. \r\n```\r\n{\r\n   &quot;ABC&quot;: &quot;123&quot;,\r\n   &quot;CDE&quot;: &quot;345&quot;,\r\n   &quot;CDE&quot;: &quot;IOP&quot;,\r\n   &quot;NEWVAR&quot;: &quot;101808&quot;,\r\n   &quot;NEWVAR2&quot;: &quot;10240404&quot;\r\n}\r\n```\r\nonly &#39;DOC&#39; is in semicolon-separated values.\r\nNEWVAR and NEWVAR2 are just plain texts.\r\n\r\ncan I use jq to do this?",
        "link": "https://stackoverflow.com/questions/68271887/how-to-convert-semicolon-separated-parameters-to-json",
        "title": "How to convert semicolon separated parameters to json?"
    },
    {
        "tags": [
            "json",
            "jq",
            "flatten"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1625598514,
                "creation_date": 1625598514,
                "answer_id": 68276221,
                "question_id": 68276052,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Something like this should do the trick:\r\n```\r\n{items: [.clients[] | {id} + .accounts[]]}\r\n```\r\n&lt;sup&gt;[Online demo](https://jqplay.org/s/h-S9bcY2ks)&lt;/sup&gt;",
                "title": "jq - how can I flat my list of lists into one level list"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1625601186,
        "creation_date": 1625597677,
        "last_edit_date": 1625601186,
        "question_id": 68276052,
        "body_markdown": "how can I have transformed my json\r\n\r\n```\r\n{\r\n    &quot;clients&quot;: [\r\n    {\r\n     &quot;id&quot; : &quot;qwerty&quot;,\r\n     &quot;accounts&quot; : [{&quot;number&quot; : &quot;6666&quot;}, {&quot;number&quot; : &quot;7777&quot;}]\r\n    },\r\n    {\r\n     &quot;id&quot; : &quot;zxcvb&quot;,\r\n     &quot;accounts&quot; : [{&quot;number&quot; : &quot;1111&quot;}, {&quot;number&quot; : &quot;2222&quot;}] \r\n    }\r\n]\r\n}\r\n```\r\n\r\ninto following type of json? using **JQ**\r\n\r\n```\r\n{\r\n&quot;items&quot;: [\r\n{\r\n&quot;id&quot; : &quot;qwerty&quot;,\r\n&quot;number&quot; : &quot;6666&quot;\r\n},{\r\n&quot;id&quot; : &quot;qwerty&quot;,\r\n&quot;number&quot; : &quot;7777&quot;\r\n},{\r\n&quot;id&quot; : &quot;zxcvb&quot;,\r\n&quot;number&quot; : &quot;1111&quot;\r\n},{\r\n&quot;id&quot; : &quot;zxcvb&quot;,\r\n&quot;number&quot; : &quot;2222&quot;\r\n}]\r\n}\r\n```\r\n\r\nWhat kind of tools from JQ can help me? I can&#39;t choose any possible way to do it\r\n",
        "link": "https://stackoverflow.com/questions/68276052/jq-how-can-i-flat-my-list-of-lists-into-one-level-list",
        "title": "jq - how can I flat my list of lists into one level list"
    },
    {
        "tags": [
            "json",
            "jq",
            "aws-cli"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1625650020,
                "creation_date": 1625650020,
                "answer_id": 68283391,
                "question_id": 68282553,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Solved, not with `.jq`,  but with an `aws` cli feature:\r\n\r\n\r\n```\r\naws rds describe-db-instances --query &#39;DBInstances[*].[DBInstanceIdentifier, EngineVersion]&#39; \r\n\r\n```",
                "title": "Filter out specific json array fields of elements using jq"
            },
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1625658731,
                "creation_date": 1625658731,
                "answer_id": 68285505,
                "question_id": 68282553,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can use the following JQ filter:\r\n```\r\n.DBInstances[] | [ .DBInstanceIdentifier, .EngineVersion ]\r\n```\r\n\r\nWhere \r\n\r\n* `.DBInstances[]` Loops over the `DBInstances` array\r\n* `[ .DBInstanceIdentifier, .EngineVersion ]` creates an array containing only the `DBInstanceIdentifier` and `EngineVersion` keys\r\n\r\n```bash\r\njq &#39;.DBInstances[] | [ .DBInstanceIdentifier, .EngineVersion ]&#39;\r\n```\r\n\r\n##### [JqPlay Demo](https://jqplay.org/s/vTrrpYXjfO)\r\n\r\n&lt;hr&gt;\r\n\r\nAs of your current JSON Example (with only 1 item in the `DBInstances` Array) the result is:\r\n```\r\n[\r\n  &quot;my-rds&quot;,\r\n  &quot;11.9&quot;\r\n]\r\n```",
                "title": "Filter out specific json array fields of elements using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1625658731,
        "creation_date": 1625646434,
        "last_edit_date": 1625650035,
        "question_id": 68282553,
        "body_markdown": "I run a `aws rds describe-instances` and I got a `json` array of the instances more or less as follows:\r\n\r\n```\r\n&quot;DBInstances&quot;: [\r\n        {\r\n            &quot;DBInstanceIdentifier&quot;: &quot;my-rds&quot;,\r\n            &quot;Endpoint&quot;: {\r\n                &quot;HostedZoneId&quot;: &quot;XXXXXXXXXXXX&quot;\r\n            },\r\n            &quot;DBSecurityGroups&quot;: [],\r\n            &quot;VpcSecurityGroups&quot;: [\r\n                {\r\n                    &quot;VpcSecurityGroupId&quot;: &quot;sg-12345&quot;,\r\n                    &quot;Status&quot;: &quot;active&quot;\r\n                },\r\n                {\r\n                    &quot;VpcSecurityGroupId&quot;: &quot;sg-12345&quot;,\r\n                    &quot;Status&quot;: &quot;active&quot;\r\n                }\r\n            ],\r\n            &quot;DBParameterGroups&quot;: [\r\n                {\r\n                    &quot;DBParameterGroupName&quot;: &quot;postgres-12&quot;,\r\n                    &quot;ParameterApplyStatus&quot;: &quot;in-sync&quot;\r\n                }\r\n            ],\r\n            &quot;AvailabilityZone&quot;: &quot;us-west-1c&quot;,\r\n            &quot;DBSubnetGroup&quot;: {\r\n                &quot;VpcId&quot;: &quot;vpc-123456&quot;,\r\n                &quot;SubnetGroupStatus&quot;: &quot;Complete&quot;,\r\n                &quot;Subnets&quot;: [\r\n                    {\r\n                        &quot;SubnetIdentifier&quot;: &quot;subnet-123456&quot;,\r\n                        &quot;SubnetAvailabilityZone&quot;: {\r\n                            &quot;Name&quot;: &quot;us-west-1b&quot;\r\n                        },\r\n                        &quot;SubnetOutpost&quot;: {},\r\n                        &quot;SubnetStatus&quot;: &quot;Active&quot;\r\n                    },\r\n                    {\r\n                        &quot;SubnetIdentifier&quot;: &quot;subnet-12345&quot;,\r\n                        &quot;SubnetAvailabilityZone&quot;: {\r\n                            &quot;Name&quot;: &quot;us-west-1c&quot;\r\n                        },\r\n                        &quot;SubnetOutpost&quot;: {},\r\n                        &quot;SubnetStatus&quot;: &quot;Active&quot;\r\n                    },\r\n                    {\r\n                        &quot;SubnetIdentifier&quot;: &quot;subnet-12345&quot;,\r\n                        &quot;SubnetAvailabilityZone&quot;: {\r\n                            &quot;Name&quot;: &quot;us-west-1e&quot;\r\n                        },\r\n                        &quot;SubnetOutpost&quot;: {},\r\n                        &quot;SubnetStatus&quot;: &quot;Active&quot;\r\n                    }\r\n                ]\r\n            },\r\n            &quot;EngineVersion&quot;: &quot;11.9&quot;,\r\n            &quot;AutoMinorVersionUpgrade&quot;: true,\r\n            &quot;ReadReplicaDBInstanceIdentifiers&quot;: [],\r\n            &quot;LicenseModel&quot;: &quot;foobar&quot;,\r\n            &quot;OptionGroupMemberships&quot;: [\r\n                {\r\n                    &quot;OptionGroupName&quot;: &quot;randomname&quot;,\r\n                    &quot;Status&quot;: &quot;in-sync&quot;\r\n                }\r\n            ],\r\n        },\r\n    }\r\n```\r\n\r\noutput truncated obviously.\r\n\r\n\r\nIs there a way using (`jq` probably?) to print:\r\n\r\na) all elements of the `DBInstances` array\r\n\r\nand for each element print only\r\n\r\nb) the `DBInstanceIdentifier` and the `EngineVersion`?",
        "link": "https://stackoverflow.com/questions/68282553/filter-out-specific-json-array-fields-of-elements-using-jq",
        "title": "Filter out specific json array fields of elements using jq"
    },
    {
        "tags": [
            "json",
            "linux",
            "group-by",
            "jq",
            "amazon-cloudwatch"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 1646676,
                    "reputation": 4395,
                    "user_id": 1518100,
                    "user_type": "registered",
                    "accept_rate": 96,
                    "profile_image": "https://i.sstatic.net/EW5RK.jpg?s=256",
                    "display_name": "Lei Yang",
                    "link": "https://stackoverflow.com/users/1518100/lei-yang"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1625724307,
                "post_id": 68296364,
                "comment_id": 120703638,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 10883446,
                    "reputation": 151,
                    "user_id": 8001672,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/36e7bff4c13b764f6d0e410e68f7ebcb?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "P.Lonnie",
                    "link": "https://stackoverflow.com/users/8001672/p-lonnie"
                },
                "reply_to_user": {
                    "account_id": 1646676,
                    "reputation": 4395,
                    "user_id": 1518100,
                    "user_type": "registered",
                    "accept_rate": 96,
                    "profile_image": "https://i.sstatic.net/EW5RK.jpg?s=256",
                    "display_name": "Lei Yang",
                    "link": "https://stackoverflow.com/users/1518100/lei-yang"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1625725589,
                "post_id": 68296364,
                "comment_id": 120704007,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 10883446,
                    "reputation": 151,
                    "user_id": 8001672,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/36e7bff4c13b764f6d0e410e68f7ebcb?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "P.Lonnie",
                    "link": "https://stackoverflow.com/users/8001672/p-lonnie"
                },
                "reply_to_user": {
                    "account_id": 1646676,
                    "reputation": 4395,
                    "user_id": 1518100,
                    "user_type": "registered",
                    "accept_rate": 96,
                    "profile_image": "https://i.sstatic.net/EW5RK.jpg?s=256",
                    "display_name": "Lei Yang",
                    "link": "https://stackoverflow.com/users/1518100/lei-yang"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1625725931,
                "post_id": 68296364,
                "comment_id": 120704112,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1646676,
                    "reputation": 4395,
                    "user_id": 1518100,
                    "user_type": "registered",
                    "accept_rate": 96,
                    "profile_image": "https://i.sstatic.net/EW5RK.jpg?s=256",
                    "display_name": "Lei Yang",
                    "link": "https://stackoverflow.com/users/1518100/lei-yang"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1625726042,
                "post_id": 68296364,
                "comment_id": 120704142,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 4181863,
                    "reputation": 4366,
                    "user_id": 7013263,
                    "user_type": "registered",
                    "accept_rate": 10,
                    "profile_image": "https://i.sstatic.net/41kW6.jpg?s=256",
                    "display_name": "dejanualex",
                    "link": "https://stackoverflow.com/users/7013263/dejanualex"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1625731448,
                "post_id": 68296364,
                "comment_id": 120706107,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1625731602,
                "post_id": 68296364,
                "comment_id": 120706158,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 10883446,
                    "reputation": 151,
                    "user_id": 8001672,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/36e7bff4c13b764f6d0e410e68f7ebcb?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "P.Lonnie",
                    "link": "https://stackoverflow.com/users/8001672/p-lonnie"
                },
                "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": 1625748421,
                "post_id": 68296364,
                "comment_id": 120713228,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": false,
                "score": 4,
                "last_activity_date": 1625753354,
                "last_edit_date": 1625753354,
                "creation_date": 1625748748,
                "answer_id": 68302034,
                "question_id": 68296364,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "\r\nYou can achieve your goal just using `jq`. Further processing by shell scripting is not necessary.\r\nThe following shell script gives you two alternatives:\r\n  * output as text\r\n  * output as json\r\n\r\n\r\n```bash\r\n#!/bin/bash\r\n\r\nINPUT=&#39;\r\n{\r\n    &quot;Messages&quot;: [],\r\n    &quot;MetricDataResults&quot;: [\r\n        {\r\n            &quot;Timestamps&quot;: [\r\n                &quot;2021-07-07T13:26:00Z&quot;\r\n            ],\r\n            &quot;StatusCode&quot;: &quot;Complete&quot;,\r\n            &quot;Values&quot;: [\r\n                0.0\r\n            ],\r\n            &quot;Id&quot;: &quot;m19&quot;,\r\n            &quot;Label&quot;: &quot;CPUSurplusCreditsCharged&quot;\r\n        },\r\n        {\r\n            &quot;Timestamps&quot;: [\r\n                &quot;2021-07-07T13:28:00Z&quot;,\r\n                &quot;2021-07-07T13:27:00Z&quot;,\r\n                &quot;2021-07-07T13:26:00Z&quot;,\r\n                &quot;2021-07-07T13:25:00Z&quot;,\r\n                &quot;2021-07-07T13:24:00Z&quot;,\r\n                &quot;2021-07-07T13:23:00Z&quot;\r\n            ],\r\n            &quot;StatusCode&quot;: &quot;Complete&quot;,\r\n            &quot;Values&quot;: [\r\n                12.750425014167137,\r\n                13.033116114731422,\r\n                12.70812153130781,\r\n                12.975,\r\n                15.441924032067199,\r\n                12.916451392476791\r\n            ],\r\n            &quot;Id&quot;: &quot;m20&quot;,\r\n            &quot;Label&quot;: &quot;CPUUtilization&quot;\r\n        },\r\n        {\r\n            &quot;Timestamps&quot;: [\r\n                &quot;2021-07-07T13:29:00Z&quot;,\r\n                &quot;2021-07-07T13:28:00Z&quot;,\r\n                &quot;2021-07-07T13:27:00Z&quot;,\r\n                &quot;2021-07-07T13:26:00Z&quot;,\r\n                &quot;2021-07-07T13:25:00Z&quot;,\r\n                &quot;2021-07-07T13:24:00Z&quot;,\r\n                &quot;2021-07-07T13:23:00Z&quot;\r\n            ],\r\n            &quot;StatusCode&quot;: &quot;Complete&quot;,\r\n            &quot;Values&quot;: [\r\n                0.7,\r\n                0.6999533364442371,\r\n                0.6998833527745376,\r\n                0.6999416715273727,\r\n                0.7,\r\n                0.7001166861143524,\r\n                0.6998950157476379\r\n            ],\r\n            &quot;Id&quot;: &quot;m21&quot;,\r\n            &quot;Label&quot;: &quot;NetworkReceiveThroughput&quot;\r\n        }\r\n    ]\r\n}\r\n&#39;\r\n\r\n# output as plain text\r\njq -r &#39;\r\n  .MetricDataResults\r\n  | map(.Values as $values | .Timestamps as $timestamps\r\n        | {Label} +\r\n          foreach range(.Timestamps | length) as $idx\r\n                  (null; {&quot;Timestamp&quot;: $timestamps[$idx], &quot;Value&quot;: $values[$idx]}; .))\r\n  | group_by(.Timestamp)[]\r\n  | [.[0].Timestamp]\r\n    + map(&quot;\\(.Label)=\\(.Value)&quot;)\r\n    | join(&quot;\\n&quot;) + &quot;\\n&quot;\r\n&#39; &lt;&lt;&lt; &quot;$INPUT&quot;\r\n\r\n# output as json\r\njq -r &#39;\r\n  .MetricDataResults\r\n  |= (map(.Values as $values | .Timestamps as $timestamps\r\n          | {Id, Label, StatusCode} +\r\n            foreach range(.Timestamps | length) as $idx\r\n                    (null; {&quot;Timestamp&quot;: $timestamps[$idx], &quot;Value&quot;: $values[$idx]}; .))\r\n     | group_by(.Timestamp)\r\n     | map({Timestamp: .[0].Timestamp,\r\n            Events: del(.[].Timestamp)}))\r\n&#39; &lt;&lt;&lt; &quot;$INPUT&quot;\r\n```\r\n\r\n---\r\n\r\nThe first `jq` command of the shell script produces:\r\n\r\n```text\r\n2021-07-07T13:23:00Z\r\nCPUUtilization=12.916451392476791\r\nNetworkReceiveThroughput=0.6998950157476379\r\n\r\n2021-07-07T13:24:00Z\r\nCPUUtilization=15.441924032067199\r\nNetworkReceiveThroughput=0.7001166861143524\r\n\r\n2021-07-07T13:25:00Z\r\nCPUUtilization=12.975\r\nNetworkReceiveThroughput=0.7\r\n\r\n2021-07-07T13:26:00Z\r\nCPUSurplusCreditsCharged=0\r\nCPUUtilization=12.70812153130781\r\nNetworkReceiveThroughput=0.6999416715273727\r\n\r\n2021-07-07T13:27:00Z\r\nCPUUtilization=13.033116114731422\r\nNetworkReceiveThroughput=0.6998833527745376\r\n\r\n2021-07-07T13:28:00Z\r\nCPUUtilization=12.750425014167137\r\nNetworkReceiveThroughput=0.6999533364442371\r\n\r\n2021-07-07T13:29:00Z\r\nNetworkReceiveThroughput=0.7\r\n```\r\n\r\n---\r\n\r\nThe second `jq` command of the shell script produces:\r\n\r\n```json\r\n{\r\n  &quot;Messages&quot;: [],\r\n  &quot;MetricDataResults&quot;: [\r\n    {\r\n      &quot;Timestamp&quot;: &quot;2021-07-07T13:23:00Z&quot;,\r\n      &quot;Events&quot;: [\r\n        {\r\n          &quot;Id&quot;: &quot;m20&quot;,\r\n          &quot;Label&quot;: &quot;CPUUtilization&quot;,\r\n          &quot;StatusCode&quot;: &quot;Complete&quot;,\r\n          &quot;Value&quot;: 12.916451392476791\r\n        },\r\n        {\r\n          &quot;Id&quot;: &quot;m21&quot;,\r\n          &quot;Label&quot;: &quot;NetworkReceiveThroughput&quot;,\r\n          &quot;StatusCode&quot;: &quot;Complete&quot;,\r\n          &quot;Value&quot;: 0.6998950157476379\r\n        }\r\n      ]\r\n    },\r\n    {\r\n      &quot;Timestamp&quot;: &quot;2021-07-07T13:24:00Z&quot;,\r\n      &quot;Events&quot;: [\r\n        {\r\n          &quot;Id&quot;: &quot;m20&quot;,\r\n          &quot;Label&quot;: &quot;CPUUtilization&quot;,\r\n          &quot;StatusCode&quot;: &quot;Complete&quot;,\r\n          &quot;Value&quot;: 15.441924032067199\r\n        },\r\n        {\r\n          &quot;Id&quot;: &quot;m21&quot;,\r\n          &quot;Label&quot;: &quot;NetworkReceiveThroughput&quot;,\r\n          &quot;StatusCode&quot;: &quot;Complete&quot;,\r\n          &quot;Value&quot;: 0.7001166861143524\r\n        }\r\n      ]\r\n    },\r\n    {\r\n      &quot;Timestamp&quot;: &quot;2021-07-07T13:25:00Z&quot;,\r\n      &quot;Events&quot;: [\r\n        {\r\n          &quot;Id&quot;: &quot;m20&quot;,\r\n          &quot;Label&quot;: &quot;CPUUtilization&quot;,\r\n          &quot;StatusCode&quot;: &quot;Complete&quot;,\r\n          &quot;Value&quot;: 12.975\r\n        },\r\n        {\r\n          &quot;Id&quot;: &quot;m21&quot;,\r\n          &quot;Label&quot;: &quot;NetworkReceiveThroughput&quot;,\r\n          &quot;StatusCode&quot;: &quot;Complete&quot;,\r\n          &quot;Value&quot;: 0.7\r\n        }\r\n      ]\r\n    },\r\n    {\r\n      &quot;Timestamp&quot;: &quot;2021-07-07T13:26:00Z&quot;,\r\n      &quot;Events&quot;: [\r\n        {\r\n          &quot;Id&quot;: &quot;m19&quot;,\r\n          &quot;Label&quot;: &quot;CPUSurplusCreditsCharged&quot;,\r\n          &quot;StatusCode&quot;: &quot;Complete&quot;,\r\n          &quot;Value&quot;: 0\r\n        },\r\n        {\r\n          &quot;Id&quot;: &quot;m20&quot;,\r\n          &quot;Label&quot;: &quot;CPUUtilization&quot;,\r\n          &quot;StatusCode&quot;: &quot;Complete&quot;,\r\n          &quot;Value&quot;: 12.70812153130781\r\n        },\r\n        {\r\n          &quot;Id&quot;: &quot;m21&quot;,\r\n          &quot;Label&quot;: &quot;NetworkReceiveThroughput&quot;,\r\n          &quot;StatusCode&quot;: &quot;Complete&quot;,\r\n          &quot;Value&quot;: 0.6999416715273727\r\n        }\r\n      ]\r\n    },\r\n    {\r\n      &quot;Timestamp&quot;: &quot;2021-07-07T13:27:00Z&quot;,\r\n      &quot;Events&quot;: [\r\n        {\r\n          &quot;Id&quot;: &quot;m20&quot;,\r\n          &quot;Label&quot;: &quot;CPUUtilization&quot;,\r\n          &quot;StatusCode&quot;: &quot;Complete&quot;,\r\n          &quot;Value&quot;: 13.033116114731422\r\n        },\r\n        {\r\n          &quot;Id&quot;: &quot;m21&quot;,\r\n          &quot;Label&quot;: &quot;NetworkReceiveThroughput&quot;,\r\n          &quot;StatusCode&quot;: &quot;Complete&quot;,\r\n          &quot;Value&quot;: 0.6998833527745376\r\n        }\r\n      ]\r\n    },\r\n    {\r\n      &quot;Timestamp&quot;: &quot;2021-07-07T13:28:00Z&quot;,\r\n      &quot;Events&quot;: [\r\n        {\r\n          &quot;Id&quot;: &quot;m20&quot;,\r\n          &quot;Label&quot;: &quot;CPUUtilization&quot;,\r\n          &quot;StatusCode&quot;: &quot;Complete&quot;,\r\n          &quot;Value&quot;: 12.750425014167137\r\n        },\r\n        {\r\n          &quot;Id&quot;: &quot;m21&quot;,\r\n          &quot;Label&quot;: &quot;NetworkReceiveThroughput&quot;,\r\n          &quot;StatusCode&quot;: &quot;Complete&quot;,\r\n          &quot;Value&quot;: 0.6999533364442371\r\n        }\r\n      ]\r\n    },\r\n    {\r\n      &quot;Timestamp&quot;: &quot;2021-07-07T13:29:00Z&quot;,\r\n      &quot;Events&quot;: [\r\n        {\r\n          &quot;Id&quot;: &quot;m21&quot;,\r\n          &quot;Label&quot;: &quot;NetworkReceiveThroughput&quot;,\r\n          &quot;StatusCode&quot;: &quot;Complete&quot;,\r\n          &quot;Value&quot;: 0.7\r\n        }\r\n      ]\r\n    }\r\n  ]\r\n}\r\n```\r\n\r\n",
                "title": "jq - group json objects by field value and output grouped values in one line"
            },
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1625766765,
                "creation_date": 1625766765,
                "answer_id": 68306534,
                "question_id": 68296364,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here is a simple, idiomatic solution for the case of text output; it can be used with any version of jq from 1.3 onwards.  Note in particular that it does not rely on `foreach`, the use of which here is overly complicated:\r\n\r\n```\r\n&lt; input.json jq -r &#39;\r\n  .MetricDataResults\r\n  | map(.Values as $values\r\n        | .Timestamps as $timestamps\r\n        | {Label} +\r\n           (range(0; .Timestamps|length) as $idx\r\n            | {Timestamp: $timestamps[$idx], \r\n               Value:     $values[$idx]} ))\r\n  | group_by(.Timestamp)[]\r\n  | .[0].Timestamp, (.[]|&quot;\\(.Label)=\\(.Value)&quot;), &quot;&quot;\r\n&#39;\r\n\r\n\r\n",
                "title": "jq - group json objects by field value and output grouped values in one line"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1625766858,
        "creation_date": 1625724210,
        "last_edit_date": 1625766858,
        "question_id": 68296364,
        "body_markdown": "I have a json format with metrics &amp; timestamps &amp; values ​​from AWS Cloudwatch.\r\n\r\n```\r\n{\r\n    &quot;Messages&quot;: [],\r\n    &quot;MetricDataResults&quot;: [\r\n        {\r\n            &quot;Timestamps&quot;: [\r\n                &quot;2021-07-07T13:26:00Z&quot;\r\n            ],\r\n            &quot;StatusCode&quot;: &quot;Complete&quot;,\r\n            &quot;Values&quot;: [\r\n                0.0\r\n            ],\r\n            &quot;Id&quot;: &quot;m19&quot;,\r\n            &quot;Label&quot;: &quot;CPUSurplusCreditsCharged&quot;\r\n        },\r\n        {\r\n            &quot;Timestamps&quot;: [\r\n                &quot;2021-07-07T13:28:00Z&quot;,\r\n                &quot;2021-07-07T13:27:00Z&quot;,\r\n                &quot;2021-07-07T13:26:00Z&quot;,\r\n                &quot;2021-07-07T13:25:00Z&quot;,\r\n                &quot;2021-07-07T13:24:00Z&quot;,\r\n                &quot;2021-07-07T13:23:00Z&quot;\r\n            ],\r\n            &quot;StatusCode&quot;: &quot;Complete&quot;,\r\n            &quot;Values&quot;: [\r\n                12.750425014167137,\r\n                13.033116114731422,\r\n                12.70812153130781,\r\n                12.975,\r\n                15.441924032067199,\r\n                12.916451392476791\r\n            ],\r\n            &quot;Id&quot;: &quot;m20&quot;,\r\n            &quot;Label&quot;: &quot;CPUUtilization&quot;\r\n        },\r\n        {\r\n            &quot;Timestamps&quot;: [\r\n                &quot;2021-07-07T13:29:00Z&quot;,\r\n                &quot;2021-07-07T13:28:00Z&quot;,\r\n                &quot;2021-07-07T13:27:00Z&quot;,\r\n                &quot;2021-07-07T13:26:00Z&quot;,\r\n                &quot;2021-07-07T13:25:00Z&quot;,\r\n                &quot;2021-07-07T13:24:00Z&quot;,\r\n                &quot;2021-07-07T13:23:00Z&quot;\r\n            ],\r\n            &quot;StatusCode&quot;: &quot;Complete&quot;,\r\n            &quot;Values&quot;: [\r\n                0.7,\r\n                0.6999533364442371,\r\n                0.6998833527745376,\r\n                0.6999416715273727,\r\n                0.7,\r\n                0.7001166861143524,\r\n                0.6998950157476379\r\n            ],\r\n            &quot;Id&quot;: &quot;m21&quot;,\r\n            &quot;Label&quot;: &quot;NetworkReceiveThroughput&quot;\r\n        }\r\n    ]\r\n}\r\n```\r\n\r\nI put these values ​​in an array variable using the jq command.&lt;br/&gt;\r\nAnd the result is output to the array variable as follows.\r\n\r\n\r\n```\r\njq -r &#39;.MetricDataResults[] | &quot;\\(.Label) \\(.Timestamps) \\(.Values)&quot;&#39; test.json | while read Label timestamp value\r\ndo\r\n\r\n  Label=`echo $Label | sed &#39;s/\\&quot;//g; s/\\[//g; s/\\]//g; s/,/ /g&#39;`\r\n  timestamp=`echo $timestamp | sed &#39;s/\\&quot;//g; s/\\[//g; s/\\]//g; s/,/ /g&#39;`\r\n  value=`echo $value | sed &#39;s/\\&quot;//g; s/\\[//g; s/\\]//g; s/,/ /g&#39;`\r\n\r\n  arr_timestamp=($timestamp)\r\n  arr_value=($value)\r\n\r\n  echo $Label\r\n  echo ${arr_timestamp[@]}\r\n  echo ${arr_value[@]}\r\ndone\r\n\r\n\r\n\r\nEvictions\r\n2021-07-07T10:51:00Z 2021-07-07T10:50:00Z 2021-07-07T10:49:00Z 2021-07-07T10:48:00Z 2021-07-07T10:47:00Z 2021-07-07T10:46:00Z 2021-07-07T10:45:00Z\r\n0 0 0 0 0 0 0\r\n\r\nCPUUtilization\r\n2021-07-07T10:50:00Z 2021-07-07T10:49:00Z 2021-07-07T10:48:00Z 2021-07-07T10:47:00Z 2021-07-07T10:46:00Z 2021-07-07T10:45:00Z\r\n1.5333333333333332 1.4666666666666666 1.5833333333333333 1.5333333333333332 1.4916666666666665 1.4916666666666665\r\n\r\nIsMaster\r\n2021-07-07T10:51:00Z 2021-07-07T10:50:00Z 2021-07-07T10:49:00Z 2021-07-07T10:48:00Z 2021-07-07T10:47:00Z 2021-07-07T10:46:00Z 2021-07-07T10:45:00Z\r\n1 1 1 1 1 1 1\r\n```\r\n\r\nWhen timestamp is not the same length for each array variable,&lt;br/&gt;\r\nI want to display only values ​​in the same timestamp as a single string.\r\n\r\nFor example\r\n```\r\n&quot;2021-07-07T10:51:00Z Evictions = 0\\nIsMaster = 1&quot;\r\n&quot;2021-07-07T10:50:00Z Evictions = 0\\nCPUUtilization = 1.5333333333333332\\n IsMaster = 1&quot;\r\n...\r\n```\r\n\r\nMy head is bad and I can&#39;t think of a good way. &lt;br/&gt;\r\nPlease let me know if there is any good way.&lt;br/&gt;\r\nI don&#39;t have much time so please help on stackoverflow.\r\n\r\n+ Add&lt;br/&gt;\r\nI mean group by Timestamps. Like this\r\n```\r\n{\r\n    &quot;MetricDataResults&quot;: [\r\n        {\r\n            &quot;Timestamps&quot;: &quot;2021-07-07T13:28:00Z&quot;,\r\n            &quot;Label&quot; : [\r\n               &quot;CPUUtilization&quot;,\r\n               &quot;NetworkReceiveThroughput&quot;\r\n            ],\r\n            &quot;Values&quot; : [\r\n               12.750425014167137,\r\n               0.7\r\n            ]\r\n         },\r\n         {\r\n            &quot;Timestamps&quot;: &quot;2021-07-07T13:27:00Z&quot;,\r\n            &quot;Label&quot; : [\r\n               &quot;CPUUtilization&quot;,\r\n               &quot;NetworkReceiveThroughput&quot;\r\n            ],\r\n            &quot;Values&quot; : [\r\n               13.033116114731422,\r\n               0.6999533364442371\r\n            ]\r\n         },\r\n         {\r\n            &quot;Timestamps&quot;: &quot;2021-07-07T13:26:00Z&quot;,\r\n            &quot;Label&quot; : [\r\n               &quot;CPUUtilization&quot;,\r\n               &quot;NetworkReceiveThroughput&quot;,\r\n               &quot;CPUSurplusCreditsCharged&quot;\r\n            ],\r\n            &quot;Values&quot; : [\r\n               12.70812153130781,\r\n               0.6998833527745376,\r\n               0.0\r\n            ]\r\n        }\r\n    ]\r\n}\r\n```",
        "link": "https://stackoverflow.com/questions/68296364/jq-group-json-objects-by-field-value-and-output-grouped-values-in-one-line",
        "title": "jq - group json objects by field value and output grouped values in one line"
    },
    {
        "tags": [
            "json",
            "jq",
            "quotes",
            "jsonpath"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1625843085,
                "post_id": 68315788,
                "comment_id": 120743336,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1625833501,
                "creation_date": 1625833501,
                "answer_id": 68316758,
                "question_id": 68315788,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "##### [tag:jsonpath] isn&#39;t the same as [tag:jq]\r\n\r\n\r\n----------\r\n\r\nThe filter, `&#39;.nodes[?(@.id==&quot;1&quot;)]&#39;` is in [JsonPath syntax][1].\r\n\r\n\r\n----------\r\n\r\n&gt; How to make the simplest **jq** filter query work?\r\n\r\nChange it to a [JQ select][2] like so:\r\n```\r\njq &#39;.nodes[] | select(.id == &quot;1&quot;)&#39;\r\n```\r\n\r\nWhere \r\n\r\n* `.nodes[]` loops over all the nodes\r\n* `select(.id == &quot;1&quot;)` only keep the objects were `id === 1`\r\n\r\n#### [JqPlay Demo](https://jqplay.org/s/Ky1JC46MXC)\r\n\r\n\r\n\r\n  [1]: https://github.com/json-path/JsonPath#operators\r\n  [2]: https://stedolan.github.io/jq/manual/v1.4/#example18",
                "title": "How to make the simplest jq filter query work?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1625833501,
        "creation_date": 1625828941,
        "question_id": 68315788,
        "body_markdown": "A very simple\r\n\r\n```\r\necho &#39;{&quot;nodes&quot;:[{&quot;id&quot;:&quot;1&quot;}]}&#39; | jq &#39;.nodes[?(@.id==&quot;1&quot;)]&#39;\r\n```\r\n\r\nfails due to\r\n\r\n```\r\njq: error: syntax error, unexpected &#39;?&#39; (Unix shell quoting issues?) at &lt;top-level&gt;, line 1:\r\n.nodes[?(@.id==&quot;1&quot;)]       \r\njq: 1 compile error\r\n```\r\n\r\nThe hint &quot;Unix shell quoting issues?&quot; doesn&#39;t apply because everything is `&#39;` quoted. However, I tried various unnecessary combinations of simple and double quotes and escaped versions thereof combined with escaping of `[`, `[`, `@` and `?`.\r\n\r\n`echo &#39;{&quot;nodes&quot;:[{&quot;id&quot;:&quot;1&quot;}]}&#39; | jq &#39;.nodes&#39;` works as does `echo &#39;{&quot;nodes&quot;:[{&quot;id&quot;:&quot;1&quot;}]}&#39; | jq &#39;.nodes[0]&#39;`, so the error must be in the filter expression which is very simple, seen like this in dozens of examples and which I&#39;m using in integration tests with the [Jayway JsonPath library](https://github.com/json-path/JsonPath).\r\n\r\nI&#39;m using jq 1.6 on Ubuntu 21.04.",
        "link": "https://stackoverflow.com/questions/68315788/how-to-make-the-simplest-jq-filter-query-work",
        "title": "How to make the simplest jq filter query work?"
    },
    {
        "tags": [
            "json",
            "csv",
            "export-to-csv",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1625841720,
                "last_edit_date": 1625841720,
                "creation_date": 1625831651,
                "answer_id": 68316336,
                "question_id": 68316206,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Store the id and name in variables, then iterate over the keys of `agent_priorities`:\r\n\r\n    jq -r &#39;.[] \r\n           | .id as $id \r\n           | .name as $name \r\n           | .agent_priorities \r\n           | keys \r\n           | .[] \r\n           | [., $id, $name ] \r\n           | @csv\r\n          &#39; file.json",
                "title": "Using jq to convert json to csv"
            },
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1625845251,
                "creation_date": 1625845251,
                "answer_id": 68319426,
                "question_id": 68316206,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The following variant of the accepted answer checks for the existence of the &quot;agent_priorities&quot; key as per the requirements, and uses `keys_unsorted` to preserve the order of the keys:\r\n```\r\njq -r &#39;\r\n       .[] \r\n       | select(has(&quot;agent_priorities&quot;))\r\n       | .id as $id \r\n       | .name as $name \r\n       | .agent_priorities \r\n       | keys_unsorted[]\r\n       | [., $id, $name ] \r\n       | @csv\r\n      &#39; file.json\r\n```",
                "title": "Using jq to convert json to csv"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1625845251,
        "creation_date": 1625831069,
        "last_edit_date": 1625844305,
        "question_id": 68316206,
        "body_markdown": "I&#39;m trying to come up with the correct jq syntax to convert json to csv.\r\n\r\n\r\n**Desired results:**\r\n\r\n    &lt;email&gt;,&lt;id&gt;,&lt;name&gt;\r\n    e.g. \r\n    user1@whatever.nevermind.no,0,general\r\n    user2@whatever.nevermind.no,0,general\r\n    user1@whatever.nevermind.no,1,local\r\n    ...\r\n\r\n* note that also need to ignore objects with empty &quot;agent_priorities&quot;\r\n\r\n\r\n\r\n**Input**\r\n\r\n    [\r\n      {\r\n        &quot;id&quot;: 0,\r\n        &quot;name&quot;: &quot;General&quot;,\r\n        &quot;agent_priorities&quot;: {\r\n          &quot;user1@whatever.nevermind.no&quot;: &quot;normal&quot;,\r\n          &quot;user2@whatever.nevermind.no&quot;: &quot;normal&quot;\r\n        }\r\n      },\r\n      {\r\n        &quot;id&quot;: 1,\r\n        &quot;name&quot;: &quot;local&quot;,\r\n        &quot;agent_priorities&quot;: {\r\n          &quot;user1@whatever.nevermind.no&quot;: &quot;normal&quot;\r\n        }\r\n      },\r\n      {\r\n        &quot;id&quot;: 2,\r\n        &quot;name&quot;: &quot;Engineering&quot;,\r\n      }\r\n    ]",
        "link": "https://stackoverflow.com/questions/68316206/using-jq-to-convert-json-to-csv",
        "title": "Using jq to convert json to csv"
    },
    {
        "tags": [
            "arrays",
            "json",
            "bash",
            "shell",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": -2,
                "last_activity_date": 1625934176,
                "last_edit_date": 1625934176,
                "creation_date": 1625933488,
                "answer_id": 68329475,
                "question_id": 68328848,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Add a loop to iterate each `city` in `$city_array` for each `$countryObj`, then `echo` your desired output line-by-line.\r\n\r\n    for k in $(jq &#39;.countries | keys | .[]&#39; country.json); do\r\n        countryObj=$(jq -r &quot;.countries[$k]&quot; country.json);\r\n        countryValue=$(jq -r &#39;.country&#39; &lt;&lt;&lt; &quot;$countryObj&quot;);\r\n        city_array=$(jq -r &#39;.city&#39; &lt;&lt;&lt; &quot;$countryObj&quot;);\r\n        \r\n        for city in $city_array; do\r\n            echo &quot;country:$countryValue, city:$city&quot;\r\n        done\r\n\r\n        echo &quot;&quot; # Blank line between each country\r\n    done",
                "title": "Json Object Parsing using shell script"
            },
            {
                "up_vote_count": 10,
                "is_accepted": true,
                "score": 10,
                "last_activity_date": 1738786835,
                "last_edit_date": 1738786835,
                "creation_date": 1625935916,
                "answer_id": 68329817,
                "question_id": 68328848,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "This can be done entirely in jq.\r\n\r\n```sh\r\njq -r &#39;\r\n   .countries |\r\n   map(\r\n      .country as $country |\r\n      .city | map(&quot;country: \\( $country ), city: \\( . )\\n&quot;) | add\r\n   ) |\r\n   join(&quot;\\n&quot;)\r\n&#39;\r\n```\r\n\r\nGives:\r\n\r\n```lang-none\r\ncountry: India, city: India1\r\ncountry: India, city: India2\r\ncountry: India, city: India3\r\n\r\ncountry: USA, city: USA1\r\ncountry: USA, city: USA2\r\ncountry: USA, city: USA3\r\n```\r\n\r\n[jqplay](https://jqplay.org/s/Qd55fnsJMP)\r\n\r\n---\r\n\r\nIf you don&#39;t need that blank line, it&#39;s a lot simpler.\r\n\r\n```sh\r\njq -r &#39;\r\n   .countries[] |\r\n   .country as $country |\r\n   .city[] |\r\n   &quot;country: \\( $country ), city: \\( . )&quot;\r\n&#39;\r\n```\r\n\r\n[jqplay](https://jqplay.org/s/cDiBeDmPRB)\r\n\r\n---\r\n\r\nThe later can be reduced to\r\n\r\n```sh\r\njq -r &#39;.countries[] | &quot;country: \\( .country ), city: \\( .city[] )&quot;&#39;\r\n```\r\n\r\n[jqplay](https://jqplay.org/s/PhMwLpXOJcOiKDj)\r\n",
                "title": "Json Object Parsing using shell script"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1738708987,
                "last_edit_date": 1738708987,
                "creation_date": 1738706592,
                "answer_id": 79413144,
                "question_id": 68328848,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If `jq` is not available, and shell script really **is** the only tool at hand, then I would suggest a two-phase strategy. In _first_ phase, convert the JSON into some format which many shell tools can easily handle: that&#39;ll give us more choices for implementing the _second_ phase.  Concretely, in this case,\r\n```bash\r\nsed &#39;/city/! d; s/[^[:alnum:]]/ /g&#39; country.json \\\r\n| awk &#39;{for (i=4;i&lt;=NF;i++) print $1 &quot;: &quot; $2 &quot;, &quot; $3 &quot;: &quot; $i; print &quot;&quot;}&#39;\r\n```\r\n#### first phase\r\n```bash\r\nsed &#39;/city/! d; s/[^[:alnum:]]/ /g&#39; country.json\r\n```\r\nLet&#39;s break that down:\r\n- `/city/! d`  ---- Delete all lines without &quot;`city`&quot; in them.\r\n- `s/[^[:alnum:]]/ /g` ---- Replace every non-alphanumeric character with a space.\r\n\r\nResult is\r\n```\r\n              country   India   city    India1   India2   India3\r\n              country   USA   city    USA1   USA2   USA3\r\n```\r\nGreat!  Many shell tools can easily handle this format; among them,\r\n- The shell (Bash or ksh or zsh or ...) itself\r\n- `cut`, `sort`, `join`, `comm`, `column`\r\n- `awk`\r\n\r\n#### second phase\r\nOK, `awk`:\r\n```bash\r\nawk &#39;{for (i=4;i&lt;=NF;i++) print $1 &quot;: &quot; $2 &quot;, &quot; $3 &quot;: &quot; $i; print &quot;&quot;}&#39;\r\n```\r\nLet&#39;s break that down:\r\n- `for (i=4;i&lt;=NF;i++)` ---- For every field starting with the 4th one.\r\n- `$1` ---- the 1st field\r\n- `$2` ---- the 2nd field\r\n- `$i` ---- the _i_ th field.\r\n---\r\n---\r\n---\r\n(Obviously, this particular solution won&#39;t work properly if a city name contains spaces; nor will it correctly handle many many other edge cases.)",
                "title": "Json Object Parsing using shell script"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1738710928,
                "creation_date": 1738710928,
                "answer_id": 79413264,
                "question_id": 68328848,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Assuming the file is formatted as presented ...\r\n\r\nOne simple `awk` script based on the double quote as delimiter:\r\n\r\n    awk -F&#39;&quot;&#39; &#39;\r\n    $2==&quot;country&quot; { for (i=8; i&lt;=NF; i+=2)\r\n                        printf &quot;country:%s, city:%s\\n&quot;, $4, $i\r\n                  }\r\n    &#39; country.json\r\n\r\nThis generates:\r\n\r\n    country:India, city:India1\r\n    country:India, city:India2\r\n    country:India, city:India3\r\n    country:USA, city:USA1\r\n    country:USA, city:USA2\r\n    country:USA, city:USA3\r\n\r\n-------------------------\r\n\r\nIf you really want a blank line *between* sections of output:\r\n\r\n    awk -F&#39;&quot;&#39; &#39;\r\n    $2==&quot;country&quot; { printf &quot;%s&quot;, pfx\r\n                    for (i=8; i&lt;=NF; i+=2)\r\n                        printf &quot;country:%s, city:%s\\n&quot;, $4, $i\r\n                    pfx=&quot;\\n&quot;\r\n                  }\r\n    &#39; country.json\r\n\r\nThis generates:\r\n\r\n    country:India, city:India1          # no leading blank line\r\n    country:India, city:India2\r\n    country:India, city:India3\r\n                                        # blank line only between sections\r\n    country:USA, city:USA1\r\n    country:USA, city:USA2\r\n    country:USA, city:USA3              # no trailing blank line",
                "title": "Json Object Parsing using shell script"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1738712398,
                "creation_date": 1738712398,
                "answer_id": 79413300,
                "question_id": 68328848,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If you don&#39;t have jq, but do have Python, that has an equally capable built-in JSON parser. A Python script that generates your desired output might look like:\r\n\r\n```python\r\n#!/usr/bin/env python\r\nimport json, sys\r\n\r\ncontent = json.loads(sys.stdin.read())\r\nfor country_dict in content[&#39;countries&#39;]:\r\n  country_name = country_dict[&#39;country&#39;]\r\n  for city in country_dict[&#39;city&#39;]:\r\n    print(f&#39;country: {country_name}, city: {city}&#39;)\r\n  print()\r\n```\r\n\r\nTo embed this inside a shell script:\r\n\r\n```bash\r\npython_script=$(cat &lt;&lt;&#39;EOF&#39;\r\nimport json, sys\r\n\r\ncontent = json.loads(sys.stdin.read())\r\nfor country_dict in content[&#39;countries&#39;]:\r\n  country_name = country_dict[&#39;country&#39;]\r\n  for city in country_dict[&#39;city&#39;]:\r\n    print(f&#39;country: {country_name}, city: {city}&#39;)\r\n  print()\r\nEOF\r\n)\r\n\r\npython -c &quot;$python_script&quot; &lt;country.json\r\n```",
                "title": "Json Object Parsing using shell script"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1738755051,
                "last_edit_date": 1738755051,
                "creation_date": 1738714152,
                "answer_id": 79413340,
                "question_id": 68328848,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s something I whipped up quickly to make the code as compact as possible.\r\n\r\nFor cmd.exe OR Bash:\r\n\r\n    jq -r &quot;.countries[] | \\&quot;country:\\&quot; + .country + \\&quot;, city:\\&quot; + (.city[])&quot; country.json\r\n\r\nFor PowerShell (using the stop-parsing operator):\r\n\r\n    jq --% -r &quot;.countries[] | \\&quot;country:\\&quot; + .country + \\&quot;, city:\\&quot; + (.city[])&quot; country.json\r\n\r\n\r\nTo get the output as requested by OP, do the following:\r\n\r\nCreate a file named filter.jq with the following contents:\r\n\r\n    .countries[] | (.country as $country | (.city[] | &quot;country:&quot; + $country + &quot;, city:&quot; + .) ), &quot;&quot;\r\n\r\n  \r\nThen run the command in PowerShell, CMD or Bash:\r\n\r\n    jq -r -f filter.jq country.json\r\n\r\n",
                "title": "Json Object Parsing using shell script"
            }
        ],
        "is_answered": true,
        "answer_count": 6,
        "score": 3,
        "last_activity_date": 1738786835,
        "creation_date": 1625929123,
        "question_id": 68328848,
        "body_markdown": "I am trying to parse below json object using shell script:\r\n\r\ncountry.json\r\n   \r\n\r\n     {\r\n            &quot;countries&quot;: [\r\n                {&quot;country&quot;:&quot;India&quot;,&quot;city&quot;:[&quot;India1&quot;,&quot;India2&quot;,&quot;India3&quot;]},\r\n                {&quot;country&quot;:&quot;USA&quot;,&quot;city&quot;:[&quot;USA1&quot;,&quot;USA2&quot;,&quot;USA3&quot;]}\r\n               \r\n               ]\r\n        }\r\n\r\nand my **desired output** should be like:\r\n\r\n    country:India, city:India1\r\n    country:India, city:India2\r\n    country:India, city:India3\r\n    \r\n    country:USA, city:USA1\r\n    country:USA, city:USA2\r\n    country:USA, city:USA3 \r\n\r\nI am using jq in shell script to iterate the above json like this:\r\n\r\n    for k in $(jq &#39;.countries | keys | .[]&#39; country.json); do\r\n        countryObj=$(jq -r &quot;.countries[$k]&quot; country.json);\r\n        countryValue=$(jq -r &#39;.country&#39; &lt;&lt;&lt; &quot;$countryObj&quot;);\r\n        city_array=$(jq -r &#39;.city&#39; &lt;&lt;&lt; &quot;$countryObj&quot;);\r\n        echo $city_array\r\n    done \r\n\r\nfrom this I am able to get city_array i.e. `[&quot;India1&quot;,&quot;India2&quot;,&quot;India3&quot;]` and `[&quot;USA1&quot;,&quot;USA2&quot;,&quot;USA3&quot;]` but I am not able to get **desired output** mentioned above",
        "link": "https://stackoverflow.com/questions/68328848/json-object-parsing-using-shell-script",
        "title": "Json Object Parsing using shell script"
    },
    {
        "tags": [
            "json",
            "select",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1625966469,
                "creation_date": 1625966469,
                "answer_id": 68332598,
                "question_id": 68332371,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Use `recurse` to walk the structure. From all the substrucures, select objects with the `emp` key. Output the corresponding values and merge the resulting arrays.\r\n```\r\njq &#39;[recurse | select (type == &quot;object&quot; and .emp) | .emp ] | add&#39; file.json\r\n```",
                "title": "Use jq to output a flat array of JSON objects nested anywhere within source document"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1625971105,
        "creation_date": 1625961640,
        "last_edit_date": 1625971105,
        "question_id": 68332371,
        "body_markdown": "I&#39;d like to select/identity-output all objects in arrays under &quot;emp&quot; keys into a flat array of those objects.\r\n```\r\n[\r\n  {\r\n    &quot;eng&quot;: {\r\n      &quot;dev&quot;: {\r\n        &quot;dir&quot;: {\r\n          &quot;name&quot;: &quot;Mickey&quot;\r\n        },\r\n        &quot;emp&quot;: [\r\n          {\r\n            &quot;name&quot;: &quot;Goofy&quot;,\r\n            &quot;job&quot;: &quot;laugh&quot;,\r\n            &quot;start&quot;: &quot;today&quot;\r\n          },\r\n          {\r\n            &quot;name&quot;: &quot;Minnie&quot;,\r\n            &quot;job&quot;: &quot;laugh&quot;\r\n          }\r\n        ]\r\n      }\r\n    }\r\n  },\r\n  {\r\n    &quot;mgmt&quot;: {\r\n      &quot;dir&quot;: {\r\n        &quot;name&quot;: &quot;Donald&quot;\r\n      },\r\n      &quot;emp&quot;: [\r\n        {\r\n          &quot;name&quot;: &quot;Woody&quot;,\r\n          &quot;job&quot;: &quot;smile&quot;\r\n        },\r\n        {\r\n          &quot;name&quot;: &quot;Buzz&quot;,\r\n          &quot;job&quot;: &quot;smile&quot;\r\n        }\r\n      ]\r\n    }\r\n  }\r\n]\r\n```\r\n\r\nI&#39;m looking for a flat array of arbitrary objects found in arbitrary locations within the document (in this example, under &quot;emp&quot; parent/keys).\r\n\r\nIn this example, it would look like\r\n```\r\n[\r\n  {\r\n    &quot;name&quot;: &quot;Goofy&quot;,\r\n    &quot;job&quot;: &quot;laugh&quot;,\r\n    &quot;start&quot;: &quot;today&quot;\r\n  },\r\n  {\r\n    &quot;name&quot;: &quot;Minnie&quot;,\r\n    &quot;job&quot;: &quot;laugh&quot;\r\n  },\r\n  {\r\n    &quot;name&quot;: &quot;Woody&quot;,\r\n    &quot;job&quot;: &quot;smile&quot;\r\n  },\r\n  {\r\n    &quot;name&quot;: &quot;Buzz&quot;,\r\n    &quot;job&quot;: &quot;smile&quot;\r\n  }\r\n]\r\n```\r\nI&#39;ve looked through a lot of documentation and am able to do this if I know in advance precisely where these &#39;emp&#39; keys are in the document, but not if they&#39;re distributed through the document at a priori unknown locations/paths.",
        "link": "https://stackoverflow.com/questions/68332371/use-jq-to-output-a-flat-array-of-json-objects-nested-anywhere-within-source-docu",
        "title": "Use jq to output a flat array of JSON objects nested anywhere within source document"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1625997902,
                "last_edit_date": 1625997902,
                "creation_date": 1625988115,
                "answer_id": 68334068,
                "question_id": 68333885,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Neither the input as shown nor the desired output is valid as JSON or as a JSON stream, so the question seems questionable, and the following responses are accordingly offered with the caveat that they probably should be avoided. \r\n\r\nIt should also be noted that, except for the sed-only approach, the solutions offered here produce comma-separated-JSON, which may not be what is desired. \r\n\r\nThey assume that the quasi-JSON input is in a file `qjson.txt`. \r\n\r\n\r\n1. sed-only\r\n```\r\n    &lt; qjson.txt sed -e &#39;1d;$d; s/^ //&#39;\r\n```\r\n2. hjson, jq, and sed\r\n```\r\n   &lt; qjson.txt hjson -j | jq -r &#39;.[] | (.,&quot;,&quot;)&#39; | sed &#39;$d&#39;\r\n```\r\n3. hjson and jq\r\n```\r\n    &lt; qjson.txt hjson -j | jq -r &#39;\r\n        foreach .[] as $x (-1; .+1; \r\n          if . == 0 then $x else &quot;,&quot;, $x end)&#39;\r\n```\r\n\r\n",
                "title": "Using JQ to convert an array of object to list of objects"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1655237691,
        "creation_date": 1625986315,
        "last_edit_date": 1655237691,
        "question_id": 68333885,
        "body_markdown": "Let&#39;s say I have the following JSON\r\n\r\n    [\r\n     {\r\n      name : &quot;A&quot;,\r\n      value : &quot;1&quot;\r\n     },\r\n     {\r\n      name : &quot;B&quot;,\r\n      value : &quot;5&quot;\r\n     },\r\n     {\r\n      name : &quot;E&quot;,\r\n      value : &quot;8&quot;\r\n     }\r\n    ]\r\n\r\nand I simply want to to be like \r\n\r\n     {\r\n      name : &quot;A&quot;,\r\n      value : &quot;1&quot;\r\n     },\r\n     {\r\n      name : &quot;B&quot;,\r\n      value : &quot;5&quot;\r\n     },\r\n     {\r\n      name : &quot;E&quot;,\r\n      value : &quot;8&quot;\r\n     }\r\nI used jq normal filter so jq&#39;.[]&#39;, however I get a list of objects separated by a return as such:\r\n```\r\n {\r\n  name : &quot;A&quot;,\r\n  value : &quot;1&quot;\r\n }\r\n {\r\n  name : &quot;B&quot;,\r\n  value : &quot;5&quot;\r\n }\r\n {\r\n  name : &quot;E&quot;,\r\n  value : &quot;8&quot;\r\n }\r\n``` \r\nNotice that the commas between the objects have magically vanished. Using reduce would work only if the object is indexed by the name let&#39;s say, I used the following: \r\n\r\n&gt; jq &#39;reduce .[] as $i ({}; .[$i.name] = $i)&#39;\r\n\r\nAnybody did run into a similar situation?",
        "link": "https://stackoverflow.com/questions/68333885/using-jq-to-convert-an-array-of-object-to-list-of-objects",
        "title": "Using JQ to convert an array of object to list of objects"
    },
    {
        "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": 0,
                "creation_date": 1626035621,
                "post_id": 68334498,
                "comment_id": 120779490,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": -2,
                "last_activity_date": 1625993218,
                "creation_date": 1625993218,
                "answer_id": 68334630,
                "question_id": 68334498,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I think you&#39;re looking for something like:\r\n\r\n```bash\r\n#!/bin/bash\r\njq -r &#39;.countries[] | .country + &quot; &quot; + .city[]&#39; country.json | while read r; do\r\n    ./child_script.sh &quot;$r&quot;\r\ndone\r\n```\r\n\r\nYou need to loop on the results that you get from the `jq` command, and apply the script for each line.\r\n\r\nNote: Remove the `\\n` after the `echo` command in `child_script.sh`.",
                "title": "How to pass jq values from master shell script to child shell script"
            },
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1625994527,
                "creation_date": 1625994527,
                "answer_id": 68334789,
                "question_id": 68334498,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Since some countries, such as &quot;New Zealand&quot;, have spaces in their names, you will probably want to take that into account, e.g. as follows:\r\n```\r\njq -r &#39;.countries[]\r\n       | .country as $country\r\n       | .city[] | &quot;\\($country)\\t\\(.)&quot;&#39; | \r\n  while IFS=$&#39;\\t&#39; read -r country city; do\r\n     ./child_script.sh &quot;$country&quot; &quot;$city&quot;\r\n  done\r\n```",
                "title": "How to pass jq values from master shell script to child shell script"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1626049215,
                "last_edit_date": 1626049215,
                "creation_date": 1626035043,
                "answer_id": 68339700,
                "question_id": 68334498,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "`while read` is the generic approach, but we can take advantage of `xargs` since the loop body consists of executing a program.\r\n\r\n```sh\r\njq -r &#39;\r\n   .countries[] |\r\n   .country as $country |\r\n   .city[] |\r\n   @sh &quot;\\($country) \\(.)&quot;\r\n&#39; country.json |\r\nxargs -rl ./child_script.sh\r\n```\r\n",
                "title": "How to pass jq values from master shell script to child shell script"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 1,
        "last_activity_date": 1626049215,
        "creation_date": 1625991960,
        "question_id": 68334498,
        "body_markdown": "In a shell script (let&#39;s say `master_script.sh`), I am trying to parse json file(`country.json`) using `jq` and passing those values to another shell script (`child_script.sh`) then print the values from `child_script` as I will be using it there.\r\n\r\n***master_script.sh***\r\n\r\n    #!/bin/bash\r\n    $(jq -r &#39; .countries[] | .country as $cntry | .city[] | (.) as $ct |\r\n    &quot;child_script.sh $cntry $ct&quot;&#39; country.json)\r\n\r\n\r\n***country.json***\r\n   \r\n\r\n     {\r\n            &quot;countries&quot;: [\r\n                {&quot;country&quot;:&quot;India&quot;,&quot;city&quot;:[&quot;India1&quot;,&quot;India2&quot;,&quot;India3&quot;]},\r\n                {&quot;country&quot;:&quot;USA&quot;,&quot;city&quot;:[&quot;USA1&quot;,&quot;USA2&quot;,&quot;USA3&quot;]}\r\n               \r\n               ]\r\n        }\r\n\r\n***child_script.sh***\r\n\r\n    #!/bin/bash\r\n    country=$1\r\n    city=$2\r\n    echo &quot;country: $country, city: $city&quot;\\n\r\n    # I need to use these two variables for further calculation\r\n\r\ndesired output from `child_script.sh` should be like: [jqplay][1]\r\n\r\n    country: India, city: India1\r\n    country: India, city: India2\r\n    country: India, city: India3\r\n    country: USA, city: USA1\r\n    country: USA, city: USA2\r\n    country: USA, city: USA3\r\n\r\n[1]: https://jqplay.org/s/cDiBeDmPRB\r\nBut I am not able to achieve this.\r\n  ",
        "link": "https://stackoverflow.com/questions/68334498/how-to-pass-jq-values-from-master-shell-script-to-child-shell-script",
        "title": "How to pass jq values from master shell script to child shell script"
    },
    {
        "tags": [
            "json",
            "select",
            "stream",
            "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": 1626067346,
                "post_id": 68342224,
                "comment_id": 120783828,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 10641999,
                    "reputation": 1592,
                    "user_id": 7836691,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/a0d43c2fb9a665b0647ee92a32ff9497?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "arunppsg",
                    "link": "https://stackoverflow.com/users/7836691/arunppsg"
                },
                "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": 1626067542,
                "post_id": 68342224,
                "comment_id": 120783869,
                "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": 1626068110,
                "post_id": 68342224,
                "comment_id": 120783984,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1626067740,
                "creation_date": 1626067740,
                "answer_id": 68342288,
                "question_id": 68342224,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Your input is not an array of objects, therefore you can&#39;t access with the `.[0]` notation. You could slurp the whole input with `-s`, but you can also use `inputs` with `-n` (null input mode) and get the nth element by specifying the index, i.e to get element at index 2\r\n\r\n```bash\r\n# doesn&#39;t support negative indices\r\njq -n &#39;[inputs] | nth(2)&#39; a.json \r\n\r\n# supports negative indices, i.e. [-1] will get the last element  \r\njq -n &#39;[inputs][2]&#39; a.json\r\n```",
                "title": "Using jq to get the nth element of a stream of JSON entities"
            },
            {
                "up_vote_count": 4,
                "is_accepted": false,
                "score": 4,
                "last_activity_date": 1626069186,
                "last_edit_date": 1626069186,
                "creation_date": 1626068773,
                "answer_id": 68342425,
                "question_id": 68342224,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "jq has a built-in filter, `nth($n; s)` for solving this type of problem very efficiently.  For example, to emit the second item, you would simply invoke:\r\n\r\n    jq -n &#39;nth(1; inputs)&#39; a.json\r\n\r\nNote that counting of the items starts from 0.\r\n\r\nEfficiency is achieved by avoiding any &quot;slurping&quot; (whether by using the -s option, or by using `[inputs]`), and by stopping once the requested item has been read.\r\n\r\n\r\n\r\n",
                "title": "Using jq to get the nth element of a stream of JSON entities"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 2,
        "last_activity_date": 1626069523,
        "creation_date": 1626067150,
        "last_edit_date": 1626069523,
        "question_id": 68342224,
        "body_markdown": "I have the following json file and I would like access the nth element in it.\r\n\r\n    $ cat a.json\r\n    {&quot;one&quot;:1}\r\n    {&quot;two&quot;:2}\r\n    {&quot;three&quot;:3}\r\n\r\nHere, the json file is in disassembled form. When I try\r\n\r\n    $ jq &#39;.[0]&#39; a.json\r\n\r\nI get the error`jq: error (at a.json:1): Cannot index object with number`. The expected output is `{&quot;one&quot;:1}`.",
        "link": "https://stackoverflow.com/questions/68342224/using-jq-to-get-the-nth-element-of-a-stream-of-json-entities",
        "title": "Using jq to get the nth element of a stream of JSON entities"
    },
    {
        "tags": [
            "json",
            "shell",
            "select",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1626220009,
                "last_edit_date": 1626220009,
                "creation_date": 1626219575,
                "answer_id": 68370392,
                "question_id": 68370257,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "With your input, the filter\r\n```\r\n.items[]\r\n| select( any(.status.conditions[];  .type == &quot;Ready&quot; and .status == &quot;False&quot;) )\r\n| .metadata.name\r\n```\r\nreturns\r\n\r\n```\r\n&quot;return-me&quot;\r\n```\r\n\r\n... which seems hopeful :-)\r\n\r\n### Note\r\nPeople familiar with SQL&#39;s `select` should note that jq&#39;s `select` selects elements from its input stream, and is thus quite different from SQL&#39;s select, which is used to select &quot;fields&quot; from each &quot;record&quot; in a table.\r\n ",
                "title": "Is it possible to get a list element based on a combination of multiple sub-list values?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1626228796,
        "creation_date": 1626218218,
        "last_edit_date": 1626228796,
        "question_id": 68370257,
        "body_markdown": "I have a data structure provided to me (by kubectl) in the following format relating to some custom resource definitions in a cluster. I want to use `jq` or similar to return `.items[x].metadata.name` when that list element&#39;s `.status.conditions` list has a condition of `.type == &quot;Ready&quot;` and `.status == &quot;False&quot;`.\r\n\r\nThe &#39;business case&#39; is &quot;Get any custom resources that are not yet ready.&quot;\r\n\r\nI get the feeling that the structure of the data is making this difficult, but am wondering if it is possible to do with `jq` at all.\r\n\r\nAny help is greatly appreciated!\r\n\r\n```json\r\n{\r\n    &quot;apiVersion&quot;: &quot;v1&quot;,\r\n    &quot;items&quot;: [\r\n        {\r\n            &quot;metadata&quot;: {\r\n                &quot;name&quot;: &quot;return-me&quot;\r\n            },\r\n            &quot;spec&quot;: {\r\n                &quot;region&quot;: &quot;ap-southeast-2&quot;\r\n            },\r\n            &quot;status&quot;: {\r\n                &quot;conditions&quot;: [\r\n                    {\r\n                        &quot;message&quot;: &quot;Some Condition A&quot;,\r\n                        &quot;reason&quot;: &quot;Supported&quot;,\r\n                        &quot;status&quot;: &quot;True&quot;,\r\n                        &quot;type&quot;: &quot;IsSupported&quot;\r\n                    },\r\n                    {\r\n                        &quot;message&quot;: &quot;Some Condition B&quot;,\r\n                        &quot;reason&quot;: &quot;Shared&quot;,\r\n                        &quot;status&quot;: &quot;True&quot;,\r\n                        &quot;type&quot;: &quot;IsShared&quot;\r\n                    },\r\n                    {\r\n                        &quot;message&quot;: &quot;Some Condition C&quot;,\r\n                        &quot;reason&quot;: &quot;Accepted&quot;,\r\n                        &quot;status&quot;: &quot;False&quot;,\r\n                        &quot;type&quot;: &quot;IsAccepted&quot;\r\n                    },\r\n                    {\r\n                        &quot;status&quot;: &quot;True&quot;,\r\n                        &quot;type&quot;: &quot;OthersReady&quot;\r\n                    },\r\n                    {\r\n                        &quot;status&quot;: &quot;False&quot;,\r\n                        &quot;type&quot;: &quot;Ready&quot;\r\n                    }\r\n                ]\r\n            }\r\n        },\r\n        {\r\n            &quot;metadata&quot;: {\r\n                &quot;name&quot;: &quot;dont-return-me&quot;\r\n            },\r\n            &quot;spec&quot;: {\r\n                &quot;region&quot;: &quot;ap-northeast-1&quot;\r\n            },\r\n            &quot;status&quot;: {\r\n                &quot;conditions&quot;: [\r\n                    {\r\n                        &quot;message&quot;: &quot;Some Condition A&quot;,\r\n                        &quot;reason&quot;: &quot;Supported&quot;,\r\n                        &quot;status&quot;: &quot;True&quot;,\r\n                        &quot;type&quot;: &quot;IsSupported&quot;\r\n                    },\r\n                    {\r\n                        &quot;message&quot;: &quot;Some Condition B&quot;,\r\n                        &quot;reason&quot;: &quot;Shared&quot;,\r\n                        &quot;status&quot;: &quot;True&quot;,\r\n                        &quot;type&quot;: &quot;IsShared&quot;\r\n                    },\r\n                    {\r\n                        &quot;message&quot;: &quot;Some Condition C&quot;,\r\n                        &quot;reason&quot;: &quot;Accepted&quot;,\r\n                        &quot;status&quot;: &quot;False&quot;,\r\n                        &quot;type&quot;: &quot;IsAccepted&quot;\r\n                    },\r\n                    {\r\n                        &quot;status&quot;: &quot;True&quot;,\r\n                        &quot;type&quot;: &quot;OthersReady&quot;\r\n                    },\r\n                    {\r\n                        &quot;status&quot;: &quot;True&quot;,\r\n                        &quot;type&quot;: &quot;Ready&quot;\r\n                    }\r\n                ]\r\n            }\r\n        },\r\n    ],\r\n    &quot;kind&quot;: &quot;List&quot;,\r\n    &quot;metadata&quot;: {\r\n        &quot;resourceVersion&quot;: &quot;&quot;,\r\n        &quot;selfLink&quot;: &quot;&quot;\r\n    }\r\n}\r\n```",
        "link": "https://stackoverflow.com/questions/68370257/is-it-possible-to-get-a-list-element-based-on-a-combination-of-multiple-sub-list",
        "title": "Is it possible to get a list element based on a combination of multiple sub-list values?"
    }
]