[
    {
        "tags": [
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 3597514,
                    "reputation": 122820,
                    "user_id": 3001761,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/feZwC.jpg?s=256",
                    "display_name": "jonrsharpe",
                    "link": "https://stackoverflow.com/users/3001761/jonrsharpe"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1708616758,
                "post_id": 78042281,
                "comment_id": 137583343,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1708620863,
                "last_edit_date": 1708620863,
                "creation_date": 1708616936,
                "answer_id": 78042308,
                "question_id": 78042281,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Your expected output contains a duplicate key `pipeline`, which jq cannot produce by regular means. But if you accept another name for one of them, e.g. renaming the first one to `parent`, you could get your expected output by decomposing the input with `to_entries`, and then assigning all the target values:\r\n```sh\r\nto_entries[]\r\n| {parent: .key} + (.value | {description, last_modified, username, pipeline})\r\n```\r\n[Demo](https://jqplay.org/s/6t3NKUn6kUn)",
                "title": "Syntax for extracting data from JSON"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1708620863,
        "creation_date": 1708616620,
        "last_edit_date": 1708616732,
        "question_id": 78042281,
        "body_markdown": "I need to extract some info from JSON. My JSON looks like this:\r\n\r\n```lang-json\r\n{\r\n  &quot;pipeline1&quot;: {\r\n    &quot;description&quot;: &quot;Desc 1&quot;,\r\n    &quot;last_modified&quot;: &quot;2023-11-14T09:27:50.235Z&quot;,\r\n    &quot;pipeline_metadata&quot;: {\r\n      &quot;version&quot;: 1,\r\n      &quot;type&quot;: &quot;logstash_pipeline&quot;\r\n    },\r\n    &quot;username&quot;: &quot;user1&quot;,\r\n    &quot;pipeline&quot;: &quot;code&quot;,\r\n    &quot;pipeline_settings&quot;: {\r\n      &quot;pipeline.batch.delay&quot;: 50,\r\n      &quot;pipeline.batch.size&quot;: 125,\r\n      &quot;pipeline.workers&quot;: 1,\r\n      &quot;queue.checkpoint.writes&quot;: 1024,\r\n      &quot;queue.max_bytes&quot;: &quot;1gb&quot;,\r\n      &quot;queue.type&quot;: &quot;memory&quot;\r\n    }\r\n  }\r\n}\r\n```\r\n\r\nExpected output:\r\n```lang-json\r\n{\r\n  &quot;pipeline&quot;: &quot;pipeline1&quot;,\r\n  &quot;description&quot;: &quot;Desc 1&quot;\r\n  &quot;last_modified&quot;: &quot;2023-11-14T09:27:50.235Z&quot;\r\n  &quot;username&quot;: &quot;user1&quot;\r\n  &quot;pipeline&quot;: &quot;code&quot;\r\n}\r\n```\r\n\r\nIs it possible with `jq`?",
        "link": "https://stackoverflow.com/questions/78042281/syntax-for-extracting-data-from-json",
        "title": "Syntax for extracting data from JSON"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 6313442,
                    "reputation": 45115,
                    "user_id": 5625547,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/oqCND.jpg?s=256",
                    "display_name": "0stone0",
                    "link": "https://stackoverflow.com/users/5625547/0stone0"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1708622033,
                "post_id": 78042884,
                "comment_id": 137584439,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1708627957,
                "creation_date": 1708627957,
                "answer_id": 78043421,
                "question_id": 78042884,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You seem to be looking for the [`JOIN` operator](https://jqlang.github.io/jq/manual/#sql-style-operators):\r\n```sh\r\nfiltre=&#39;\r\n  JOIN(\r\n    .&quot;coretemp-isa-0000&quot;; input.cpus[]; &quot;Core \\(.cpu)&quot;; [first.cpu, first.mhz, (\r\n      last | to_entries[] | select(.key | endswith(&quot;_input&quot;)).value\r\n    ) | trunc]\r\n  ) | join(&quot; &quot;)\r\n&#39;\r\n\r\njq -r &quot;$filtre&quot; &lt;(…sensors…) &lt;(…lscpu…)\r\n```\r\n```csv\r\n0 2997 32\r\n1 3191 22\r\n2 2948 31\r\n3 1600 28\r\n```\r\n[Demo](https://jqplay.org/s/m54vyrMC-CR)",
                "title": "json jq add an object to an existing array at the bottom of JSON"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1708627957,
        "creation_date": 1708621948,
        "last_edit_date": 1708622045,
        "question_id": 78042884,
        "body_markdown": "I&#39;m trying to get some infos from `lscpu` and `sensors` in `bash` with `jq`:\r\n\r\n```\r\njq -s &#39;add&#39; \\\r\n    &lt;(LC_NUMERIC=C sensors -j coretemp-isa-0000) \\\r\n    &lt;(LC_NUMERIC=C lscpu -J -e=cpu,mhz)\r\n```\r\n\r\nhere&#39;s what I get:\r\n```\r\n{\r\n  &quot;coretemp-isa-0000&quot;: {\r\n    &quot;Adapter&quot;: &quot;ISA adapter&quot;,\r\n    &quot;Package id 0&quot;: {\r\n      &quot;temp1_input&quot;: 32.000,\r\n      &quot;temp1_max&quot;: 80.000,\r\n      &quot;temp1_crit&quot;: 99.000,\r\n      &quot;temp1_crit_alarm&quot;: 0.000\r\n    },\r\n    &quot;Core 0&quot;: {\r\n      &quot;temp2_input&quot;: 32.000,\r\n      &quot;temp2_max&quot;: 80.000,\r\n      &quot;temp2_crit&quot;: 99.000,\r\n      &quot;temp2_crit_alarm&quot;: 0.000\r\n    },\r\n    &quot;Core 1&quot;: {\r\n      &quot;temp3_input&quot;: 22.000,\r\n      &quot;temp3_max&quot;: 80.000,\r\n      &quot;temp3_crit&quot;: 99.000,\r\n      &quot;temp3_crit_alarm&quot;: 0.000\r\n    },\r\n    &quot;Core 2&quot;: {\r\n      &quot;temp4_input&quot;: 31.000,\r\n      &quot;temp4_max&quot;: 80.000,\r\n      &quot;temp4_crit&quot;: 99.000,\r\n      &quot;temp4_crit_alarm&quot;: 0.000\r\n    },\r\n    &quot;Core 3&quot;: {\r\n      &quot;temp5_input&quot;: 28.000,\r\n      &quot;temp5_max&quot;: 80.000,\r\n      &quot;temp5_crit&quot;: 99.000,\r\n      &quot;temp5_crit_alarm&quot;: 0.000\r\n    }\r\n  },\r\n  &quot;cpus&quot;: [\r\n    {\r\n      &quot;cpu&quot;: 0,\r\n      &quot;mhz&quot;: 2997.8560\r\n    },\r\n    {\r\n      &quot;cpu&quot;: 1,\r\n      &quot;mhz&quot;: 3191.4871\r\n    },\r\n    {\r\n      &quot;cpu&quot;: 2,\r\n      &quot;mhz&quot;: 2948.6250\r\n    },\r\n    {\r\n      &quot;cpu&quot;: 3,\r\n      &quot;mhz&quot;: 1600.0000\r\n    }\r\n  ]\r\n}\r\n```\r\nand what I want is:\r\n```\r\n0 2997 32\r\n1 3191 22\r\n2 2948 31\r\n3 1600 28\r\n```\r\n\r\nI come to this:\r\n```\r\n#!/bin/bash\r\n\r\nfiltre=&#39;add\r\n    |(.[&quot;coretemp-isa-0000&quot;]\r\n    |keys[] as $core\r\n    |select($core|test(&quot;^Core [0-9]$&quot;))\r\n    |($core|ltrimstr(&quot;Core &quot;)) as $id\r\n    |.[$core]\r\n    |keys[] as $temp\r\n    |select($temp|test(&quot;temp[0-9]_input&quot;))\r\n    |.cpus[$id|tonumber] += {&quot;temp&quot;:.[$temp]}),.cpus&#39;\r\n\r\njq -rs &quot;$filtre&quot; \\\r\n    &lt;(LC_NUMERIC=C sensors -j coretemp-isa-0000) \\\r\n    &lt;(LC_NUMERIC=C lscpu -J -e=cpu,mhz)\r\n```\r\nbut it doesn&#39;t do what I want : it only feeds a `.cpus` array in each `$core`, and leaves the `.cpus` I want to be changed unchanged.",
        "link": "https://stackoverflow.com/questions/78042884/json-jq-add-an-object-to-an-existing-array-at-the-bottom-of-json",
        "title": "json jq add an object to an existing array at the bottom of JSON"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1708659263,
                "creation_date": 1708659263,
                "answer_id": 78045051,
                "question_id": 78045037,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Expand `.data` only once:\r\n``` sh\r\njq -c &#39;.data[] | {a, b}&#39;\r\n```\r\n&lt;sup&gt;[Online demo](https://jqplay.org/s/JAgQyYrSeon)&lt;/sup&gt;",
                "title": "Can I use JQ to narrow the json object in an array?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1708659464,
        "creation_date": 1708659018,
        "last_edit_date": 1708659464,
        "question_id": 78045037,
        "body_markdown": "Input:\r\n```\r\n{\r\n   &quot;data&quot;: [\r\n      {\r\n        &quot;a&quot;: &quot;a1&quot;,\r\n        &quot;b&quot;: &quot;b1&quot;,\r\n        &quot;c&quot;: &quot;1&quot;\r\n      },\r\n      {\r\n        &quot;a&quot;: &quot;a2&quot;,\r\n        &quot;b&quot;: &quot;b2&quot;,\r\n        &quot;c&quot;: &quot;2&quot;\r\n      }\r\n    ]\r\n}\r\n```\r\nExpected output:\r\n```\r\n{&quot;a&quot;: &quot;a1&quot;, &quot;b&quot;: &quot;b1&quot;}\r\n{&quot;a&quot;: &quot;a2&quot;, &quot;b&quot;: &quot;b2&quot;}\r\n```\r\n\r\nThe closest approach I can get so far is:\r\n```\r\n&quot;a1&quot;\r\n&quot;a2&quot;\r\n&quot;b1&quot;\r\n&quot;b2&quot;\r\n```\r\n[Demo](https://jqplay.org/jq?q=.foo&amp;j=%7B%22foo%22%3A%2042%2C%20%22bar%22%3A%20%22less%20interesting%20data%22%7D)\r\n\r\nChecked the document and tried multiple combination include map_values, but can&#39;t finger out. I think it should be a prettier useful use case...\r\n\r\nIf I use:\r\n```\r\n{a: .data[].a, b: .data[].b}\r\n```\r\nThe output becomes:\r\n```\r\n{\r\n  &quot;a&quot;: &quot;a1&quot;,\r\n  &quot;b&quot;: &quot;b1&quot;\r\n}\r\n{\r\n  &quot;a&quot;: &quot;a1&quot;,\r\n  &quot;b&quot;: &quot;b2&quot;\r\n}\r\n{\r\n  &quot;a&quot;: &quot;a2&quot;,\r\n  &quot;b&quot;: &quot;b1&quot;\r\n}\r\n{\r\n  &quot;a&quot;: &quot;a2&quot;,\r\n  &quot;b&quot;: &quot;b2&quot;\r\n}\r\n```\r\nobvious not what I want.\r\n\r\nAny one can advise on this?\r\nThanks.",
        "link": "https://stackoverflow.com/questions/78045037/can-i-use-jq-to-narrow-the-json-object-in-an-array",
        "title": "Can I use JQ to narrow the json object in an array?"
    },
    {
        "tags": [
            "ubuntu",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 63657,
                    "reputation": 54375,
                    "user_id": 188331,
                    "user_type": "registered",
                    "accept_rate": 85,
                    "profile_image": "https://i.sstatic.net/UhYfd.jpg?s=256",
                    "display_name": "Raptor",
                    "link": "https://stackoverflow.com/users/188331/raptor"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1708674001,
                "post_id": 78045777,
                "comment_id": 137590105,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 30556690,
                    "reputation": 23,
                    "user_id": 23420664,
                    "user_type": "registered",
                    "profile_image": "https://lh3.googleusercontent.com/a/ACg8ocLdMtHmIqwEH_XHzfA-TDmF-gavbbal4FCu5OtKerEw=k-s256",
                    "display_name": "Tony Stark",
                    "link": "https://stackoverflow.com/users/23420664/tony-stark"
                },
                "reply_to_user": {
                    "account_id": 63657,
                    "reputation": 54375,
                    "user_id": 188331,
                    "user_type": "registered",
                    "accept_rate": 85,
                    "profile_image": "https://i.sstatic.net/UhYfd.jpg?s=256",
                    "display_name": "Raptor",
                    "link": "https://stackoverflow.com/users/188331/raptor"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1708677602,
                "post_id": 78045777,
                "comment_id": 137590598,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1450087,
                    "reputation": 12022,
                    "user_id": 1409374,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/97d424fe924f2139812a4a6de1ef6b79?s=256&d=identicon&r=PG",
                    "display_name": "rickhg12hs",
                    "link": "https://stackoverflow.com/users/1409374/rickhg12hs"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1708714668,
                "post_id": 78045777,
                "comment_id": 137596531,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "is_answered": false,
        "answer_count": 0,
        "score": 0,
        "last_activity_date": 1708673313,
        "creation_date": 1708673313,
        "question_id": 78045777,
        "body_markdown": "I am trying to install JQ using below command but ends up in error when I don&#39;t provide the version the installation works fine. I am using Ubuntu 22.04.4 LTS version.\r\n\r\n\r\n\r\n```\r\nsudo apt-get install jq=1.6\r\n```\r\n\r\n```\r\nReading package lists... Done\r\nBuilding dependency tree\r\nReading state information... Done\r\nE: Version &#39;1.6&#39; for &#39;jq&#39; was not found\r\n```",
        "link": "https://stackoverflow.com/questions/78045777/error-while-installing-jq-of-specific-version",
        "title": "Error while installing JQ of specific version"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1708703877,
                "post_id": 78048588,
                "comment_id": 137594695,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1124518,
                    "reputation": 33,
                    "user_id": 1112113,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/86885537050173177522e147edbaf211?s=256&d=identicon&r=PG",
                    "display_name": "willdashwood",
                    "link": "https://stackoverflow.com/users/1112113/willdashwood"
                },
                "reply_to_user": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1708704300,
                "post_id": 78048588,
                "comment_id": 137594783,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1450087,
                    "reputation": 12022,
                    "user_id": 1409374,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/97d424fe924f2139812a4a6de1ef6b79?s=256&d=identicon&r=PG",
                    "display_name": "rickhg12hs",
                    "link": "https://stackoverflow.com/users/1409374/rickhg12hs"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1708713579,
                "post_id": 78048588,
                "comment_id": 137596376,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1708763034,
                "last_edit_date": 1708763034,
                "creation_date": 1708762369,
                "answer_id": 78051669,
                "question_id": 78048588,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "&gt; … contains …\r\n\r\n\r\n    data.zone[].record[]\r\n    | select(.cname | tostring | test(&quot;comodoca[.]com&quot;)).Line\r\n\r\nOne of many alternatives would be to use `index/1`.\r\n\r\n\r\n\r\n",
                "title": "jq - select an 1 attribute when matching another"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1708763034,
        "creation_date": 1708703586,
        "last_edit_date": 1708704195,
        "question_id": 78048588,
        "body_markdown": "Input JSON :\r\n\r\n```json\r\n{\r\n  &quot;data&quot;: {\r\n    &quot;zone&quot;: [\r\n      {\r\n        &quot;record&quot;: [\r\n          {\r\n            &quot;Line&quot;: 1,\r\n            &quot;raw&quot;: &quot;; cPanel first:11.25.0-CURRENT_46156 (update_time):1708598274 Cpanel::ZoneFile::VERSION:1.3 hostname:server2.something.com latest:110.0.23&quot;,\r\n            &quot;type&quot;: &quot;:RAW&quot;\r\n          },\r\n          {\r\n            &quot;Line&quot;: 4,\r\n            &quot;Lines&quot;: 1,\r\n            &quot;class&quot;: &quot;IN&quot;,\r\n            &quot;expire&quot;: &quot;1209600&quot;,\r\n            &quot;minimum&quot;: &quot;86400&quot;,\r\n            &quot;mname&quot;: &quot;ns1.something.com&quot;,\r\n            &quot;name&quot;: &quot;domain.com.&quot;,\r\n            &quot;refresh&quot;: &quot;3600&quot;,\r\n            &quot;retry&quot;: &quot;1800&quot;,\r\n            &quot;rname&quot;: &quot;noreply.something.com&quot;,\r\n            &quot;serial&quot;: &quot;2024022220&quot;,\r\n            &quot;ttl&quot;: 86400,\r\n            &quot;type&quot;: &quot;SOA&quot;\r\n          },\r\n          {\r\n            &quot;Line&quot;: 6,\r\n            &quot;address&quot;: &quot;195.216.197.40&quot;,\r\n            &quot;class&quot;: &quot;IN&quot;,\r\n            &quot;name&quot;: &quot;ftp.domain.com.&quot;,\r\n            &quot;ttl&quot;: 60,\r\n            &quot;type&quot;: &quot;A&quot;\r\n          },\r\n          {\r\n            &quot;Line&quot;: 97,\r\n            &quot;class&quot;: &quot;IN&quot;,\r\n            &quot;cname&quot;: &quot;0c960d0901ed2ec4ae18f39c5dcf547e.b3778944564d3daa444a04e58f3b1649.comodoca.com&quot;,\r\n            &quot;name&quot;: &quot;_f0ff734bef4f3db24a0dc94fc6b1d21a.fab.domain.com.&quot;,\r\n            &quot;ttl&quot;: 60,\r\n            &quot;type&quot;: &quot;CNAME&quot;\r\n          },\r\n          {\r\n            &quot;Line&quot;: 114,\r\n            &quot;class&quot;: &quot;IN&quot;,\r\n            &quot;cname&quot;: &quot;eaf925d9c7f0fbe3e1abcaa94671918b.814242e76a38aea40755b96ee978a9fc.comodoca.com&quot;,\r\n            &quot;name&quot;: &quot;_671f4707fe0a8b2443fc93fe3a7a7a1d.www.software.domain.com.&quot;,\r\n            &quot;ttl&quot;: 60,\r\n            &quot;type&quot;: &quot;CNAME&quot;\r\n          }\r\n        ]\r\n      }\r\n    ]\r\n  },\r\n  &quot;metadata&quot;: {\r\n    &quot;command&quot;: &quot;dumpzone&quot;,\r\n    &quot;reason&quot;: &quot;Zone Serialized&quot;,\r\n    &quot;result&quot;: 1,\r\n    &quot;version&quot;: 1\r\n  }\r\n}\r\n```\r\n\r\nWhat I&#39;m trying to get is the &quot;Line&quot; number where &quot;cname&quot; contains or ends with &quot;comodoca.com&quot;. For example:\r\n\r\n```\r\n97\r\n114\r\n```\r\n\r\nI spent ages struggling to get it to work so in the end I cheated and used grep and awk.\r\n\r\n\r\n```\r\njq --raw-output &#39;.data.zone[].record[] | (.Line|tostring) + &quot;,&quot; + .cname &#39; | grep -i &#39;comodoca.com&#39; | awk -F, &#39;{ print $1}&#39;\r\n```\r\n\r\nIs there a way of doing it all in jq? Thanks!\r\n\r\nThe closest I got to coming up with something that might work was:\r\n\r\n```\r\njq --raw-output &#39;.data.zone[].record[] | select(endswith(&quot;comodoca.com&quot;))]&#39;\r\n```\r\n\r\nWork, it did not.",
        "link": "https://stackoverflow.com/questions/78048588/jq-select-an-1-attribute-when-matching-another",
        "title": "jq - select an 1 attribute when matching another"
    },
    {
        "tags": [
            "json",
            "jq",
            "edit"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1708957365,
                "last_edit_date": 1708957365,
                "creation_date": 1708798764,
                "answer_id": 78053499,
                "question_id": 78053275,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Your expected outputs aren&#39;t valid JSON (either they lack array brackets, or they have abundant commas). The first of the two even lists multiple values to a single object key, which is not possible (unless the value is enclosed within array brackets). Here&#39;s how to start collecting from a stream:\r\n\r\n```sh\r\njq -n &#39;reduce (inputs | to_entries)[] as $e ({}; .[$e.key] += [$e.value])&#39;\r\n```\r\n```json\r\n{\r\n  &quot;london&quot;: [\r\n    [\r\n      &quot;x&quot;,\r\n      0\r\n    ],\r\n    [\r\n      &quot;y&quot;,\r\n      97\r\n    ]\r\n  ],\r\n  &quot;paris&quot;: [\r\n    [\r\n      &quot;x&quot;,\r\n      15\r\n    ],\r\n    [\r\n      &quot;y&quot;,\r\n      8\r\n    ]\r\n  ]\r\n}\r\n```\r\n[Demo](https://jqplay.org/s/5IQ3gCmkHoT)\r\n\r\nFrom here, decide what your (valid) target structure should look like, and, if needed, ask another question based on that.\r\n\r\n---\r\nEdit 1: Your approach using `group_by` relies on the premise that each input object consists of just one key. If you want to pursue that approach, create objects with each first of a group&#39;s first key:\r\n```sh\r\njq -sc &#39;group_by(keys_unsorted[])[] | {(.[0] | keys_unsorted[]): [.[][]]}&#39;\r\n```\r\n```json\r\n{&quot;london&quot;:[[&quot;x&quot;,0],[&quot;y&quot;,97]]}\r\n{&quot;paris&quot;:[[&quot;x&quot;,15],[&quot;y&quot;,8]]}\r\n```\r\n[Demo](https://jqplay.org/s/IRB_4sOstAw)\r\n\r\n---\r\nEdit 2: Your original filter can be simplified to `{(.city): (.zoo[] | [.room.name, .gpu.sum])}` ([Demo](https://jqplay.org/s/venGoYLt6km)), which then can be concatenated with this post&#39;s first approach by replacing `inputs` with the above ([Demo](https://jqplay.org/s/7jNxKjW8tFc)), which in turn can be simplified (quite similarly to the previous simplification) by not generating objects to just destructure them again, but by directly operating on the original input data instead:\r\n```sh\r\njq -c &#39;{(.city): .zoo | map([.room.name, .gpu.sum])}&#39;\r\n```\r\n```json\r\n{&quot;london&quot;:[[&quot;x&quot;,0],[&quot;y&quot;,97]]}\r\n{&quot;paris&quot;:[[&quot;x&quot;,15],[&quot;y&quot;,8]]}\r\n```\r\n[Demo](https://jqplay.org/s/Lcyp91h8vnn)",
                "title": "how to group_by with tables&#39; key name"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1708957365,
        "creation_date": 1708794855,
        "last_edit_date": 1708869961,
        "question_id": 78053275,
        "body_markdown": "My input json file:\r\n\r\n    { &quot;london&quot;: [ &quot;x&quot;, 0 ] }\r\n    { &quot;london&quot;: [ &quot;y&quot;, 97 ] }\r\n    { &quot;paris&quot;: [ &quot;x&quot;, 15 ] }\r\n    { &quot;paris&quot;: [ &quot;y&quot;, 8 ] }\r\n\r\nI try to group by  key and make the output:\r\n\r\n    { &quot;london&quot;:  [&quot;x&quot;, 0], [&quot;y&quot;, 97] },\r\n    { &quot;paris&quot;:   [&quot;x&quot;, 15], [&quot;y&quot;, 8] }\r\nor:\r\n\r\n    { &quot;london&quot;: [ {&quot;x&quot;, 0}, {&quot;y&quot;, 97} ] },\r\n    { &quot;paris&quot;:  [ {&quot;x&quot;, 15}, {&quot;y&quot;, 8} ] }\r\n\r\n\r\nThe following command give me an error message: \r\n\r\n     jq -s &#39;group_by(keys_unsorted[0]) | map({(.[0]): map(.[1])})&#39;\r\n\r\njq: error (at &lt;stdin&gt;:4): Cannot index object with number\r\n\r\nI try to change the numbers to strings, but, it does not help.\r\nI guess that I missed something in the map *(?)*\r\n\r\nEDIT:\r\n\r\nExtantion regarding the answer from @pmf.\r\nThe Original source is:\r\n\r\n     {\r\n       &quot;city&quot;: &quot;london&quot;,\r\n       &quot;zoo&quot;: [\r\n         { &quot;room&quot;: { &quot;name&quot;: &quot;x&quot; }, &quot;gpu&quot;: { &quot;id&quot;: &quot;fish&quot;,  &quot;sum&quot;: 0 } },\r\n         { &quot;room&quot;: { &quot;name&quot;: &quot;y&quot; }, &quot;gpu&quot;: { &quot;id&quot;: &quot;zebra&quot;, &quot;sum&quot;: 97 } }\r\n        ]\r\n      }\r\n      {\r\n        &quot;city&quot;: &quot;paris&quot;,\r\n        &quot;zoo&quot;: [\r\n           { &quot;room&quot;: { &quot;name&quot;: &quot;x&quot; }, &quot;gpu&quot;: { &quot;id&quot;: &quot;fish&quot;,  &quot;sum&quot;: 15 } },\r\n           { &quot;room&quot;: { &quot;name&quot;: &quot;y&quot; }, &quot;gpu&quot;: { &quot;id&quot;: &quot;zebra&quot;, &quot;sum&quot;: 8 } }\r\n        ]\r\n      }\r\n\r\nand I try to get the output as above. I started with following:\r\n\r\n          jq -c &#39;.city as $j | foreach .zoo[] as $i (.; .; {($j): [$i.room.name, $i.gpu.sum]})&#39;\r\n\r\nthen i stuck and @pmf helped me. Can I do it else?",
        "link": "https://stackoverflow.com/questions/78053275/how-to-group-by-with-tables-key-name",
        "title": "how to group_by with tables&#39; key name"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1708931580,
                "post_id": 78058760,
                "comment_id": 137612808,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1101186,
                    "reputation": 35,
                    "user_id": 1093548,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/NeZwx.jpg?s=256",
                    "display_name": "Dima",
                    "link": "https://stackoverflow.com/users/1093548/dima"
                },
                "reply_to_user": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1708932761,
                "post_id": 78058760,
                "comment_id": 137612949,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1708929319,
                "creation_date": 1708929319,
                "answer_id": 78058972,
                "question_id": 78058760,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here is a way:\r\n```\r\n./sizes.sh | jq &#39;[., [{size: inputs}]] | transpose | map(add)&#39; file.json -\r\n```",
                "title": "Adding into each existing object within JSON array new values from file/variable/command using jq"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1708934064,
                "creation_date": 1708934064,
                "answer_id": 78059345,
                "question_id": 78058760,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "&gt; How can I update my original json\r\n\r\n`jq` cannot &quot;update&quot; a file, you&#39;ll have to let the shell do it. Assuming a POSIX shell, you could redirect the output to a temporary file using `&gt;`, and overwrite the original on success using `mv -f`:\r\n```sh\r\n./sizes.sh |\r\njq -Rn --slurpfile in original.json &gt; temp.json \\\r\n  &#39;$in + [[{size: inputs}]] | transpose | map(add)&#39; &amp;&amp;\r\nmv -f temp.json original.json\r\n```",
                "title": "Adding into each existing object within JSON array new values from file/variable/command using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1708934064,
        "creation_date": 1708925217,
        "last_edit_date": 1708929978,
        "question_id": 78058760,
        "body_markdown": "I have json like this:\r\n\r\n    [\r\n        {\r\n            &quot;id&quot;: &quot;1&quot;\r\n        }, \r\n        {\r\n            &quot;id&quot;: &quot;2&quot;\r\n        }, \r\n        {\r\n            &quot;id&quot;: &quot;3&quot;\r\n        } \r\n    ]\r\n\r\nI call some &quot;sizes.sh&quot; that give me result:\r\n\r\n    10\r\n    20\r\n    30\r\n\r\nHow can I update my original json with these results, so it will look:\r\n\r\n    [\r\n        {\r\n            &quot;id&quot;: &quot;1&quot;,\r\n            &quot;size&quot;: 10\r\n        }, \r\n        {\r\n            &quot;id&quot;: &quot;2&quot;,\r\n            &quot;size&quot;: 20\r\n    \r\n        }, \r\n        {\r\n            &quot;id&quot;: &quot;3&quot;,\r\n            &quot;size&quot;: 30\r\n    \r\n        }\r\n    ]",
        "link": "https://stackoverflow.com/questions/78058760/adding-into-each-existing-object-within-json-array-new-values-from-file-variable",
        "title": "Adding into each existing object within JSON array new values from file/variable/command using jq"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1708950695,
                "post_id": 78060881,
                "comment_id": 137615777,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1708950482,
                "creation_date": 1708950482,
                "answer_id": 78060905,
                "question_id": 78060881,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "```\r\n.arrays[].properties |= map({ type: &quot;FOOBAR&quot;, file: &quot;someFile&quot; })\r\n```\r\n\r\nWill result in:\r\n```json\r\n{\r\n  &quot;arrays&quot;: [\r\n    {\r\n      &quot;name&quot;: &quot;foo&quot;,\r\n      &quot;properties&quot;: [\r\n        {\r\n          &quot;type&quot;: &quot;FOOBAR&quot;,\r\n          &quot;file&quot;: &quot;someFile&quot;\r\n        }\r\n      ]\r\n    }\r\n  ]\r\n}\r\n```\r\n\r\n\r\n----------\r\n\r\n##### [Try it online!](https://jqplay.org/s/CF5ZR9G3dEh)",
                "title": "Editing json file in line with jq"
            },
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1708952307,
                "last_edit_date": 1708952307,
                "creation_date": 1708950509,
                "answer_id": 78060913,
                "question_id": 78060881,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I would replace the whole properties field :\r\n\r\n    jq &#39;(.arrays[]| select(.name == &quot;foo&quot;)).properties |= [{\r\n        &quot;type&quot; : &quot;bar&quot;,\r\n        &quot;file&quot; : &quot;filename&quot;\r\n    }]&#39; test.json\r\n\r\nYou can [try it here](https://jqplay.org/s/xupiiF5mz_a).",
                "title": "Editing json file in line with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1708952307,
        "creation_date": 1708950201,
        "question_id": 78060881,
        "body_markdown": "I have a json file like this:\r\n\r\n```json\r\n{\r\n&quot;arrays&quot;: [\r\n    {\r\n      &quot;name&quot;: &quot;foo&quot;,\r\n      &quot;properties&quot;: [\r\n        {\r\n          &quot;type&quot;: &quot;app&quot;,\r\n          &quot;url&quot;: &quot;https://example.com&quot;,\r\n          &quot;checksum&quot;: &quot;d6fd580fe890b826250aa5d5a88bcdb28839cff4d447ba51536cda4ceae89c4e&quot;\r\n        }\r\n      ]\r\n    }\r\n  ]\r\n}\r\n\r\n```\r\n\r\nI want to change the type to something else, delete the url and checksum key and add a file key in their place with a value.\r\n\r\nThe final thing should be:\r\n\r\n```json\r\n{\r\n&quot;arrays&quot;: [\r\n    {\r\n      &quot;name&quot;: &quot;foo&quot;,\r\n      &quot;properties&quot;: [\r\n        {\r\n          &quot;type&quot;: &quot;Bar&quot;,\r\n          &quot;file&quot;: &quot;filename&quot;\r\n        }\r\n      ]\r\n    }\r\n  ]\r\n}\r\n\r\n```\r\n\r\nHow would I do this inline with `jq`\r\n\r\nI got upto modifying the type value:\r\n\r\n```sh\r\njq &#39;(.arrays[]| select(.name == &quot;foo&quot;).properties[]).type |= &quot;Bar&quot;&#39; test.json\r\n```",
        "link": "https://stackoverflow.com/questions/78060881/editing-json-file-in-line-with-jq",
        "title": "Editing json file in line with jq"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1708954601,
                "creation_date": 1708954601,
                "answer_id": 78061347,
                "question_id": 78061337,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Use `add` to concatenate, and `|=` to update:\r\n```sh\r\njq &#39;.[] |= ([.charInfo[].char] | add)&#39;\r\n```\r\n```json\r\n{\r\n  &quot;font1&quot;: &quot;ab&quot;,\r\n  &quot;font2&quot;: &quot;sx&quot;\r\n}\r\n```\r\n[Demo](https://jqplay.org/s/nlwazy_Fwvu)",
                "title": "Concatenate strings in jq"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1708956871,
                "creation_date": 1708956871,
                "answer_id": 78061577,
                "question_id": 78061337,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Not efficient, but maybe a bit clearer leveraging `map_values` and `join`:\r\n\r\n```\r\nmap_values(.charInfo|map(.char)|join(&quot;&quot;))\r\n```",
                "title": "Concatenate strings in jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1708956871,
        "creation_date": 1708954483,
        "last_edit_date": 1708956854,
        "question_id": 78061337,
        "body_markdown": "My input looks like:\r\n\r\n    {\r\n        &quot;font1&quot;: {\r\n            &quot;charInfo&quot;: [\r\n                {\r\n                    &quot;char&quot;: &quot;a&quot;,\r\n                    &quot;other_stuff&quot;: 12\r\n                },\r\n                {\r\n                    &quot;char&quot;: &quot;b&quot;,\r\n                    &quot;other_stuff&quot;: 63\r\n                }\r\n            ]\r\n        },\r\n        &quot;font2&quot;: {\r\n            &quot;charInfo&quot;: [\r\n                {\r\n                    &quot;char&quot;: &quot;s&quot;,\r\n                    &quot;other_stuff&quot;: 1\r\n                },\r\n                {\r\n                    &quot;char&quot;: &quot;x&quot;,\r\n                    &quot;other_stuff&quot;: 4\r\n                }\r\n            ]\r\n        }\r\n    }\r\nand I&#39;d like to aggregate (ideally concatenate) the &quot;char&quot;-s per font:\r\n\r\n    {\r\n        &quot;font1&quot;: &quot;ab&quot;,\r\n        &quot;font2&quot;: &quot;sx&quot;\r\n    }\r\nHow can achieve this using jq?\r\n\r\nThis is what I have so far:\r\n\r\n    jq &#39;. | keys[] as $font | {font: $font} + .[$font] | {font:.font, chars:[.charInfo[].char]|join(&quot;&quot;)}&#39;\r\n    enter code here\r\n\r\nWhich brings it to:\r\n\r\n    {\r\n      &quot;font&quot;: &quot;font1&quot;,\r\n      &quot;chars&quot;: &quot;ab&quot;\r\n    }\r\n    {\r\n      &quot;font&quot;: &quot;font2&quot;,\r\n      &quot;chars&quot;: &quot;sx&quot;\r\n    }\r\n\r\nbut I can&#39;t find how I turn the &quot;font&quot; to a key of a map\r\n\r\n",
        "link": "https://stackoverflow.com/questions/78061337/concatenate-strings-in-jq",
        "title": "Concatenate strings in jq"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 100740,
                    "reputation": 79490,
                    "user_id": 271415,
                    "user_type": "registered",
                    "accept_rate": 91,
                    "profile_image": "https://www.gravatar.com/avatar/8648256cc53b261c5e1d266380a256fc?s=256&d=identicon&r=PG",
                    "display_name": "jarmod",
                    "link": "https://stackoverflow.com/users/271415/jarmod"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1708977447,
                "post_id": 78063435,
                "comment_id": 137620388,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "reply_to_user": {
                    "account_id": 100740,
                    "reputation": 79490,
                    "user_id": 271415,
                    "user_type": "registered",
                    "accept_rate": 91,
                    "profile_image": "https://www.gravatar.com/avatar/8648256cc53b261c5e1d266380a256fc?s=256&d=identicon&r=PG",
                    "display_name": "jarmod",
                    "link": "https://stackoverflow.com/users/271415/jarmod"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1708979289,
                "post_id": 78063435,
                "comment_id": 137620604,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 100740,
                    "reputation": 79490,
                    "user_id": 271415,
                    "user_type": "registered",
                    "accept_rate": 91,
                    "profile_image": "https://www.gravatar.com/avatar/8648256cc53b261c5e1d266380a256fc?s=256&d=identicon&r=PG",
                    "display_name": "jarmod",
                    "link": "https://stackoverflow.com/users/271415/jarmod"
                },
                "reply_to_user": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1708987531,
                "post_id": 78063435,
                "comment_id": 137621627,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1708977249,
                "last_edit_date": 1708977249,
                "creation_date": 1708976561,
                "answer_id": 78063487,
                "question_id": 78063435,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The &quot;problem&quot; of your approach is with `if type == &quot;array&quot; then .[] else . end`. As `.Prices.Pricing` is indeed an array, this branches to `.[]`, destructuring the array, so the following code is executed three times, once for each item. The first one will produce the default item (as there is nothing else), the second outputs nothing (neither the target nor the default is present), and the third immediately finds the target item.\r\n\r\nMy approach would be using `INDEX` to turn the array into an object, and the alternative operator `//` to select a default if the previous returns null:\r\n```sh\r\nmap({\r\n  sku: .PartNumber,\r\n  price: (.Prices.Pricing | INDEX(.&quot;@PriceType&quot;) | .RMP // .RET | .Price.&quot;#text&quot;)\r\n})\r\n```\r\n```json\r\n[\r\n  {\r\n    &quot;sku&quot;: &quot;ABC123&quot;,\r\n    &quot;price&quot;: &quot;152.0000&quot;\r\n  }\r\n]\r\n```\r\n[Demo](https://jqplay.org/s/RwHYZpHFPEx)",
                "title": "How to conditionally select value with JQ"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1708977249,
        "creation_date": 1708975925,
        "question_id": 78063435,
        "body_markdown": "I am trying to select 1 price if it exists, otherwise I want to select a &quot;default&quot; price which always exists. My JQ works if the RMP price doesn&#39;t exist, I just get the 1 value back. But as you can see, if RMP exists I end up with 2 entries ... one with each price. I am only looking for 1 result back. It will either have the RMP price if it exists, or it will have the RET price. Not sure what I&#39;m doing wrong here.\r\n\r\nJSON\r\n```\r\n[\r\n  {\r\n    &quot;PartNumber&quot;: &quot;ABC123&quot;,\r\n    &quot;Prices&quot;: {\r\n      &quot;Pricing&quot;: [\r\n        {\r\n          &quot;@PriceType&quot;: &quot;RET&quot;,\r\n          &quot;Price&quot;: {\r\n            &quot;#text&quot;: &quot;230.3800&quot;\r\n          }\r\n        },\r\n        {\r\n          &quot;@PriceType&quot;: &quot;LST&quot;,\r\n          &quot;Price&quot;: {\r\n            &quot;#text&quot;: &quot;230.3800&quot;\r\n          }\r\n        },\r\n        {\r\n          &quot;@PriceType&quot;: &quot;RMP&quot;,\r\n          &quot;Price&quot;: {\r\n            &quot;#text&quot;: &quot;152.0000&quot;\r\n          }\r\n        }\r\n      ]\r\n    }\r\n  }\r\n]\r\n```\r\n\r\nJQ\r\n```\r\n[.[] | {\r\n    sku: .PartNumber,\r\n    price: (.Prices?.Pricing? | if type == &quot;array&quot; then .[] else . end | if any(.; .&quot;@PriceType&quot; == &quot;RMP&quot;) then select(.&quot;@PriceType&quot;? == &quot;RMP&quot;).Price.&quot;#text&quot; else select(.&quot;@PriceType&quot;? == &quot;RET&quot;).Price.&quot;#text&quot; end),\r\n}]\r\n```\r\n\r\nRESULT\r\n```\r\n[\r\n  {\r\n    &quot;sku&quot;: &quot;ABC123&quot;,\r\n    &quot;price&quot;: &quot;230.3800&quot;\r\n  },\r\n  {\r\n    &quot;sku&quot;: &quot;ABC123&quot;,\r\n    &quot;price&quot;: &quot;152.0000&quot;\r\n  }\r\n]\r\n```",
        "link": "https://stackoverflow.com/questions/78063435/how-to-conditionally-select-value-with-jq",
        "title": "How to conditionally select value with JQ"
    },
    {
        "tags": [
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 25473910,
                    "reputation": 3219,
                    "user_id": 19271565,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/31bf9ca02fb67ae4610ede66fc9fe146?s=256&d=identicon&r=PG",
                    "display_name": "tjm3772",
                    "link": "https://stackoverflow.com/users/19271565/tjm3772"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1709046901,
                "post_id": 78068546,
                "comment_id": 137628884,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 25473910,
                    "reputation": 3219,
                    "user_id": 19271565,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/31bf9ca02fb67ae4610ede66fc9fe146?s=256&d=identicon&r=PG",
                    "display_name": "tjm3772",
                    "link": "https://stackoverflow.com/users/19271565/tjm3772"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1709046963,
                "post_id": 78068546,
                "comment_id": 137628893,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 39208,
                    "reputation": 267964,
                    "user_id": 112968,
                    "user_type": "registered",
                    "accept_rate": 68,
                    "profile_image": "https://i.sstatic.net/zHTaT.png?s=256",
                    "display_name": "knittl",
                    "link": "https://stackoverflow.com/users/112968/knittl"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1709047713,
                "post_id": 78068546,
                "comment_id": 137629034,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 30489357,
                    "reputation": 15,
                    "user_id": 23364953,
                    "user_type": "registered",
                    "profile_image": "https://lh3.googleusercontent.com/a/ACg8ocJXOtcirlAaql5UzVPGwBV-CQSla0aMTiFX1gy2NZoD=k-s256",
                    "display_name": "sigemer",
                    "link": "https://stackoverflow.com/users/23364953/sigemer"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1709050596,
                "post_id": 78068546,
                "comment_id": 137629599,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1709047316,
                "last_edit_date": 1709047316,
                "creation_date": 1709047060,
                "answer_id": 78068620,
                "question_id": 78068546,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The response is not valid JSON, because strings are not allowed to contain newlines. This is stated in https://www.ietf.org/rfc/rfc4627.txt:\r\n\r\n&gt; All Unicode characters may be placed within the    quotation marks\r\n&gt; except for the characters that must be escaped:    quotation mark,\r\n&gt; reverse solidus, and the control characters (U+0000    through\r\n&gt; U+001F).\r\n\r\nThe newline character needs to be escaped as `&quot;\\n&quot;`.\r\n\r\nThe reason you&#39;re getting newlines in the strings is probably because you&#39;re passing the `jq -r` flag (meaning &quot;Output raw strings, not JSON texts&quot;).",
                "title": "JQ / Bash How to handle whitespace in JSON response?"
            },
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1709048410,
                "creation_date": 1709048410,
                "answer_id": 78068773,
                "question_id": 78068546,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If there are actually newlines in the response then @k314159 is correct and you need to fix that in the response. If the output you provided is the result of `echo $check` though then you have a different problem - word splitting is breaking your `for` loop.\r\n\r\nLet&#39;s say the output of `$(echo &quot;$checksResponse&quot; | jq -r -c &#39;.value[]&#39;)` is simply: `{&quot;configuration&quot;:{&quot;createdBy&quot;:{&quot;displayName&quot;:&quot;John Smith&quot;}}}`. This is how bash is going to parse the `for` loop:\r\n\r\n`for` `check` `in` `{&quot;configuration&quot;:{&quot;createdBy&quot;:{&quot;displayName&quot;:&quot;John ` `Smith&quot;}}}`\r\n\r\nNotice that your JSON got split into two pieces - whitespace is used for word splitting after all. That means you&#39;re only passing partial JSON snippets to `jq` inside the loop and that will never work.\r\n\r\nThe simplest fix in this case is to do all your processing in one `jq` statement:\r\n\r\n```\r\nprintf &#39;%s&#39; &quot;$checksResponse&quot; | jq -r &#39;.value[].configuration.id&#39;\r\n```",
                "title": "JQ / Bash How to handle whitespace in JSON response?"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1709061470,
                "last_edit_date": 1709061470,
                "creation_date": 1709059004,
                "answer_id": 78069835,
                "question_id": 78068546,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Your question shouldn&#39;t be &quot;how to handle whitespace in a shell loop?&quot;, but your question should be &quot;how to extract a property based on another value from a JSON document?&quot; instead. You don&#39;t need a shell loop here, jq is perfectly capable of extracting objects (or values) based on a condition.\r\n\r\n```\r\njq -r --argjson id 173 &#39;.value[] | select(.configuration.id == $id).status&#39;\r\n```\r\n\r\n`--argjson` even allows you to capture values from &quot;outside&quot; in a variable to be then used in the jq program.",
                "title": "JQ / Bash How to handle whitespace in JSON response?"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 0,
        "last_activity_date": 1709061470,
        "creation_date": 1709046432,
        "last_edit_date": 1709050532,
        "question_id": 78068546,
        "body_markdown": "I&#39;m making calls to Azure DevOps API, and parsing the response with jq in a bash script. The JSON response contains whitespace in the form of new lines for some reason, and jq cannot handle and parse it. \r\n\r\nE.g., I&#39;m logging the response and it looks like this:\r\n\r\n    {&quot;configuration&quot;:{&quot;createdBy&quot;:{&quot;displayName&quot;:&quot;John\r\n\r\n\r\n\r\n    Smith&quot;,&quot;url&quot;:&quot;&quot;, ..... etc `\r\n\r\njq gives me errors like \r\n\r\njq: parse error: Unfinished string at EOF at line 2, column 0\r\njq: parse error: Invalid literal at line 2, column 0\r\n\r\nIt can&#39;t deal with the space between John and Smith\r\n\r\nHow can I clean this response up so that jq can handle it?\r\n\r\n\r\n\r\nMy script:\r\n\r\n    checksResponse=$(curl -s -H &quot;$headers&quot; -X GET &quot;$policyChecksUrl&quot;)\r\n    \r\n    for check in $(echo &quot;$checksResponse&quot; | jq -r -c &#39;.value[]&#39;); do\r\n        echo $check\r\n        $(echo &quot;$check&quot; | jq -r &#39;.configuration.id&#39;)\r\n    done\r\n\r\n\r\n\r\nMore complete response: I want to select an item by the id field, e.g. 174 and get the associated status field\r\n\r\n    {\r\n        &quot;value&quot;: [\r\n            {\r\n                &quot;configuration&quot;: {\r\n                    &quot;createdBy&quot;: {\r\n                        &quot;displayName&quot;: &quot;John Smith&quot;,\r\n                        &quot;url&quot;: &quot;https://url&quot;,\r\n                        &quot;_links&quot;: {\r\n                            &quot;avatar&quot;: {\r\n                                &quot;href&quot;: &quot;https://dev.azure.com/thecompany/_apis/GraphProfile/MemberAvatars/aad&quot;\r\n                            }\r\n                        },\r\n                        &quot;id&quot;: &quot;0eecda65-30dc-6b28-b497-8411e97df5b6&quot;,\r\n                        &quot;uniqueName&quot;: &quot;js@thecompany.com&quot;,\r\n                        &quot;imageUrl&quot;: &quot;https://dev.azure.com/thecompany/_api/_common/&quot;,\r\n                        &quot;descriptor&quot;: &quot;aad.MGVlY2RhNjUtMzBkYy03YjI4LWI0OTctODQxMWU5N2RmNWI2&quot;\r\n                    },\r\n                    &quot;createdDate&quot;: &quot;2023-01-10T14:52:24.7359941Z&quot;,\r\n                    &quot;isEnabled&quot;: true,\r\n                    &quot;isBlocking&quot;: true,\r\n                    &quot;isDeleted&quot;: false,\r\n                    &quot;settings&quot;: {\r\n                        &quot;minimumApproverCount&quot;: 2,\r\n                        &quot;creatorVoteCounts&quot;: false,\r\n                        &quot;allowDownvotes&quot;: false,\r\n                        &quot;resetOnSourcePush&quot;: false,\r\n                        &quot;requireVoteOnLastIteration&quot;: true,\r\n                        &quot;resetRejectionsOnSourcePush&quot;: false,\r\n                        &quot;blockLastPusherVote&quot;: false,\r\n                        &quot;scope&quot;: [\r\n                            {\r\n                                &quot;refName&quot;: &quot;refs/heads/master&quot;,\r\n                                &quot;matchKind&quot;: &quot;Exact&quot;,\r\n                                &quot;repositoryId&quot;: &quot;d416904f-641b-470a-9d&quot;\r\n                            }\r\n                        ]\r\n                    },\r\n                    &quot;isEnterpriseManaged&quot;: false,\r\n                    &quot;_links&quot;: {\r\n                        &quot;self&quot;: {\r\n                            &quot;href&quot;: &quot;https://dev.azure.com/thecompany/97f88eba-ecb2-484b-ae7c-c2d43a008cea/_apis/policy/configurations/173&quot;\r\n                        },\r\n                        &quot;policyType&quot;: {\r\n                            &quot;href&quot;: &quot;https://dev.azure.com/thecompany/97f88eba-ecb2fa4e907d-c16b-4a4c-9dfa-4906e5d171dd&quot;\r\n                        }\r\n                    },\r\n                    &quot;revision&quot;: 16,\r\n                    &quot;id&quot;: 173,\r\n                    &quot;url&quot;: &quot;https://dev.azure.com/thecompany/97f88eba-ecb2-484b-ae7c-c2d43a008cea/_apis/policy/configurations/173&quot;,\r\n                    &quot;type&quot;: {\r\n                        &quot;id&quot;: &quot;fa4e907d-c16b-171dd&quot;,\r\n                        &quot;url&quot;: &quot;https://dev.azure.com/thecompany/97f88eba-ecb2-484bc16b-4a4c-9dfa-4906e5d171dd&quot;,\r\n                        &quot;displayName&quot;: &quot;Minimum number of reviewers&quot;\r\n                    }\r\n                },\r\n                &quot;artifactId&quot;: &quot;vstfs:///CodeReview/CodeRev2f38956&quot;,\r\n                &quot;evaluationId&quot;: &quot;0c7b74ad661353ee2&quot;,\r\n                &quot;startedDate&quot;: &quot;2024-02-22T17:14:01.8987983Z&quot;,\r\n                &quot;status&quot;: &quot;queued&quot;,\r\n                &quot;context&quot;: {}\r\n            },\r\n            {\r\n                &quot;configuration&quot;: {\r\n                    &quot;createdBy&quot;: {\r\n                        &quot;displayName&quot;: &quot;Jon Snow&quot;,\r\n                        &quot;url&quot;: &quot;https://s-6ea05e3f7377&quot;,\r\n                        &quot;_links&quot;: {\r\n                            &quot;avatar&quot;: {\r\n                                &quot;href&quot;: &quot;https://dev.azure.com/thecompany/_apis/GraphProfile/MemberAvatars/aad.YzZhNGMDVlM2Y3Mzc3&quot;\r\n                            }\r\n                        },\r\n                        &quot;id&quot;: &quot;c6a4cf2d-0529-6a3d-88fb-6ea05e3f7377&quot;,\r\n                        &quot;uniqueName&quot;: &quot;jonsnow@thecompany.com&quot;,\r\n                        &quot;imageUrl&quot;: &quot;https://dev.azure.com/thecompany/_api/_common/identityIfb-6ea05e3f7377&quot;,\r\n                        &quot;descriptor&quot;: &quot;aad.YzZhNGNmVhMDVlM2Y3Mzc3&quot;\r\n                    },\r\n                    &quot;createdDate&quot;: &quot;2021-01-28T20:13:48.555187Z&quot;,\r\n                    &quot;isEnabled&quot;: true,\r\n                    &quot;isBlocking&quot;: true,\r\n                    &quot;isDeleted&quot;: false,\r\n                    &quot;settings&quot;: {\r\n                        &quot;requiredReviewerIds&quot;: [\r\n                            &quot;b4704bd8fb603d&quot;\r\n                        ],\r\n                        &quot;minimumApproverCount&quot;: 1,\r\n                        &quot;creatorVoteCounts&quot;: true,\r\n                        &quot;scope&quot;: [\r\n                            {\r\n                                &quot;refName&quot;: &quot;refs/heads/master&quot;,\r\n                                &quot;matchKind&quot;: &quot;Exact&quot;,\r\n                                &quot;repositoryId&quot;: &quot;d4169f-7210d2c5b1ad&quot;\r\n                            }\r\n                        ]\r\n                    },\r\n                    &quot;isEnterpriseManaged&quot;: false,\r\n                    &quot;_links&quot;: {\r\n                        &quot;self&quot;: {\r\n                            &quot;href&quot;: &quot;https://dev.azure.com/thecompany/97f88ebay/configurations/174&quot;\r\n                        },\r\n                        &quot;policyType&quot;: {\r\n                            &quot;href&quot;: &quot;https://dev.azure.com/thecompany/97f88eba-ecb2-8ec8-39368250530e&quot;\r\n                        }\r\n                    },\r\n                    &quot;revision&quot;: 1,\r\n                    &quot;id&quot;: 174,\r\n                    &quot;url&quot;: &quot;https://dev.azure.com/thecompany/97f88eba-ecb2-484b-acy/configurations/174&quot;,\r\n                    &quot;type&quot;: {\r\n                        &quot;id&quot;: &quot;fd2167ab-b0be68250530e&quot;,\r\n                        &quot;url&quot;: &quot;https://dev.azure.com/thecompany/97f88eba-ecb2-484b-ae7c-c2d43a008cea/_abe-447a-8ec8-39368250530e&quot;,\r\n                        &quot;displayName&quot;: &quot;Required reviewers&quot;\r\n                    }\r\n                },\r\n                &quot;artifactId&quot;: &quot;vstfs:///CodeReview/Ca%2f38956&quot;,\r\n                &quot;evaluationId&quot;: &quot;8a60f138-10c8-4838-81b4-031763798fdf&quot;,\r\n                &quot;startedDate&quot;: &quot;2024-02-22T17:12:38.7413814Z&quot;,\r\n                &quot;status&quot;: &quot;queued&quot;\r\n            }\r\n        ],\r\n        &quot;count&quot;: 2\r\n    }\r\n    ",
        "link": "https://stackoverflow.com/questions/78068546/jq-bash-how-to-handle-whitespace-in-json-response",
        "title": "JQ / Bash How to handle whitespace in JSON response?"
    },
    {
        "tags": [
            "json",
            "jq",
            "okta-api"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1709050860,
                "creation_date": 1709050860,
                "answer_id": 78069028,
                "question_id": 78068982,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The error is explicit: you&#39;re trying to use `&quot;id&quot;` to access an element of an array.\r\n\r\nIn the first case you use `&#39;.[] | .profile.authenticatorName&#39;` which is equivalent to &quot;map each element of the array to its sub property &#39;.profile.authenticatorName&#39;&quot;\r\n\r\nIn the second case you use `&#39;.id&#39;` which is &quot;extract the &#39;id&#39; property from the input&quot;.\r\n\r\nWhat you probably meant to use is **`&#39;.[] | .id&#39;`** which is &quot;map each element of the array to its property &#39;id&#39;&quot;",
                "title": "Grab top level json element with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1709050860,
        "creation_date": 1709050416,
        "question_id": 78068982,
        "body_markdown": "I can grab sub elements without an issue, but if i try top level element it fails, i was wondering if anyone knew the best way to grab the value for the ID element\r\n\r\nThis works to grab sub elements\r\n\r\n    AUTHENTICATOR_NAME=$(echo &quot;$RESPONSE2&quot; | jq &#39;.[] | .profile.authenticatorName&#39;)\r\n        \r\nThis does not work for grabbing the value of &quot;id&quot; at a higher level, it returns &quot;jq: error (at &lt;stdin&gt;:1): Cannot index array with string &quot;id&quot;\r\n\r\n    FACTOR_ID=$(echo &quot;$RESPONSE2&quot; | jq -r &#39;.id&#39;)\r\n\r\n\r\n        [\r\n        {\r\n            &quot;id&quot;: &quot;xxxxxxxxxxx1111111111&quot;,\r\n            &quot;factorType&quot;: &quot;webauthn&quot;,\r\n            &quot;provider&quot;: &quot;FIDO&quot;,\r\n            &quot;vendorName&quot;: &quot;FIDO&quot;,\r\n            &quot;status&quot;: &quot;ACTIVE&quot;,\r\n            &quot;created&quot;: &quot;2024-01-31T19:38:50.000Z&quot;,\r\n            &quot;lastVerified&quot;: &quot;2024-02-27T13:28:19.000Z&quot;,\r\n            &quot;lastUpdated&quot;: &quot;2024-01-31T19:38:50.000Z&quot;,\r\n            &quot;profile&quot;: {\r\n                &quot;credentialId&quot;: &quot;xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx&quot;,\r\n                &quot;appId&quot;: null,\r\n                &quot;version&quot;: null,\r\n                &quot;authenticatorName&quot;: &quot;YubiKey 5&quot;,\r\n                &quot;presetPinAvailable&quot;: null,\r\n                &quot;fulfillmentProvider&quot;: null\r\n\r\n\r\n\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/78068982/grab-top-level-json-element-with-jq",
        "title": "Grab top level json element with jq"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1709140714,
                "creation_date": 1709140714,
                "answer_id": 78076448,
                "question_id": 78076363,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "This worked:\r\n\r\n    .[] |select(.name|test(&quot;^env&quot;))|&quot;\\(.name) = \\(.value)&quot;",
                "title": "jq filter objects based on value of a property (not key)"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1709872873,
                "creation_date": 1709872873,
                "answer_id": 78125578,
                "question_id": 78076363,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "```sh\r\necho $data | jq -r &#39;.[]|&quot;\\(.name)=\\(.value|@json)&quot;|select(test(&quot;^env\\\\.&quot;))&#39;\r\n\r\necho $data | jq -r &#39;.[]|select(.name|test(&quot;^env\\\\.&quot;))|&quot;\\(.name)=\\(.value|@json)&quot;&#39; \r\n```\r\n\r\n* You need to escape the periods in `test()` with 2 backslashes\r\n* Use `@json` to double quote .value or `@sh` for single quote\r\n\r\n```sh\r\n# fyi the data you provided has missing commas and brackets\r\ndata=&#39;[{&quot;name&quot;:&quot;Genus&quot;,&quot;value&quot;:&quot;canis&quot;},{&quot;name&quot;:&quot;env.VAR1&quot;,&quot;value&quot;:&quot;dogsdrool&quot;},{&quot;name&quot;:&quot;env.VAR2&quot;,&quot;value&quot;:&quot;catsrule&quot;}]&#39;\r\n\r\ntest1=&#39;{&quot;name&quot;:&quot;environment&quot;,&quot;value&quot;:&quot;nodot&quot;}&#39; \r\n\r\n# unescaped periods will include unwanted items\r\necho $data $test1 | jq -rs &#39;flatten[]|select(.name|test(&quot;^env.&quot;))|&quot;\\(.name)=\\(.value|@json)&quot;&#39; \r\n# env.VAR1=&quot;dogsdrool&quot;\r\n# env.VAR2=&quot;catsrule&quot;\r\n# environment=&quot;nodot&quot;\r\n\r\n# escaping with a single backslash will throw an error\r\necho $data | jq -rs &#39;flatten[]|select(.name|test(&quot;^env\\.&quot;))|&quot;\\(.name)=\\(.value|@json)&quot;&#39; \r\n```",
                "title": "jq filter objects based on value of a property (not key)"
            }
        ],
        "is_answered": false,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1709872873,
        "creation_date": 1709140005,
        "question_id": 78076363,
        "body_markdown": "I have a structure like this:\r\n\r\n    [\r\n      { &quot;name&quot;:&quot;Genus&quot;, &quot;value&quot;: &quot;canis&quot; }\r\n      { &quot;name&quot;:&quot;env.VAR1&quot;, &quot;value&quot;: &quot;dogsdrool&quot;\r\n      { &quot;name&quot;:&quot;env.VAR2&quot;, &quot;value&quot;: &quot;catsrule&quot; }\r\n    ]\r\n\r\nI want to select the objects where the value of the name property starts with &quot;env.&quot; (equivalently, where it matches the regex `&quot;^env\\.&quot;`)\r\nand then concatenate the name property value with the value property value like this:\r\n\r\n    env.VAR1=&quot;dogsdrool&quot;\r\n    env.VAR2=&quot;catsrule&quot;\r\n\r\nFor the first part I&#39;ve flailed around with select and gotten basically nowhere. It seems like this should not be hard, but it eludes me.  This is *not* filtering based on key but on a property value.\r\n\r\nFor the second part I&#39;ve got this, which works well. I just can&#39;t figure out how to filter only the objects where the name property starts with `env.`\r\n\r\n    |&quot;\\(.name) = \\(.value)&quot;\r\n\r\n",
        "link": "https://stackoverflow.com/questions/78076363/jq-filter-objects-based-on-value-of-a-property-not-key",
        "title": "jq filter objects based on value of a property (not key)"
    },
    {
        "tags": [
            "yaml",
            "jq",
            "yq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1709171718,
                "last_edit_date": 1709171718,
                "creation_date": 1709154075,
                "answer_id": 78077571,
                "question_id": 78077341,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can use `with_entries` to modify each `.key` and `.value`. Or update each subitem `.[] |=` by modifying `key` and the context as value. Then, use `sub` with `&quot;&quot;` in the second argument to remove substrings by regex:\r\n\r\n```sh\r\nyq -oj &#39;.content.images | with_entries(\r\n  .key = .value.image | .value |= [.layers[].digest | sub(&quot;^sha256:&quot;, &quot;&quot;)]\r\n)&#39;\r\n\r\n# or\r\n\r\nyq -oj &#39;.content.images | .[] |= (\r\n  key = .image | [.layers[].digest | sub(&quot;^sha256:&quot;, &quot;&quot;)]\r\n)&#39;\r\n```\r\n```json\r\n{\r\n  &quot;image1&quot;: [\r\n    &quot;8ece9ac45f2b7228b2ed95e9f407b4f0dc2ac74f93c62ff1156f24c53042ba54&quot;\r\n  ],\r\n  &quot;image2&quot;: [\r\n    &quot;8ece9ac45f2b7228b2ed95e9f407b4f0dc2ac74f93c62ff1156f24c53042ba54&quot;,\r\n    &quot;8ece9ac45f2b7228b2ed95e9f407b4f0dc2ac74f93c62ff1156f24c53042ba5h&quot;,\r\n    &quot;8ece9ac45f2b7228b2ed95e9f407b4f0dc2ac74f93c62ff1156f24c53042ba6u&quot;\r\n  ],\r\n  &quot;image3&quot;: [\r\n    &quot;8ece9ac45f2b7228b2ed95e9f407b4f0dc2ac74f93c62ff1156f24c53042ba54&quot;\r\n  ]\r\n}\r\n```",
                "title": "yq traverse complex values and convert to json file"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1709185215,
        "creation_date": 1709151346,
        "last_edit_date": 1709185215,
        "question_id": 78077341,
        "body_markdown": "I have a complex yaml and want to extract information from it using bash script.\r\n\r\nThe yaml is like:\r\n```\r\ncontent:\r\n  images:\r\n    sha256:4c8b96d4fffdfae29258d94a22ae4ad1fe36139d47288b8960d9958d1e63a9d0:\r\n      annotations:\r\n        kbld.carvel.dev/id: index.docker.io/dkalinin/k8s-simple-app\r\n        kbld.carvel.dev/origins: |\r\n          - resolved:\r\n              tag: latest\r\n              url: index.docker.io/dkalinin/k8s-simple-app\r\n      image: image1\r\n      imageType: Image\r\n      layers:\r\n      - digest: sha256:8ece9ac45f2b7228b2ed95e9f407b4f0dc2ac74f93c62ff1156f24c53042ba54\r\n      origin: index.docker.io/dkalinin/k8s-simple-app@sha256:4c8b96d4fffdfae29258d94a22ae4ad1fe36139d47288b8960d9958d1e63a9d0\r\n    sha256:4c8b96d4fffdfae29258d94a22ae4ad1fe36139d47288b8960d9958d1e63a9d1:\r\n      annotations:\r\n        kbld.carvel.dev/id: index.docker.io/dkalinin/k8s-simple-app\r\n        kbld.carvel.dev/origins: |\r\n          - resolved:\r\n              tag: latest\r\n              url: index.docker.io/dkalinin/k8s-simple-app\r\n      image: image2\r\n      imageType: Image\r\n      layers:\r\n      - digest: sha256:8ece9ac45f2b7228b2ed95e9f407b4f0dc2ac74f93c62ff1156f24c53042ba54\r\n      - digest: sha256:8ece9ac45f2b7228b2ed95e9f407b4f0dc2ac74f93c62ff1156f24c53042ba5h\r\n      - digest: sha256:8ece9ac45f2b7228b2ed95e9f407b4f0dc2ac74f93c62ff1156f24c53042ba6u\r\n      origin: index.docker.io/dkalinin/k8s-simple-app@sha256:4c8b96d4fffdfae29258d94a22ae4ad1fe36139d47288b8960d9958d1e63a9d0\r\n    sha256:4c8b96d4fffdfae29258d94a22ae4ad1fe36139d47288b8960d9958d1e63a9d2:\r\n      annotations:\r\n        kbld.carvel.dev/id: index.docker.io/dkalinin/k8s-simple-app\r\n        kbld.carvel.dev/origins: |\r\n          - resolved:\r\n              tag: latest\r\n              url: index.docker.io/dkalinin/k8s-simple-app\r\n      image: image3\r\n      imageType: Image\r\n      layers:\r\n      - digest: sha256:8ece9ac45f2b7228b2ed95e9f407b4f0dc2ac74f93c62ff1156f24c53042ba54\r\n      origin: index.docker.io/dkalinin/k8s-simple-app@sha256:4c8b96d4fffdfae29258d94a22ae4ad1fe36139d47288b8960d9958d1e63a9d0\r\n```\r\n\r\nThe expected result is:\r\n```\r\n{\r\n&quot;image1&quot;:\r\n [&quot;8ece9ac45f2b7228b2ed95e9f407b4f0dc2ac74f93c62ff1156f24c53042ba54&quot;], \r\n&quot;image2&quot;: \r\n  [&quot;8ece9ac45f2b7228b2ed95e9f407b4f0dc2ac74f93c62ff1156f24c53042ba54&quot;, \r\n   &quot;8ece9ac45f2b7228b2ed95e9f407b4f0dc2ac74f93c62ff1156f24c53042ba5h&quot;, \r\n   &quot;8ece9ac45f2b7228b2ed95e9f407b4f0dc2ac74f93c62ff1156f24c53042ba6u&quot;], \r\n&quot;image3&quot;: \r\n  [&quot;8ece9ac45f2b7228b2ed95e9f407b4f0dc2ac74f93c62ff1156f24c53042ba54&quot;]\r\n}\r\n```\r\n\r\nThe key `image1`, `image2`, `image3` are the `.content.images.image` value.\r\n\r\nThe value is the sha256 part of all digests in the Layers as a string list.\r\n\r\n\r\nWhat I tried is to first get all keys using `images=$(yq -r &#39;.content.images | keys&#39; file)`\r\nThen traverse the values using each key. But failed to traverse the values since the value is a complex one. Is there any simpler way to achieve this?\r\n\r\nI&#39;m using Go [yq][1]\r\n\r\n\r\n  [1]: https://mikefarah.gitbook.io/yq/",
        "link": "https://stackoverflow.com/questions/78077341/yq-traverse-complex-values-and-convert-to-json-file",
        "title": "yq traverse complex values and convert to json file"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1709200673,
                "post_id": 78080371,
                "comment_id": 137650284,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1709200858,
                "creation_date": 1709200858,
                "answer_id": 78080424,
                "question_id": 78080371,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Ok, I fixed my own problem. In contrast to the manual, you don&#39;t have to escape the quotes.\r\n\r\n```\r\n$ echo $msg | jq -r &#39;&quot;\\(.[&quot;@timestamp&quot;])&quot;&#39;\r\n2024-02-28T10:21:51.939Z\r\n\r\n$ echo $msg | jq -r &#39;&quot;\\(.[&quot;log.level&quot;])&quot;&#39;\r\ninfo\r\n",
                "title": "Fieldnames with special characters in jq string interpolation"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1709868512,
                "last_edit_date": 1709868512,
                "creation_date": 1709866728,
                "answer_id": 78125332,
                "question_id": 78080371,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here are some ways:\r\n\r\n```sh\r\n# if you don&#39;t like working with blackslashes\r\necho $msg | jq -r &#39;[.[&quot;@timestamp&quot;,&quot;log.level&quot;,&quot;msg&quot;]]|join(&quot; - &quot;)&#39;         \r\n\r\n# if you want all the values (which in your case you do)\r\necho $msg | jq -r &#39;values|join(&quot; - &quot;)&#39;\r\n\r\n# to_entries if you want to manipulate value\r\necho $msg | jq -r &#39;to_entries|map(.value)|join(&quot; - &quot;)&#39;\r\necho $msg | jq -r &#39;to_entries|map(.value|ascii_upcase)|join(&quot; - &quot;)&#39;\r\n\r\n# without using map\r\necho $msg | jq -r &#39;[to_entries[].value]|join(&quot; - &quot;)&#39;\r\n```",
                "title": "Fieldnames with special characters in jq string interpolation"
            }
        ],
        "is_answered": false,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1709868512,
        "creation_date": 1709200456,
        "question_id": 78080371,
        "body_markdown": "I have a logfile with entries like this:\r\n\r\n```json\r\n{&quot;@timestamp&quot;:&quot;2024-02-28T10:21:51.939Z&quot;, &quot;log.level&quot;:&quot;info&quot;, &quot;msg&quot;: &quot;done&quot;}\r\n```\r\n\r\nI want to convert this json into something like this:\r\n\r\n```\r\n2024-02-28T10:21:51.939Z - info - done\r\n```\r\n\r\nThis is the output I get from my shell commands:\r\n\r\n```\r\n$ msg=&#39;{&quot;@timestamp&quot;:&quot;2024-02-28T10:21:51.939Z&quot;, &quot;log.level&quot;:&quot;info&quot;, &quot;msg&quot;: &quot;done&quot;}&#39;\r\n\r\n$ echo $msg | jq -r &#39;&quot;\\(.[\\&quot;log.level\\&quot;])&quot;&#39;\r\njq: error: syntax error, unexpected INVALID_CHARACTER (Unix shell quoting issues?) at &lt;top-level&gt;, line 1:\r\n&quot;\\(.[\\&quot;log.level\\&quot;])&quot;     \r\njq: 1 compile error\r\n\r\n$ echo $msg | jq -r &#39;&quot;\\(.msg)&quot;&#39;\r\ndone\r\n\r\n$ echo $msg | jq -r &#39;&quot;\\(.[\\&quot;@timestamp\\&quot;])&quot;&#39;\r\njq: error: syntax error, unexpected INVALID_CHARACTER (Unix shell quoting issues?) at &lt;top-level&gt;, line 1:\r\n&quot;\\(.[\\&quot;@timestamp\\&quot;])&quot;     \r\njq: 1 compile error\r\n\r\n$ echo $msg | jq -r &#39;&quot;\\(.@timestamp)&quot;&#39;\r\njq: error: syntax error, unexpected QQSTRING_INTERP_END, expecting QQSTRING_START (Unix shell quoting issues?) at &lt;top-level&gt;, line 1:\r\n&quot;\\(.@timestamp)&quot;              \r\njq: error: try .[&quot;field&quot;] instead of .field for unusually named fields at &lt;top-level&gt;, line 1:\r\n&quot;\\(.@timestamp)&quot;   \r\njq: 2 compile errors\r\n```\r\n\r\nI&#39;m using bash on Ubuntu. jq-1.6",
        "link": "https://stackoverflow.com/questions/78080371/fieldnames-with-special-characters-in-jq-string-interpolation",
        "title": "Fieldnames with special characters in jq string interpolation"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 6313442,
                    "reputation": 45115,
                    "user_id": 5625547,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/oqCND.jpg?s=256",
                    "display_name": "0stone0",
                    "link": "https://stackoverflow.com/users/5625547/0stone0"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1709288911,
                "post_id": 78087092,
                "comment_id": 137662898,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 6313442,
                    "reputation": 45115,
                    "user_id": 5625547,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/oqCND.jpg?s=256",
                    "display_name": "0stone0",
                    "link": "https://stackoverflow.com/users/5625547/0stone0"
                },
                "edited": false,
                "score": 3,
                "creation_date": 1709288934,
                "post_id": 78087092,
                "comment_id": 137662905,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 10013756,
                    "reputation": 207,
                    "user_id": 7405806,
                    "user_type": "registered",
                    "accept_rate": 80,
                    "profile_image": "https://i.sstatic.net/zRiSH.jpg?s=256",
                    "display_name": "Weili Gao",
                    "link": "https://stackoverflow.com/users/7405806/weili-gao"
                },
                "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": 1709291570,
                "post_id": 78087092,
                "comment_id": 137663314,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 6313442,
                    "reputation": 45115,
                    "user_id": 5625547,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/oqCND.jpg?s=256",
                    "display_name": "0stone0",
                    "link": "https://stackoverflow.com/users/5625547/0stone0"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1709295193,
                "post_id": 78087092,
                "comment_id": 137663879,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 130446,
                    "reputation": 8369,
                    "user_id": 4154375,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/QVkYF.png?s=256",
                    "display_name": "pjh",
                    "link": "https://stackoverflow.com/users/4154375/pjh"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1709295811,
                "post_id": 78087092,
                "comment_id": 137663990,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1709295331,
                "creation_date": 1709295331,
                "answer_id": 78087676,
                "question_id": 78087092,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "1. You should quote (`&quot;&quot;`) all bash variables that might contain a space\r\n    * &lt;https://stackoverflow.com/questions/10067266/when-to-wrap-quotes-around-a-shell-variable&gt;\r\n2. Prever `jq &#39;.&#39; &lt;&lt;&lt; &quot;$some_var&quot;` over using `echo $some_var | jq`\r\n    * [echo vs &lt;&lt;&lt;, or Useless Use of echo in Bash Award?](https://unix.stackexchange.com/questions/59007/echo-vs-or-useless-use-of-echo-in-bash-award)\r\n3. Use `readarray` to create a bash array of jq&#39;s output\r\n\r\n\r\n----------\r\n\r\n```bash\r\n#!/bin/bash\r\n\r\njson_response=&#39;{&quot;value&quot;:[{&quot;displayName&quot;:&quot;1&quot;},{&quot;displayName&quot;:&quot;2&quot;},{&quot;displayName&quot;:&quot;3&quot;},{&quot;displayName&quot;:&quot;Has Space&quot;}]}&#39;\r\n\r\nreadarray -t workspaces &lt; &lt;(jq -c &#39;.value[]&#39; &lt;&lt;&lt; &quot;$json_response&quot;)\r\n\r\nfor workspace in &quot;${workspaces[@]}&quot;; do\r\n    echo &quot;--&gt; $workspace &lt;--&quot;\r\ndone\r\n```\r\n\r\nGives the following on bash 4.4.20\r\n```none\r\n--&gt; {&quot;displayName&quot;:&quot;1&quot;} &lt;--\r\n--&gt; {&quot;displayName&quot;:&quot;2&quot;} &lt;--\r\n--&gt; {&quot;displayName&quot;:&quot;3&quot;} &lt;--\r\n--&gt; {&quot;displayName&quot;:&quot;Has Space&quot;} &lt;--\r\n```\r\n\r\n\r\n----------\r\n\r\n\r\nRegarding my _You should consider doing to loop work in jq tho_ comment;\r\n* You&#39;re already looping over the array in JQ, so why not use that to create the desired output so you don&#39;t need to capture the output in a bash array an looping over that, instead, convert all your magic to jq if possible",
                "title": "How to loop through a JSON array of objects in bash which includes space characters"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1709295425,
        "creation_date": 1709288768,
        "last_edit_date": 1709295425,
        "question_id": 78087092,
        "body_markdown": "I&#39;m calling an API which returns a JSON response that includes an array of objects. I would like to store the objects in an array in bash which I want to loop through.\r\n\r\nIt has worked for me to use `jq -c` to make use of the compact output:\r\n\r\n    json_response=&#39;{&quot;value&quot;:[{&quot;displayName&quot;:&quot;1&quot;},{&quot;displayName&quot;:&quot;2&quot;},{&quot;displayName&quot;:&quot;3&quot;}]}&#39;\r\n    \r\n    workspaces=$(echo $json_response | jq -c &#39;.value.[]&#39;)\r\n    \r\n    for workspace in ${workspaces[@]}; do\r\n        echo $workspace\r\n    done\r\n\r\nThis is the output:\r\n\r\n    {&quot;displayName&quot;:&quot;1&quot;}\r\n    {&quot;displayName&quot;:&quot;2&quot;}\r\n    {&quot;displayName&quot;:&quot;3&quot;}\r\n\r\nHowever, this doesn&#39;t work if there is a space character in the `displayName`:\r\n\r\n    json_response=&#39;{&quot;value&quot;:[{&quot;displayName&quot;:&quot;1&quot;},{&quot;displayName&quot;:&quot;2&quot;},{&quot;displayName&quot;:&quot;3&quot;},{&quot;displayName&quot;:&quot;Has Space&quot;}]}&#39;\r\n        \r\n    workspaces=$(echo $json_response | jq -c &#39;.value.[]&#39;)\r\n        \r\n    for workspace in ${workspaces[@]}; do\r\n        echo $workspace\r\n    done\r\nThe output then contains a line break where the space character was:\r\n\r\n    {&quot;displayName&quot;:&quot;1&quot;}\r\n    {&quot;displayName&quot;:&quot;2&quot;}\r\n    {&quot;displayName&quot;:&quot;3&quot;}\r\n    {&quot;displayName&quot;:&quot;Has\r\n    Space&quot;}\r\nHow can I still loop through the objects even if there is a space character?",
        "link": "https://stackoverflow.com/questions/78087092/how-to-loop-through-a-json-array-of-objects-in-bash-which-includes-space-charact",
        "title": "How to loop through a JSON array of objects in bash which includes space characters"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1709299346,
                "post_id": 78088034,
                "comment_id": 137664625,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 113371,
                    "reputation": 104439,
                    "user_id": 298607,
                    "user_type": "registered",
                    "accept_rate": 88,
                    "profile_image": "https://i.sstatic.net/DVW9g.jpg?s=256",
                    "display_name": "dawg",
                    "link": "https://stackoverflow.com/users/298607/dawg"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1709307092,
                "post_id": 78088034,
                "comment_id": 137666150,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 10015983,
                    "reputation": 144648,
                    "user_id": 9072753,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/EPmGy.jpg?s=256",
                    "display_name": "KamilCuk",
                    "link": "https://stackoverflow.com/users/9072753/kamilcuk"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1709307606,
                "post_id": 78088034,
                "comment_id": 137666243,
                "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": 1709311988,
                "post_id": 78088034,
                "comment_id": 137667100,
                "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": 1709312109,
                "post_id": 78088034,
                "comment_id": 137667123,
                "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": 1709312255,
                "post_id": 78088034,
                "comment_id": 137667151,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1709312906,
                "last_edit_date": 1709312906,
                "creation_date": 1709312590,
                "answer_id": 78089329,
                "question_id": 78088034,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Pipe from the `select` to code that does what you want with the output that passes it.\r\n\r\n```\r\njq --arg time &#39;2023-11-29T08:46:30.202778Z&#39; &#39;\r\n  .[].data.payload[] | select(.createdAt == $time) | .message\r\n&#39;\r\n```\r\n\r\nLoading your messages into a shell array _safely_, in a way that allows for messages that contain spaces, newlines, and other unexpected content (other than NUL literals) is maybe more involved. Using jq 1.7 or later:\r\n\r\n```\r\nmessages=( )\r\nwhile IFS= read -r -d &#39;&#39; message; do\r\n  messages+=( &quot;$message&quot; )\r\ndone &lt; &lt;(jq --raw-output0 --arg time &#39;2023-11-29T08:46:30.202778Z&#39; &#39;\r\n  .[].data.payload[]\r\n  | select(.createdAt == $time)\r\n  | .message\r\n&#39;)\r\n```\r\n\r\n...or, compatible with older versions of jq having `-j` but not `--raw-output0`:\r\n\r\n```\r\nmessages=( )\r\nwhile IFS= read -r -d &#39;&#39; message; do\r\n  messages+=( &quot;$message&quot; )\r\ndone &lt; &lt;(jq -j --arg time &#39;2023-11-29T08:46:30.202778Z&#39; &#39;\r\n  .[].data.payload[]\r\n  | select(.createdAt == $time)\r\n  | .message\r\n  | sub(&quot;\\u0000&quot;; &quot;&quot;)\r\n  | (., &quot;\\u0000&quot;)\r\n&#39;)\r\n```\r\n",
                "title": "Extract a field by the value of another field"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1709312906,
        "creation_date": 1709299153,
        "last_edit_date": 1709306319,
        "question_id": 78088034,
        "body_markdown": "I have the JSON file with that structure:\r\n\r\n```json\r\n[\r\n    {\r\n        &quot;id&quot;: &quot;6a6176c1-b879-8f66-6ccb-2532ec151589&quot;,\r\n        &quot;name&quot;: &quot;Name&quot;,\r\n        &quot;data&quot;: {\r\n            &quot;payload&quot;: [\r\n                {\r\n                    &quot;initiator&quot;: &quot;Manager&quot;,\r\n                    &quot;action&quot;: &quot;update&quot;,\r\n                    &quot;userId&quot;: &quot;user&quot;,\r\n                    &quot;createdAt&quot;: &quot;2023-11-29T08:46:30.202778Z&quot;,\r\n                    &quot;message&quot;: &quot;&lt;bulky message 1&gt;&quot;\r\n                },\r\n                {\r\n                    &quot;initiator&quot;: &quot;clusterManager&quot;,\r\n                    &quot;action&quot;: &quot;update&quot;,\r\n                    &quot;userId&quot;: &quot;user&quot;,\r\n                    &quot;createdAt&quot;: &quot;2023-11-29T08:46:30.202778Z&quot;,\r\n                    &quot;message&quot;: &quot;&lt;bulky message 2&gt;&quot;\r\n                }\r\n            ]\r\n        }\r\n    }\r\n]\r\n```\r\nI use the `jq` command to parse that JSON.\r\nI could obtain the `createdAt` field to put it into an array.\r\n\r\n```bash\r\nCHANGELOG_DATES=($(jq &#39;.[].data.payload[].createdAt&#39; /tmp/changelog.json))\r\n\r\necho ${CHANGELOG_DATES[@]}\r\n\r\n&quot;2023-11-29T08:46:30.202778Z&quot; &quot;2023-11-29T08:46:30.202778Z&quot;\r\n```\r\nBut I can&#39;t imagine how to select the `message` field by the `createdAt` field. If I select `&quot;2023-11-29T08:46:30.202778Z&quot;` I&#39;ll get `&lt;bulky message 1&gt;`.\r\n\r\nBut if try to use map I&#39;ll get an error\r\n\r\n```bash\r\njq &#39;.[].data.payload[].map(select(.type == &quot;2023-11-29T08:46:30.202778Z&quot;)&#39; /tmp/changelog.json\r\n\r\n.[].data.payload[].map(select(.type == &quot;2023-11-29T08:46:30.202778Z&quot;): Unknown host\r\nifconfig: `--help&#39; gives usage information.\r\n```\r\n\r\nSo I can&#39;t understand how to find a field by a value name. ",
        "link": "https://stackoverflow.com/questions/78088034/extract-a-field-by-the-value-of-another-field",
        "title": "Extract a field by the value of another field"
    },
    {
        "tags": [
            "python",
            "json",
            "performance",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 3597514,
                    "reputation": 122820,
                    "user_id": 3001761,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/feZwC.jpg?s=256",
                    "display_name": "jonrsharpe",
                    "link": "https://stackoverflow.com/users/3001761/jonrsharpe"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1709576657,
                "post_id": 78103339,
                "comment_id": 137692590,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 49492,
                    "reputation": 316217,
                    "user_id": 147356,
                    "user_type": "registered",
                    "accept_rate": 54,
                    "profile_image": "https://www.gravatar.com/avatar/b9506717d24256a090524dd5505d3207?s=256&d=identicon&r=PG",
                    "display_name": "larsks",
                    "link": "https://stackoverflow.com/users/147356/larsks"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1709577710,
                "post_id": 78103339,
                "comment_id": 137692734,
                "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": 1709585439,
                "post_id": 78103339,
                "comment_id": 137693814,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 40164,
                    "reputation": 10391,
                    "user_id": 116286,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/ec678dd3ac4b2243d150d591e748182e?s=256&d=identicon&r=PG",
                    "display_name": "jb.",
                    "link": "https://stackoverflow.com/users/116286/jb"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1709601422,
                "post_id": 78103339,
                "comment_id": 137695485,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 10251021,
                    "reputation": 118,
                    "user_id": 7565275,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/iQL9Q.jpg?s=256",
                    "display_name": "ma2tl",
                    "link": "https://stackoverflow.com/users/7565275/ma2tl"
                },
                "reply_to_user": {
                    "account_id": 49492,
                    "reputation": 316217,
                    "user_id": 147356,
                    "user_type": "registered",
                    "accept_rate": 54,
                    "profile_image": "https://www.gravatar.com/avatar/b9506717d24256a090524dd5505d3207?s=256&d=identicon&r=PG",
                    "display_name": "larsks",
                    "link": "https://stackoverflow.com/users/147356/larsks"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1711796637,
                "post_id": 78103339,
                "comment_id": 137948742,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1709580494,
                "creation_date": 1709580494,
                "answer_id": 78103626,
                "question_id": 78103339,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Not a tested solution (due to missing data) but I think the expression \r\n\r\n    nth(100000; fromstream(1|truncate_stream(inputs)))\r\n\r\ncreates 100000 objects and throws them away (except the last).\r\n\r\nThis expression should avoid that overhead and might be faster:\r\n\r\n    fromstream(1|truncate_stream( inputs | select(.[0][0] == 100000)))",
                "title": "Optimising object retrieval from a large JSON array using jq"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1709583573,
                "creation_date": 1709583573,
                "answer_id": 78103865,
                "question_id": 78103339,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If you want to do this repeatedly, you could create a prepared file of one item per line at the one-time cost of retrieving the last line, and then use that with external tools to perform the actual retrieval, which they can do faster as they only parse for the occurrences of a row delimiter (newline in this case). This way, the JSON parsing happens once only.\r\n\r\nFor example, using `sed` as the external tool:\r\n```sh\r\njq -c &#39;.[]&#39; &gt; lines    # slow, once only\r\n\r\nsed &#39;100000q;d&#39; lines  # fast, repeatable\r\n:\r\n```\r\n\r\nOr `awk`:\r\n```sh\r\njq -c &#39;.[]&#39; &gt; lines\r\n\r\nawk &#39;NR==100000 {print; exit}&#39; lines\r\n:\r\n```\r\n\r\n\r\nAfter that, you can use `jq` again to operate on the item(s) retrieved.",
                "title": "Optimising object retrieval from a large JSON array using jq"
            },
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1709611246,
                "last_edit_date": 1709611246,
                "creation_date": 1709599874,
                "answer_id": 78104791,
                "question_id": 78103339,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If you don&#39;t want to create an intermediary file or database (e.g. along the lines suggested by @pmf) but want something that&#39;s faster than `jq --stream`, then consider the &quot;[JSON Machine][1]&quot;-based command-line program named [jm][2] (or the similar Python-based program named `jm.py`). Assuming `input.json` contains a JSON array and you just want the 1000th item, you could write:\r\n\r\n    jm --limit 1000 input.json | sed -n &#39;$p&#39;\r\n\r\nor\r\n\r\n    jm.py --limit 1000 input.json | sed -n &#39;$p&#39;\r\n\r\n\r\nThe reason these should generally be (slightly?) faster than using `jq --stream` is that JSON Machine does precisely what is needed here: minimally parse the top-level array with a view to &quot;splatting&quot; it.\r\n \r\n---\r\nHere is a performance summary (in increasing order of u+s times) for a file, 1e7.json, consisting\r\nof an array of 1e7 objects:\r\n\r\n```\r\n                                       u+s(secs)         mrss\r\njm.py --limit 100000 | sed -n &#39;$p&#39;     1.16          15163392\r\njm --limit 100000 | sed -n &#39;$p&#39;        1.9           15532032\r\n\r\ngojq -n --stream ...skimpy...          2.54          10375168\r\njq -n --stream ...skimpy...            3.3            1826816\r\n\r\ngojq -n --stream ...                   4.47         189091840\r\njq -n --stream ...                     5.41           1843200\r\n\r\njsonpointer /99999                    17.8         4636860416\r\n```\r\n\r\nwhere `...` is the jq program:\r\n\r\n\r\n    nth(99999; fromstream( inputs|(.[0] |= .[1:]) | select(. != [[]]) ))\r\n##\r\n\r\nand the skimpy program is:\r\n```\r\nnth(99999; fromstream(1|tostream(inputs)))\r\n```\r\n\r\n---\r\nFor reference:\r\n```\r\n$ /usr/bin/time -lp jq length 1e7.json\r\n10000000\r\nuser 44.65\r\nsys 9.38\r\n          5196390400  maximum resident set size\r\n```\r\n---\r\nDisclosure: I am the author of the jm and jm.py scripts.\r\n\r\n  [1]: https://github.com/halaxa/json-machine\r\n  [2]: https://github.com/pkoppstein/jm",
                "title": "Optimising object retrieval from a large JSON array using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 1,
        "last_activity_date": 1709611246,
        "creation_date": 1709576363,
        "last_edit_date": 1709576604,
        "question_id": 78103339,
        "body_markdown": "I need to retrieve an object at a specific index from a massive JSON array. The array contains 2,000,000 objects and the file size is around 5GB.\r\n\r\nI&#39;ve experimented with various approaches using `jq` in combination with Python, but performance remains an issue. \r\nHere are some of the methods I&#39;ve tried:\r\n\r\n1. Direct indexing:\r\n\r\n    ```bash\r\n    jq -c &#39;.[100000]&#39; Movies.json\r\n    ```\r\n\r\n2. Slurping and indexing:\r\n\r\n    ```bash\r\n    jq --slurp &#39;.[0].[100000]&#39; Movies.json\r\n    ```\r\n\r\n3. Using `nth()`:\r\n\r\n    ```bash\r\n    jq -c &#39;nth(100000; .[])&#39; Movies.json\r\n    ```\r\n\r\nWhile these methods seem to work, they are too slow for my requirements. I&#39;ve also tried using streams, which significantly improves performance:\r\n\r\n```bash\r\njq -cn --stream &#39;nth(100000; fromstream(1|truncate_stream(inputs)))&#39; Movies.json\r\n```\r\n\r\nHowever, as the index increases, so does the retrieval time, which I suspect is due to how streaming operates.\r\n\r\nI understand that one option is to divide the file into chunks, but I&#39;d rather avoid creating additional files by doing so.\r\n\r\nJSON structure example:\r\n```json\r\n[\r\n    {\r\n        &quot;Item&quot;: {\r\n            &quot;Name&quot;: &quot;Darkest Legend&quot;,\r\n            &quot;Year&quot;: 1992,\r\n            &quot;Genre&quot;: [&quot;War&quot;],\r\n            &quot;Director&quot;: &quot;Sherill Eal Eisenberg&quot;,\r\n            &quot;Producer&quot;: &quot;Arabella Orth&quot;,\r\n            &quot;Screenplay&quot;: [&quot;Octavia Delmer&quot;],\r\n            &quot;Cast&quot;: [&quot;Johanna Azar&quot;, &quot;...&quot;],\r\n            &quot;Runtime&quot;: 161,\r\n            &quot;Rate&quot;: &quot;9.0&quot;,\r\n            &quot;Description&quot;: &quot;Robin Northrop Cymbre&quot;,\r\n            &quot;Reviews&quot;: &quot;Gisela Seumas&quot;\r\n        },\r\n        &quot;Similars&quot;: [\r\n            {\r\n                &quot;Name&quot;: &quot;Smooth of Edge&quot;,\r\n                &quot;Year&quot;: 1985,\r\n                &quot;Genre&quot;: [&quot;Western&quot;],\r\n                &quot;Director&quot;: &quot;Vitoria Eustacia&quot;,\r\n                &quot;Producer&quot;: &quot;Auguste Jamaal Corry&quot;,\r\n                &quot;Screenplay&quot;: [&quot;Jaquenette Lance Gibe&quot;],\r\n                &quot;Cast&quot;: [&quot;Althea Nicole&quot;, &quot;...&quot;],\r\n                &quot;Runtime&quot;: 96,\r\n                &quot;Rate&quot;: &quot;6.5&quot;,\r\n                &quot;Description&quot;: &quot;Ashlan Grobe&quot;,\r\n                &quot;Reviews&quot;: &quot;Annnora Vasquez&quot;\r\n            }\r\n        ]\r\n    },\r\n    ...\r\n]\r\n\r\n```\r\n\r\nHow could I improve the efficiency of object retrieval from such a large array?",
        "link": "https://stackoverflow.com/questions/78103339/optimising-object-retrieval-from-a-large-json-array-using-jq",
        "title": "Optimising object retrieval from a large JSON array using jq"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 100740,
                    "reputation": 79490,
                    "user_id": 271415,
                    "user_type": "registered",
                    "accept_rate": 91,
                    "profile_image": "https://www.gravatar.com/avatar/8648256cc53b261c5e1d266380a256fc?s=256&d=identicon&r=PG",
                    "display_name": "jarmod",
                    "link": "https://stackoverflow.com/users/271415/jarmod"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1709580143,
                "post_id": 78103595,
                "comment_id": 137693041,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 30690952,
                    "reputation": 1,
                    "user_id": 23530529,
                    "user_type": "registered",
                    "profile_image": "https://lh3.googleusercontent.com/a/ACg8ocLfRyajufEtrtDcRMvzIY9gKaGm1HXMx8bF0xf_DmlA=k-s256",
                    "display_name": "Raghav Krishna",
                    "link": "https://stackoverflow.com/users/23530529/raghav-krishna"
                },
                "reply_to_user": {
                    "account_id": 100740,
                    "reputation": 79490,
                    "user_id": 271415,
                    "user_type": "registered",
                    "accept_rate": 91,
                    "profile_image": "https://www.gravatar.com/avatar/8648256cc53b261c5e1d266380a256fc?s=256&d=identicon&r=PG",
                    "display_name": "jarmod",
                    "link": "https://stackoverflow.com/users/271415/jarmod"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1709580324,
                "post_id": 78103595,
                "comment_id": 137693062,
                "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": 1709584714,
                "post_id": 78103595,
                "comment_id": 137693702,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 39208,
                    "reputation": 267964,
                    "user_id": 112968,
                    "user_type": "registered",
                    "accept_rate": 68,
                    "profile_image": "https://i.sstatic.net/zHTaT.png?s=256",
                    "display_name": "knittl",
                    "link": "https://stackoverflow.com/users/112968/knittl"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1709585500,
                "post_id": 78103595,
                "comment_id": 137693825,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 30690952,
                    "reputation": 1,
                    "user_id": 23530529,
                    "user_type": "registered",
                    "profile_image": "https://lh3.googleusercontent.com/a/ACg8ocLfRyajufEtrtDcRMvzIY9gKaGm1HXMx8bF0xf_DmlA=k-s256",
                    "display_name": "Raghav Krishna",
                    "link": "https://stackoverflow.com/users/23530529/raghav-krishna"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1709585742,
                "post_id": 78103595,
                "comment_id": 137693853,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 30690952,
                    "reputation": 1,
                    "user_id": 23530529,
                    "user_type": "registered",
                    "profile_image": "https://lh3.googleusercontent.com/a/ACg8ocLfRyajufEtrtDcRMvzIY9gKaGm1HXMx8bF0xf_DmlA=k-s256",
                    "display_name": "Raghav Krishna",
                    "link": "https://stackoverflow.com/users/23530529/raghav-krishna"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1709585808,
                "post_id": 78103595,
                "comment_id": 137693864,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1709587552,
                "last_edit_date": 1709587552,
                "creation_date": 1709580716,
                "answer_id": 78103649,
                "question_id": 78103595,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Not sure how it works on Windows, but on Linux, the following works:\r\n```\r\njq -r &#39;.Rows[] | split(&quot;\\t&quot;) | .[0]+&quot;,&quot;+.[1]&#39; &lt; file.json \r\n001-CARDIO-GRAN,1052\r\n01_MO_FIN,1148\r\n02_MO_S_PACK,1148\r\n```\r\nIt makes more sense to generate CSV instead which would double quote the strings:\r\n```\r\njq -r &#39;.Rows[] | split(&quot;\\t&quot;) | @csv&#39; &lt; file.json \r\n&quot;001-CARDIO-GRAN&quot;,&quot;1052&quot;\r\n&quot;01_MO_FIN&quot;,&quot;1148&quot;\r\n&quot;02_MO_S_PACK&quot;,&quot;1148&quot;\r\n```\r\n",
                "title": "Using jq to split"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1709587552,
        "creation_date": 1709580016,
        "last_edit_date": 1709584659,
        "question_id": 78103595,
        "body_markdown": "New to jq. I am using it on windows command line. I need to split an array from the input JSON into rows and further split the element of the array into columns based on the tab delimiter (\\t)\r\n\r\nExample:\r\n\r\nInput:\r\n\r\n```json\r\n{\r\n  &quot;ProcessId&quot;: &quot;5452&quot;,\r\n  &quot;TotalRows&quot;: 226171,\r\n  &quot;Rows&quot;: [\r\n    &quot;001-CARDIO-GRAN\\t1052&quot;,\r\n    &quot;01_MO_FIN\\t1148&quot;,\r\n    &quot;02_MO_S_PACK\\t1148&quot;\r\n  ]\r\n}\r\n```\r\n\r\nI need:\r\n\r\n```csv\r\nGRAN,1052\r\n01_MO_FIN,1148\r\n02_MO_S_PACK,1148\r\n```\r\n\r\nI tried this:\r\n\r\n```cmd\r\njq-win32 &quot;last(.[])&quot; output.json\r\n```\r\n\r\nAnd got\r\n\r\n```none\r\nGRAN\\t1052&quot;,\r\n&quot;01_MO_FIN\\t1148&quot;,\r\n&quot;02_MO_S_PACK\\t1148&quot;,\r\n```\r\n\r\nHow do I further pipe this to split to accomplish what I need.\r\n",
        "link": "https://stackoverflow.com/questions/78103595/using-jq-to-split",
        "title": "Using jq to split"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq",
            "echo"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 20241009,
                    "reputation": 79,
                    "user_id": 14844895,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/joCnC.png?s=256",
                    "display_name": "TheCyberFox",
                    "link": "https://stackoverflow.com/users/14844895/thecyberfox"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1709596244,
                "post_id": 78104546,
                "comment_id": 137695114,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 13789219,
                    "reputation": 53538,
                    "user_id": 9952196,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/cd1a3f93172eb89e221c98e35e6e22b3?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Shawn",
                    "link": "https://stackoverflow.com/users/9952196/shawn"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1709599334,
                "post_id": 78104546,
                "comment_id": 137695351,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 32384,
                    "reputation": 127026,
                    "user_id": 89817,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/df253c3b6533949ea94f31f328f3e769?s=256&d=identicon&r=PG",
                    "display_name": "Gordon Davisson",
                    "link": "https://stackoverflow.com/users/89817/gordon-davisson"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1709601637,
                "post_id": 78104546,
                "comment_id": 137695498,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 130446,
                    "reputation": 8369,
                    "user_id": 4154375,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/QVkYF.png?s=256",
                    "display_name": "pjh",
                    "link": "https://stackoverflow.com/users/4154375/pjh"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1709601815,
                "post_id": 78104546,
                "comment_id": 137695511,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1709648962,
                "last_edit_date": 1709648962,
                "creation_date": 1709617042,
                "answer_id": 78105512,
                "question_id": 78104546,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The issue that you are asking about is that the output of `$(echo $entry | jq -cr .fields[])` is being split on spaces, tabs and line feeds when passed to `for` (assuming the `IFS` env var has its default value). You want it to be split on line feeds only.\r\n\r\nAn easy way to fix that is to switch to using `read`.\r\n\r\nOther changes:\r\n\r\n* Fixed a slew of injection bugs. (Still assumes that all variables names are valid.)\r\n* `jq -cr &#39;.fields[]&#39;` is wrong since you do want JSON. (Thankfully, the incorrect `-r` was simply ignored.)\r\n* Different `echo` do different things. Best to avoid it in scripts to avoid surprises.\r\n* Replaced `sed -e &quot;s/ /_/g&quot;` with the use of `gsub( &quot; &quot;; &quot;_&quot; )` in the jq program.\r\n* Replaced `select( . != null )` with the shorter `values`.\r\n\r\nNot fixed: \r\n\r\n* The value of `$item` contains dashes, an unsuitable character for variable names.\r\n\r\n```bash\r\n#!/usr/bin/bash\r\n\r\n# to_shell_lit() - Creates a shell literal\r\n# Usage: shell_lit=&quot;$( to_shell_lit &quot;...&quot; )&quot;\r\nto_shell_lit() {\r\n   printf \\&#39;\r\n   printf %s &quot;$1&quot; | sed &quot;s/&#39;/&#39;\\\\\\\\&#39;&#39;/g&quot;\r\n   printf \\&#39;\r\n}\r\n\r\noutput_var() {\r\n   printf &#39;%s=%s\\n&#39; &quot;$1&quot; &quot;$( to_shell_lit &quot;$2&quot; )&quot;\r\n}\r\n\r\nexec &gt;GITHUB_ENV\r\n\r\nfor item in 55f8864a-ec88-410c-ab0e-8bee2119042a; do\r\n   entry=&#39;{&quot;passwordHistory&quot;:[{&quot;lastUsedDate&quot;:&quot;2024-02-23T17:10:59.343Z&quot;,&quot;password&quot;:&quot;versteckt_name-leerzeichen: versteckt_wert leerzeichen&quot;},{&quot;lastUsedDate&quot;:&quot;2024-02-23T17:10:59.343Z&quot;,&quot;password&quot;:&quot;TestPasswort&quot;},{&quot;lastUsedDate&quot;:&quot;2024-02-23T16:45:56.662Z&quot;,&quot;password&quot;:&quot;versteckt_name leerzeichen: versteckt_wert leerzeichen&quot;},{&quot;lastUsedDate&quot;:&quot;2024-02-23T16:28:04.951Z&quot;,&quot;password&quot;:&quot;versteckt_name: versteckt_wert&quot;}],&quot;revisionDate&quot;:&quot;2024-02-23T17:14:48.810Z&quot;,&quot;creationDate&quot;:&quot;2024-02-18T21:04:02.811Z&quot;,&quot;deletedDate&quot;:null,&quot;object&quot;:&quot;item&quot;,&quot;id&quot;:&quot;55f8864a-ec88-410c-ab0e-8bee2119042a&quot;,&quot;organizationId&quot;:null,&quot;folderId&quot;:null,&quot;type&quot;:1,&quot;reprompt&quot;:0,&quot;name&quot;:&quot;TestName&quot;,&quot;notes&quot;:&quot;notizen notizen1 notizen2&quot;,&quot;favorite&quot;:false,&quot;fields&quot;:[{&quot;name&quot;:&quot;benutzerdefiniert_name leerzeichen&quot;,&quot;value&quot;:&quot;benutzerdefiniert_wert leerzeichen&quot;,&quot;type&quot;:0,&quot;linkedId&quot;:null},{&quot;name&quot;:&quot;versteckt_name leerzeichen&quot;,&quot;value&quot;:&quot;versteckt_wert leerzeichen&quot;,&quot;type&quot;:1,&quot;linkedId&quot;:null},{&quot;name&quot;:&quot;bool_name leerzeichen&quot;,&quot;value&quot;:&quot;false&quot;,&quot;type&quot;:2,&quot;linkedId&quot;:null}],&quot;login&quot;:{&quot;fido2Credentials&quot;:[],&quot;uris&quot;:[],&quot;username&quot;:&quot;TestBenutzername leerzeichen&quot;,&quot;password&quot;:&quot;TestPasswort leerzeichen&quot;,&quot;totp&quot;:null,&quot;passwordRevisionDate&quot;:&quot;2024-02-23T17:10:59.343Z&quot;},&quot;collectionIds&quot;:[]}&#39;\r\n\r\n   output_var &quot;${item}_USERNAME&quot; &quot;$( printf %s &quot;$entry&quot; | jq -r &#39;.login.username&#39; )&quot;\r\n   output_var &quot;${item}_PASSWORD&quot; &quot;$( printf %s &quot;$entry&quot; | jq -r &#39;.login.password&#39; )&quot;\r\n   output_var &quot;${item}_NOTES&quot;    &quot;$( printf %s &quot;$entry&quot; | jq -r &#39;.notes | values&#39; )&quot;\r\n\r\n   printf %s &quot;$entry&quot; | jq -c &#39;.fields[]&#39; | while read -r field; do\r\n     field_name=$(  printf %s &quot;$field&quot; | jq -r &#39;.name | gsub( &quot; &quot;; &quot;_&quot; )&#39; )\r\n     field_value=$( printf %s &quot;$field&quot; | jq -r &#39;.value&#39; )\r\n     output_var &quot;${item}_FIELD_${field_name}&quot; &quot;$field_value&quot;\r\n   done\r\ndone\r\n```\r\n\r\nOutput:\r\n\r\n```sh\r\n55f8864a-ec88-410c-ab0e-8bee2119042a_USERNAME=&#39;TestBenutzername leerzeichen&#39;\r\n55f8864a-ec88-410c-ab0e-8bee2119042a_PASSWORD=&#39;TestPasswort leerzeichen&#39;\r\n55f8864a-ec88-410c-ab0e-8bee2119042a_NOTES=&#39;notizen notizen1 notizen2&#39;\r\n55f8864a-ec88-410c-ab0e-8bee2119042a_FIELD_benutzerdefiniert_name_leerzeichen=&#39;benutzerdefiniert_wert leerzeichen&#39;\r\n55f8864a-ec88-410c-ab0e-8bee2119042a_FIELD_versteckt_name_leerzeichen=&#39;versteckt_wert leerzeichen&#39;\r\n55f8864a-ec88-410c-ab0e-8bee2119042a_FIELD_bool_name_leerzeichen=&#39;false&#39;\r\n```\r\n\r\n---\r\n\r\nBetter yet, just do everything in jq.\r\n\r\n```bash\r\n#!/usr/bin/bash\r\n\r\nexec &gt;GITHUB_ENV\r\n\r\nfor item in 55f8864a-ec88-410c-ab0e-8bee2119042a; do\r\n   entry=&#39;{&quot;passwordHistory&quot;:[{&quot;lastUsedDate&quot;:&quot;2024-02-23T17:10:59.343Z&quot;,&quot;password&quot;:&quot;versteckt_name-leerzeichen: versteckt_wert leerzeichen&quot;},{&quot;lastUsedDate&quot;:&quot;2024-02-23T17:10:59.343Z&quot;,&quot;password&quot;:&quot;TestPasswort&quot;},{&quot;lastUsedDate&quot;:&quot;2024-02-23T16:45:56.662Z&quot;,&quot;password&quot;:&quot;versteckt_name leerzeichen: versteckt_wert leerzeichen&quot;},{&quot;lastUsedDate&quot;:&quot;2024-02-23T16:28:04.951Z&quot;,&quot;password&quot;:&quot;versteckt_name: versteckt_wert&quot;}],&quot;revisionDate&quot;:&quot;2024-02-23T17:14:48.810Z&quot;,&quot;creationDate&quot;:&quot;2024-02-18T21:04:02.811Z&quot;,&quot;deletedDate&quot;:null,&quot;object&quot;:&quot;item&quot;,&quot;id&quot;:&quot;55f8864a-ec88-410c-ab0e-8bee2119042a&quot;,&quot;organizationId&quot;:null,&quot;folderId&quot;:null,&quot;type&quot;:1,&quot;reprompt&quot;:0,&quot;name&quot;:&quot;TestName&quot;,&quot;notes&quot;:&quot;notizen notizen1 notizen2&quot;,&quot;favorite&quot;:false,&quot;fields&quot;:[{&quot;name&quot;:&quot;benutzerdefiniert_name leerzeichen&quot;,&quot;value&quot;:&quot;benutzerdefiniert_wert leerzeichen&quot;,&quot;type&quot;:0,&quot;linkedId&quot;:null},{&quot;name&quot;:&quot;versteckt_name leerzeichen&quot;,&quot;value&quot;:&quot;versteckt_wert leerzeichen&quot;,&quot;type&quot;:1,&quot;linkedId&quot;:null},{&quot;name&quot;:&quot;bool_name leerzeichen&quot;,&quot;value&quot;:&quot;false&quot;,&quot;type&quot;:2,&quot;linkedId&quot;:null}],&quot;login&quot;:{&quot;fido2Credentials&quot;:[],&quot;uris&quot;:[],&quot;username&quot;:&quot;TestBenutzername leerzeichen&quot;,&quot;password&quot;:&quot;TestPasswort leerzeichen&quot;,&quot;totp&quot;:null,&quot;passwordRevisionDate&quot;:&quot;2024-02-23T17:10:59.343Z&quot;},&quot;collectionIds&quot;:[]}&#39;\r\n\r\n   printf %s &quot;$entry&quot; | jq -r --arg item &quot;$item&quot; &#39;\r\n      &quot;\\( $item )_USERNAME=\\( .login.username | @sh )&quot;,\r\n      &quot;\\( $item )_PASSWORD=\\( .login.password | @sh )&quot;,\r\n      &quot;\\( $item )_NOTES=\\(    .notes // &quot;&quot;    | @sh )&quot;,\r\n      (\r\n         .fields[] |\r\n         ( .name | gsub( &quot; &quot;; &quot;_&quot; ) ) as $field_name  |\r\n         ( .value                   ) as $field_value |\r\n         &quot;\\( $item )_FIELD_\\( $field_name )=\\( $field_value | @sh )&quot;\r\n      )\r\n   &#39;\r\ndone\r\n```\r\n\r\nOutput:\r\n\r\n```sh\r\n55f8864a-ec88-410c-ab0e-8bee2119042a_USERNAME=&#39;TestBenutzername leerzeichen&#39;\r\n55f8864a-ec88-410c-ab0e-8bee2119042a_PASSWORD=&#39;TestPasswort leerzeichen&#39;\r\n55f8864a-ec88-410c-ab0e-8bee2119042a_NOTES=&#39;notizen notizen1 notizen2&#39;\r\n55f8864a-ec88-410c-ab0e-8bee2119042a_FIELD_benutzerdefiniert_name_leerzeichen=&#39;benutzerdefiniert_wert leerzeichen&#39;\r\n55f8864a-ec88-410c-ab0e-8bee2119042a_FIELD_versteckt_name_leerzeichen=&#39;versteckt_wert leerzeichen&#39;\r\n55f8864a-ec88-410c-ab0e-8bee2119042a_FIELD_bool_name_leerzeichen=&#39;false&#39;\r\n```",
                "title": "JSON String processing injects quotes"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1709648962,
        "creation_date": 1709594438,
        "last_edit_date": 1709594539,
        "question_id": 78104546,
        "body_markdown": "I get json encoded secrets from a Vaulwarden-Instance by their UUID.\r\nI want so loop over any uuid and set environment variables accordingly.\r\n\r\nFor every field there should be variable (see below)\r\n\r\n```bash\r\nuuid_USERNAME=username\r\nuuid_PASSWORD=password\r\nuuid_FIELD_fieldname=fieldvalue\r\n...\r\n```\r\n\r\necho does inject single quotes so that the script breaks in the for loop ehich sets these field-based environment variables.\r\n\r\nCan anyone give me a hint on how to handle this situation?\r\n\r\nBest regards!\r\n\r\nHere is the script:\r\n\r\n```bash\r\n#!/bin/bash\r\nfor item in 55f8864a-ec88-410c-ab0e-8bee2119042a\r\ndo\r\n  entry=&#39;{&quot;passwordHistory&quot;:[{&quot;lastUsedDate&quot;:&quot;2024-02-23T17:10:59.343Z&quot;,&quot;password&quot;:&quot;versteckt_name-leerzeichen: versteckt_wert leerzeichen&quot;},{&quot;lastUsedDate&quot;:&quot;2024-02-23T17:10:59.343Z&quot;,&quot;password&quot;:&quot;TestPasswort&quot;},{&quot;lastUsedDate&quot;:&quot;2024-02-23T16:45:56.662Z&quot;,&quot;password&quot;:&quot;versteckt_name leerzeichen: versteckt_wert leerzeichen&quot;},{&quot;lastUsedDate&quot;:&quot;2024-02-23T16:28:04.951Z&quot;,&quot;password&quot;:&quot;versteckt_name: versteckt_wert&quot;}],&quot;revisionDate&quot;:&quot;2024-02-23T17:14:48.810Z&quot;,&quot;creationDate&quot;:&quot;2024-02-18T21:04:02.811Z&quot;,&quot;deletedDate&quot;:null,&quot;object&quot;:&quot;item&quot;,&quot;id&quot;:&quot;55f8864a-ec88-410c-ab0e-8bee2119042a&quot;,&quot;organizationId&quot;:null,&quot;folderId&quot;:null,&quot;type&quot;:1,&quot;reprompt&quot;:0,&quot;name&quot;:&quot;TestName&quot;,&quot;notes&quot;:&quot;notizen notizen1 notizen2&quot;,&quot;favorite&quot;:false,&quot;fields&quot;:[{&quot;name&quot;:&quot;benutzerdefiniert_name leerzeichen&quot;,&quot;value&quot;:&quot;benutzerdefiniert_wert leerzeichen&quot;,&quot;type&quot;:0,&quot;linkedId&quot;:null},{&quot;name&quot;:&quot;versteckt_name leerzeichen&quot;,&quot;value&quot;:&quot;versteckt_wert leerzeichen&quot;,&quot;type&quot;:1,&quot;linkedId&quot;:null},{&quot;name&quot;:&quot;bool_name leerzeichen&quot;,&quot;value&quot;:&quot;false&quot;,&quot;type&quot;:2,&quot;linkedId&quot;:null}],&quot;login&quot;:{&quot;fido2Credentials&quot;:[],&quot;uris&quot;:[],&quot;username&quot;:&quot;TestBenutzername leerzeichen&quot;,&quot;password&quot;:&quot;TestPasswort leerzeichen&quot;,&quot;totp&quot;:null,&quot;passwordRevisionDate&quot;:&quot;2024-02-23T17:10:59.343Z&quot;},&quot;collectionIds&quot;:[]}&#39;\r\n  echo $entry\r\n  echo ${item}_USERNAME=$(echo ${entry} | jq -r &quot;.login.username&quot;)  &gt; GITHUB_ENV\r\n  echo ${item}_PASSWORD=$(echo $entry | jq -r &quot;.login.password&quot;)  &gt;&gt; GITHUB_ENV\r\n  echo ${item}_NOTES=$(echo $entry | jq -r &quot;.notes | select( . != null )&quot;) &gt;&gt; GITHUB_ENV\r\n  for field in $(echo $entry | jq -cr .fields[])\r\n  do\r\n    echo $field\r\n    field_name=$(echo $field | jq -r &quot;.name&quot; | sed -e &quot;s/ /_/g&quot;)\r\n    field_value=$(echo $field | jq -r &quot;.value&quot;)\r\n    echo ${item}_FIELD_${field_name}=${field_value} &gt;&gt; GITHUB_ENV\r\n  done\r\ndone\r\n```\r\n\r\nHere is the JSON in pretty:\r\n\r\n```\r\n{\r\n  &quot;passwordHistory&quot;: [\r\n    {\r\n      &quot;lastUsedDate&quot;: &quot;2024-02-23T17:10:59.343Z&quot;,\r\n      &quot;password&quot;: &quot;versteckt_name-leerzeichen: versteckt_wert leerzeichen&quot;\r\n    },\r\n    {\r\n      &quot;lastUsedDate&quot;: &quot;2024-02-23T17:10:59.343Z&quot;,\r\n      &quot;password&quot;: &quot;TestPasswort&quot;\r\n    },\r\n    {\r\n      &quot;lastUsedDate&quot;: &quot;2024-02-23T16:45:56.662Z&quot;,\r\n      &quot;password&quot;: &quot;versteckt_name leerzeichen: versteckt_wert leerzeichen&quot;\r\n    },\r\n    {\r\n      &quot;lastUsedDate&quot;: &quot;2024-02-23T16:28:04.951Z&quot;,\r\n      &quot;password&quot;: &quot;versteckt_name: versteckt_wert&quot;\r\n    }\r\n  ],\r\n  &quot;revisionDate&quot;: &quot;2024-02-23T17:14:48.810Z&quot;,\r\n  &quot;creationDate&quot;: &quot;2024-02-18T21:04:02.811Z&quot;,\r\n  &quot;deletedDate&quot;: null,\r\n  &quot;object&quot;: &quot;item&quot;,\r\n  &quot;id&quot;: &quot;55f8864a-ec88-410c-ab0e-8bee2119042a&quot;,\r\n  &quot;organizationId&quot;: null,\r\n  &quot;folderId&quot;: null,\r\n  &quot;type&quot;: 1,\r\n  &quot;reprompt&quot;: 0,\r\n  &quot;name&quot;: &quot;TestName&quot;,\r\n  &quot;notes&quot;: &quot;notizen notizen1 notizen2&quot;,\r\n  &quot;favorite&quot;: false,\r\n  &quot;fields&quot;: [\r\n    {\r\n      &quot;name&quot;: &quot;benutzerdefiniert_name leerzeichen&quot;,\r\n      &quot;value&quot;: &quot;benutzerdefiniert_wert leerzeichen&quot;,\r\n      &quot;type&quot;: 0,\r\n      &quot;linkedId&quot;: null\r\n    },\r\n    {\r\n      &quot;name&quot;: &quot;versteckt_name leerzeichen&quot;,\r\n      &quot;value&quot;: &quot;versteckt_wert leerzeichen&quot;,\r\n      &quot;type&quot;: 1,\r\n      &quot;linkedId&quot;: null\r\n    },\r\n    {\r\n      &quot;name&quot;: &quot;bool_name leerzeichen&quot;,\r\n      &quot;value&quot;: &quot;false&quot;,\r\n      &quot;type&quot;: 2,\r\n      &quot;linkedId&quot;: null\r\n    }\r\n  ],\r\n  &quot;login&quot;: {\r\n    &quot;fido2Credentials&quot;: [],\r\n    &quot;uris&quot;: [],\r\n    &quot;username&quot;: &quot;TestBenutzername leerzeichen&quot;,\r\n    &quot;password&quot;: &quot;TestPasswort leerzeichen&quot;,\r\n    &quot;totp&quot;: null,\r\n    &quot;passwordRevisionDate&quot;: &quot;2024-02-23T17:10:59.343Z&quot;\r\n  },\r\n  &quot;collectionIds&quot;: []\r\n}\r\n```\r\n\r\nHere is the output:\r\n\r\n```bash\r\n55f8864a-ec88-410c-ab0e-8bee2119042a_USERNAME=TestBenutzername leerzeichen\r\n55f8864a-ec88-410c-ab0e-8bee2119042a_PASSWORD=TestPasswort leerzeichen\r\n55f8864a-ec88-410c-ab0e-8bee2119042a_NOTES=notizen notizen1 notizen2\r\n{&quot;name&quot;:&quot;benutzerdefiniert_name\r\njq: parse error: Unfinished string at EOF at line 2, column 0\r\njq: parse error: Unfinished string at EOF at line 2, column 0\r\n55f8864a-ec88-410c-ab0e-8bee2119042a_FIELD_=\r\nleerzeichen&quot;,&quot;value&quot;:&quot;benutzerdefiniert_wert\r\njq: parse error: Invalid numeric literal at line 1, column 12\r\njq: parse error: Invalid numeric literal at line 1, column 12\r\n55f8864a-ec88-410c-ab0e-8bee2119042a_FIELD_=\r\nleerzeichen&quot;,&quot;type&quot;:0,&quot;linkedId&quot;:null}\r\njq: parse error: Invalid numeric literal at line 1, column 12\r\njq: parse error: Invalid numeric literal at line 1, column 12\r\n55f8864a-ec88-410c-ab0e-8bee2119042a_FIELD_=\r\n{&quot;name&quot;:&quot;versteckt_name\r\njq: parse error: Unfinished string at EOF at line 2, column 0\r\njq: parse error: Unfinished string at EOF at line 2, column 0\r\n55f8864a-ec88-410c-ab0e-8bee2119042a_FIELD_=\r\nleerzeichen&quot;,&quot;value&quot;:&quot;versteckt_wert\r\njq: parse error: Invalid numeric literal at line 1, column 12\r\njq: parse error: Invalid numeric literal at line 1, column 12\r\n55f8864a-ec88-410c-ab0e-8bee2119042a_FIELD_=\r\nleerzeichen&quot;,&quot;type&quot;:1,&quot;linkedId&quot;:null}\r\njq: parse error: Invalid numeric literal at line 1, column 12\r\njq: parse error: Invalid numeric literal at line 1, column 12\r\n55f8864a-ec88-410c-ab0e-8bee2119042a_FIELD_=\r\n{&quot;name&quot;:&quot;bool_name\r\njq: parse error: Unfinished string at EOF at line 2, column 0\r\njq: parse error: Unfinished string at EOF at line 2, column 0\r\n55f8864a-ec88-410c-ab0e-8bee2119042a_FIELD_=\r\nleerzeichen&quot;,&quot;value&quot;:&quot;false&quot;,&quot;type&quot;:2,&quot;linkedId&quot;:null}\r\njq: parse error: Invalid numeric literal at line 1, column 12\r\njq: parse error: Invalid numeric literal at line 1, column 12\r\n55f8864a-ec88-410c-ab0e-8bee2119042a_FIELD_=\r\n```\r\n\r\nI tried executing this script and tried different methods e.g. `echo &lt;&lt;&lt; $entry` or piping the output into files and then cat-ing them which didn&#39;t do the trick.\r\n\r\nThe variables should be set like mentioned in the text above.",
        "link": "https://stackoverflow.com/questions/78104546/json-string-processing-injects-quotes",
        "title": "JSON String processing injects quotes"
    },
    {
        "tags": [
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1709654077,
                "post_id": 78104993,
                "comment_id": 137703007,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 673865,
                    "reputation": 5739,
                    "user_id": 889053,
                    "user_type": "registered",
                    "accept_rate": 38,
                    "profile_image": "https://www.gravatar.com/avatar/3e26b08aa9c9bff40d6dab7b98680bf4?s=256&d=identicon&r=PG",
                    "display_name": "Christian Bongiorno",
                    "link": "https://stackoverflow.com/users/889053/christian-bongiorno"
                },
                "reply_to_user": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1709676759,
                "post_id": 78104993,
                "comment_id": 137706596,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1709605472,
                "creation_date": 1709605472,
                "answer_id": 78105022,
                "question_id": 78104993,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "key expressions at top level need parenthesis:\r\n\r\nThis should work:\r\n\r\n```bash\r\nexport USERNAME=joe\r\nexport PASSWORD=whatever\r\nexport DOCKER_REGISTRY=&quot;hub.docker.io&quot;\r\njq -n --arg reg &quot;${DOCKER_REGISTRY}&quot; \\\r\n        --arg u &quot;$USERNAME&quot; \\\r\n        --arg p &quot;${PASSWORD}&quot; \\\r\n        --arg auth &quot;$(echo &quot;$USERNAME:$PASSWORD&quot; | base64)&quot; \\\r\n        &#39;{\r\n          &quot;auths&quot;: {\r\n            ($reg): {\r\n              &quot;username&quot;: $u,\r\n              &quot;password&quot;: $p,\r\n              &quot;auth&quot;: $auth\r\n            }\r\n          }\r\n        }&#39;\r\n```",
                "title": "How to use arg substitution in jq as a key"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1709949608,
                "creation_date": 1709949608,
                "answer_id": 78131006,
                "question_id": 78104993,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If you&#39;re already exporting your variables why not use `env`?\r\n\r\n```sh\r\nexport USERNAME=joe\r\nexport PASSWORD=whatever\r\nexport DOCKER_REGISTRY=&quot;hub.docker.io&quot;\r\n\r\njq -n &#39;{        \r\n  &quot;auths&quot;: {\r\n    &quot;\\(env.DOCKER_REGISTRY)&quot;: {\r\n      &quot;username&quot;: env.USERNAME,    \r\n      &quot;password&quot;: env.PASSWORD,\r\n      &quot;auth&quot;: (&quot;\\(env.USERNAME):\\(env.PASSWORD)&quot;|@base64) \r\n    }\r\n  }\r\n}&#39;\r\n```\r\n\r\nOutput\r\n```json\r\n{\r\n  &quot;auths&quot;: {\r\n    &quot;hub.docker.io&quot;: {\r\n      &quot;username&quot;: &quot;joe&quot;,\r\n      &quot;password&quot;: &quot;whatever&quot;,\r\n      &quot;auth&quot;: &quot;am9lOndoYXRldmVy&quot;\r\n    }\r\n  }\r\n}\r\n```\r\n\r\n",
                "title": "How to use arg substitution in jq as a key"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1709949608,
        "creation_date": 1709604710,
        "question_id": 78104993,
        "body_markdown": "I am trying to use an arg substitution with jq and one of the args needs to be a key.\r\nI have tried \r\n`$reg` - error\r\n\r\n`&quot;$reg&quot;` - no sub\r\n\r\n`\\$reg` - error\r\n\r\nCan this be done?\r\n\r\n```\r\nexport USERNAME=joe\r\nexport PASSWORD=whatever\r\nexport DOCKER_REGISTRY=&quot;hub.docker.io&quot;\r\njq -n --arg reg &quot;${DOCKER_REGISTRY}&quot; \\\r\n        --arg u &quot;$USERNAME&quot; \\\r\n        --arg p &quot;${PASSWORD}&quot; \\\r\n        --arg auth &quot;$(echo &quot;$USERNAME:$PASSWORD&quot; | base64)&quot; \\\r\n        &#39;{\r\n          &quot;auths&quot;: {\r\n            $reg: {\r\n              &quot;username&quot;: $u,\r\n              &quot;password&quot;: $p,\r\n              &quot;auth&quot;: $auth\r\n            }\r\n          }\r\n        }&#39;\r\n```",
        "link": "https://stackoverflow.com/questions/78104993/how-to-use-arg-substitution-in-jq-as-a-key",
        "title": "How to use arg substitution in jq as a key"
    },
    {
        "tags": [
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 6313442,
                    "reputation": 45115,
                    "user_id": 5625547,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/oqCND.jpg?s=256",
                    "display_name": "0stone0",
                    "link": "https://stackoverflow.com/users/5625547/0stone0"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1709651265,
                "post_id": 78108684,
                "comment_id": 137702456,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1709651953,
                "last_edit_date": 1709651953,
                "creation_date": 1709651248,
                "answer_id": 78108697,
                "question_id": 78108684,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Assuming all `.ID` values are unique, you could use the `INDEX` [function](https://jqlang.github.io/jq/manual/#sql-style-operators) (available since jq 1.6) which takes a stream and creates an object, using a given index, `.ID` in this case, as keys:\r\n```sh\r\njq &#39;INDEX(.Items[]; .ID)&#39; input.json\r\n```\r\n```json\r\n{\r\n  &quot;123abc&quot;: {\r\n    &quot;ID&quot;: &quot;123abc&quot;,\r\n    &quot;Name&quot;: &quot;test name&quot;,\r\n    &quot;Description&quot;: &quot;item 1&quot;\r\n  },\r\n  &quot;321zyx&quot;: {\r\n    &quot;ID&quot;: &quot;321zyx&quot;,\r\n    &quot;Name&quot;: &quot;test name two&quot;,\r\n    &quot;Description&quot;: &quot;item 2&quot;\r\n  }\r\n}\r\n```\r\n[Demo](https://jqplay.org/s/wYiIPiXLHvp)\r\n\r\nTo remove the `.ID` keys from the output, use `del` to update each key:\r\n```sh\r\njq &#39;INDEX(.Items[]; .ID) | .[] |= del(.ID)&#39;\r\n```\r\n```json\r\n{\r\n  &quot;123abc&quot;: {\r\n    &quot;Name&quot;: &quot;test name&quot;,\r\n    &quot;Description&quot;: &quot;item 1&quot;\r\n  },\r\n  &quot;321zyx&quot;: {\r\n    &quot;Name&quot;: &quot;test name two&quot;,\r\n    &quot;Description&quot;: &quot;item 2&quot;\r\n  }\r\n}\r\n```\r\n[Demo](https://jqplay.org/s/c7NwiixmAdC)\r\n\r\nIf you don&#39;t have the `INDEX` function, you could adapt from it from [jq&#39;s source](https://github.com/jqlang/jq/blob/ce0e788ce28c675808a6bc9a34f8db1199cd7cef/src/builtin.jq#L271C3-L271C63):\r\n```sh\r\njq &#39;reduce .Items[] as $i ({}; .[$i.ID|tostring] = $i)&#39; input.json\r\n# or\r\njq &#39;reduce .Items[] as $i ({}; .[$i.ID|tostring] = ($i | del(.ID)))&#39; input.json\r\n```\r\n[Demo](https://jqplay.org/s/hqvhnyFfs0W) or\r\n[Demo](https://jqplay.org/s/CILvud0kwKz)",
                "title": "Use jq to merge list of dictionaries into one dictionary with keys"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1709651806,
                "last_edit_date": 1709651806,
                "creation_date": 1709651747,
                "answer_id": 78108761,
                "question_id": 78108684,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "As always, I post a question, and seconds later I determine the answer. (I do not do this on purpose! It&#39;s a fairy curse.)\r\n\r\nThe JSON is in a file, so:\r\n\r\n```bash\r\ncat items.json | jq &#39;\r\n    .Items\r\n    | map(select(.ID)\r\n    | {(.ID): . } )\r\n    | add&#39;\r\n```\r\n\r\nWhich turns into:\r\n\r\n```json\r\n{\r\n    &quot;123abc&quot;: {\r\n        &quot;ID&quot;: &quot;123abc&quot;,\r\n        &quot;Name&quot;: &quot;test name&quot;,\r\n        &quot;Description&quot;: &quot;item 1&quot;\r\n    },\r\n    &quot;321zyx&quot;: {\r\n        &quot;ID&quot;: &quot;321zyx&quot;,\r\n        &quot;Name&quot;: &quot;test name two&quot;,\r\n        &quot;Description&quot;: &quot;item 2&quot;\r\n    }\r\n}\r\n```\r\n\r\nIt keeps the ID as part of the dictionary, but that&#39;s acceptable to me.",
                "title": "Use jq to merge list of dictionaries into one dictionary with keys"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1709732103,
                "creation_date": 1709732103,
                "answer_id": 78114815,
                "question_id": 78108684,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "```\r\n.Items | map({key: .ID, value: del(.ID)}) | from_entries\r\n```\r\nproduces the desired output.",
                "title": "Use jq to merge list of dictionaries into one dictionary with keys"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 0,
        "last_activity_date": 1709732103,
        "creation_date": 1709651149,
        "question_id": 78108684,
        "body_markdown": "I have a dictionary like:\r\n\r\n```\r\n{\r\n    &quot;Items&quot;: [\r\n        {\r\n            &quot;ID&quot;: &quot;123abc&quot;,\r\n            &quot;Name&quot;: &quot;test name&quot;,\r\n            &quot;Description&quot;: &quot;item 1&quot;\r\n        },\r\n        {\r\n            &quot;ID&quot;: &quot;321zyx&quot;,\r\n            &quot;Name&quot;: &quot;test name two&quot;,\r\n            &quot;Description&quot;: &quot;item 2&quot;\r\n        }\r\n    ]\r\n}\r\n```\r\n\r\nI&#39;d like to use `jq` to convert this into:\r\n\r\n```\r\n{\r\n    &quot;123abc&quot;: {\r\n        &quot;Name&quot;: &quot;test name&quot;,\r\n        &quot;Description&quot;: &quot;item 1&quot;\r\n    },\r\n    &quot;321zyx&quot;: {\r\n        &quot;Name&quot;: &quot;test name two&quot;,\r\n        &quot;Description&quot;: &quot;item 2&quot;\r\n    }\r\n}\r\n```\r\n\r\nIs that possible? If so, how would I accomplish this?",
        "link": "https://stackoverflow.com/questions/78108684/use-jq-to-merge-list-of-dictionaries-into-one-dictionary-with-keys",
        "title": "Use jq to merge list of dictionaries into one dictionary with keys"
    },
    {
        "tags": [
            "bash",
            "jenkins",
            "groovy",
            "jenkins-pipeline",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1709666040,
                "post_id": 78109928,
                "comment_id": 137705137,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 3837378,
                    "reputation": 37248,
                    "user_id": 3181392,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/SIgPs.png?s=256",
                    "display_name": "cfrick",
                    "link": "https://stackoverflow.com/users/3181392/cfrick"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1709666256,
                "post_id": 78109928,
                "comment_id": 137705174,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 32384,
                    "reputation": 127026,
                    "user_id": 89817,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/df253c3b6533949ea94f31f328f3e769?s=256&d=identicon&r=PG",
                    "display_name": "Gordon Davisson",
                    "link": "https://stackoverflow.com/users/89817/gordon-davisson"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1709666393,
                "post_id": 78109928,
                "comment_id": 137705203,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 4420256,
                    "reputation": 1672,
                    "user_id": 3600487,
                    "user_type": "registered",
                    "accept_rate": 62,
                    "profile_image": "https://www.gravatar.com/avatar/e52e454781fd5788df48a9df3a2ae390?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Rafiq",
                    "link": "https://stackoverflow.com/users/3600487/rafiq"
                },
                "reply_to_user": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1709666751,
                "post_id": 78109928,
                "comment_id": 137705259,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 4420256,
                    "reputation": 1672,
                    "user_id": 3600487,
                    "user_type": "registered",
                    "accept_rate": 62,
                    "profile_image": "https://www.gravatar.com/avatar/e52e454781fd5788df48a9df3a2ae390?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Rafiq",
                    "link": "https://stackoverflow.com/users/3600487/rafiq"
                },
                "reply_to_user": {
                    "account_id": 3837378,
                    "reputation": 37248,
                    "user_id": 3181392,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/SIgPs.png?s=256",
                    "display_name": "cfrick",
                    "link": "https://stackoverflow.com/users/3181392/cfrick"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1709666994,
                "post_id": 78109928,
                "comment_id": 137705295,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 3837378,
                    "reputation": 37248,
                    "user_id": 3181392,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/SIgPs.png?s=256",
                    "display_name": "cfrick",
                    "link": "https://stackoverflow.com/users/3181392/cfrick"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1709667326,
                "post_id": 78109928,
                "comment_id": 137705338,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 4420256,
                    "reputation": 1672,
                    "user_id": 3600487,
                    "user_type": "registered",
                    "accept_rate": 62,
                    "profile_image": "https://www.gravatar.com/avatar/e52e454781fd5788df48a9df3a2ae390?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Rafiq",
                    "link": "https://stackoverflow.com/users/3600487/rafiq"
                },
                "reply_to_user": {
                    "account_id": 32384,
                    "reputation": 127026,
                    "user_id": 89817,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/df253c3b6533949ea94f31f328f3e769?s=256&d=identicon&r=PG",
                    "display_name": "Gordon Davisson",
                    "link": "https://stackoverflow.com/users/89817/gordon-davisson"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1709668078,
                "post_id": 78109928,
                "comment_id": 137705451,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 4420256,
                    "reputation": 1672,
                    "user_id": 3600487,
                    "user_type": "registered",
                    "accept_rate": 62,
                    "profile_image": "https://www.gravatar.com/avatar/e52e454781fd5788df48a9df3a2ae390?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Rafiq",
                    "link": "https://stackoverflow.com/users/3600487/rafiq"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1709671280,
                "post_id": 78109928,
                "comment_id": 137705890,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 32384,
                    "reputation": 127026,
                    "user_id": 89817,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/df253c3b6533949ea94f31f328f3e769?s=256&d=identicon&r=PG",
                    "display_name": "Gordon Davisson",
                    "link": "https://stackoverflow.com/users/89817/gordon-davisson"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1709671552,
                "post_id": 78109928,
                "comment_id": 137705915,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1709757971,
                "post_id": 78109928,
                "comment_id": 137718127,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1709708391,
                "creation_date": 1709708391,
                "answer_id": 78112357,
                "question_id": 78109928,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "As stated in the comments, the value of `cfn_template` contains `&#39;` chars -- which are also used in an attempt to quote it.  So the effective call is basically something like this: `echo &#39;&#39;(&#39;&#39; | ...`.\r\n\r\nSo your options are:\r\n\r\n- quote `cfn_template` on the groovy side so it can be used when you bang strings together for the shell\r\n- do not use `echo`\r\n  - use a temp-file to store the content and pass it to `jq`\r\n  - pipe the content\r\n    - directly send the output from `aws` into `jq` (e.g. `aws ... | jq ...`)\r\n    - write the content on the groovy side into the stdin for the `jq` call",
                "title": "Syntax error: &quot;(&quot; unexpected in Jenkins Groovy scripted pipeline"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1709708391,
        "creation_date": 1709664450,
        "last_edit_date": 1709667918,
        "question_id": 78109928,
        "body_markdown": "I have the following code in a Jenkins Groovy scripted pipeline. \r\n\r\n```\r\ncfn_template = sh(script: &quot;aws --region $aws_region cloudformation get-template --stack-name $asg_cfn_stack_name --query &#39;TemplateBody&#39; --output json&quot;, returnStdout: true).trim()\r\n\r\necho &quot;Debugging test line-2&quot;\r\n\r\ndef min_size = sh(script: &quot;echo &#39;${cfn_template}&#39; | jq -r &#39;.Resources.devfoenergybkrblueasgASG12345678.Properties.MinSize&#39;&quot;, returnStdout: true).trim()\r\n```\r\n\r\nThe first `sh(script: &quot;aws ... json&quot;).trim()` is working fine and storing CFN template in to the Groovy variable `cfn_template`. However, the 3rd line is giving a syntax error. \r\n\r\nHere are the relevant console log lines:\r\n\r\n```\r\n13:18:46  [Pipeline] sh\r\n13:18:46  + aws --region us-east-1 cloudformation get-template --stack-name dev-fo-energy-bkr-blue-asg --query TemplateBody --output json\r\n13:18:49  [Pipeline] echo\r\n13:18:49  Debugging test line-2\r\n13:18:49  [Pipeline] sh\r\n13:18:50  /home/jenkins/agent/workspace/and_deployment_feature_AGM-448-2/cdk_build@tmp/durable-6410a3dd/script.sh: 700: Syntax error: &quot;(&quot; unexpected\r\n13:18:50  [Pipeline] echo\r\n13:18:50  Failure at CDK deployment. hudson.AbortException: script returned exit code 2\r\n```\r\n\r\nPlease note that, I am trying to get the `MinSize` property of the Autoscaling Group (ASG) from the CFN template for a reason instead of getting it from the ASG itself.\r\n\r\nWhat is the mistake here and how can I fix this?\r\n\r\nI also have a Groovy variable `asg_logical_id` that sores the value `devfoenergybkrblueasgASG12345678`. I&#39;d like to use this variable in the command that is giving syntax error now, instead of this direct value. I&#39;m not sure if I face any other issue with that after passing the current issue. So, if you could please include it in your solution that would be helpful as well.\r\n\r\n**Update**:\r\n\r\nA typo in the first command `(CFN)` that was added after bring the command here from the code base has been removed.\r\n\r\nThe following two work on a Linux terminal:\r\n```\r\ncfn_template=$(aws --region $aws_region cloudformation get-template --stack-name $asg_cfn_stack_name --query &#39;TemplateBody&#39; --output json)\r\n\r\nmin_size=$(echo ${cfn_template} | jq -r &#39;.Resources.devfoenergybkrblueasgASG12345678.Properties.MinSize&#39;)\r\n```",
        "link": "https://stackoverflow.com/questions/78109928/syntax-error-unexpected-in-jenkins-groovy-scripted-pipeline",
        "title": "Syntax error: &quot;(&quot; unexpected in Jenkins Groovy scripted pipeline"
    },
    {
        "tags": [
            "bash",
            "github-actions",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 26928743,
                    "reputation": 353,
                    "user_id": 20501583,
                    "user_type": "registered",
                    "profile_image": "https://lh3.googleusercontent.com/a/ALm5wu06glVEQoNfX8NNnQ90TcEmlpHkkYT0Wxhth2Kr=k-s256",
                    "display_name": "Mohammed Ehab",
                    "link": "https://stackoverflow.com/users/20501583/mohammed-ehab"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1709738136,
                "post_id": 78114596,
                "comment_id": 137714586,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 39208,
                    "reputation": 267964,
                    "user_id": 112968,
                    "user_type": "registered",
                    "accept_rate": 68,
                    "profile_image": "https://i.sstatic.net/zHTaT.png?s=256",
                    "display_name": "knittl",
                    "link": "https://stackoverflow.com/users/112968/knittl"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1709738983,
                "post_id": 78114596,
                "comment_id": 137714790,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1717430625,
                "last_edit_date": 1717430625,
                "creation_date": 1709739611,
                "answer_id": 78115675,
                "question_id": 78114596,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You&#39;re using `.value.[]`; support for chained `.[]` was added in jq 1.7 (see the [release notes][1], under &quot;language changes&quot;), and ubuntu-22.04 Actions runners use jq 1.6.\r\n\r\nYou can fix it by using `.value[]` instead.\r\n\r\nAlternatively, you can run your job on an `ubuntu-24.04` runner; they have jq 1.7.1 installed, but the image is currently (June 2024) in beta. `ubuntu-latest` still uses 22.04.\r\n\r\n\r\n  [1]: https://github.com/jqlang/jq/releases/tag/jq-1.7",
                "title": "jq array filter works locally, but not in a GitHub workflow"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1717430625,
        "creation_date": 1709730054,
        "last_edit_date": 1709736642,
        "question_id": 78114596,
        "body_markdown": "I&#39;m using jq to extract an array from a JSON in a GitHub workflow:\r\n\r\n    name: Test\r\n    \r\n    on:\r\n      workflow_dispatch:\r\n    \r\n    jobs:\r\n      test:\r\n        runs-on: ubuntu-latest\r\n        \r\n        steps:\r\n        - name: Test\r\n          run: echo $(echo &#39;{&quot;value&quot;:[{&quot;displayName&quot;:&quot;test&quot;}]}&#39; | jq -c &#39;.value.[]&#39;)\r\n\r\nHowever, it fails with the error\r\n\r\n    Run echo $(echo &#39;{&quot;value&quot;:[{&quot;displayName&quot;:&quot;test&quot;}]}&#39; | jq -c &#39;.value.[]&#39;)\r\n    jq: error: syntax error, unexpected &#39;[&#39;, expecting FORMAT or QQSTRING_START (Unix shell quoting issues?) at &lt;top-level&gt;, line 1:\r\n    .value.[]       \r\n    jq: 1 compile error\r\n\r\nIf I run the same command with jq locally, it works - why doesn&#39;t it work on a GitHub runner?\r\n\r\n",
        "link": "https://stackoverflow.com/questions/78114596/jq-array-filter-works-locally-but-not-in-a-github-workflow",
        "title": "jq array filter works locally, but not in a GitHub workflow"
    },
    {
        "tags": [
            "json",
            "jq",
            "duration"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1709739387,
                "post_id": 78115604,
                "comment_id": 137714867,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 6313442,
                    "reputation": 45115,
                    "user_id": 5625547,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/oqCND.jpg?s=256",
                    "display_name": "0stone0",
                    "link": "https://stackoverflow.com/users/5625547/0stone0"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1709739454,
                "post_id": 78115604,
                "comment_id": 137714879,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2589820,
                    "reputation": 4015,
                    "user_id": 2244766,
                    "user_type": "registered",
                    "accept_rate": 62,
                    "profile_image": "https://i.sstatic.net/iZQFE.jpg?s=256",
                    "display_name": "murison",
                    "link": "https://stackoverflow.com/users/2244766/murison"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1709739571,
                "post_id": 78115604,
                "comment_id": 137714893,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2589820,
                    "reputation": 4015,
                    "user_id": 2244766,
                    "user_type": "registered",
                    "accept_rate": 62,
                    "profile_image": "https://i.sstatic.net/iZQFE.jpg?s=256",
                    "display_name": "murison",
                    "link": "https://stackoverflow.com/users/2244766/murison"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1709739906,
                "post_id": 78115604,
                "comment_id": 137714983,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1709803155,
                "last_edit_date": 1709803155,
                "creation_date": 1709753049,
                "answer_id": 78116926,
                "question_id": 78115604,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here is a way that doesn&#39;t use time builtins:\r\n```\r\nmap(\r\n  [foreach (\r\n    [60, &quot;seconds&quot;],\r\n    [60, &quot;minutes&quot;],\r\n    [24, &quot;hours&quot;],\r\n    [365, &quot;days&quot;],\r\n    [false, &quot;years&quot;]\r\n  ) as [$unit, $key] (\r\n    {in: .};\r\n    if $unit then\r\n      {in: (.in/$unit | floor), out: {($key): (.in%$unit)}}\r\n    else\r\n      {out: {($key): .in}}\r\n    end;\r\n    .out\r\n  )] | add | [\r\n    (.years | if . &gt; 0 then &quot;\\(.)y&quot; else empty end),\r\n    &quot;\\(.days)d,&quot;,\r\n    ([.hours, .minutes] | map(if . &lt; 10 then &quot;0\\(.)&quot; else . end) | join(&quot;:&quot;))\r\n  ] | join(&quot; &quot;)\r\n)\r\n```\r\n&lt;sup&gt;[Online demo](https://jqplay.org/s/nwDeCX9HBH5)&lt;/sup&gt;",
                "title": "how to present seconds as duration in jq"
            },
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1709800829,
                "creation_date": 1709800829,
                "answer_id": 78119871,
                "question_id": 78115604,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here is a solution written for flexibility and using a generic `seconds2object` function:\r\n```\r\n# Emit a JSON object of the form {years, days, hours, minutes, seconds}\r\n# assuming a 365-day year\r\ndef seconds2object:\r\n  def divrem($x; $y):\r\n    [$x/$y|floor, $x % $y];\r\n\r\n  def units:\r\n    { min: 60}\r\n      | .hour =  60 * .min\r\n      | .day  =  24 * .hour\r\n      | .year = 365 * .day;\r\n\r\n  units as $units\r\n  | divrem( .; $units.year) as [$years, $r]\r\n  | divrem($r; $units.day)  as [$days, $r]\r\n  | divrem($r; $units.hour) as [$hours, $r]\r\n  | divrem($r; $units.min)  as [$mins, $secs]\r\n  | {$years, $days, $hours, $mins, $secs} ;\r\n\r\n# Emit a string in Yy Dd HH:MM format,\r\n# ignoring residual seconds and omitting 0y\r\ndef seconds2human:\r\n  def lpad($len): tostring | ($len - length) as $l | (&quot;0&quot; * $l) + .;\r\n  seconds2object\r\n  | if .years == 0 then &quot;&quot; else &quot;\\(.years)y &quot; end\r\n    + &quot;\\(.days)d, \\(.hours|lpad(2)):\\(.mins|lpad(2))&quot; ;\r\n \r\n \r\n[\r\n  30300,\r\n  120300,\r\n  296700,\r\n  31922700,\r\n  63458700\r\n] \r\n| map(seconds2human)\r\n\r\n```",
                "title": "how to present seconds as duration in jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 2,
        "last_activity_date": 1709819761,
        "creation_date": 1709739065,
        "last_edit_date": 1709819761,
        "question_id": 78115604,
        "body_markdown": "I want to display some amount of seconds that correspond to dime duration rather than regular date in some human-readable form. say sth like:\r\n\r\n    [\r\n      30300,\r\n      120300,\r\n      296700,\r\n      31922700,\r\n      63458700\r\n    ]\r\nand what i would like to get\r\n\r\n    [\r\n      &quot;0d, 08:25&quot;,\r\n      &quot;1d, 09:25&quot;,\r\n      &quot;3d, 10:25&quot;,\r\n      &quot;1y 4d, 11:25&quot;,\r\n      &quot;2y 4d, 11:25&quot;\r\n    ]\r\n\r\nseems there is no &quot;easy&quot; (built in) way to get this. found some lib that does almost what i need:\r\n\r\nhttps://github.com/fearphage/jq-duration\r\n\r\nbut it has a fixed output format, which doesnt quite fit my needs. \r\n\r\ni was able to achieve what i want with `strftime`, basically this is &quot;almost a date&quot;, right? i can get hours and minutes, i can get &quot;day # of year&quot; (`&amp;j`), i can get year (`%Y`). but there are some caveats: by default year starts at 1970, and according to the doc: day of year is 1-366.\r\n\r\nwhat if i just subtract 1970 from &quot;years&quot; to get years counting from 0, and do same for &quot;days&quot;  (subtract one) ?\r\n\r\nso we would end up with by below jq filter:\r\n\r\n    gmtime | (.[0] -= 1970) | (.[7] -= 1) | strftime (&quot;%Yy %jd, %H:%M&quot;) | ltrimstr(&quot;0y &quot;) | sub(&quot;0+(?&lt;ds&gt;[0-9]+d)&quot;;&quot;\\(.ds)&quot;)\r\n\r\nthe only thing left is to ltrim excessive zeros (`%j` produces a fixed width (3chars))\r\n\r\nkind of hacky, but gets the job done - what do you think?\r\n\r\nhttps://jqplay.org/s/JGUUnI8q1zK\r\n\r\nmaybe sbd has a better way to approach such problem?\r\n\r\nbtw - i checked also on bigger values (exceeding 4 years) , and it seems that &quot;my way&quot; returns the same as javascript `moment.js` + https://github.com/jsmreese/moment-duration-format lib:\r\n\r\n* https://jqplay.org/s/Z1GJXHpegz9\r\n* https://jsfiddle.net/5y09ns38/1/",
        "link": "https://stackoverflow.com/questions/78115604/how-to-present-seconds-as-duration-in-jq",
        "title": "how to present seconds as duration in jq"
    },
    {
        "tags": [
            "json",
            "key",
            "jq",
            "export-to-csv"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 30711022,
                    "reputation": 1,
                    "user_id": 23547857,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/c0f29cba6430d37714b4a03f1536936a?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "scool",
                    "link": "https://stackoverflow.com/users/23547857/scool"
                },
                "reply_to_user": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1709766123,
                "post_id": 78117813,
                "comment_id": 137719227,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1709766414,
                "creation_date": 1709766414,
                "answer_id": 78117900,
                "question_id": 78117813,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Just fetch the keys using [`keys_unsorted`](https://jqlang.github.io/jq/manual/#keys-keys_unsorted):\r\n```sh\r\n.result_set | keys_unsorted[]\r\n```\r\n[Demo](https://jqplay.org/s/G_Av7dYnGwC)\r\n\r\n---\r\n\r\n&gt; Would it be possible to further enhance this to give below output?\r\n&gt; ```csv\r\n&gt; /api/device/4756, Arbitrator, 127.0.0.1, acme.arbitrate.com \r\n&gt; /api/device/4757, Auditor, 127.0.0.2, acme.auditor.com\r\n&gt; /api/device/4758, Augumentor, 127.0.0.3, acme.augumentor.com\r\n&gt; ```\r\n\r\nThen store the key to access it later:\r\n```sh\r\n.result_set | keys_unsorted[] as $key | .[$key] | [$key, .name, .ip, .hostname]\r\n| join(&quot;, &quot;) # or @csv\r\n```\r\n[Demo](https://jqplay.org/s/P-4uR_F8Wf5)\r\n\r\nOr use [`to_entries`](https://jqlang.github.io/jq/manual/#to_entries-from_entries-with_entries) instead, which breaks up an object into a list of key-value pairs:\r\n```sh\r\n.result_set | to_entries[] | [.key, .value.name, .value.ip, .value.hostname]\r\n| join(&quot;, &quot;) # or @csv\r\n```\r\n[Demo](https://jqplay.org/s/KdZqtRFF8-d)",
                "title": "How to get parent node from JSON?"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1709833224,
        "creation_date": 1709764731,
        "last_edit_date": 1709833224,
        "question_id": 78117813,
        "body_markdown": "[Update my question little bit]\r\n\r\nI have below JSON in a test.json file. And I&#39;m trying to figure out how to get all the root names, who&#39;s values are completely dynamic in nature.\r\n\r\n    {\r\n           &quot;result_set&quot;: {\r\n            &quot;/api/device/4756&quot;: {\r\n                &quot;name&quot;: &quot;Arbitrator&quot;,\r\n                &quot;ip&quot;: &quot;127.0.0.1&quot;,\r\n                &quot;hostname&quot;: &quot;acme.arbitrate.com&quot;\r\n            },\r\n            &quot;/api/device/4757&quot;: {\r\n                &quot;name&quot;: &quot;Auditor&quot;,\r\n                &quot;ip&quot;: &quot;127.0.0.2&quot;,\r\n                &quot;hostname&quot;: &quot;acme.auditor.com&quot;\r\n            },\r\n            &quot;/api/device/4758&quot;: {\r\n                &quot;name&quot;: &quot;Augumentor&quot;,\r\n                &quot;ip&quot;: &quot;127.0.0.3&quot;,\r\n                &quot;hostname&quot;: &quot;acme.augumentor.com&quot;\r\n            }\r\n        }\r\n    }\r\n\r\nSo far I&#39;ve tried but it doesn&#39;t return what I&#39;m looking for....\r\n\r\n    cat test.json | jq -r &#39;[&quot;names&quot;], (.result_set | [])&#39;\r\n\r\nI&#39;m looking for a result that looks like below ...\r\n\r\n    /api/device/4756, Arbitrator, 127.0.0.1, acme.arbitrate.com\r\n    /api/device/4757, Auditor, 127.0.0.2, acme.auditor.com\r\n    /api/device/4758, Augumentor, 127.0.0.3, acme.augumentor.com\r\n",
        "link": "https://stackoverflow.com/questions/78117813/how-to-get-parent-node-from-json",
        "title": "How to get parent node from JSON?"
    },
    {
        "tags": [
            "python",
            "json",
            "jq",
            "export-to-csv"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 230492,
                    "reputation": 33658,
                    "user_id": 494134,
                    "user_type": "registered",
                    "accept_rate": 66,
                    "profile_image": "https://i.sstatic.net/3XHKr.png?s=256",
                    "display_name": "John Gordon",
                    "link": "https://stackoverflow.com/users/494134/john-gordon"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1709779773,
                "post_id": 78118487,
                "comment_id": 137720340,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": -1,
                    "reputation": 1,
                    "user_id": -1,
                    "user_type": "moderator",
                    "profile_image": "https://www.gravatar.com/avatar/a007be5a61f6aa8f3e85ae2fc18dd66e?s=256&d=identicon&r=PG",
                    "display_name": "Community",
                    "link": "https://stackoverflow.com/users/-1/community"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1709781110,
                "post_id": 78118487,
                "comment_id": 137720442,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1709779725,
                "creation_date": 1709779725,
                "answer_id": 78118496,
                "question_id": 78118487,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You need to collect the output rows into arrays. As for the headers, you have alreday given the path yourself: `.Columns[].Id`. And the actual rows are also already organized into an array.\r\n\r\n```sh\r\njq -r &#39;[.Columns[].Id], .Rows[].Values | @csv&#39;\r\n```\r\n```csv\r\n&quot;ItemName&quot;,&quot;Date&quot;,&quot;Qty&quot;\r\n&quot;ITEM1&quot;,&quot;10-MAY-2024&quot;,&quot;100&quot;\r\n&quot;ITEM2&quot;,&quot;20-MAY-2024&quot;,&quot;200&quot;\r\n&quot;ITEM3&quot;,&quot;30-MAY-2024&quot;,&quot;400&quot;\r\n```\r\n[Demo](https://jqplay.org/s/FM9Z141pBTK)\r\n\r\nNote: To change capitalization, use `ascii_upcase` or `ascii_downcase`. Split into single characters first, if not all of them need to change case, then `add` them together again.",
                "title": "JSON to CSV using jq or python"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -2,
        "last_activity_date": 1709795119,
        "creation_date": 1709779441,
        "last_edit_date": 1709795119,
        "question_id": 78118487,
        "body_markdown": "Need help converting this JSON and using a specific element of the Column Dimension as the Column header line in CSV using jq\r\n\r\nInput JSON`your text`\r\n\r\n```\r\n{\r\n    &quot;Columns&quot;: [\r\n        {\r\n            &quot;Id&quot;: &quot;ItemName&quot;,\r\n            &quot;IsEditable&quot;: false\r\n        },\r\n        {\r\n            &quot;Id&quot;: &quot;Date&quot;,\r\n            &quot;IsEditable&quot;: false\r\n        },\r\n        {\r\n            &quot;Id&quot;: &quot;Qty&quot;,\r\n            &quot;IsEditable&quot;: false\r\n        }\r\n    ],\r\n    &quot;Rows&quot;: [\r\n        {\r\n            &quot;Values&quot;: [\r\n                &quot;ITEM1&quot;,\r\n                &quot;10-MAY-2024&quot;,\r\n                &quot;100&quot;\r\n            ]\r\n        },\r\n        {\r\n            &quot;Values&quot;: [\r\n                &quot;ITEM2&quot;,\r\n                &quot;20-MAY-2024&quot;,\r\n                &quot;200&quot;\r\n            ]\r\n        },\r\n        {\r\n            &quot;Values&quot;: [\r\n                &quot;ITEM3&quot;,\r\n                &quot;30-MAY-2024&quot;,\r\n                &quot;400&quot;\r\n            ]\r\n        }\r\n    ],\r\n    &quot;QueryHandle&quot;: {\r\n        &quot;QueryID&quot;: &quot;00101&quot;,\r\n        &quot;Worksheet&quot;: {\r\n            &quot;Name&quot;: &quot;Test20&quot;,\r\n            &quot;Scope&quot;: &quot;NA&quot;\r\n        },\r\n        &quot;WorkAlloc&quot;: &quot;2024-MAY&quot;\r\n    },\r\n    &quot;RowCount&quot;: 3\r\n}\r\n```\r\n\r\n \r\nRequired Output in CSV format ( I only the data below and the rest of the elements in JSON to be ignored).\r\n\r\nThe header columns come from .Columns\\[\\]|.Id\r\n\r\n    ItemName, Date, Qty\r\n    &quot;Item1&quot;,&quot;10-MAY-2024&quot;,&quot;100&quot;\r\n    &quot;Item2&quot;,&quot;20-MAY-2024&quot;,&quot;200&quot;\r\n    &quot;Item3&quot;,&quot;20-MAy-2024&quot;,&quot;400&quot;\r\n\r\nTried following this post:\r\n\r\nhttps://stackoverflow.com/questions/32960857/how-to-convert-arbitrary-simple-json-to-csv-using-jq\r\n\r\nbut haven&#39;t been able to get it to work\r\n",
        "link": "https://stackoverflow.com/questions/78118487/json-to-csv-using-jq-or-python",
        "title": "JSON to CSV using jq or python"
    },
    {
        "tags": [
            "json",
            "jq",
            "data-wrangling"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1709820770,
                "creation_date": 1709820770,
                "answer_id": 78122026,
                "question_id": 78121993,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Either use [`to_entries`](https://jqlang.github.io/jq/manual/#to_entries-from_entries-with_entries) to create an array of key-value pairs, which you can access by using `.key` and `.value`:\r\n```sh\r\nto_entries[] | &quot;\\(.key) \\(.value[][].p)&quot;\r\n```\r\n[Demo](https://jqplay.org/s/h0b6GUbzhV3)\r\n\r\n\r\nOr fetch just the keys using [`keys_unsorted`](https://jqlang.github.io/jq/manual/#keys-keys_unsorted), bind them to a variable using `as`, and access the fields using the variable:\r\n```sh\r\nkeys_unsorted[] as $key | &quot;\\($key) \\(.[$key][][].p)&quot;\r\n```\r\n[Demo](https://jqplay.org/s/paZJDui3J3v)\r\n\r\nIn both cases I used [string interpolation](https://jqlang.github.io/jq/manual/#string-interpolation) `&quot;\\(…)&quot;` to construct the final values, but depending on your processing pipeline, there might be better ways.",
                "title": "JQ question about parsing dictionaries within lists"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1710187385,
        "creation_date": 1709820394,
        "last_edit_date": 1710187385,
        "question_id": 78121993,
        "body_markdown": "I have a json file in the following format\r\n```lang-json\r\n{\r\n  &quot;a&quot;: [\r\n    [\r\n      {\r\n        &quot;p&quot;: &quot;p1-value&quot;,\r\n        &quot;d&quot;: &quot;d1-value&quot;\r\n      },\r\n      {\r\n        &quot;p&quot;: &quot;p2-value&quot;,\r\n        &quot;d&quot;: &quot;d2-value&quot;\r\n      }\r\n    ],\r\n    [\r\n      {\r\n        &quot;p&quot;: &quot;p3-value&quot;,\r\n        &quot;d&quot;: &quot;d3-value&quot;\r\n      }\r\n    ]\r\n  ],\r\n  &quot;z&quot;: [\r\n    [\r\n      {\r\n        &quot;p&quot;: &quot;p1-value&quot;,\r\n        &quot;d&quot;: &quot;d1-value&quot;\r\n      }\r\n    ]\r\n  ]\r\n}\r\n```\r\nand I&#39;d like to know how to output something like this\r\n```\r\na p1-value\r\na p2-value\r\na p3-value\r\nz p1-value\r\n```\r\n\r\nI&#39;ve tried a few different jq queries but I can&#39;t get it to work.\r\n\r\nI know I can use &#39;keys[]&#39; at the top level but that doesn&#39;t give me anything below it. I&#39;ve tried ```.&quot;a&quot; | .[] | .[] | .path``` but that means I have to specify each top level key..\r\n\r\nThanks",
        "link": "https://stackoverflow.com/questions/78121993/jq-question-about-parsing-dictionaries-within-lists",
        "title": "JQ question about parsing dictionaries within lists"
    },
    {
        "tags": [
            "linux",
            "jq",
            "array-merge"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1709908902,
                "creation_date": 1709908902,
                "answer_id": 78128455,
                "question_id": 78128389,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "    .componentsByProdTourId[] += .ticketData\r\n\r\nis enough. Your version is failing because at the time when you try to access `.ticketData`, `.` is the item you&#39;re mapping over, and not the root object. You could fix that by using `as` to capture `.ticketData`, but there&#39;s an easier way which is to skip `map` entirely.",
                "title": "Merging two arrays using Jq command"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1709928002,
        "creation_date": 1709908405,
        "last_edit_date": 1709928002,
        "question_id": 78128389,
        "body_markdown": "I have the following JSON object that I want to merge. So the scenario is `ticketId` and `requester_id` should become an attribute of each objects in `componentsByProdTourId` array. \r\nHere is the input JSON data. \r\n\r\n```lang-json\r\n{\r\n  &quot;componentsByProdTourId&quot;: [\r\n    {\r\n      &quot;region&quot;: &quot;Europe&quot;,\r\n      &quot;compSpec&quot;: {\r\n        &quot;country&quot;: &quot;France&quot;,\r\n        &quot;attributes&quot;: [\r\n          {\r\n            &quot;attributeCode&quot;: &quot;ABC&quot;,\r\n            &quot;attributeType&quot;: &quot;xyx&quot;\r\n          }\r\n        ]\r\n      }\r\n    },\r\n    {\r\n      &quot;region&quot;: &quot;Europe&quot;,\r\n      &quot;compSpec&quot;: {\r\n        &quot;country&quot;: &quot;France&quot;,\r\n        &quot;attributes&quot;: [\r\n          {\r\n            &quot;attributeCode&quot;: &quot;EFG&quot;,\r\n            &quot;attributeType&quot;: &quot;lmn&quot;\r\n          }\r\n        ]\r\n      }\r\n    },\r\n    {\r\n      &quot;region&quot;: &quot;Europe&quot;,\r\n      &quot;compSpec&quot;: {\r\n        &quot;country&quot;: &quot;United Kingdom&quot;,\r\n        &quot;attributes&quot;: [\r\n          {\r\n            &quot;attributeCode&quot;: &quot;FLC&quot;,\r\n            &quot;attributeType&quot;: &quot;omp&quot;\r\n          }\r\n        ]\r\n      }\r\n    }\r\n  ],\r\n  &quot;ticketData&quot;: {\r\n    &quot;ticketId&quot;: &quot;1234&quot;,\r\n    &quot;requester_id&quot;: &quot;99885&quot;\r\n  }\r\n}\r\n```\r\nThe desired out I am looking for:\r\n\r\n```lang-json\r\n{\r\n  &quot;componentsByProdTourId&quot;: [\r\n    {\r\n      &quot;region&quot;: &quot;Europe&quot;,\r\n      &quot;compSpec&quot;: {\r\n        &quot;country&quot;: &quot;France&quot;,\r\n        &quot;attributes&quot;: [\r\n          {\r\n            &quot;attributeCode&quot;: &quot;ABC&quot;,\r\n            &quot;attributeType&quot;: &quot;xyx&quot;\r\n          }\r\n        ]\r\n      },\r\n      &quot;ticketId&quot;: 1234,\r\n      &quot;requester_id&quot;: 99885\r\n    },\r\n    {\r\n      &quot;region&quot;: &quot;Europe&quot;,\r\n      &quot;compSpec&quot;: {\r\n        &quot;country&quot;: &quot;France&quot;,\r\n        &quot;attributes&quot;: [\r\n          {\r\n            &quot;attributeCode&quot;: &quot;EFG&quot;,\r\n            &quot;attributeType&quot;: &quot;lmn&quot;\r\n          }\r\n        ]\r\n      },\r\n      &quot;ticketId&quot;: 1234,\r\n      &quot;requester_id&quot;: 99885\r\n    },\r\n    {\r\n      &quot;region&quot;: &quot;Europe&quot;,\r\n      &quot;compSpec&quot;: {\r\n        &quot;country&quot;: &quot;United Kingdom&quot;,\r\n        &quot;attributes&quot;: [\r\n          {\r\n            &quot;attributeCode&quot;: &quot;FLC&quot;,\r\n            &quot;attributeType&quot;: &quot;omp&quot;\r\n          }\r\n        ]\r\n      },\r\n      &quot;ticketId&quot;: 1234,\r\n      &quot;requester_id&quot;: 99885\r\n    }\r\n  ],\r\n  &quot;ticketData&quot;: {\r\n    &quot;ticketId&quot;: &quot;1234&quot;,\r\n    &quot;requester_id&quot;: &quot;99885&quot;\r\n  }\r\n}\r\n```\r\n\r\n\r\n\r\nThanks in advance. \r\n\r\nI tried this Jq command:\r\n\r\n    .componentsByProdTourId |= map(. + {ticketId: .ticketData.ticketId, requester_id: .ticketData.requester_id})\r\n\r\n \r\nBut the result was not ideal. `ticketId` and `requester_id` were null. Here is the output:\r\n```lang-json\r\n{\r\n  &quot;componentsByProdTourId&quot;: [\r\n    {\r\n      &quot;region&quot;: &quot;Europe&quot;,\r\n      &quot;compSpec&quot;: {\r\n        &quot;country&quot;: &quot;France&quot;,\r\n        &quot;attributes&quot;: [\r\n          {\r\n            &quot;attributeCode&quot;: &quot;ABC&quot;,\r\n            &quot;attributeType&quot;: &quot;xyx&quot;\r\n          }\r\n        ]\r\n      },\r\n      &quot;ticketId&quot;: null,\r\n      &quot;requester_id&quot;: null\r\n    },\r\n    {\r\n      &quot;region&quot;: &quot;Europe&quot;,\r\n      &quot;compSpec&quot;: {\r\n        &quot;country&quot;: &quot;France&quot;,\r\n        &quot;attributes&quot;: [\r\n          {\r\n            &quot;attributeCode&quot;: &quot;EFG&quot;,\r\n            &quot;attributeType&quot;: &quot;lmn&quot;\r\n          }\r\n        ]\r\n      },\r\n      &quot;ticketId&quot;: null,\r\n      &quot;requester_id&quot;: null\r\n    },\r\n    {\r\n      &quot;region&quot;: &quot;Europe&quot;,\r\n      &quot;compSpec&quot;: {\r\n        &quot;country&quot;: &quot;United Kingdom&quot;,\r\n        &quot;attributes&quot;: [\r\n          {\r\n            &quot;attributeCode&quot;: &quot;FLC&quot;,\r\n            &quot;attributeType&quot;: &quot;omp&quot;\r\n          }\r\n        ]\r\n      },\r\n      &quot;ticketId&quot;: null,\r\n      &quot;requester_id&quot;: null\r\n    }\r\n  ],\r\n  &quot;ticketData&quot;: {\r\n    &quot;ticketId&quot;: &quot;1234&quot;,\r\n    &quot;requester_id&quot;: &quot;99885&quot;\r\n  }\r\n}\r\n```",
        "link": "https://stackoverflow.com/questions/78128389/merging-two-arrays-using-jq-command",
        "title": "Merging two arrays using Jq command"
    },
    {
        "tags": [
            "json",
            "select",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1709978065,
                "post_id": 78131884,
                "comment_id": 137743782,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1042959,
                    "reputation": 668672,
                    "user_id": 1048572,
                    "user_type": "registered",
                    "accept_rate": 77,
                    "profile_image": "https://www.gravatar.com/avatar/7f2c4de95e8f4f8f5a71c3aaf0ed312a?s=256&d=identicon&r=PG",
                    "display_name": "Bergi",
                    "link": "https://stackoverflow.com/users/1048572/bergi"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1709981757,
                "post_id": 78131884,
                "comment_id": 137744052,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1709987900,
                "creation_date": 1709987900,
                "answer_id": 78132343,
                "question_id": 78131884,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can easily chain multiple `select` filters:\r\n\r\n```\r\n.results[]\r\n| select(.cluster.name == $cluster)\r\n| select(.cluster.os == $os)\r\n| .primary_ip.address\r\n```\r\n\r\nor combine multiple predicates with [`and`](https://jqlang.github.io/jq/manual/#and-or-not) (note the case):\r\n\r\n```\r\n.results[]\r\n| select(.cluster.name == $cluster and .cluster.os == $os)\r\n| .primary_ip.address\r\n```\r\n\r\nThe result is identical.\r\n\r\nTo check if a string [`contains`](https://jqlang.github.io/jq/manual/#contains) another substring, you&#39;d use:\r\n\r\n```\r\n.results[]\r\n| select(.cluster.name == $cluster)\r\n| select(.cluster.os | contains($os))\r\n| .primary_ip.address\r\n```\r\n",
                "title": "JSON JQ - filter with two statements"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1710055755,
        "creation_date": 1709977619,
        "last_edit_date": 1710055755,
        "question_id": 78131884,
        "body_markdown": "I&#39;m using the below which is working perfectly but I want to add one more variable to the filtering, preferably &quot;contains&quot; as I want to filter this one based on a OS field which contains different strings:\r\n\r\n&gt; curl -H &quot;Accept: application/json; indent=4&quot; -H &quot;Authorization: Token $token&quot; &quot;$url_devices&quot; -k | jq -r --arg device &quot;$device&quot; &#39;.results[] | **select(.cluster.name == $cluster)** | .primary_ip.address&#39;\r\n\r\nThank you in advance! I tried the following code, but it didn&#39;t work:\r\n\r\n&gt; curl -H &quot;Accept: application/json; indent=4&quot; -H &quot;Authorization: Token $token&quot; &quot;$url_devices&quot; -k | jq -r --arg device &quot;$device&quot; &#39;.results[] | **select(.cluster.name == $cluster AND .cluster.os == $os)** | .primary_ip.address&#39;\r\n\t",
        "link": "https://stackoverflow.com/questions/78131884/json-jq-filter-with-two-statements",
        "title": "JSON JQ - filter with two statements"
    },
    {
        "tags": [
            "linux",
            "shell",
            "command-line",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 212394,
                    "reputation": 187080,
                    "user_id": 465183,
                    "user_type": "registered",
                    "accept_rate": 77,
                    "profile_image": "https://i.sstatic.net/yhE6n.jpg?s=256",
                    "display_name": "Gilles Qu&#233;not",
                    "link": "https://stackoverflow.com/users/465183/gilles-qu%c3%a9not"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1710193227,
                "post_id": 78143536,
                "comment_id": 137764258,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 212394,
                    "reputation": 187080,
                    "user_id": 465183,
                    "user_type": "registered",
                    "accept_rate": 77,
                    "profile_image": "https://i.sstatic.net/yhE6n.jpg?s=256",
                    "display_name": "Gilles Qu&#233;not",
                    "link": "https://stackoverflow.com/users/465183/gilles-qu%c3%a9not"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1710193270,
                "post_id": 78143536,
                "comment_id": 137764263,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1613587,
                    "reputation": 786618,
                    "user_id": 1491895,
                    "user_type": "registered",
                    "accept_rate": 69,
                    "profile_image": "https://www.gravatar.com/avatar/82f9e178a16364bf561d0ed4da09a35d?s=256&d=identicon&r=PG",
                    "display_name": "Barmar",
                    "link": "https://stackoverflow.com/users/1491895/barmar"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1710193347,
                "post_id": 78143536,
                "comment_id": 137764272,
                "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": 1710193524,
                "post_id": 78143536,
                "comment_id": 137764293,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 6229027,
                    "reputation": 31628,
                    "user_id": 4850040,
                    "user_type": "registered",
                    "accept_rate": 62,
                    "profile_image": "https://i.sstatic.net/acYd0.png?s=256",
                    "display_name": "Toby Speight",
                    "link": "https://stackoverflow.com/users/4850040/toby-speight"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1710232710,
                "post_id": 78143536,
                "comment_id": 137767906,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1710193884,
                "creation_date": 1710193884,
                "answer_id": 78143585,
                "question_id": 78143536,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If I correctly understand your formatting, you want\r\n\r\n```sh\r\n.fields[] | [\r\n\r\n  # .name in quotes (what about escaping?)\r\n  &quot;\\&quot;\\(.name)\\&quot;&quot;,\r\n\r\n  # .type.type or .type[] or .type as a scalar, filtering out null\r\n  (.type | objects.type // arrays[] // . | select(. != &quot;null&quot;)),\r\n\r\n  # .default, only if it exists\r\n  (select(has(&quot;default&quot;)).default | tostring)\r\n\r\n] | join(&quot; &quot;)\r\n```\r\n\r\nUse it as `jq -r &#39;…&#39; file.json` to get\r\n```\r\n&quot;shopId&quot; string\r\n&quot;productId&quot; string\r\n&quot;sourceId&quot; string\r\n&quot;timestampTransmission&quot; long\r\n&quot;productQuantity&quot; double null\r\n```\r\n[Demo](https://jqplay.org/s/_MrnovCuE9m)",
                "title": "Exploring json with command lines"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1710193884,
        "creation_date": 1710193035,
        "last_edit_date": 1710193578,
        "question_id": 78143536,
        "body_markdown": "Can someone helps me finding out a solution for this problem with a command line?\r\nHere&#39;s my Json file : \r\n\r\n```json\r\n{\r\n  &quot;type&quot;: &quot;record&quot;,\r\n  &quot;name&quot;: &quot;ShelfEx &#187;position,\r\n  &quot;fields&quot;: [\r\n    {\r\n      &quot;name&quot;: &quot;shopId&quot;,\r\n      &quot;type&quot;: {\r\n        &quot;type&quot;: &quot;string&quot;,\r\n        &quot;avro.java.string&quot;: &quot;String&quot;\r\n      },\r\n      &quot;doc&quot;: &quot;Id of the shop&quot;\r\n    },\r\n    {\r\n      &quot;name&quot;: &quot;productId&quot;,\r\n      &quot;type&quot;: {\r\n        &quot;type&quot;: &quot;string&quot;,\r\n        &quot;avro.java.string&quot;: &quot;String&quot;\r\n      },\r\n      &quot;doc&quot;: &quot;Id of the product&quot;\r\n    },\r\n    {\r\n      &quot;name&quot;: &quot;sourceId&quot;,\r\n      &quot;type&quot;: {\r\n        &quot;type&quot;: &quot;string&quot;,\r\n        &quot;avro.java.string&quot;: &quot;String&quot;\r\n      },\r\n      &quot;doc&quot;: &quot;Id of the source&quot;\r\n    },\r\n    {\r\n      &quot;name&quot;: &quot;timestampTransmission&quot;,\r\n      &quot;type&quot;: &quot;long&quot;,\r\n      &quot;doc&quot;: &quot;Timestamp of the message&quot;\r\n    },\r\n    {\r\n      &quot;name&quot;: &quot;productQuantity&quot;,\r\n      &quot;type&quot;: [\r\n        &quot;null&quot;,\r\n        &quot;double&quot;\r\n      ],\r\n      &quot;doc&quot;: &quot;Quantity of the product&quot;,\r\n      &quot;default&quot;: null\r\n    }\r\n  ]\r\n}\r\n```\r\n\r\nand i want to get the name of each field, with it&#39;s type and eventually it&#39;s default value (null in the case of productQuantity).\r\nSo the output should but something like :\r\n\r\n```\r\n&quot;shopId&quot; string\r\n&quot;productId&quot; string\r\n...\r\n&quot;timestampTransmission&quot; long\r\n&quot;productQuantity&quot; double null\r\n```\r\n\r\nAny idea please?\r\n\r\n    `cat file.json | jq -r &#39;.fields[] | &quot;\\&quot;\\(.name)\\&quot; : \\(.type | tostring | sub(&quot;^(null)$&quot;; &quot;\\\\1 :     null&quot;) | sub(&quot;(^\\&quot;|\\&quot;$)&quot;; &quot;&quot;))&quot;&#39;`\r\n\r\nInstead of : \r\n    \r\n    &quot;shopId&quot; string\r\n    &quot;productId&quot; string\r\n    ...\r\n    &quot;timestampTransmission&quot; long\r\n    &quot;productQuantity&quot; double null\r\n\r\ni had :\r\n\r\n    &quot;shopId&quot; : {&quot;type&quot;:&quot;string&quot;,&quot;avro.java.string&quot;:&quot;String&quot;}\r\n    &quot;productId&quot; : {&quot;type&quot;:&quot;string&quot;,&quot;avro.java.string&quot;:&quot;String&quot;}\r\n    &quot;sourceId&quot; : {&quot;type&quot;:&quot;string&quot;,&quot;avro.java.string&quot;:&quot;String&quot;}\r\n    &quot;timestampTransmission&quot; : long\r\n    &quot;productQuantity&quot; : [&quot;null&quot;,&quot;double&quot;]",
        "link": "https://stackoverflow.com/questions/78143536/exploring-json-with-command-lines",
        "title": "Exploring json with command lines"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1710367349,
                "creation_date": 1710367349,
                "answer_id": 78157047,
                "question_id": 78157031,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "&gt; I just want the exact same json, but filtering out prop3,prop4 and nestedprop2\r\n\r\nUpdate each item in the array by deleting what you want to be filtered out:\r\n```sh\r\n.data[] |= del(.prop3, .prop4, .nestedprops.nestedprop2)\r\n```\r\n[Demo](https://jqplay.org/s/D-I2Mqjg6dl)\r\n\r\n&gt; I want to filter in the whole tree for prop1, prop2 and nestedprop1\r\n\r\nUpdate each item by picking what you need. Filter for non-null values using `values`, and default to an empty object using `//`.\r\n```sh\r\n.data[] |= (pick(.prop1, .prop2, .nestedprops.nestedprop1 | values) // {})\r\n```\r\n[Demo](https://jqplay.org/s/j1ndjRV3YCL)",
                "title": "In jq, how to select the desired properties at all levels?"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1710369340,
                "last_edit_date": 1710369340,
                "creation_date": 1710367773,
                "answer_id": 78157075,
                "question_id": 78157031,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "To omit specific keys at all levels, you could use `walk`, e.g.\r\n```\r\nwalk(if type == &quot;object&quot; then del(.prop3, .prop4, .nestedprop2) end)\r\n```\r\n\r\nThe above presupposes your jq allows `if ... then ... end`; if not, add the `else .` clause.\r\n\r\n---\r\n\r\nTo keep selected keys recursively in this case is perhaps a bit trickier and depends on the specific requirements.  Here&#39;s one approach:\r\n```\r\ndef keep:\r\n  if type == &quot;object&quot;\r\n  then if has(&quot;prop1&quot;) or has(&quot;prop2&quot;) or has(&quot;nestedprops&quot;)\r\n       then {prop1, prop2, nestedprops} | with_entries( if .value == null then empty end)\r\n       elif has(&quot;nestedprop1&quot;) then {nestedprop1}\r\n       else {}\r\n       end\r\n  else .\r\n  end;\r\n\r\n.data |= walk(keep)\r\n\r\n```",
                "title": "In jq, how to select the desired properties at all levels?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1710369340,
        "creation_date": 1710367090,
        "question_id": 78157031,
        "body_markdown": "It seems a pretty basic need, but I can&#39;t find it in the tutorial\r\n\r\nImagine we got an object like:\r\n\r\n    {&quot;data&quot;:[\r\n      {&quot;prop1&quot;:&quot;a&quot;, &quot;prop2&quot;:&quot;b&quot;, &quot;prop3&quot;:&quot;c&quot;, &quot;prop4&quot;:&quot;d&quot;, &quot;nestedprops&quot;:{&quot;nestedprop1&quot;:&quot;A&quot;,&quot;nestedprop2&quot;:&quot;B&quot;} },\r\n      {&quot;prop2&quot;:&quot;b&quot;, &quot;prop3&quot;:&quot;c&quot;, &quot;nestedprops&quot;:{&quot;nestedprop1&quot;:&quot;A&quot;}},\r\n      {&quot;prop3&quot;:&quot;c&quot;}\r\n    ]}\r\n\r\nI just want the exact same json, but filtering out prop3,prop4 and nestedprop2, \r\nor in other words, I want to filter in the whole tree for prop1, prop2 and nestedprop1\r\n\r\n    {&quot;data&quot;:[\r\n      {&quot;prop1&quot;:&quot;a&quot;, &quot;prop2&quot;:&quot;b&quot;, &quot;nestedprops&quot;:{&quot;nestedprop1&quot;:&quot;A&quot;} },\r\n      {&quot;prop2&quot;:&quot;b&quot;, &quot;nestedprops&quot;:{&quot;nestedprop1&quot;:&quot;A&quot;}},\r\n      {}\r\n    ]}\r\n \r\nI&#39;m trying with jq &#39;.data[] | {prop1,prop2,nestedprops:{nestedprop1}}&#39; and the like but I can&#39;t find it",
        "link": "https://stackoverflow.com/questions/78157031/in-jq-how-to-select-the-desired-properties-at-all-levels",
        "title": "In jq, how to select the desired properties at all levels?"
    },
    {
        "tags": [
            "bash",
            "curl",
            "post",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 9629731,
                    "reputation": 51350,
                    "user_id": 10248678,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d8f818402f22d485b135a3b685ef908e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "oguz ismail",
                    "link": "https://stackoverflow.com/users/10248678/oguz-ismail"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1710431276,
                "post_id": 78161552,
                "comment_id": 137796322,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 7049989,
                    "reputation": 108,
                    "user_id": 5399432,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/321cce894eca41e1a467f854129bd106?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "maxosh22",
                    "link": "https://stackoverflow.com/users/5399432/maxosh22"
                },
                "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": 1710431914,
                "post_id": 78161552,
                "comment_id": 137796448,
                "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": 1710436403,
                "post_id": 78161552,
                "comment_id": 137797303,
                "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": 1710436468,
                "post_id": 78161552,
                "comment_id": 137797313,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 7049989,
                    "reputation": 108,
                    "user_id": 5399432,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/321cce894eca41e1a467f854129bd106?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "maxosh22",
                    "link": "https://stackoverflow.com/users/5399432/maxosh22"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1710436615,
                "post_id": 78161552,
                "comment_id": 137797340,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 6,
                "is_accepted": true,
                "score": 6,
                "last_activity_date": 1710776170,
                "last_edit_date": 1710776170,
                "creation_date": 1710436262,
                "answer_id": 78162277,
                "question_id": 78161552,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "In the end it was a syntax problem. To fix this issue I needed to change the -h to -H. After fixing the initial issue I also had to wrap the data object in double quotes e.g. &quot;$mergedTest&quot;. The script then worked as desired.\r\n\r\nDocs showing &#39;-H&#39; required syntactically: https://ec.haxx.se/http/post/content-type.html\r\n\r\nIn regards to the lack of double quotes around my $mergedTest variable.\r\n\r\nTo quote Charles Duffy &quot;you risk the contents of mergedTest being split on whitespace, having those individidual components expanded as globs, and then being sent to curl as several separate, smaller arguments&quot;.\r\n\r\nPreviously asked question showing why double quotes should be used: https://stackoverflow.com/questions/29378566/i-just-assigned-a-variable-but-echo-variable-shows-something-else",
                "title": "Why does curl return &quot;Usage: curl [options...] &lt;url&gt; Invalid category provided&quot; when running in bash script?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1710776170,
        "creation_date": 1710429350,
        "question_id": 78161552,
        "body_markdown": "I&#39;m trying to create a POST request in a .sh file that posts some json stored in a variable. After the POST it should store the response of the post for me to check via echo. I&#39;m doing this in a pipeline that&#39;s using curl 7.81.0. When I run the code I get:\r\n\r\nUsage: curl [options...] &lt;url&gt; Invalid category provided, here is a list of all categories: auth Different types of authentication methods connection Low level networking operations curl The command line tool itself dns General DNS options file FILE protocol options ftp FTP protocol options http HTTP and HTTPS protocol options imap IMAP protocol options misc Options that don&#39;t fit into any other category output Filesystem output pop3 POP3 protocol options post HTTP Post specific options proxy All options related to proxies scp SCP protocol options sftp SFTP protocol options smtp SMTP protocol options ssh SSH protocol options telnet TELNET protocol options tftp TFTP protocol options tls All TLS/SSL related options upload All options for uploads verbose Options related to any kind of command line output of curl\r\n\r\n\r\nI have a curl Get request that happens earlier in the file that works.\r\n\r\n```\r\ntest=$(curl -X GET &quot;https://test.com/test/test&quot; -u username:password | jq &#39;{id, things}&#39; &gt; test.json)\r\n```\r\n\r\nWhen I run a similar post I get the issue:\r\n\r\n```\r\n{\r\n  jq -cn  --arg url $url  --arg key $key &#39;{things: { stuff: $ARGS.named}}&#39;\r\n} | jq -s add &gt; newTest.json\r\n\r\nmergedTest=$(jq -s &#39;.[0] * .[1]&#39; test.json newTest.json)\r\n\r\ntest2=$(curl -X POST https://test.com/test/test -u username:password -h &quot;Content-Type: application/json&quot; --data $mergedTest)\r\necho $test2\r\n```\r\n\r\nAny help would be appreciated.",
        "link": "https://stackoverflow.com/questions/78161552/why-does-curl-return-usage-curl-options-url-invalid-category-provided",
        "title": "Why does curl return &quot;Usage: curl [options...] &lt;url&gt; Invalid category provided&quot; when running in bash script?"
    },
    {
        "tags": [
            "python",
            "arrays",
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 1393836,
                    "reputation": 43370,
                    "user_id": 1324033,
                    "user_type": "registered",
                    "accept_rate": 97,
                    "profile_image": "https://i.sstatic.net/PaonW.png?s=256",
                    "display_name": "Sayse",
                    "link": "https://stackoverflow.com/users/1324033/sayse"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1710501420,
                "post_id": 78166506,
                "comment_id": 137804626,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 10275035,
                    "reputation": 121775,
                    "user_id": 7582247,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/KPNHoVDG.png?s=256",
                    "display_name": "Ted Lyngmo",
                    "link": "https://stackoverflow.com/users/7582247/ted-lyngmo"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1710501492,
                "post_id": 78166506,
                "comment_id": 137804636,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 39208,
                    "reputation": 267964,
                    "user_id": 112968,
                    "user_type": "registered",
                    "accept_rate": 68,
                    "profile_image": "https://i.sstatic.net/zHTaT.png?s=256",
                    "display_name": "knittl",
                    "link": "https://stackoverflow.com/users/112968/knittl"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1710761704,
                "post_id": 78166506,
                "comment_id": 137827987,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1710762078,
                "creation_date": 1710762078,
                "answer_id": 78179936,
                "question_id": 78166506,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Python has loops (and list comprehensions) that can be used here.\r\n\r\n```\r\nb = []\r\nfor cis in data1[&#39;cis&#39;]:\r\n  name = cis[&#39;properties&#39;][&#39;cloud_vm_display_name&#39;]\r\n  if not &#39;null&#39; in name:\r\n    b.append(name)\r\nprint(b)\r\n```\r\n\r\nWith a list comprehension:\r\n\r\n```\r\nb = [cis[&#39;properties&#39;][&#39;cloud_vm_display_name&#39;] for cis in data1[&#39;cis&#39;] if not &#39;null&#39; in cis[&#39;properties&#39;][&#39;cloud_vm_display_name&#39;]]\r\n```\r\n\r\nor a generator expression to prepare the data and a list comprehension to filter the desired names:\r\n\r\n```\r\nnames = (cis[&#39;properties&#39;][&#39;cloud_vm_display_name&#39;] for cis in data1[&#39;cis&#39;])\r\nb = [name for name in names if not &#39;null&#39; in name]\r\n```\r\n\r\nNote that this implements the same behavior as your `grep` example: any name that contains null anywhere (e.g. &quot;nullified&quot; or &quot;anulled&quot;), will not be part of the resulting list. You probably meant `grep -vx` or `name == &#39;null&#39;`, respectively. Even better, don&#39;t use grep at all, but filter with jq directly: `.cis[].properties.cloud_vm_display_name | values`.",
                "title": "jq equivalent in python"
            },
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1712555456,
                "creation_date": 1712555456,
                "answer_id": 78290433,
                "question_id": 78166506,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "My requirement was to collect file system details of Windows server deployed in Azure.\r\nThe CMDB tool was collecting complete information of all Windows server and to get desired information via API call was not successful because the properties number was varying for every server, hence, I used below mechanism to retrieve the data.\r\nThanks to all members for suggestion, might be I was not able to describe my issue properly.\r\n \r\n        cis[103].properties.mount_point --&gt; for one server\r\n        cis[333].properties.mount_point --&gt; for another server\r\n        cis[348].properties.mount_point\r\n\r\nI managed it using following method:-\r\n\r\n    for line in cidet:\r\n     line_number += 1\r\n     target_number = &#39;&quot;type&quot; : &quot;file_system&quot;&#39;\r\n     if target_number in line:\r\n          fir_num = line_number\r\n          last_num = fir_num + 40\r\n          lin1 = fir_num + 20\r\n          lin2 = fir_num + 22\r\n          lin3 = fir_num + 36\r\n          mt_pt = open(&quot;/home/&quot;+udcid+&quot;&quot;,&quot;r&quot;).readlines()[lin1]\r\n          mt_pt = mt_pt.strip(&#39;&quot;mount_point&quot; : &quot;&#39;)\r\n          mt_pt = mt_pt.strip(&#39;&quot;,\\n&#39;)\r\n          dk_sz = open(&quot;/home/&quot;+udcid+&quot;&quot;,&quot;r&quot;).readlines()[lin2]\r\n          dk_sz = dk_sz.strip(&#39;&quot;disk_size&quot; : &quot;&#39;)\r\n          dk_sz = dk_sz.strip(&#39;&quot;,\\n&#39;)\r\n          fr_sp = open(&quot;/home/a&quot;+udcid+&quot;&quot;,&quot;r&quot;).readlines()[lin3]\r\n          fr_sp = fr_sp.strip(&#39;&quot;free_space&quot; : &quot;&#39;)",
                "title": "jq equivalent in python"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1712555456,
        "creation_date": 1710501324,
        "last_edit_date": 1710761783,
        "question_id": 78166506,
        "body_markdown": "    cat * | jq &#39;.cis[].properties.cloud_vm_display_name&#39; | grep -v null\r\n&quot;azuXXXXX&quot;\r\n&quot;azuXXXXX&quot;\r\n&quot;azuXXXXXX&quot;\r\n&quot;azuXXXXXX&quot;\r\n\r\nNeed to extract cloud VM name from multiple json files where the array number is different in every file.\r\n\r\n    a = data1[&#39;cis&#39;][0][&#39;properties&#39;][&#39;TenantsUses&#39;][0]\r\n    print(a)\r\n    b = data1[&#39;cis&#39;][][&#39;properties&#39;][&#39;cloud_vm_display_name&#39;]\r\n\r\n```\r\nFile &quot;&lt;stdin&gt;&quot;, line 17\r\nb = data1[&#39;cis&#39;][][&#39;properties&#39;][&#39;cloud_vm_display_name&#39;]\r\n                 ^\r\nSyntaxError: invalid syntax\r\n```\r\n\r\nprint(a) is providing correct output but the value [] for variable b is not known, need your support in finding the output.\r\n\r\n\r\nTo find the VM name from various json files which are generated for different servers.",
        "link": "https://stackoverflow.com/questions/78166506/jq-equivalent-in-python",
        "title": "jq equivalent in python"
    },
    {
        "tags": [
            "cygwin",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1710509388,
                "creation_date": 1710509388,
                "answer_id": 78167277,
                "question_id": 78167276,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Try `strace jq`:\r\n\r\n~~~~\r\n$ strace jq\r\n--- Process 15008 created\r\n--- Process 15008 loaded C:\\Windows\\System32\\ntdll.dll at 00007ffa97ab0000\r\n--- Process 15008 loaded C:\\Windows\\System32\\kernel32.dll at 00007ffa97990000\r\n--- Process 15008 loaded C:\\Windows\\System32\\KernelBase.dll at 00007ffa952c0000\r\n--- Process 15008 thread 6216 created\r\n--- Process 15008 thread 14800 created\r\n--- Process 15008 loaded C:\\cygwin64\\bin\\cygjq-1.dll at 00000005be860000\r\n--- Process 15008 loaded C:\\cygwin64\\bin\\cygwin1.dll at 00007ffa2b080000\r\n--- Process 15008 thread 17460 created\r\n--- Process 15008 thread 6216 exited with status 0xc0000135\r\n--- Process 15008 thread 16484 exited with status 0xc0000135\r\n--- Process 15008 thread 14800 exited with status 0xc0000135\r\n--- Process 15008 exited with status 0xc0000135\r\n~~~~\r\nFinally you get a dialog box that says:\r\n\r\n    cygonig-5.dll was not found\r\n\r\nhttps://cygwin.com/cgi-bin2/package-grep.cgi?grep=cygoni tells you that this is probably in libonig5, so:\r\n\r\n    apt-cyg install libonig5\r\n\r\nAnd now `jq` works.",
                "title": "jq: C:/cygwin64/bin/jq.exe: error while loading shared libraries: ?: cannot open shared object"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1710571631,
                "creation_date": 1710571631,
                "answer_id": 78170847,
                "question_id": 78167276,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "While Ole answer is correct, a more fast solution is to use `cygcheck`.\r\n\r\n    $ cygcheck  jq |grep -iv system32\r\n    cygcheck: track_down: could not find cygonig-5.dll\r\n    \r\n    Found: C:\\cygwin64\\bin\\jq.exe\r\n    C:\\cygwin64\\bin\\jq.exe\r\n      C:\\cygwin64\\bin\\cygjq-1.dll\r\n        C:\\cygwin64\\bin\\cygwin1.dll\r\n\r\nCygcheck will also help to find the proper package to install\r\n\r\n    $ cygcheck  -p cygonig-5.dll\r\n    Found 6 matches for cygonig-5.dll\r\n    libonig5-6.9.1-1 - libonig5: Oniguruma regular expressions library (runtime)\r\n    libonig5-6.9.4-1 - libonig5: Oniguruma regular expressions library (runtime)\r\n    libonig5-6.9.9-1 - libonig5: Regular expressions library (runtime)\r\n    ...\r\n\r\nMy general recommendation is to install any Cygwin package using its own setup   \r\nhttps://cygwin.com/setup-x86_64.exe\r\n\r\nin this way all the dependencies are properly managed.\r\n\r\n\r\n",
                "title": "jq: C:/cygwin64/bin/jq.exe: error while loading shared libraries: ?: cannot open shared object"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1710571631,
        "creation_date": 1710509388,
        "last_edit_date": 1710509489,
        "question_id": 78167276,
        "body_markdown": "`jq` fails with:\r\n\r\n    $ jq\r\n    C:/cygwin64/bin/jq.exe: error while loading shared libraries: ?: cannot open shared object file: No such file or directory\r\n\r\nHow can I find out which libary was missing?\r\n",
        "link": "https://stackoverflow.com/questions/78167276/jq-c-cygwin64-bin-jq-exe-error-while-loading-shared-libraries-cannot-open",
        "title": "jq: C:/cygwin64/bin/jq.exe: error while loading shared libraries: ?: cannot open shared object"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1710517812,
                "creation_date": 1710517812,
                "answer_id": 78168150,
                "question_id": 78168096,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You&#39;ll need to remember `.now` before looping (`[]`) deeper.\r\n\r\nStart your filter with `.now as $now | ...`\r\n\r\nThen in the array you create to keep some data, you can use `$now` as needed:\r\n```\r\n.now as $now \r\n    | .aircraft[] \r\n    | [.lon, .lat, .alt_baro, .seen_pos, .hex, ($now - .seen_pos) ] \r\n    | select(.[0] &gt; 7) | select(.[0] &lt; 10) | select(.[1] &gt; 49) | select(.[1] &lt; 51) | select(.[2] != null) | select(.[2] != &quot;ground&quot;) | select(.[2] &lt; 13000) \r\n    | @csv\r\n```\r\n\r\nOutput:\r\n```none\r\n7.385010,49.848068,5250,0.180,&quot;3c4dc5&quot;,1685613599.699\r\n```\r\n\r\nAs you can test in [this online JqPlay Demo](https://jqplay.org/s/0AEGNO4xIQ_h).\r\n\r\n\r\n----------\r\n\r\nAn additional tip, consider using `select()` on the object itself, you&#39;re now creating a new array even tho `select` will ignore that object, something like this will prevent creating new arrays when it&#39;s not needed and stuff like `.lon &lt; 7` is a lot more readable then `.[0] &lt; 7`.\r\n```\r\n.now as $now \r\n    | .aircraft[] \r\n    | select(.lon &gt; 7 or .lat &lt; 10)\r\n    | [.lon, .lat, .alt_baro, .seen_pos, .hex, ($now - .seen_pos) ] \r\n    | @csv\r\n```",
                "title": "How to subtract inner array value from outer array value?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1710530720,
        "creation_date": 1710517297,
        "last_edit_date": 1710530720,
        "question_id": 78168096,
        "body_markdown": "I have the following `test.json` file:\r\n\r\n    {\r\n        &quot;now&quot;: 1685613599.879,\r\n        &quot;messages&quot;: 1347296469,\r\n        &quot;aircraft&quot;: [\r\n          {\r\n            &quot;hex&quot;: &quot;7c806e&quot;,\r\n            &quot;type&quot;: &quot;adsc&quot;,\r\n            &quot;flight&quot;: &quot;QF94    &quot;,\r\n            &quot;r&quot;: &quot;VH-ZNK&quot;,\r\n            &quot;t&quot;: &quot;B789&quot;,\r\n            &quot;alt_baro&quot;: 34000,\r\n            &quot;gs&quot;: 475.0,\r\n            &quot;track&quot;: 231.55,\r\n            &quot;lat&quot;: 12.694702,\r\n            &quot;lon&quot;: -146.525860,\r\n            &quot;nic&quot;: 0,\r\n            &quot;rc&quot;: 0,\r\n            &quot;seen_pos&quot;: 24.752,\r\n            &quot;alert&quot;: 0,\r\n            &quot;spi&quot;: 0,\r\n            &quot;mlat&quot;: [],\r\n            &quot;tisb&quot;: [],\r\n            &quot;messages&quot;: 6145890,\r\n            &quot;seen&quot;: 24.8,\r\n            &quot;rssi&quot;: -49.5\r\n          },\r\n          {\r\n            &quot;hex&quot;: &quot;3c4dc5&quot;,\r\n            &quot;type&quot;: &quot;adsb_icao&quot;,\r\n            &quot;flight&quot;: &quot;DLH9LL  &quot;,\r\n            &quot;r&quot;: &quot;D-ACNE&quot;,\r\n            &quot;t&quot;: &quot;CRJ9&quot;,\r\n            &quot;alt_baro&quot;: 5250,\r\n            &quot;gs&quot;: 253.3,\r\n            &quot;track&quot;: 182.72,\r\n            &quot;lat&quot;: 49.848068,\r\n            &quot;lon&quot;: 7.385010,\r\n            &quot;nic&quot;: 8,\r\n            &quot;rc&quot;: 186,\r\n            &quot;seen_pos&quot;: 0.180,\r\n            &quot;alert&quot;: 0,\r\n            &quot;spi&quot;: 0,\r\n            &quot;mlat&quot;: [],\r\n            &quot;tisb&quot;: [],\r\n            &quot;messages&quot;: 9278490,\r\n            &quot;seen&quot;: 0.2,\r\n            &quot;rssi&quot;: -9.7\r\n          }\r\n        ]\r\n      }\r\n      \r\n\r\nI&#39;m matching certain `aircraft` with several `select` statements:\r\n\r\n```\r\njq -r &#39;.aircraft[] | [.lon, .lat, .alt_baro, .seen_pos, .hex ] | select(.[0] &gt; 7) | select(.[0] &lt; 10) | select(.[1] &gt; 49) | select(.[1] &lt; 51) | select(.[2] != null) | select(.[2] != &quot;ground&quot;) | select(.[2] &lt; 13000) | @csv&#39; test.json\r\n````\r\n\r\nThis part works fine (matches the second `aircraft` from the example above):\r\n\r\n```\r\n7.385010,49.848068,5250,0.180,&quot;3c4dc5&quot;\r\n```\r\n\r\nNow my problem: I&#39;m struggling with doing some math on the fly. I want to subtract `seen_pos` from `now` and use that value in the result. My result should look like \r\n\r\n```\r\n7.385010,49.848068,5250,1685613599.699,&quot;3c4dc5&quot;\r\n```\r\nI can&#39;t figure out how to access `now` from the outer array. Would you kindly nudge me in the right direction?",
        "link": "https://stackoverflow.com/questions/78168096/how-to-subtract-inner-array-value-from-outer-array-value",
        "title": "How to subtract inner array value from outer array value?"
    },
    {
        "tags": [
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 9629731,
                    "reputation": 51350,
                    "user_id": 10248678,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d8f818402f22d485b135a3b685ef908e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "oguz ismail",
                    "link": "https://stackoverflow.com/users/10248678/oguz-ismail"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1710643931,
                "post_id": 78173589,
                "comment_id": 137817749,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1710631126,
                "creation_date": 1710631126,
                "answer_id": 78173611,
                "question_id": 78173589,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can do it with a single call to jq like this :\r\n\r\n```\r\njq -n &#39;reduce inputs as $i({};. * $i)&#39; file{1..4}.json\r\n```",
                "title": "Combine an arbitrary number of JSON files with jq"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1710643099,
                "last_edit_date": 1710643099,
                "creation_date": 1710640879,
                "answer_id": 78173873,
                "question_id": 78173589,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Be aware that `*` potentially does more than you might think.\r\n(See https://jqlang.github.io/jq/manual/v1.7/#multiplication-division-modulo for details.)\r\n\r\nThe &quot;+&quot; operator on objects is much less complicated, so chances are that something like the following will meet your needs:\r\n\r\n    jq -n &#39;[inputs] | add&#39; file*.json",
                "title": "Combine an arbitrary number of JSON files with jq"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1710813449,
                "creation_date": 1710813449,
                "answer_id": 78183878,
                "question_id": 78173589,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Doesn&#39;t really combine files like `.[0] * .[1]` but will merge an any number of files into a single object\r\n\r\n```sh\r\njq -n &#39;reduce inputs as $s (.; .[input_filename] += $s)&#39; *.json\r\n```\r\n\r\nExample output: combine `cars.json`, `cities.json`, `contacts.json`, and `countries.json`\r\n\r\n```json\r\n{\r\n  &quot;cars.json&quot;: [\r\n    {\r\n      &quot;name&quot;: &quot;AMC Ambassador Brougham&quot;,\r\n      &quot;brand&quot;: &quot;AMC&quot;,\r\n      &quot;economy_mpg_&quot;: 13,\r\n      &quot;cylinders&quot;: 8,\r\n      &quot;displacement_cc_&quot;: 360,\r\n      &quot;power_hp_&quot;: 175,\r\n      &quot;weight_lb_&quot;: 3821,\r\n      &quot;0_60_mph_s_&quot;: 11,\r\n      &quot;year&quot;: 1973\r\n    }\r\n  ],\r\n  &quot;cities.json&quot;: [\r\n    {\r\n      &quot;Continent&quot;: &quot;Asia&quot;,\r\n      &quot;Country&quot;: &quot;China&quot;,\r\n      &quot;City&quot;: &quot;Shanghai&quot;,\r\n      &quot;Population&quot;: 24256800\r\n    }\r\n  ],\r\n  &quot;contacts.json&quot;: [\r\n    {\r\n      &quot;person&quot;: {\r\n        &quot;personid&quot;: 123456,\r\n        &quot;name&quot;: &quot;Person 1&quot;,\r\n        &quot;addresses&quot;: {\r\n          &quot;address&quot;: [\r\n            {\r\n              &quot;addressid&quot;: &quot;2&quot;,\r\n              &quot;street&quot;: &quot;Street 2&quot;,\r\n              &quot;postcode&quot;: &quot;1234 AB&quot;,\r\n              &quot;city&quot;: &quot;City 1&quot;\r\n            },\r\n            {\r\n              &quot;addressid&quot;: &quot;2&quot;,\r\n              &quot;street&quot;: &quot;Street 2&quot;,\r\n              &quot;postcode&quot;: &quot;5678 CD&quot;,\r\n              &quot;city&quot;: &quot;City 2&quot;\r\n            }\r\n          ]\r\n        }\r\n      }\r\n    }\r\n  ],\r\n  &quot;countries.json&quot;: [\r\n    {\r\n      &quot;country&quot;: &quot;Afghanistan&quot;,\r\n      &quot;Region&quot;: &quot;ASIA (EX. NEAR EAST)&quot;,\r\n      &quot;Population&quot;: 31056997,\r\n      &quot;Area_square_miles&quot;: 647500,\r\n      &quot;GDP_per_capita&quot;: 700\r\n    }\r\n  ]\r\n}\r\n```",
                "title": "Combine an arbitrary number of JSON files with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": -1,
        "last_activity_date": 1710813449,
        "creation_date": 1710630477,
        "question_id": 78173589,
        "body_markdown": "I can combine 2 json files using jq, thus:\r\n```\r\njq -s &#39;.[0] * .[1]&#39; file1.json file2.json &gt;merged.json\r\n```\r\n\r\nI can combine an arbitrary number of json files by using a loop and on the second and subsequent iterations, used the output of the previous operation as one of the inputs. And with process substitution, that can be done via a pipe:\r\n```\r\njq -s &#39;.[0] * .[1]&#39; file1.json file2.json | \\\r\n   jq -s &#39;.[0] * .[1]&#39; &lt;(cat) file3.json | \\\r\n   jq -s &#39;.[0] * .[1]&#39; &lt;(cat) file4.json ...\r\n```\r\n\r\nBut how can I script merging of an arbitrary number of files without writing intermediate versions? \r\n\r\n(I imagine that with a VERY large number of files I will have issues with ulimits / file handles - I am not concerned about that yet).\r\n",
        "link": "https://stackoverflow.com/questions/78173589/combine-an-arbitrary-number-of-json-files-with-jq",
        "title": "Combine an arbitrary number of JSON files with jq"
    },
    {
        "tags": [
            "json",
            "key",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 1042959,
                    "reputation": 668672,
                    "user_id": 1048572,
                    "user_type": "registered",
                    "accept_rate": 77,
                    "profile_image": "https://www.gravatar.com/avatar/7f2c4de95e8f4f8f5a71c3aaf0ed312a?s=256&d=identicon&r=PG",
                    "display_name": "Bergi",
                    "link": "https://stackoverflow.com/users/1048572/bergi"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1710717400,
                "post_id": 78177249,
                "comment_id": 137823400,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "reply_to_user": {
                    "account_id": 1042959,
                    "reputation": 668672,
                    "user_id": 1048572,
                    "user_type": "registered",
                    "accept_rate": 77,
                    "profile_image": "https://www.gravatar.com/avatar/7f2c4de95e8f4f8f5a71c3aaf0ed312a?s=256&d=identicon&r=PG",
                    "display_name": "Bergi",
                    "link": "https://stackoverflow.com/users/1048572/bergi"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1710717487,
                "post_id": 78177249,
                "comment_id": 137823409,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1042959,
                    "reputation": 668672,
                    "user_id": 1048572,
                    "user_type": "registered",
                    "accept_rate": 77,
                    "profile_image": "https://www.gravatar.com/avatar/7f2c4de95e8f4f8f5a71c3aaf0ed312a?s=256&d=identicon&r=PG",
                    "display_name": "Bergi",
                    "link": "https://stackoverflow.com/users/1048572/bergi"
                },
                "reply_to_user": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1710717832,
                "post_id": 78177249,
                "comment_id": 137823429,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1710717212,
                "creation_date": 1710717212,
                "answer_id": 78177272,
                "question_id": 78177249,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "JSON has a tree-like hierarchy. The top-level (the &quot;root&quot;) in this case is an object. Objects are a set of key-value pairs. You want to extract all keys of that top-level object. `jq` provides two functions that provide those keys in an array: [`keys` and `keys_unsorted`](https://jqlang.github.io/jq/manual/#keys-keys_unsorted). Their difference: the latter returns all the keys in the order they appeared in the input document, while the former additionally sorts that array. Either way, to get your desired output, iterate over that array using [`.[]`](https://jqlang.github.io/jq/manual/#array-object-value-iterator). You can combine the function and the iterator to:\r\n```sh\r\njq -r &#39;keys_unsorted[]&#39; items.json\r\n# or\r\njq -r &#39;keys[]&#39; items.json\r\n```\r\nThe `--raw-output` (or `-r`) flag converts the resulting JSON strings into raw strings.\r\n\r\n[Demo](https://jqplay.org/s/CIHYYHWD0FP)",
                "title": "jq: how to extract a value without a property name"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1710730414,
        "creation_date": 1710716650,
        "last_edit_date": 1710730414,
        "question_id": 78177249,
        "body_markdown": "I am trying to get values out of a json file. However, my file has a value without a property name.\r\n\r\nThe json file, names items.json, looks like this:\r\n```\r\n{\r\n  &quot;AQ_01_Availability&quot;: {\r\n    &quot;class&quot;: &quot;org.openhab.core.items.ManagedItemProvider$PersistedItem&quot;,\r\n    &quot;value&quot;: {\r\n      &quot;groupNames&quot;: [\r\n        &quot;gAirQuality_01&quot;\r\n      ],\r\n      &quot;itemType&quot;: &quot;Switch&quot;,\r\n      &quot;tags&quot;: [],\r\n      &quot;label&quot;: &quot;Availability&quot;\r\n    }\r\n  },\r\n  &quot;AQ_01_CO2&quot;: {\r\n    &quot;class&quot;: &quot;org.openhab.core.items.ManagedItemProvider$PersistedItem&quot;,\r\n    &quot;value&quot;: {\r\n      &quot;groupNames&quot;: [\r\n        &quot;gAirQuality_01&quot;\r\n      ],\r\n      &quot;itemType&quot;: &quot;Number&quot;,\r\n      &quot;tags&quot;: [],\r\n      &quot;label&quot;: &quot;CO2&quot;\r\n    }\r\n  },\r\n  &quot;AQ_01_Formaldehyde&quot;: {\r\n    &quot;class&quot;: &quot;org.openhab.core.items.ManagedItemProvider$PersistedItem&quot;,\r\n    &quot;value&quot;: {\r\n      &quot;groupNames&quot;: [\r\n        &quot;gAirQuality_01&quot;\r\n      ],\r\n      &quot;itemType&quot;: &quot;Number&quot;,\r\n      &quot;tags&quot;: [],\r\n      &quot;label&quot;: &quot;Formaldehyde&quot;\r\n    }\r\n  },\r\n  &quot;AQ_01_Humidity&quot;: {\r\n    &quot;class&quot;: &quot;org.openhab.core.items.ManagedItemProvider$PersistedItem&quot;,\r\n    &quot;value&quot;: {\r\n      &quot;groupNames&quot;: [\r\n        &quot;gAirQuality_01&quot;\r\n      ],\r\n      &quot;itemType&quot;: &quot;Number&quot;,\r\n      &quot;tags&quot;: [],\r\n      &quot;label&quot;: &quot;Humidity&quot;,\r\n      &quot;category&quot;: &quot;humidity&quot;\r\n    }\r\n  }\r\n}\r\n```\r\n\r\nI thought `jq .items[0] items.json` would return the name of each object; but it returns `null`.\r\n\r\nMy desired result would be:\r\n```\r\nAQ_01_Availability\r\nAQ_01_CO2\r\nAQ_01_Formaldehyde\r\nAQ_01_Humidity\r\n```\r\nI have never used jq nor am I too familiar with json. My assumption was a well-structured file, thinking that each object starts with, say, `item_name`.",
        "link": "https://stackoverflow.com/questions/78177249/jq-how-to-extract-a-value-without-a-property-name",
        "title": "jq: how to extract a value without a property name"
    },
    {
        "tags": [
            "arrays",
            "shell",
            "jq",
            "aws-cli"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1710767387,
                "post_id": 78180419,
                "comment_id": 137828960,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1710767883,
                "last_edit_date": 1710767883,
                "creation_date": 1710767493,
                "answer_id": 78180455,
                "question_id": 78180419,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Because that&#39;s still just a string, albeit a string which would represent a valid JSON array if you gave it to a JSON parser; but Bash is not one.\r\n\r\nIf you want to get the output in a Bash array, try\r\n\r\n```\r\ntestoutput=($(aws elbv2 describe-rules \\\r\n    --rule-arns arn:aws:elasticloadbalancing:ap-northeast-1:xxxx:listener-rule/app/k8s-ctrlroute-xxx/xxx/xxx \\\r\n    --region ap-northeast-1 --no-cli-pager |\r\n  jq &#39;[.Rules[0].Conditions[0].Values[]] | @sh&#39;))\r\n```\r\n\r\nThe crucial changes are\r\n\r\n* parentheses around the value to actually assign to an array, not a string scalar\r\n* adding the `| @sh` decorator to the `jq` expression\r\n\r\nAlso, for good measure, single-quote the `jq` expression; and add backslash line wraps to untangle the horrendously long command line.\r\n\r\nThe next inevitable question if you are unfamiliar with Bash arrays is, &quot;how do I examine the array?&quot;\r\n\r\n```\r\nprintf &#39;%s\\n&#39; &quot;${testoutput[@]}&quot;\r\n```\r\nto print all of it, or\r\n\r\n```\r\nfor value in &quot;${testoutput[@]}&quot;; do\r\n    : something with &quot;$value&quot;\r\ndone\r\n```\r\nto loop over them individually.\r\n\r\nBeginners tend to try\r\n\r\n```\r\necho &quot;$testoutput&quot;\r\n```\r\n(even without the quotes, for a true beginner)\r\nand be flabbergasted when it only prints the first element.\r\n\r\nTangentially also [don&#39;t use upper case for your private variables.](https://stackoverflow.com/questions/673055/correct-bash-and-shell-script-variable-capitalization) ",
                "title": "Pipe aws output to jq will not result in array"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1710768229,
                "creation_date": 1710768229,
                "answer_id": 78180532,
                "question_id": 78180419,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "`jq` speaks json, but most programs do not.  If you want to manipulate json, you&#39;ll want to do it with `jq`.\r\n\r\n\r\n```\r\n echo &#39;{&quot;Rules&quot;: [ { &quot;Conditions&quot;:[ { &quot;Values&quot;: [ &quot;host1.cloud&quot;, &quot;host2.cloud&quot;, &quot;host3.cloud&quot; ] } ] } ] }&#39; \\\r\n|jq &#39;.Rules[0].Conditions[0].Values += [&quot;host4.cloud&quot;]&#39;\r\n{\r\n  &quot;Rules&quot;: [\r\n    {\r\n      &quot;Conditions&quot;: [\r\n        {\r\n          &quot;Values&quot;: [\r\n            &quot;host1.cloud&quot;,\r\n            &quot;host2.cloud&quot;,\r\n            &quot;host3.cloud&quot;,\r\n            &quot;host4.cloud&quot;\r\n          ]\r\n        }\r\n      ]\r\n    }\r\n  ]\r\n}\r\n```",
                "title": "Pipe aws output to jq will not result in array"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1710768229,
        "creation_date": 1710767197,
        "question_id": 78180419,
        "body_markdown": "I try to use to get all hosts from an elbv2 LoadBalancer rule to an array to expand the list.\r\nI tried to query the existing hosts inside the rule with\r\n\r\n````\r\nTESTOUTPUT=$(aws elbv2 describe-rules --rule-arns arn:aws:elasticloadbalancing:ap-northeast-1:xxxx:listener-rule/app/k8s-ctrlroute-xxx/xxx/xxx --region ap-northeast-1 --no-cli-pager)\r\n````\r\nworks great, I get the JSON with the hosts back. No I try to parse the output direct to an Array with\r\n````\r\nTESTOUTPUT=$(aws elbv2 describe-rules --rule-arns arn:aws:elasticloadbalancing:ap-northeast-1:xxxx:listener-rule/app/k8s-ctrlroute-xxx/xxx/xxx --region ap-northeast-1 --no-cli-pager | jq [.Rules[0].Conditions[0].Values[]])\r\n````\r\nThe result are the expected hosts. It looks like \r\n````\r\n[ &quot;host1.cloud&quot;, &quot;host2.cloud&quot;, &quot;host3.cloud&quot; ]\r\n````\r\nBut if I not try to add an entry with TESTOUTPUT+=&quot;host4.cloud&quot; I will get\r\n````\r\n[ &quot;host1.cloud&quot;, &quot;host2.cloud&quot;, &quot;host3.cloud&quot; ]host4.cloud\r\n````\r\nSo I assume the expected array is not an array. But the jq output is the syntax for array output.\r\nMaybe someone can borrow me two eyes for a different view on the case to find out what is wrong in my code.",
        "link": "https://stackoverflow.com/questions/78180419/pipe-aws-output-to-jq-will-not-result-in-array",
        "title": "Pipe aws output to jq will not result in array"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": -1,
                "last_activity_date": 1721839163,
                "last_edit_date": 1721839163,
                "creation_date": 1710773337,
                "answer_id": 78181027,
                "question_id": 78181026,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Use `jq -r &#39;paths | map(numbers |= &quot;[\\(.)]&quot;) | join(&quot;.&quot;)&#39;`.\r\n\r\nFor example:\r\n\r\n```bash\r\n$ jq -r &#39;paths | map(numbers |= &quot;[\\(.)]&quot;) | join(&quot;.&quot;)&#39; &lt;&lt;&lt; &#39;{&quot;k1&quot;: &quot;v1&quot;, &quot;k2&quot;: {&quot;k21&quot;: &quot;v21&quot;}, &quot;k3&quot;: {&quot;k31&quot;: {&quot;k311&quot;: &quot;v311&quot;}}, &quot;k4&quot;: [{&quot;k41&quot;: &quot;v41&quot;}, {&quot;k42&quot;: &quot;v42&quot;}], &quot;k5&quot;: {&quot;0&quot;: &quot;v50&quot;, &quot;1&quot;: &quot;v51&quot;}}&#39;\r\nk1\r\nk2\r\nk2.k21\r\nk3\r\nk3.k31\r\nk3.k31.k311\r\nk4\r\nk4.[0]\r\nk4.[0].k41\r\nk4.[1]\r\nk4.[1].k42\r\nk5\r\nk5.0\r\nk5.1\r\n```\r\n\r\nA more succinct expression like `paths | join(&quot;.&quot;)` will render array indices and numeric object keys the same way. That might be not desirable.\r\n\r\n\r\n```bash\r\n$ jq -r &#39;paths | join(&quot;.&quot;)&#39; &lt;&lt;&lt; &#39;{&quot;k1&quot;: &quot;v1&quot;, &quot;k2&quot;: {&quot;k21&quot;: &quot;v21&quot;}, &quot;k3&quot;: {&quot;k31&quot;: {&quot;k311&quot;: &quot;v311&quot;}}, &quot;k4&quot;: [{&quot;k41&quot;: &quot;v41&quot;}, {&quot;k42&quot;: &quot;v42&quot;}], &quot;k5&quot;: {&quot;0&quot;: &quot;v50&quot;, &quot;1&quot;: &quot;v51&quot;}}&#39;\r\nk1\r\nk2\r\nk2.k21\r\nk3\r\nk3.k31\r\nk3.k31.k311\r\nk4\r\nk4.0\r\nk4.0.k41\r\nk4.1\r\nk4.1.k42\r\nk5\r\nk5.0\r\nk5.1\r\n```\r\n\r\nCredit for both solutions goes to @pmf.",
                "title": "How to recursively print the path of all keys in jq"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1742594886,
                "last_edit_date": 1742594886,
                "creation_date": 1710779778,
                "answer_id": 78181690,
                "question_id": 78181026,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "This version handles the cases where keys are not identifiers (have spaces, etc.), and the result can be given back to jq :\r\n\r\n```\r\necho &#39;[{&quot;a&quot;:1},{&quot;a b&quot;:[{&quot;π&quot;:3.14}]}]&#39; |\r\njq -r &#39;\r\n    paths | (if (first|type)==&quot;string&quot; then &quot;&quot; else &quot;.&quot; end) + (map(\r\n        if type==&quot;string&quot;\r\n        then &quot;.&quot; +\r\n             if test(&quot;^[a-zA-Z_][a-zA-Z_0-9]*$&quot;)\r\n             then .\r\n             else .|tojson\r\n             end\r\n        else &quot;[\\(.)]&quot;\r\n        end) |\r\n        join(&quot;&quot;)\r\n    )&#39;\r\n```\r\n```\r\n[0]\r\n[0].a\r\n[1]\r\n[1].&quot;a b&quot;\r\n[1].&quot;a b&quot;[0]\r\n[1].&quot;a b&quot;[0].&quot;π&quot;\r\n```",
                "title": "How to recursively print the path of all keys in jq"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1710820141,
                "last_edit_date": 1710820141,
                "creation_date": 1710798516,
                "answer_id": 78183174,
                "question_id": 78181026,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "To get just the paths of the keys (including the key), consider starting with:\r\n```\r\npaths\r\n| select(.[-1] | type == &quot;string&quot;)\r\n```\r\nFor example:\r\n```\r\n[{a:1},{&quot;a b&quot;:[{c:&quot;2&quot;}]}]\r\n| paths\r\n| select(.[-1] | type == &quot;string&quot;)\r\n```\r\nyields:\r\n```\r\n[0,&quot;a&quot;]\r\n[1,&quot;a b&quot;]\r\n[1,&quot;a b&quot;,0,&quot;c&quot;]\r\n```\r\n\r\nIf you want just the paths to the leaf keys (without their names), then tack on `| .[:-1]` to the filter.\r\n\r\nIf you want some other representation of the path, consider `@csv` as that is &quot;lossless&quot;, unlike `join(&quot;.&quot;)`.\r\n\r\nFor very large JSON documents, the full list of paths will probably not be so helpful if there are arrays in the JSON document.  In that case, you could change all the numeric components to &quot;*&quot; (for example), and then remove redundant lines, e.g. \r\n```\r\ndef uniq(s):\r\n  foreach s as $x (null;\r\n    if . and $x == .[0] then .[1] = false\r\n    else [$x, true]\r\n    end;\r\n    if .[1] then .[0] else empty end);\r\n\r\n[{a: [1,2], x: {&quot;a b&quot;:[{c:2}]} } ]\r\n| paths, &quot;&quot;,\r\n  uniq(paths\r\n   | select(.[-1] | type == &quot;string&quot;)\r\n   | map(if type == &quot;number&quot; then &quot;*&quot; else . end) )\r\n```\r\n\r\nThis produces:\r\n```\r\n[0]\r\n[0,&quot;a&quot;]\r\n[0,&quot;a&quot;,0]\r\n[0,&quot;a&quot;,1]\r\n[0,&quot;x&quot;]\r\n[0,&quot;x&quot;,&quot;a b&quot;]\r\n[0,&quot;x&quot;,&quot;a b&quot;,0]\r\n[0,&quot;x&quot;,&quot;a b&quot;,0,&quot;c&quot;]\r\n\r\n[&quot;*&quot;,&quot;a&quot;]\r\n[&quot;*&quot;,&quot;x&quot;]\r\n[&quot;*&quot;,&quot;x&quot;,&quot;a b&quot;]\r\n[&quot;*&quot;,&quot;x&quot;,&quot;a b&quot;,&quot;*&quot;,&quot;c&quot;]\r\n```\r\n\r\n---\r\nTo understand the structure of large JSON documents, an inferred structural schema can be handy.  To give an idea of what this might mean, let&#39;s use the JSON corresponding to the example immediately above, using [schema.jq][1]:\r\n```\r\njq &#39;include &quot;schema&quot; {search: &quot;./&quot;}; schema&#39; &lt;&lt;&lt; &#39;[{&quot;a&quot;: [1,2], &quot;x&quot;: {&quot;a b&quot;:[{&quot;c&quot;:2}]} } ]&#39;\r\n{\r\n  &quot;a&quot;: [\r\n    &quot;number&quot;\r\n  ],\r\n  &quot;x&quot;: {\r\n    &quot;a b&quot;: [\r\n      {\r\n        &quot;c&quot;: &quot;number&quot;\r\n      }\r\n    ]\r\n  }\r\n}\r\n\r\n```\r\nyields\r\n```\r\n{\r\n  &quot;a&quot;: [\r\n    &quot;number&quot;\r\n  ],\r\n  &quot;x&quot;: {\r\n    &quot;a b&quot;: [\r\n      {\r\n        &quot;c&quot;: &quot;number&quot;\r\n      }\r\n    ]\r\n  }\r\n}\r\n```\r\n\r\n\r\n  [1]: https://gist.github.com/pkoppstein/a5abb4ebef3b0f72a6ed",
                "title": "How to recursively print the path of all keys in jq"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1710814178,
                "creation_date": 1710814178,
                "answer_id": 78183902,
                "question_id": 78181026,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "```sh\r\njq &#39;[paths|(map(if type == &quot;number&quot; then &quot;[]&quot; else &quot;.\\(.)&quot; end)|join(&quot;&quot;))]|unique&#39;\r\n```\r\n\r\nHere&#39;s an example using stocks data from:  \r\nhttps://query1.finance.yahoo.com/v8/finance/chart/GTLB\r\n\r\n```json\r\n[\r\n  &quot;.chart&quot;,\r\n  &quot;.chart.error&quot;,\r\n  &quot;.chart.result&quot;,\r\n  &quot;.chart.result[]&quot;,\r\n  &quot;.chart.result[].indicators&quot;,\r\n  &quot;.chart.result[].indicators.adjclose&quot;,\r\n  &quot;.chart.result[].indicators.adjclose[]&quot;,\r\n  &quot;.chart.result[].indicators.adjclose[].adjclose&quot;,\r\n  &quot;.chart.result[].indicators.adjclose[].adjclose[]&quot;,\r\n  &quot;.chart.result[].indicators.quote&quot;,\r\n  &quot;.chart.result[].indicators.quote[]&quot;,\r\n  &quot;.chart.result[].indicators.quote[].close&quot;,\r\n  &quot;.chart.result[].indicators.quote[].close[]&quot;,\r\n  &quot;.chart.result[].indicators.quote[].high&quot;,\r\n  &quot;.chart.result[].indicators.quote[].high[]&quot;,\r\n  &quot;.chart.result[].indicators.quote[].low&quot;,\r\n  &quot;.chart.result[].indicators.quote[].low[]&quot;,\r\n  &quot;.chart.result[].indicators.quote[].open&quot;,\r\n  &quot;.chart.result[].indicators.quote[].open[]&quot;,\r\n  &quot;.chart.result[].indicators.quote[].volume&quot;,\r\n  &quot;.chart.result[].indicators.quote[].volume[]&quot;,\r\n  &quot;.chart.result[].meta&quot;,\r\n  &quot;.chart.result[].meta.chartPreviousClose&quot;,\r\n  &quot;.chart.result[].meta.currency&quot;,\r\n  &quot;.chart.result[].meta.currentTradingPeriod&quot;,\r\n  &quot;.chart.result[].meta.currentTradingPeriod.post&quot;,\r\n  &quot;.chart.result[].meta.currentTradingPeriod.post.end&quot;,\r\n  &quot;.chart.result[].meta.currentTradingPeriod.post.gmtoffset&quot;,\r\n  &quot;.chart.result[].meta.currentTradingPeriod.post.start&quot;,\r\n  &quot;.chart.result[].meta.currentTradingPeriod.post.timezone&quot;,\r\n  &quot;.chart.result[].meta.currentTradingPeriod.pre&quot;,\r\n  &quot;.chart.result[].meta.currentTradingPeriod.pre.end&quot;,\r\n  &quot;.chart.result[].meta.currentTradingPeriod.pre.gmtoffset&quot;,\r\n  &quot;.chart.result[].meta.currentTradingPeriod.pre.start&quot;,\r\n  &quot;.chart.result[].meta.currentTradingPeriod.pre.timezone&quot;,\r\n  &quot;.chart.result[].meta.currentTradingPeriod.regular&quot;,\r\n  &quot;.chart.result[].meta.currentTradingPeriod.regular.end&quot;,\r\n  &quot;.chart.result[].meta.currentTradingPeriod.regular.gmtoffset&quot;,\r\n  &quot;.chart.result[].meta.currentTradingPeriod.regular.start&quot;,\r\n  &quot;.chart.result[].meta.currentTradingPeriod.regular.timezone&quot;,\r\n  &quot;.chart.result[].meta.dataGranularity&quot;,\r\n  &quot;.chart.result[].meta.exchangeName&quot;,\r\n  &quot;.chart.result[].meta.exchangeTimezoneName&quot;,\r\n  &quot;.chart.result[].meta.firstTradeDate&quot;,\r\n  &quot;.chart.result[].meta.gmtoffset&quot;,\r\n  &quot;.chart.result[].meta.hasPrePostMarketData&quot;,\r\n  &quot;.chart.result[].meta.instrumentType&quot;,\r\n  &quot;.chart.result[].meta.priceHint&quot;,\r\n  &quot;.chart.result[].meta.range&quot;,\r\n  &quot;.chart.result[].meta.regularMarketPrice&quot;,\r\n  &quot;.chart.result[].meta.regularMarketTime&quot;,\r\n  &quot;.chart.result[].meta.symbol&quot;,\r\n  &quot;.chart.result[].meta.timezone&quot;,\r\n  &quot;.chart.result[].meta.validRanges&quot;,\r\n  &quot;.chart.result[].meta.validRanges[]&quot;,\r\n  &quot;.chart.result[].timestamp&quot;,\r\n  &quot;.chart.result[].timestamp[]&quot;\r\n]\r\n```\r\n\r\nThe paths created above can even be used in jq:\r\n\r\n```console\r\n$ jq &#39;.chart.result[].meta.exchangeName&#39; gtlb.json \r\n&quot;NMS&quot;\r\n```\r\n",
                "title": "How to recursively print the path of all keys in jq"
            }
        ],
        "is_answered": true,
        "answer_count": 4,
        "score": 1,
        "last_activity_date": 1742594886,
        "creation_date": 1710773337,
        "last_edit_date": 1721839502,
        "question_id": 78181026,
        "body_markdown": "I&#39;d like to get a list of all paths available in a JSON document, just to get an idea of the layout of a big json document.\r\n\r\n**One liners** preferred, of course a big jq/python program can do the trick.\r\n\r\nExample:\r\n\r\n```bash\r\n$ jq -r &#39;short magic here&#39; &lt;&lt;&lt; &#39;{&quot;k1&quot;: {&quot;k12&quot;: &quot;v12&quot;}, &quot;k2&quot;: {&quot;k21&quot;: {&quot;k211&quot;: &quot;v211&quot;}}}&#39;\r\nk1\r\nk1.k12\r\nk2\r\nk2.k21\r\nk2.k21.k211\r\n```\r\n\r\nThere are variations (not exactly duplicates) of this question like &#39;all paths matching a given pattern&#39; or &#39;print paths plus value&#39;. I&#39;m asking just about the keys, all of them, and a short expression.\r\n\r\nThere is also third parties like [`gron`][1] that prints keys and values colorized.\r\n\r\n\r\n[1]: https://github.com/tomnomnom/gron",
        "link": "https://stackoverflow.com/questions/78181026/how-to-recursively-print-the-path-of-all-keys-in-jq",
        "title": "How to recursively print the path of all keys in jq"
    },
    {
        "tags": [
            "node.js",
            "bash",
            "ubuntu",
            "jq",
            "package.json"
        ],
        "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": 1710957912,
                "post_id": 78195387,
                "comment_id": 137856003,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "user_type": "does_not_exist",
                    "display_name": "user22884804"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1710958074,
                "post_id": 78195387,
                "comment_id": 137856028,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 16872618,
                    "reputation": 1614,
                    "user_id": 12200808,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d7c46fc17be48297d8630ef076e7d780?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "stackbiz",
                    "link": "https://stackoverflow.com/users/12200808/stackbiz"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1710958570,
                "post_id": 78195387,
                "comment_id": 137856105,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 468289,
                    "reputation": 190915,
                    "user_id": 874188,
                    "user_type": "registered",
                    "accept_rate": 62,
                    "profile_image": "https://www.gravatar.com/avatar/091f411d57db5be8298e057a32e5ad72?s=256&d=identicon&r=PG",
                    "display_name": "tripleee",
                    "link": "https://stackoverflow.com/users/874188/tripleee"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1710961469,
                "post_id": 78195387,
                "comment_id": 137856513,
                "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": 1710961824,
                "post_id": 78195387,
                "comment_id": 137856559,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "user_type": "does_not_exist",
                    "display_name": "user7665043"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1710964418,
                "post_id": 78195387,
                "comment_id": 137856898,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1710962792,
                "creation_date": 1710962792,
                "answer_id": 78195834,
                "question_id": 78195387,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The syntax being used (`. += dependencies`) seems incorrect.\r\n\r\nTo add or modify a key in `dependencies`, use the following syntax:\r\n```\r\njq &#39;.dependencies[&quot;foo&quot;]=&quot;1.1.1&quot;&#39; &quot;package.json&quot;\r\n```\r\nThis will output the edited contents. Since we cannot pipe back into the file (it is open for reading while `jq` is being executed), we have to pipe it to a new file and rename it (use the `mv` command for this).\r\n\r\n```\r\njq &#39;.dependencies[&quot;foo&quot;]=&quot;1.1.1&quot;&#39; &quot;package.json&quot; &gt; package.json.new \\\r\n&amp;&amp; mv package.json.new package.json\r\n```\r\n",
                "title": "How to add dependencies into package.json with jq"
            },
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1710965118,
                "creation_date": 1710965118,
                "answer_id": 78195996,
                "question_id": 78195387,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "First of all, all you need is this:\r\n\r\n```sh\r\ncat &lt;&lt;&#39;.&#39; &gt;package.json\r\n{\r\n   &quot;dependencies&quot;: {\r\n      &quot;foo&quot;: &quot;3.3.3&quot;,\r\n      &quot;bar&quot;: &quot;2.2.2&quot;\r\n   }\r\n}\r\n.\r\n```\r\n\r\nBut let&#39;s assume you have a reason to break it down into steps.\r\n\r\n---\r\n\r\nThe linked answer is about adding to an array. You are not trying to add to an array. To add a key and value to an object, you can simply use\r\n\r\n```jq\r\n.object[&quot;key&quot;] = value\r\n```\r\n\r\nTherefore, doing one addition at a time, the program would look like the following:\r\n\r\n```jq\r\n{ } |\r\n.dependencies = { } |\r\n.dependencies[ &quot;foo&quot; ] = &quot;3.3.3&quot; |\r\n.dependencies[ &quot;bar&quot; ] = &quot;2.2.2&quot;\r\n```\r\n\r\n[Demo](https://jqplay.org/s/8qYJdvg7Ixz) on jqplay.\r\n\r\nAs separate calls to `jq`, we get the following:\r\n\r\n```sh\r\nprintf &#39;{ }\\n&#39; |\r\njq &#39;.dependencies = { }&#39; |\r\njq &#39;.dependencies[ &quot;foo&quot; ] = &quot;3.3.3&quot;&#39; |\r\njq &#39;.dependencies[ &quot;bar&quot; ] = &quot;2.2.2&quot;&#39; &gt;package.json\r\n```\r\n\r\nAs a single pipeline, these commands are still entangled. To separate them, we will need a temporary file or the `sponge` command-line utility.\r\n\r\n```sh\r\nprintf &#39;{ }\\n&#39;                                          &gt;package.tmp1.json\r\njq &#39;.dependencies = { }&#39;              package.tmp1.json &gt;package.tmp2.json\r\njq &#39;.dependencies[ &quot;foo&quot; ] = &quot;3.3.3&quot;&#39; package.tmp2.json &gt;package.tmp3.json\r\njq &#39;.dependencies[ &quot;bar&quot; ] = &quot;2.2.2&quot;&#39; package.tmp3.json &gt;package.tmp4.json\r\n\r\nmv package.tmp4.json package.json\r\nrm package.tmp{1,2,3}.json\r\n```\r\n\r\nWhat if you wanted to add `.dependencies` only if it didn&#39;t already exist? Replace\r\n\r\n```jq\r\n.dependencies = { }\r\n```\r\n\r\nwith\r\n\r\n```jq\r\n.dependencies //= { }\r\n```\r\n",
                "title": "How to add dependencies into package.json with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1710965118,
        "creation_date": 1710957106,
        "last_edit_date": 1710961362,
        "question_id": 78195387,
        "body_markdown": "I want to add package dependencies to the `package.json` file by `bash` script using `jq`.\r\n\r\nhttps://stackoverflow.com/questions/42245288/add-new-element-to-existing-json-array-with-jq\r\n\r\nHere is the test script with 5 steps:\r\n\r\n    #!/bin/bash\r\n    \r\n    add_element_with_jq() {\r\n        \r\n        # step 1: Add a new root element &quot;{}&quot; first\r\n        echo &quot;============= step 1 ================&quot;\r\n        \r\n        echo &quot;{}&quot; &gt; &quot;package.json&quot;\r\n        \r\n        # step 2: Add a &quot;dependencies&quot; sub element to the root element &quot;{}&quot;\r\n        echo &quot;============= step 2 ================&quot;\r\n        # step 3: Add a &quot;foo&quot; package with version &quot;1.1.1&quot; to the &quot;dependencies&quot;\r\n        echo &quot;============= step 3 ================&quot;\r\n        \r\n        jq &#39;. += dependencies {\r\n          &quot;foo&quot;: &quot;1.1.1&quot;\r\n        }&#39; &quot;package.json&quot;\r\n        \r\n        echo &quot;=========== step 3 output ==================&quot;\r\n        cat &quot;package.json&quot;\r\n        \r\n        # step 4: Add a &quot;bar&quot; package with version &quot;2.2.2&quot; to the &quot;dependencies&quot;\r\n        echo &quot;============= step 4 ================&quot;\r\n        \r\n        jq &#39;.dependencies += \r\n          &quot;bar&quot;: &quot;2.2.2&quot;\r\n        &#39; &quot;package.json&quot;\r\n        \r\n        # step 5: If the &quot;foo&quot; package already existed, then update to the latest version. Otherwise, add the &quot;foo&quot; package to the dependencies.\r\n        echo &quot;============= step 5 ================&quot;\r\n        \r\n        jq &#39;.dependencies += \r\n          &quot;foo&quot;: &quot;3.3.3&quot;\r\n        &#39; &quot;package.json&quot;\r\n        \r\n        echo &quot;=========== final output ==================&quot;\r\n        cat &quot;package.json&quot;\r\n    }\r\n    \r\n    add_element_with_jq\r\n\r\nHere is the error:\r\n\r\n    ============= step 1 ================\r\n    ============= step 2 ================\r\n    ============= step 3 ================\r\n    jq: error: syntax error, unexpected &#39;{&#39;, expecting $end (Unix shell quoting issues?) at &lt;top-level&gt;, line 1:\r\n    . += dependencies {                  \r\n    jq: 1 compile error\r\n    =========== step 3 output ==================\r\n    {}\r\n    ============= step 4 ================\r\n    jq: error: syntax error, unexpected &#39;:&#39;, expecting $end (Unix shell quoting issues?) at &lt;top-level&gt;, line 2:\r\n          &quot;bar&quot;: &quot;2.2.2&quot;           \r\n    jq: 1 compile error\r\n    ============= step 5 ================\r\n    jq: error: syntax error, unexpected &#39;:&#39;, expecting $end (Unix shell quoting issues?) at &lt;top-level&gt;, line 2:\r\n          &quot;foo&quot;: &quot;3.3.3&quot;           \r\n    jq: 1 compile error\r\n    =========== final output ==================\r\n    {}\r\n\r\nHere is the expected output:\r\n\r\n    =========== step 3 output ==================\r\n    {\r\n      &quot;dependencies&quot;: {\r\n        &quot;foo&quot;: &quot;1.1.1&quot;\r\n      }\r\n    }\r\n    =========== final output ==================\r\n    {\r\n      &quot;dependencies&quot;: {\r\n        &quot;foo&quot;: &quot;3.3.3&quot;,\r\n        &quot;bar&quot;: &quot;2.2.2&quot;\r\n      }\r\n    }\r\n\r\nWhat&#39;s wrong in my `bash` function, and how to fix the `jq` commands?\r\n\r\n",
        "link": "https://stackoverflow.com/questions/78195387/how-to-add-dependencies-into-package-json-with-jq",
        "title": "How to add dependencies into package.json with jq"
    },
    {
        "tags": [
            "yaml",
            "jq",
            "yq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1711022580,
                "last_edit_date": 1711022580,
                "creation_date": 1711017512,
                "answer_id": 78199244,
                "question_id": 78199185,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Operator precedence is important. You can force order of evaluation by parenthesizing:\r\n\r\n```\r\nyq e &#39;(\r\n  .spec.groups[]\r\n  | select(.name == &quot;deep_learning&quot;)\r\n  | .items[]\r\n  | select(.name == &quot;triton_release_version&quot;)\r\n  | .default\r\n) = &quot;new_release_version&quot;&#39; config.yaml\r\n```\r\n\r\nFirst select the items you want to update (`…[] | select(…) | …`), then update them (`… = &quot;new_release_version&quot;`).\r\n\r\nAn alternative way of writing the program is:\r\n\r\n```\r\nyq e &#39;(\r\n  .spec.groups[]\r\n  | select(.name == &quot;deep_learning&quot;).items[]\r\n  | select(.name == &quot;triton_release_version&quot;)\r\n).default = &quot;new_release_version&quot;&#39; config.yaml\r\n```\r\n\r\nWith [mikefarah&#39;s `yq`](https://github.com/mikefarah/yq), you get:\r\n\r\n```yaml\r\napiVersion: kots.io/v1beta1\r\nkind: Config\r\nmetadata:\r\n  name: enterprise\r\nspec:\r\n  groups:\r\n    - name: api_authorization\r\n      title: API Authorization\r\n      items:\r\n        - name: api_key\r\n          title: API Key\r\n          type: password\r\n          required: true\r\n        - name: workspace_id\r\n          title: Workspace ID\r\n          type: text\r\n          required: true\r\n    - name: deep_learning\r\n      title: Deep Learning\r\n      description: Deep Learning Service Options\r\n      items:\r\n        - name: triton_release_options\r\n          title: Release Options\r\n          type: heading\r\n        - name: triton_release_version\r\n          title: Triton Release Version\r\n          type: text\r\n          default: &quot;new_release_version&quot; ## Shoudl be updated when the triton release is true\r\n          required: true\r\n        - name: tracker_release_version\r\n          title: Tracker Version\r\n          type: text\r\n          default: &quot;release-v308&quot; ## Shoudl be updated when the tracker is being build as part of the component\r\n          required: true\r\n```",
                "title": "Conditional statement in yq parser for updating script"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1711044769,
        "creation_date": 1711017003,
        "last_edit_date": 1711044769,
        "question_id": 78199185,
        "body_markdown": "I m trying to replace a string value in a yaml file and I m not able to get the `if` working. \r\n\r\nYAML file\r\n\r\n```yaml\r\napiVersion: kots.io/v1beta1\r\nkind: Config\r\nmetadata:\r\n  name: enterprise\r\nspec:\r\n  groups:\r\n    - name: api_authorization\r\n      title: API Authorization\r\n      items:\r\n        - name: api_key\r\n          title: API Key\r\n          type: password\r\n          required: true\r\n        - name: workspace_id\r\n          title: Workspace ID\r\n          type: text\r\n          required: true\r\n    - name: deep_learning\r\n      title: Deep Learning\r\n      description: Deep Learning Service Options\r\n      items:\r\n        - name: triton_release_options\r\n          title: Release Options\r\n          type: heading\r\n        - name: triton_release_version\r\n          title: Triton Release Version\r\n          type: text\r\n          default: &quot;release-v308&quot; ## Shoudl be updated when the triton release is true\r\n          required: true\r\n        - name: tracker_release_version\r\n          title: Tracker Version\r\n          type: text\r\n          default: &quot;release-v308&quot; ## Shoudl be updated when the tracker is being build as part of the component\r\n          required: true\r\n```\r\n\r\n\r\nI have tried the following with no luck\r\n\r\n```sh\r\nyq e &#39;\r\n   .spec.groups[] |=\r\n      if .name == &quot;deep_learning&quot; then\r\n         .items[] |\r\n         select( .name == &quot;triton_release_version&quot; ) |\r\n         .default = &quot;new_release_version&quot;\r\n      else\r\n         .\r\n      end\r\n&#39; config.yaml\r\n```\r\n\r\n```sh\r\nyq e &#39;\r\n   .spec.groups[] |\r\n   select(.name == &quot;deep_learning&quot;) |\r\n   .items[] |\r\n   select( .name == &quot;triton_release_version&quot; ) |\r\n   .default = &quot;new_release_version&quot;\r\n&#39; config.yaml\r\n```\r\n\r\nI am able to update, but then i m losing the whole yaml file content if i m not using the if condition. With the if I get a syntax error.\r\n",
        "link": "https://stackoverflow.com/questions/78199185/conditional-statement-in-yq-parser-for-updating-script",
        "title": "Conditional statement in yq parser for updating script"
    },
    {
        "tags": [
            "azure-devops",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 28560085,
                    "reputation": 2306,
                    "user_id": 21863762,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/Oukur.png?s=256",
                    "display_name": "zori",
                    "link": "https://stackoverflow.com/users/21863762/zori"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1711128204,
                "post_id": 78207829,
                "comment_id": 137877979,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2095740,
                    "reputation": 497,
                    "user_id": 1864552,
                    "user_type": "registered",
                    "accept_rate": 57,
                    "profile_image": "https://www.gravatar.com/avatar/de24aaffe828f735e7232cc9cd765c8d?s=256&d=identicon&r=PG",
                    "display_name": "JS noob",
                    "link": "https://stackoverflow.com/users/1864552/js-noob"
                },
                "reply_to_user": {
                    "account_id": 28560085,
                    "reputation": 2306,
                    "user_id": 21863762,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/Oukur.png?s=256",
                    "display_name": "zori",
                    "link": "https://stackoverflow.com/users/21863762/zori"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1711133501,
                "post_id": 78207829,
                "comment_id": 137878781,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1711334478,
                "creation_date": 1711334478,
                "answer_id": 78216845,
                "question_id": 78207829,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can change to like as one of the below ways.\r\n```sh\r\njq --argjson timestamp `date +%s` &#39;.common |= . + {&quot;TimeValue&quot;: $timestamp }&#39; ${service}/${env}.json &gt; tmpfile &amp;&amp; mv tmpfile ${service}/${env}.json\r\n```\r\n\r\nOR\r\n```sh\r\ntimestamp=`date +%s`\r\njq --argjson timestamp $timestamp &#39;.common |= . + {&quot;TimeValue&quot;: $timestamp }&#39; ${service}/${env}.json &gt; tmpfile &amp;&amp; mv tmpfile ${service}/${env}.json\r\n```",
                "title": "AzureDevops passing $`` instead of $() into jq arg via taskgroup"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1711334478,
        "creation_date": 1711127304,
        "last_edit_date": 1711332116,
        "question_id": 78207829,
        "body_markdown": "I currently have the following in my taskgroup bash script\r\n\r\n```            \r\njq --argjson timestamp &quot;$`date +%s`&quot; &#39;.common |= . + {&quot;TimeValue&quot;: $timestamp }&#39; ${service}/${env}.json &gt; tmpfile &amp;&amp; mv tmpfile ${service}/${env}.json\r\n```\r\n\r\nmy issue is with this part\r\n\r\n```\r\n&quot;$`date +%s`&quot;\r\n```\r\n\r\nwhen the task runs I get the following error\r\n\r\n```\r\njq: invalid JSON text passed to --argjson\r\nUse jq --help for help with command-line options,\r\n```\r\n\r\nSo if I edit the existing release and change it to the following everything works:\r\n\r\n```\r\n&quot;$(date +%s)&quot;\r\n```\r\n\r\nThe problem is when I change to the above in my taskgroup it now thinks that I am trying to add a new parameter which I do not want.\r\n\r\nHow can I solve this?",
        "link": "https://stackoverflow.com/questions/78207829/azuredevops-passing-instead-of-into-jq-arg-via-taskgroup",
        "title": "AzureDevops passing $`` instead of $() into jq arg via taskgroup"
    },
    {
        "tags": [
            "python",
            "json",
            "character-encoding",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 289134,
                    "reputation": 389369,
                    "user_id": 589924,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/b2cf53d5a3d25f95c0db4e025aed4153?s=256&d=identicon&r=PG",
                    "display_name": "ikegami",
                    "link": "https://stackoverflow.com/users/589924/ikegami"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1711378784,
                "post_id": 78210979,
                "comment_id": 137899351,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1711202247,
                "last_edit_date": 1711202247,
                "creation_date": 1711200439,
                "answer_id": 78211038,
                "question_id": 78210979,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "A workaround I found so far is not using json at all. Instead, I only process those line wich are known to have the wrong character set. This works because I know the files are very well-structured and formatted and I can easily find the broken lines by static text patterns.\r\nNote that I&#39;m still working with the wrong charset. But so far, opening utf-8 as latin1 and saving it as lating1 again hasn&#39;t damaged anything of the utf-8 parts.\r\n\r\n    #!/usr/bin/python3\r\n    \r\n    with open(&#39;in.txt&#39;, encoding=&#39;latin1&#39;) as fh:\r\n      lines = fh.readlines()\r\n    \r\n    # change the encoding of all filename: lines and keep everything else\r\n    lines = [line.encode(&#39;utf-8&#39;).decode(&#39;latin1&#39;) if line.startswith(&quot;\\t\\t\\t\\&quot;filename\\&quot;: \\&quot;&quot;) else line for line in lines]\r\n    \r\n    with open(&#39;out.txt&#39;, &#39;w&#39;, encoding=&#39;latin1&#39;) as fh:\r\n        fh.writelines(lines)\r\n\r\noutput:\r\n\r\n    {\r\n      &quot;title&quot;: {\r\n        &quot;ger&quot;: &quot;Kom&#246;die&quot;\r\n      },\r\n      &quot;files&quot;: [\r\n        {\r\n          &quot;filename&quot;: &quot;Kom&#246;die&quot;\r\n        }\r\n      ]\r\n    }",
                "title": "Handle mixed charsets in the same json file"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1711202247,
        "creation_date": 1711199369,
        "last_edit_date": 1711201335,
        "question_id": 78210979,
        "body_markdown": "Given I have the following file:\r\n\r\n```\r\n{\r\n  &quot;title&quot;: {\r\n    &quot;ger&quot;: &quot;Kom&#246;die&quot;    (utf8, encoded as c3 b6)\r\n  },\r\n  &quot;files&quot;: [\r\n    {\r\n      &quot;filename&quot;: &quot;Kom�die&quot;   (latin1, encoded as f6)\r\n    }\r\n  ]\r\n}\r\n```\r\n\r\n(might look differently if you try to copy-paste it)\r\n\r\nThis happened due to an application bug, I cannot fix the source which generates these files.\r\n\r\nI try now to fix the charset of the filename field(s), there can be multiple of them. I tried first with jq (single field):\r\n\r\n    value=&quot;$(jq &#39;.files[0].filename&#39; &lt;in.txt | iconv -f latin1 -t utf-8)&quot;\r\n    jq --arg f &quot;$value&quot; &#39;.files[0].filename = $f&#39; &lt;in.txt\r\n\r\nBut jq interprets the whole file as utf-8 and this damages the single f6 character.\r\n\r\nI would like to find a solution in python, but also there, the input is by default interpreted as utf-8 in linux. I tried with &#39;ascii&#39;, but this doesn&#39;t allow characters &gt;= 128.\r\n\r\nNow, I think I found a way, but the json serializer escapes all characters. As I (intentionally) work with the wrong character set, the escaped sequence is also garbage. \r\n\r\n    #!/usr/bin/python3\r\n    \r\n    import sys\r\n    import io\r\n    import json\r\n    \r\n    with open(&#39;in.txt&#39;, encoding=&#39;latin1&#39;) as fh:\r\n      j = json.load(fh)\r\n    \r\n    for f in j[&#39;files&#39;]:\r\n      f[&#39;filename&#39;] = f[&#39;filename&#39;].encode(&#39;utf-8&#39;).decode(&#39;latin1&#39;)   # might be wrong, couldn&#39;t test\r\n    \r\n    with open(&#39;out.txt&#39;, &#39;w&#39;, encoding=&#39;latin1&#39;) as fh:\r\n      json.dump(j, fh)\r\n\r\nWhat can I do to achieve the expected result, a clean non-escaped utf-8 json file?",
        "link": "https://stackoverflow.com/questions/78210979/handle-mixed-charsets-in-the-same-json-file",
        "title": "Handle mixed charsets in the same json file"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 1535561,
                    "reputation": 8861,
                    "user_id": 1431720,
                    "user_type": "registered",
                    "accept_rate": 89,
                    "profile_image": "https://www.gravatar.com/avatar/f5a1388d4d3b2bf03b11bb5658c68c29?s=256&d=identicon&r=PG",
                    "display_name": "Robert",
                    "link": "https://stackoverflow.com/users/1431720/robert"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1711396668,
                "post_id": 78221337,
                "comment_id": 137902350,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1711396674,
                "post_id": 78221337,
                "comment_id": 137902351,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "is_answered": false,
        "answer_count": 0,
        "score": 0,
        "last_activity_date": 1711450069,
        "creation_date": 1711394738,
        "last_edit_date": 1711450069,
        "question_id": 78221337,
        "body_markdown": "I have a bash script that is set up below which is attempting to compare the remote s3 version of a file with the local version. Currently, the if conditions I try never actually work. The latest version is below, I am simply looking to create a temp s3 file and initialize it with the s3 version, compare the temp s3 with the local, if there are differences than I want to have the temp s3 file get the latest updates and then after the s3 file is updated to remove the temp files. Any help would be greatly appreciated, as this below setup always results in the code not detecting any differences, even when I manually create differences to test the logic.\r\n\r\nCurrent setup:\r\n\r\n```sh\r\n#!/bin/sh\r\n\r\nFILE_NAME = config.json\r\nREMOTE_FILE_LOCATION=&quot;s3://path/to/s3/file/$FILE_NAME&quot;\r\n\r\naws cp $REMOTE_FILE_LOCATION s3-$FILE_NAME\r\n\r\nif ! jq -s &#39;.[0] == .[1]&#39; &quot;$FILE_NAME&quot; &quot;s3-$FILE_NAME&quot; &amp;&gt; /dev/null; then\r\n     echo &quot;differences found&quot;\r\n\r\n     cp $FILE_NAME s3-$FILE_NAME\r\n\r\n     aws s3 cp s3-$FILE_NAME $REMOTE_FILE_LOCATION\r\n else\r\n     echo &quot;No differences - local and s3 files in sync.&quot;\r\nfi\r\n\r\nrm -r $s3-$FILE_NAME\r\n```\r\n\r\nTried re-writing the if conditions, actually building logic to compare objects in each files based on their id, yet I have not been able to get the if condition to correctly determine when .json files are the same vs. when they are not. Previous solutions resolving around comparing JSON files did not have an answer where there was a solution that worked with jq. I have tried multiple suggestions from prior posts. ",
        "link": "https://stackoverflow.com/questions/78221337/how-i-can-compare-these-two-json-files-correctly-using-jq-in-a-bash-script",
        "title": "How I can compare these two .json files correctly using jq in a bash script"
    },
    {
        "tags": [
            "json",
            "linux",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 4,
                "creation_date": 1711396963,
                "post_id": 78221461,
                "comment_id": 137902386,
                "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": 1711397034,
                "post_id": 78221461,
                "comment_id": 137902395,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 12,
                "is_accepted": true,
                "score": 12,
                "last_activity_date": 1711396717,
                "creation_date": 1711396717,
                "answer_id": 78221479,
                "question_id": 78221461,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Remove the dot before the key:\r\n\r\n    .SecretString[$keyvar]\r\n                ~~",
                "title": "JQ error when trying to parse JSON string - unexpected &#39;[&#39;"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 5,
        "last_activity_date": 1711396717,
        "creation_date": 1711396392,
        "question_id": 78221461,
        "body_markdown": "When trying to query a JSON str, using the script below, I get an error.\r\n\r\n    db_secret_data=$(aws secretsmanager get-secret-value --secret-id &quot;$db_secret_name&quot; --output json)\r\n        \r\n    echo &quot;$db_secret_data&quot;\r\n     \r\n    db_secret_str=$(echo &quot;$db_secret_data&quot; | jq --arg keyvar &quot;${uid_str}-TY&quot; &#39;.SecretString.[$keyvar]&#39; -r)\r\n\r\nHere is the error:\r\n\r\n    jq: error: syntax error, unexpected &#39;[&#39;, expecting FORMAT or QQSTRING_START (Unix shell quoting issues?) at &lt;top-level&gt;, line 1:\r\n    .SecretString.[$keyvar]   \r\n\r\nI&#39;ve gone over the syntax over and over, and can&#39;t see what&#39;s wrong. Can anyone help?",
        "link": "https://stackoverflow.com/questions/78221461/jq-error-when-trying-to-parse-json-string-unexpected",
        "title": "JQ error when trying to parse JSON string - unexpected &#39;[&#39;"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 1079173,
                    "reputation": 43571,
                    "user_id": 1076640,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/e0VNy.jpg?s=256",
                    "display_name": "yshavit",
                    "link": "https://stackoverflow.com/users/1076640/yshavit"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1711479362,
                "post_id": 78227591,
                "comment_id": 137913393,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 62058,
                    "reputation": 32587,
                    "user_id": 184595,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/d6jGq.jpg?s=256",
                    "display_name": "CrayonViolent",
                    "link": "https://stackoverflow.com/users/184595/crayonviolent"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1711479365,
                "post_id": 78227591,
                "comment_id": 137913396,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1079173,
                    "reputation": 43571,
                    "user_id": 1076640,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/e0VNy.jpg?s=256",
                    "display_name": "yshavit",
                    "link": "https://stackoverflow.com/users/1076640/yshavit"
                },
                "reply_to_user": {
                    "account_id": 62058,
                    "reputation": 32587,
                    "user_id": 184595,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/d6jGq.jpg?s=256",
                    "display_name": "CrayonViolent",
                    "link": "https://stackoverflow.com/users/184595/crayonviolent"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1711479399,
                "post_id": 78227591,
                "comment_id": 137913398,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 62058,
                    "reputation": 32587,
                    "user_id": 184595,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/d6jGq.jpg?s=256",
                    "display_name": "CrayonViolent",
                    "link": "https://stackoverflow.com/users/184595/crayonviolent"
                },
                "reply_to_user": {
                    "account_id": 1079173,
                    "reputation": 43571,
                    "user_id": 1076640,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/e0VNy.jpg?s=256",
                    "display_name": "yshavit",
                    "link": "https://stackoverflow.com/users/1076640/yshavit"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1711479449,
                "post_id": 78227591,
                "comment_id": 137913404,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 3516142,
                    "reputation": 10035,
                    "user_id": 2939522,
                    "user_type": "registered",
                    "accept_rate": 91,
                    "profile_image": "https://www.gravatar.com/avatar/ed18b9e3dc43cddcebe279fe9d1362e5?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Abdul Ahmad",
                    "link": "https://stackoverflow.com/users/2939522/abdul-ahmad"
                },
                "reply_to_user": {
                    "account_id": 1079173,
                    "reputation": 43571,
                    "user_id": 1076640,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/e0VNy.jpg?s=256",
                    "display_name": "yshavit",
                    "link": "https://stackoverflow.com/users/1076640/yshavit"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1711479523,
                "post_id": 78227591,
                "comment_id": 137913409,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 3516142,
                    "reputation": 10035,
                    "user_id": 2939522,
                    "user_type": "registered",
                    "accept_rate": 91,
                    "profile_image": "https://www.gravatar.com/avatar/ed18b9e3dc43cddcebe279fe9d1362e5?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Abdul Ahmad",
                    "link": "https://stackoverflow.com/users/2939522/abdul-ahmad"
                },
                "reply_to_user": {
                    "account_id": 1079173,
                    "reputation": 43571,
                    "user_id": 1076640,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/e0VNy.jpg?s=256",
                    "display_name": "yshavit",
                    "link": "https://stackoverflow.com/users/1076640/yshavit"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1711479592,
                "post_id": 78227591,
                "comment_id": 137913419,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1079173,
                    "reputation": 43571,
                    "user_id": 1076640,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/e0VNy.jpg?s=256",
                    "display_name": "yshavit",
                    "link": "https://stackoverflow.com/users/1076640/yshavit"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1711479640,
                "post_id": 78227591,
                "comment_id": 137913430,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 3516142,
                    "reputation": 10035,
                    "user_id": 2939522,
                    "user_type": "registered",
                    "accept_rate": 91,
                    "profile_image": "https://www.gravatar.com/avatar/ed18b9e3dc43cddcebe279fe9d1362e5?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Abdul Ahmad",
                    "link": "https://stackoverflow.com/users/2939522/abdul-ahmad"
                },
                "reply_to_user": {
                    "account_id": 1079173,
                    "reputation": 43571,
                    "user_id": 1076640,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/e0VNy.jpg?s=256",
                    "display_name": "yshavit",
                    "link": "https://stackoverflow.com/users/1076640/yshavit"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1711479689,
                "post_id": 78227591,
                "comment_id": 137913440,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 3516142,
                    "reputation": 10035,
                    "user_id": 2939522,
                    "user_type": "registered",
                    "accept_rate": 91,
                    "profile_image": "https://www.gravatar.com/avatar/ed18b9e3dc43cddcebe279fe9d1362e5?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Abdul Ahmad",
                    "link": "https://stackoverflow.com/users/2939522/abdul-ahmad"
                },
                "reply_to_user": {
                    "account_id": 1079173,
                    "reputation": 43571,
                    "user_id": 1076640,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/e0VNy.jpg?s=256",
                    "display_name": "yshavit",
                    "link": "https://stackoverflow.com/users/1076640/yshavit"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1711479869,
                "post_id": 78227591,
                "comment_id": 137913464,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1079173,
                    "reputation": 43571,
                    "user_id": 1076640,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/e0VNy.jpg?s=256",
                    "display_name": "yshavit",
                    "link": "https://stackoverflow.com/users/1076640/yshavit"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1711479971,
                "post_id": 78227591,
                "comment_id": 137913476,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 10015983,
                    "reputation": 144648,
                    "user_id": 9072753,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/EPmGy.jpg?s=256",
                    "display_name": "KamilCuk",
                    "link": "https://stackoverflow.com/users/9072753/kamilcuk"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1711481728,
                "post_id": 78227591,
                "comment_id": 137913738,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1711479834,
                "creation_date": 1711479834,
                "answer_id": 78227637,
                "question_id": 78227591,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The `$output` is a string, not an array.\r\n\r\nTo declare a bash array, you need the following syntax:\r\n\r\n    output=(one two)\r\n\r\nIt then provides the expected result.\r\n```bash\r\nservice_list_json=$(jq -c -n &#39;$ARGS.positional&#39; --args &quot;${output[@]}&quot;)\r\necho &quot;$service_list_json&quot;\r\n```\r\nOutput:\r\n```\r\n[&quot;one&quot;,&quot;two&quot;]\r\n```\r\n",
                "title": "stringify bash array to json string"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1711479834,
        "creation_date": 1711479148,
        "last_edit_date": 1711479756,
        "question_id": 78227591,
        "body_markdown": "I&#39;m new to bash and I have a bash script with a variable that is an array called &#39;output&#39;\r\n\r\nI&#39;d like to convert the bash array to a JSON string. for example:\r\n\r\noriginal array:\r\n`output = [&#39;one&#39;, &#39;two&#39;]`\r\n\r\ndesired output:\r\n`&#39;[&quot;one&quot;,&quot;two&quot;]&#39;`\r\n\r\nI have tried the following:\r\n```\r\n&quot;$(jq -c -n &#39;$ARGS.positional&#39; --args &quot;${output[@]}&quot;)&quot;\r\n```\r\n\r\nbut that seems to wrap the array inside another set of square brackets:\r\n```\r\n&#39;[&quot;[\\&quot;one\\&quot;,\\&quot;two\\&quot;]&quot;]&#39;\r\n```\r\n\r\nwhich is not what I want.\r\n\r\nalso, I&#39;d like to assign the JSON string to a variable.\r\n\r\nI also saw that I can do this:\r\n```\r\necho &#39;{&quot;foo&quot; : &quot;bar&quot;}&#39; | jq -R .\r\n```\r\n\r\nbut I dont know how to use my variable &#39;output&#39; instead of the hard-coded object. Also, not sure how to assign the result of that to a variable\r\n\r\n\r\nEDIT\r\n\r\nhere&#39;s the bash script:\r\n```\r\nservice_list_json=&quot;$(jq -c -n &#39;$ARGS.positional&#39; --args &quot;${output[@]}&quot;)&quot;\r\n```\r\n\r\nEDIT 2\r\n\r\nok, I think I might be seeing where the issue is. the original array looks like this:\r\n\r\n```\r\n&#39;[&quot;one&quot;,&quot;two&quot;]&#39;\r\n```\r\n\r\ni&#39;m guessing the extra set of quotes around the array are causing it to be treated like a string?",
        "link": "https://stackoverflow.com/questions/78227591/stringify-bash-array-to-json-string",
        "title": "stringify bash array to json string"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 6196394,
                    "reputation": 86601,
                    "user_id": 5291015,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/4tAvO.jpg?s=256",
                    "display_name": "Inian",
                    "link": "https://stackoverflow.com/users/5291015/inian"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1711610896,
                "post_id": 78236176,
                "comment_id": 137928915,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1711611315,
                "last_edit_date": 1711611315,
                "creation_date": 1711610807,
                "answer_id": 78236473,
                "question_id": 78236176,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The filter is not quite correct. You need to do,\r\n\r\n```none\r\n.[].Wind.Direction | [.Localized]\r\n```\r\n\r\nRemember you are accessing an array at the top level, so `.[]` selects the objects within. And `Wind` is an object and not an array, so just `.Wind` is needed to access the sub-element `.Direction`. By doing `.Wind[]`, you can end up with values _only_ part of all the sub-elements, which is not desirable (See [Array/Object Value Iterator][1]). But you could still do `.[].Wind[] | [.Localized]`.\r\n\r\nBut the top level array access is needed.\r\n\r\n\r\n  [1]: https://jqlang.github.io/jq/manual/v1.7/#array-object-value-iterator",
                "title": "Parsing a nested JSON record present in an array of objects"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1711611315,
        "creation_date": 1711606751,
        "last_edit_date": 1711610813,
        "question_id": 78236176,
        "body_markdown": "I want to get down to the values in Wind / Direction.\r\nOne example (of many) I&#39;ve tried, [I want to use jq in a bash script]:\r\n\r\n```bash\r\ncat accuweather_raw | jq &quot;.Wind[].Direction[] | [.Localized]&quot;\r\n```\r\nMost times I get err cannot index array with string &quot;of some iteration&quot;\r\n\r\nHelp!\r\n\r\nTake this JSON:\r\n\r\n    [\r\n      {\r\n        &quot;LocalObservationDateTime&quot;: &quot;2024-03-27T21:32:00-05:00&quot;,\r\n        &quot;EpochTime&quot;: 1711593120,\r\n        &quot;WeatherText&quot;: &quot;Clear&quot;,\r\n        &quot;WeatherIcon&quot;: 33,\r\n        &quot;HasPrecipitation&quot;: false,\r\n        &quot;PrecipitationType&quot;: null,\r\n        &quot;IsDayTime&quot;: false,\r\n        &quot;Temperature&quot;: {\r\n          &quot;Metric&quot;: {\r\n            &quot;Value&quot;: 20,\r\n            &quot;Unit&quot;: &quot;C&quot;,\r\n            &quot;UnitType&quot;: 17\r\n          },\r\n          &quot;Imperial&quot;: {\r\n            &quot;Value&quot;: 68,\r\n            &quot;Unit&quot;: &quot;F&quot;,\r\n            &quot;UnitType&quot;: 18\r\n          }\r\n        },\r\n        &quot;RealFeelTemperature&quot;: {\r\n          &quot;Metric&quot;: {\r\n            &quot;Value&quot;: 17.8,\r\n            &quot;Unit&quot;: &quot;C&quot;,\r\n            &quot;UnitType&quot;: 17,\r\n            &quot;Phrase&quot;: &quot;Pleasant&quot;\r\n          },\r\n          &quot;Imperial&quot;: {\r\n            &quot;Value&quot;: 64,\r\n            &quot;Unit&quot;: &quot;F&quot;,\r\n            &quot;UnitType&quot;: 18,\r\n            &quot;Phrase&quot;: &quot;Pleasant&quot;\r\n          }\r\n        },\r\n        &quot;RealFeelTemperatureShade&quot;: {\r\n          &quot;Metric&quot;: {\r\n            &quot;Value&quot;: 17.8,\r\n            &quot;Unit&quot;: &quot;C&quot;,\r\n            &quot;UnitType&quot;: 17,\r\n            &quot;Phrase&quot;: &quot;Pleasant&quot;\r\n          },\r\n          &quot;Imperial&quot;: {\r\n            &quot;Value&quot;: 64,\r\n            &quot;Unit&quot;: &quot;F&quot;,\r\n            &quot;UnitType&quot;: 18,\r\n            &quot;Phrase&quot;: &quot;Pleasant&quot;\r\n          }\r\n        },\r\n        &quot;RelativeHumidity&quot;: 62,\r\n        &quot;IndoorRelativeHumidity&quot;: 63,\r\n        &quot;DewPoint&quot;: {\r\n          &quot;Metric&quot;: {\r\n            &quot;Value&quot;: 12.8,\r\n            &quot;Unit&quot;: &quot;C&quot;,\r\n            &quot;UnitType&quot;: 17\r\n          },\r\n          &quot;Imperial&quot;: {\r\n            &quot;Value&quot;: 55,\r\n            &quot;Unit&quot;: &quot;F&quot;,\r\n            &quot;UnitType&quot;: 18\r\n          }\r\n        },\r\n        &quot;Wind&quot;: {\r\n          &quot;Direction&quot;: {\r\n            &quot;Degrees&quot;: 90,\r\n            &quot;Localized&quot;: &quot;E&quot;,\r\n            &quot;English&quot;: &quot;E&quot;}, \r\n\r\n... continued\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/78236176/parsing-a-nested-json-record-present-in-an-array-of-objects",
        "title": "Parsing a nested JSON record present in an array of objects"
    },
    {
        "tags": [
            "arrays",
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": -1,
                    "reputation": 1,
                    "user_id": -1,
                    "user_type": "moderator",
                    "profile_image": "https://www.gravatar.com/avatar/a007be5a61f6aa8f3e85ae2fc18dd66e?s=256&d=identicon&r=PG",
                    "display_name": "Community",
                    "link": "https://stackoverflow.com/users/-1/community"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1711624021,
                "post_id": 78237633,
                "comment_id": 137930973,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1711625018,
                "creation_date": 1711625018,
                "answer_id": 78237811,
                "question_id": 78237633,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "A simple replacement with both, the old and the new values provided explicitly, would be to traverse to the desired item by iteration and selection, then using that as the LHS for an assignment:\r\n\r\n```sh\r\njq &#39;(.run_list[] | select(. == &quot;role[test09]&quot;)) = &quot;role[hello]&quot;&#39; input.json\r\n```\r\n[Demo](https://jqplay.org/s/2BX75xeaUWZ)\r\n\r\nGoing further, you can import the string values using the `--arg` option. You could also have an elaborated update, like `|= sub(&quot;test09&quot;; &quot;hello&quot;)`. If you provide more details to the circumstances of your desired replacement, you could get responses more tailored to your specific needs.",
                "title": "Update array element of a JSON array with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1711625018,
        "creation_date": 1711623185,
        "question_id": 78237633,
        "body_markdown": "I have a JSON object and would like to update for example the array element &quot;role\\[test09\\]&quot; to &quot;role\\[hello\\]&quot;, I don&#39;t have the index number.  I have tried a few things but somehow can&#39;t figure it out.\r\n\r\nHow can I do this with jq ?\r\n\r\nThis is my JSON object.\r\n\r\n```\r\n    {\r\n      &quot;run_list&quot;: [\r\n        &quot;role[test01]&quot;,\r\n        &quot;role[test09]&quot;,\r\n        &quot;role[test05]&quot;\r\n      ]\r\n    }\r\n```\r\n\r\nThe updated object should look like this\r\n\r\n```\r\n    {\r\n      &quot;run_list&quot;: [\r\n        &quot;role[test01]&quot;,\r\n        &quot;role[hello]&quot;,\r\n        &quot;role[test05]&quot;\r\n      ]\r\n    }\r\n```",
        "link": "https://stackoverflow.com/questions/78237633/update-array-element-of-a-json-array-with-jq",
        "title": "Update array element of a JSON array with jq"
    },
    {
        "tags": [
            "shell",
            "environment-variables",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1711640015,
                "post_id": 78239304,
                "comment_id": 137933868,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2435703,
                    "reputation": 27493,
                    "user_id": 2125671,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/13a492143ab4a2575b5a1f500691193c?s=256&d=identicon&r=PG",
                    "display_name": "Philippe",
                    "link": "https://stackoverflow.com/users/2125671/philippe"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1711641306,
                "post_id": 78239304,
                "comment_id": 137934134,
                "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": 2435703,
                    "reputation": 27493,
                    "user_id": 2125671,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/13a492143ab4a2575b5a1f500691193c?s=256&d=identicon&r=PG",
                    "display_name": "Philippe",
                    "link": "https://stackoverflow.com/users/2125671/philippe"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1711642562,
                "post_id": 78239304,
                "comment_id": 137934326,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1711641505,
                "last_edit_date": 1711641505,
                "creation_date": 1711640060,
                "answer_id": 78239307,
                "question_id": 78239304,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "JQ has a built-in `env` function that refers to the current environment and exposes it as a dictionary.\r\n\r\nThus, all you need is:\r\n\r\n```\r\njq -n env &gt;src/assets/config.json\r\n```\r\n\r\n...or, to merge an existing config file to add new keys from the environment (and overwrite existing keys where they conflict):\r\n\r\n```\r\nif jq &#39;. * env&#39; &lt;src/assets/config.json &gt;src/assets/config.json.&quot;$$&quot; ; then\r\n  mv -- src/assets/config.json.&quot;$$&quot; src/assets/config.json\r\nelse\r\n  rm -f -- src/assets/config.json.&quot;$$&quot;\r\nfi\r\n```",
                "title": "Shell script for copying environment variables into config.json?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -1,
        "last_activity_date": 1711641505,
        "creation_date": 1711639963,
        "question_id": 78239304,
        "body_markdown": "I&#39;m tearing my hair out a bit at this.  I&#39;m trying to write a shell script which indexes through all environment variables, and then overrides variables in a config.json file.\r\n\r\nI have a demo angular app which is running in a docker file and I&#39;d like to be able to set config variables as environment variables.  I know it&#39;s not the safest approach but this code will never see production and the flexibility it grants me is desirable.\r\n\r\nSo far I have this:\r\n\r\n    #!/bin/sh\r\n    \r\n    env | while IFS= read -r line; do\r\n      value=${line#*=}\r\n      name=${line%%=*}\r\n      \r\n      jq --arg name &quot;$name&quot; --arg value &quot;$value&quot; &#39;.[$name] = $value&#39; src/assets/config.json &gt; src/assets/config.json\r\n    done\r\n\r\n\r\n    jq . src/assets/config.json\r\n\r\nThe output json file keeps ending up empty though.",
        "link": "https://stackoverflow.com/questions/78239304/shell-script-for-copying-environment-variables-into-config-json",
        "title": "Shell script for copying environment variables into config.json?"
    },
    {
        "tags": [
            "json",
            "bash",
            "homebrew",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 1523408,
                    "reputation": 4054,
                    "user_id": 1514049,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/1c960a26826934bed45e27b5ca3d9824?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "segFault",
                    "link": "https://stackoverflow.com/users/1514049/segfault"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1711643482,
                "post_id": 78239630,
                "comment_id": 137934503,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 8,
                "is_accepted": true,
                "score": 8,
                "last_activity_date": 1711659043,
                "creation_date": 1711659043,
                "answer_id": 78240810,
                "question_id": 78239630,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can get directly json format with `brew info`:\r\n\r\n```\r\nbrew info --json --installed | jq &#39;map({name, version:.installed[0].version})&#39;\r\n```",
                "title": "How to get brew list as JSON output"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1711738910,
        "creation_date": 1711642999,
        "last_edit_date": 1711645729,
        "question_id": 78239630,
        "body_markdown": "I am running `brew list --versions` to get this list:\r\n\r\n```bash\r\n    user@mac ~ [1]&gt; brew list --versions\r\n    fish 3.7.0\r\n    ncurses 6.4\r\n    pcre2 10.43\r\n    syncthing 1.27.4\r\n    appcleaner 3.6.8\r\n    teamviewer 15.51.6\r\n```\r\nHow can I put the output to a json object like this:\r\n\r\n```json\r\n[\r\n   {\r\n      &quot;name&quot;:&quot;fish&quot;,\r\n      &quot;version&quot;:&quot;3.7.0&quot;\r\n   },\r\n   {\r\n      &quot;name&quot;:&quot;ncurses&quot;,\r\n      &quot;version&quot;:&quot;6.4&quot;\r\n   }\r\n]\r\n```\r\n",
        "link": "https://stackoverflow.com/questions/78239630/how-to-get-brew-list-as-json-output",
        "title": "How to get brew list as JSON output"
    },
    {
        "tags": [
            "string",
            "bash",
            "jq",
            "string-comparison"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 6,
                "creation_date": 1711657150,
                "post_id": 78240671,
                "comment_id": 137936420,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 11317286,
                    "reputation": 351,
                    "user_id": 11013417,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/5bc4ed142795a86adc1726ae0a5484db?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Matheus",
                    "link": "https://stackoverflow.com/users/11013417/matheus"
                },
                "reply_to_user": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1711657243,
                "post_id": 78240671,
                "comment_id": 137936435,
                "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": 3,
                "creation_date": 1711657715,
                "post_id": 78240671,
                "comment_id": 137936491,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 4879,
                    "reputation": 248190,
                    "user_id": 7552,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/b60298053f87465641c1b1192338c8cd?s=256&d=identicon&r=PG",
                    "display_name": "glenn jackman",
                    "link": "https://stackoverflow.com/users/7552/glenn-jackman"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1711658246,
                "post_id": 78240671,
                "comment_id": 137936562,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 468289,
                    "reputation": 190915,
                    "user_id": 874188,
                    "user_type": "registered",
                    "accept_rate": 62,
                    "profile_image": "https://www.gravatar.com/avatar/091f411d57db5be8298e057a32e5ad72?s=256&d=identicon&r=PG",
                    "display_name": "tripleee",
                    "link": "https://stackoverflow.com/users/874188/tripleee"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1711658579,
                "post_id": 78240671,
                "comment_id": 137936614,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 47502,
                    "reputation": 213658,
                    "user_id": 140750,
                    "user_type": "registered",
                    "accept_rate": 92,
                    "profile_image": "https://www.gravatar.com/avatar/4c7af12cad08c95bc206a9636d164224?s=256&d=identicon&r=PG",
                    "display_name": "William Pursell",
                    "link": "https://stackoverflow.com/users/140750/william-pursell"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1711664892,
                "post_id": 78240671,
                "comment_id": 137937344,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1711702666,
                "creation_date": 1711702666,
                "answer_id": 78242834,
                "question_id": 78240671,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "As you can see from the trace which you have posted, `commandOutput` does not hold the string `true`, but the string `&quot;true&quot;`, so you have to test for this:\r\n\r\n\r\n     [[ $commandOutput == &#39;&quot;true&quot;&#39; ]]",
                "title": "Why my string comparison isn&#39;t working in bash?"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1712132010,
                "creation_date": 1712132010,
                "answer_id": 78266239,
                "question_id": 78240671,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "`[[ $commandOutput == &quot;true&quot; ]]` compares the value of `$commandOutput` to the string `true`. The string against which the value is compared does not contain quotes, the quotes are part of the shell&#39;s syntax. The following is equivalent to the test: `[[ $commandOutput == true ]]`. You can easily verify this claim yourself:\r\n\r\n```\r\nnoquotes=true\r\nnoquotes2=&#39;true&#39;\r\nnoquotes3=&quot;true&quot;\r\nwithquotes=&#39;&quot;true&quot;&#39;\r\nwithquotes2=&quot;&#39;true&#39;&quot;\r\n[[ $noquotes == true ]] &amp;&amp; echo &#39;no quotes!&#39;\r\n[[ $noquotes2 == true ]] &amp;&amp; echo &#39;no quotes!&#39;\r\n[[ $noquotes3 == true ]] &amp;&amp; echo &#39;no quotes!&#39;\r\n[[ $noquotes == &quot;true&quot; ]] &amp;&amp; echo &#39;no quotes!&#39;\r\n[[ $noquotes2 == &quot;true&quot; ]] &amp;&amp; echo &#39;no quotes!&#39;\r\n[[ $noquotes3 == &quot;true&quot; ]] &amp;&amp; echo &#39;no quotes!&#39;\r\n[[ $noquotes == &#39;true&#39; ]] &amp;&amp; echo &#39;no quotes!&#39;\r\n[[ $noquotes2 == &#39;true&#39; ]] &amp;&amp; echo &#39;no quotes!&#39;\r\n[[ $noquotes3 == &#39;true&#39; ]] &amp;&amp; echo &#39;no quotes!&#39;\r\n\r\n[[ $withquotes == &#39;&quot;true&quot;&#39; ]] &amp;&amp; echo &#39;double quotes!&#39;\r\n[[ $withquotes2 == &quot;&#39;true&#39;&quot; ]] &amp;&amp; echo &#39;single quotes!&#39;\r\n```\r\n\r\n`echo &#39;{&quot;data&quot;:&quot;true&quot;}&#39; | jq &#39;.data&#39;` outputs `&quot;true&quot;` (with quotes; you get valid JSON strings as output), if you want to get the raw strings (no longer valid JSON), you can pass the  [`-r`/`--raw-output` flag](https://jqlang.github.io/jq/manual/#invoking-jq) to jq:\r\n\r\n```\r\necho &#39;{&quot;data&quot;:&quot;true&quot;}&#39; | jq -r &#39;.data&#39;\r\n```\r\n\r\nThis will only output the string content; `true` (without quotes) in your case.\r\n\r\nBut you don&#39;t need to compare the string in your shell at all, you can do the comparison directly in jq and leverage the [`-e`/`--exit-status` flag](https://jqlang.github.io/jq/manual/#invoking-jq) to set the exit code from jq:\r\n\r\n```\r\nif echo &#39;{&quot;data&quot;:&quot;true&quot;}&#39; | jq -re &#39;.data==&quot;true&quot;&#39; &gt;/dev/null; then\r\n  echo &#39;data was &quot;true&quot;&#39;\r\nfi",
                "title": "Why my string comparison isn&#39;t working in bash?"
            }
        ],
        "is_answered": false,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1712132010,
        "creation_date": 1711657038,
        "last_edit_date": 1711657318,
        "question_id": 78240671,
        "body_markdown": "I&#39;ve a script that does something like this:\r\n\r\n```bash\r\nset -x\r\n\r\nmyJson=&quot;echo &#39;{\\&quot;data\\&quot;:\\&quot;true\\&quot;}&#39;&quot;\r\n\r\ncommandOutput=$(eval $myJson | jq &#39;.data&#39;)\r\n\r\necho $commandOutput\r\n\r\nwhile :\r\ndo\r\n    if [[ $commandOutput == &quot;true&quot; ]]\r\n    then\r\n        break\r\n    fi\r\n    sleep 1\r\ndone\r\n\r\necho &quot;Done&quot;\r\n```\r\n\r\nHowever, my string comparison never works. The only way I managed this to work was putting &#39;&quot;true&quot;&#39; in the string comparison. It seems that is something related to the eval. Since I&#39;ve set the x flag here is the output of this script:\r\n\r\n    + myJson=&#39;echo &#39;\\&#39;&#39;{&quot;data&quot;:&quot;true&quot;}&#39;\\&#39;&#39;&#39;\r\n    ++ eval echo &#39;&#39;\\&#39;&#39;{&quot;data&quot;:&quot;true&quot;}&#39;\\&#39;&#39;&#39;\r\n    +++ echo &#39;{&quot;data&quot;:&quot;true&quot;}&#39;\r\n    ++ jq .data\r\n    + commandOutput=&#39;&quot;true&quot;&#39;\r\n    + echo &#39;&quot;true&quot;&#39;\r\n    &quot;true&quot;\r\n    + :\r\n    + [[ &quot;true&quot; == \\t\\r\\u\\e ]]\r\n    + sleep 1\r\n    + :\r\n    + [[ &quot;true&quot; == \\t\\r\\u\\e ]]\r\n    + sleep 1\r\n    + :\r\n    + [[ &quot;true&quot; == \\t\\r\\u\\e ]]\r\n    + sleep 1\r\n\r\nIt seems that the string at the right side is being always scaped, if this is the case why is this happening?",
        "link": "https://stackoverflow.com/questions/78240671/why-my-string-comparison-isnt-working-in-bash",
        "title": "Why my string comparison isn&#39;t working in bash?"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1711683291,
                "last_edit_date": 1711683291,
                "creation_date": 1711682309,
                "answer_id": 78241819,
                "question_id": 78241769,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here is a way:\r\n```\r\n.arrays | map(\r\n  select(. == &quot;a_string&quot;) = &quot;b_string&quot;\r\n| select(objects | .name == &quot;foo&quot;) .properties = [{type: &quot;sometypeB&quot;, file: &quot;filename&quot;}]\r\n)\r\n```\r\n&lt;sup&gt;[Online demo](https://jqplay.org/s/AXRKdSEi6cy)&lt;/sup&gt;",
                "title": "Modify json with string in it"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1711683291,
        "creation_date": 1711681139,
        "last_edit_date": 1711681794,
        "question_id": 78241769,
        "body_markdown": "I have a json file like this:\r\n\r\n```json\r\n{\r\n&quot;arrays&quot;: [\r\n    &quot;a_string&quot;,\r\n    {\r\n      &quot;name&quot;: &quot;foo&quot;,\r\n      &quot;properties&quot;: [\r\n        {\r\n          &quot;type&quot;: &quot;some_type1&quot;,\r\n          &quot;url&quot;: &quot;https://example.com&quot;,\r\n          &quot;checksum&quot;: &quot;d6fd580fe890b826250aa5d5a88bcdb28839cff4d447ba51536cda4ceae89c4e&quot;\r\n        }\r\n      ]\r\n    },\r\n    &quot;another_string&quot;,\r\n    {\r\n      &quot;name&quot;: &quot;bar&quot;,\r\n      &quot;properties&quot;: [\r\n        {\r\n          &quot;type&quot;: &quot;some_type2&quot;,\r\n          &quot;url&quot;: &quot;https://example.org&quot;,\r\n          &quot;checksum&quot;: &quot;d6fd580fe890b826250aa5d5a88bcdb28839cff4d447ba51536cda4ceae89c4e&quot;\r\n        }\r\n      ]\r\n    }\r\n  ]\r\n}\r\n```\r\n\r\nI want to modify `&quot;a_string&quot;` to say `&quot;b_string&quot;` and the `properties` block of `foo` with something like `jq &#39;(.arrays[]| select(.name == &quot;foo&quot;)).sources |= [{&quot;type&quot; : &quot;sometypeB&quot;, &quot;file&quot; : &quot;filename&quot;}]&#39;`.\r\n\r\nBut `select(.name == &quot;foo&quot;)` fails here due to the string not having any `name`, any idea how I can modify both?\r\n\r\n\r\nThe final json should look like:\r\n\r\n```json\r\n{\r\n&quot;arrays&quot;: [\r\n    &quot;b_string&quot;,\r\n    {\r\n      &quot;name&quot;: &quot;foo&quot;,\r\n      &quot;properties&quot;: [\r\n        {\r\n          &quot;type&quot;: &quot;sometypeB&quot;,\r\n          &quot;file&quot;: &quot;filename&quot;\r\n        }\r\n      ]\r\n    },\r\n    &quot;another_string&quot;,\r\n    {\r\n      &quot;name&quot;: &quot;bar&quot;,\r\n      &quot;properties&quot;: [\r\n        {\r\n          &quot;type&quot;: &quot;some_type2&quot;,\r\n          &quot;url&quot;: &quot;https://example.org&quot;,\r\n          &quot;checksum&quot;: &quot;d6fd580fe890b826250aa5d5a88bcdb28839cff4d447ba51536cda4ceae89c4e&quot;\r\n        }\r\n      ]\r\n    }\r\n  ]\r\n}\r\n```",
        "link": "https://stackoverflow.com/questions/78241769/modify-json-with-string-in-it",
        "title": "Modify json with string in it"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1711690320,
                "last_edit_date": 1711690320,
                "creation_date": 1711688330,
                "answer_id": 78242072,
                "question_id": 78241999,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You were close. Try this:\r\n```\r\n.arrays |= map(select(objects | .name == &quot;foo&quot;) .properties = [{type : &quot;foo&quot;, url : &quot;bar&quot;}])\r\n```\r\n&lt;sup&gt;[Online demo](https://jqplay.org/s/8St1ZjXvRxn)&lt;/sup&gt;",
                "title": "Modify object in a JSON array that also contains strings"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1711690320,
        "creation_date": 1711686581,
        "last_edit_date": 1711689028,
        "question_id": 78241999,
        "body_markdown": "I have a JSON file like this:\r\n\r\n```json\r\n{\r\n&quot;header&quot;: &quot;headername&quot;,\r\n&quot;arrays&quot;: [\r\n    &quot;a_string&quot;,\r\n    {\r\n      &quot;name&quot;: &quot;foo&quot;,\r\n      &quot;properties&quot;: [\r\n        {\r\n          &quot;type&quot;: &quot;some_type1&quot;,\r\n          &quot;url&quot;: &quot;https://example.com&quot;,\r\n          &quot;checksum&quot;: &quot;d6fd580fe890b826250aa5d5a88bcdb28839cff4d447ba51536cda4ceae89c4e&quot;\r\n        }\r\n      ]\r\n    },\r\n    &quot;another_string&quot;,\r\n    {\r\n      &quot;name&quot;: &quot;bar&quot;,\r\n      &quot;properties&quot;: [\r\n        {\r\n          &quot;type&quot;: &quot;some_type2&quot;,\r\n          &quot;url&quot;: &quot;https://example.org&quot;,\r\n          &quot;checksum&quot;: &quot;d6fd580fe890b826250aa5d5a88bcdb28839cff4d447ba51536cda4ceae89c4e&quot;\r\n        }\r\n      ]\r\n    }\r\n  ]\r\n}\r\n```\r\n\r\nI want to change `properties` block of the array whose `name` is `foo`. The expected output is:\r\n\r\n```json\r\n{\r\n&quot;header&quot;: &quot;headername&quot;,\r\n&quot;arrays&quot;: [\r\n    &quot;a_string&quot;,\r\n    {\r\n      &quot;name&quot;: &quot;foo&quot;,\r\n      &quot;properties&quot;: [\r\n        {\r\n          &quot;type&quot;: &quot;foo&quot;,\r\n          &quot;url&quot;: &quot;bar&quot;\r\n        }\r\n      ]\r\n    },\r\n    &quot;another_string&quot;,\r\n    {\r\n      &quot;name&quot;: &quot;bar&quot;,\r\n      &quot;properties&quot;: [\r\n        {\r\n          &quot;type&quot;: &quot;some_type2&quot;,\r\n          &quot;url&quot;: &quot;https://example.org&quot;\r\n        }\r\n      ]\r\n    }\r\n  ]\r\n}\r\n```\r\n\r\nSomething like `.arrays[]| select(.name == &quot;foo&quot;).sources |= [{&quot;type&quot; : &quot;foo&quot;, &quot;url&quot; : &quot;bar&quot;}]` results in `jq: error (at &lt;stdin&gt;:26): Cannot index string with string &quot;name&quot;`\r\nand `.| select(.name == &quot;foo&quot;).sources |= [{&quot;type&quot; : &quot;foo&quot;, &quot;url&quot; : &quot;bar&quot;}]` can parse it but changes nothing.\r\n",
        "link": "https://stackoverflow.com/questions/78241999/modify-object-in-a-json-array-that-also-contains-strings",
        "title": "Modify object in a JSON array that also contains strings"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1711791246,
                "creation_date": 1711791246,
                "answer_id": 78247430,
                "question_id": 78247386,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Using a regex:\r\n```\r\n.foo[].bar.second\r\n| (.key1 | capture(&quot;delimiter1(?&lt;v&gt;.*)delimter2&quot;).v)\r\n, .key2\r\n```\r\n&lt;sup&gt;[Online demo](https://jqplay.org/s/BOnbXIbskPN)&lt;/sup&gt;",
                "title": "Is there a way of extracting portion of a key value between delimiters?"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1711827264,
                "last_edit_date": 1711827264,
                "creation_date": 1711791578,
                "answer_id": 78247450,
                "question_id": 78247386,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can do it using a regex:\r\n\r\n    cat file1.txt | jq &#39;.foo[].bar.second | (.key1 | match(&quot;delimiter1([^*]*)delimter2&quot;).captures[0].string), .key2&#39;",
                "title": "Is there a way of extracting portion of a key value between delimiters?"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1712208023,
                "last_edit_date": 1712208023,
                "creation_date": 1712206879,
                "answer_id": 78271769,
                "question_id": 78247386,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can use `--arg` to assign `$d1=delimiter1` and `$d2=delimter2` then replace everything before $d1 and everything after $d2\r\n\r\njq will read `.*\\($d1)|\\($d2).*` as `.*delimiter1|delimter2.*`\r\n\r\n```console\r\n$ jq \\\r\n  --arg d1 delimiter1 \\\r\n  --arg d2 delimter2 \\\r\n  &#39;.foo[].bar.second.key1|gsub(&quot;.*\\($d1)|\\($d2).*&quot;;&quot;&quot;)&#39;\r\n\r\n&quot;_FIRST_IMPORTANT_VALUE_&quot;\r\n&quot;_SECOND_IMPORTANT_VALUE_&quot;\r\n```\r\n\r\n---\r\n\r\n**if you want .key1 and .key2:**  \r\n`&#39;.foo[].bar.second|[.key1,.key2][]|gsub(&quot;.*\\($d1)|\\($d2).*&quot;;&quot;&quot;)&#39;`\r\n\r\n**if you want .key1, .key2, and .key3**:  \r\n`&#39;.foo[].bar.second|values[]|gsub(&quot;.*\\($d1)|\\($d2).*&quot;;&quot;&quot;)&#39;`",
                "title": "Is there a way of extracting portion of a key value between delimiters?"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 2,
        "last_activity_date": 1712208023,
        "creation_date": 1711790254,
        "last_edit_date": 1711825714,
        "question_id": 78247386,
        "body_markdown": "Here is my JSON. Its in a file called `file1.txt`\r\n\r\n    {\r\n        &quot;foo&quot;: [\r\n            {\r\n                &quot;bar&quot;: {\r\n                    &quot;second&quot;: {\r\n                        &quot;key1&quot;: &quot;some/path/to/delimiter1_FIRST_IMPORTANT_VALUE_delimter2&quot;,\r\n                        &quot;key2&quot;: &quot;OK_as_it_is&quot;,\r\n                        &quot;key3&quot;: &quot;Just to show there is more stuff&quot;\r\n                    }\r\n                }\r\n            },\r\n            {\r\n                &quot;bar&quot;: {\r\n                    &quot;second&quot;: {\r\n                        &quot;key1&quot;: &quot;some/path/to/delimiter1_SECOND_IMPORTANT_VALUE_delimter2&quot;,\r\n                        &quot;key2&quot;: &quot;Also_OK_as_it_is&quot;,\r\n                        &quot;key3&quot;: &quot;Just to show there is more stuff&quot;\r\n                    }\r\n                }\r\n            }\r\n        ]\r\n    }\r\n\r\nWhat I want to do is extract PORTION of the `key1` value - the bits between `delimiter1` and `delimiter2` which would be **\\_FIRST_IMPORTANT_VALUE\\_** and **\\_SECOND_IMPORTANT_VALUE\\_**\r\n\r\nI know that the following ALMOST works:\r\n\r\n    $ cat file1.txt | jq &#39;.foo[].bar.second | (.key1[23:46]),  .key2&#39;\r\n    &quot;_FIRST_IMPORTANT_VALUE_&quot;\r\n    &quot;OK_as_it_is&quot;\r\n    &quot;_SECOND_IMPORTANT_VALUE&quot;\r\n    &quot;Also_OK_as_it_is&quot;\r\n\r\n...but as you can see, it misses the last character of **\\_SECOND_IMPORTANT_VALUE\\_**\r\n\r\nSo I need a more generalised form of the `jq &#39;.foo[].bar.second | (.key1[23:46]),  .key2&#39;` that replaces the numbers `23` and `46` with values determined from **delimiter1** and **delimiter2**\r\n\r\nI really want to keep it to a single line - without using bash variables over multiple lines, sort of keep it within **jq**.",
        "link": "https://stackoverflow.com/questions/78247386/is-there-a-way-of-extracting-portion-of-a-key-value-between-delimiters",
        "title": "Is there a way of extracting portion of a key value between delimiters?"
    },
    {
        "tags": [
            "bash",
            "jq",
            "ripgrep"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 2435703,
                    "reputation": 27493,
                    "user_id": 2125671,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/13a492143ab4a2575b5a1f500691193c?s=256&d=identicon&r=PG",
                    "display_name": "Philippe",
                    "link": "https://stackoverflow.com/users/2125671/philippe"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1711912071,
                "post_id": 78252129,
                "comment_id": 137957014,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1974896,
                    "reputation": 14280,
                    "user_id": 1772898,
                    "user_type": "registered",
                    "accept_rate": 65,
                    "profile_image": "https://www.gravatar.com/avatar/f768b6e41490b85bcfa9823404519fa8?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Ahmad Ismail",
                    "link": "https://stackoverflow.com/users/1772898/ahmad-ismail"
                },
                "reply_to_user": {
                    "account_id": 2435703,
                    "reputation": 27493,
                    "user_id": 2125671,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/13a492143ab4a2575b5a1f500691193c?s=256&d=identicon&r=PG",
                    "display_name": "Philippe",
                    "link": "https://stackoverflow.com/users/2125671/philippe"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1711913757,
                "post_id": 78252129,
                "comment_id": 137957166,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 6014861,
                    "reputation": 20007,
                    "user_id": 7939871,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/1199ba5dde05e4083823a058c5ac6bed?s=256&d=identicon&r=PG",
                    "display_name": "L&#233;a Gris",
                    "link": "https://stackoverflow.com/users/7939871/l%c3%a9a-gris"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1711914021,
                "post_id": 78252129,
                "comment_id": 137957190,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1711925708,
                "last_edit_date": 1711925708,
                "creation_date": 1711911958,
                "answer_id": 78252525,
                "question_id": 78252129,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "OP Here.\r\n\r\nBoth of the following commands are working for me:\r\n\r\n    curl -Lfs &quot;https://motivatedsisters.com/2019/07/08/arabic-review-sr-rahat-basit/&quot; | rg -o &#39;&lt;li&gt;.*?href=&quot;(.*?)&quot;.*?&lt;/a&gt; (.*?)&lt;\\/li&gt;&#39; -r &#39;echo $1 $(unescape_html &quot;$2&quot;)&#39; | bash | rg -o &#39;(https?://\\S+)\\s(.*)&#39; -r &#39;echo $1 $(unescape_html &quot;$2&quot;)&#39;  -r &#39;{&quot;url&quot;: &quot;$1&quot;, &quot;title&quot;: &quot;$2&quot;}&#39; | jq -s &#39;.&#39;\r\n\r\nand \r\n\r\n    curl -Lfs &quot;https://motivatedsisters.com/2019/07/08/arabic-review-sr-rahat-basit/&quot; | rg &#39;&lt;li&gt;.*?href=&quot;(.*?)&quot;.*?&lt;/a&gt; (.*?)&lt;\\/li&gt;&#39; -or &#39;$1 $2&#39; | while read -r link title; do echo &quot;$link&quot; &quot;$(unescape_html &quot;$title&quot;)&quot;; done | rg -o &#39;(https?://\\S+)\\s(.*)&#39; -r &#39;{&quot;url&quot;: &quot;$1&quot;, &quot;title&quot;: &quot;$2&quot;}&#39; | jq -s &#39;.&#39;",
                "title": "Run an external command within jq to manipulate each values of a particular key"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": -1,
        "last_activity_date": 1711925708,
        "creation_date": 1711904049,
        "last_edit_date": 1711911908,
        "question_id": 78252129,
        "body_markdown": "I have a json like \r\n\r\n    [\r\n      {\r\n        &quot;url&quot;: &quot;https://drive.google.com/file/d/1tO-qVknlH0PLK9CblQsyd568ZiptdKff/view?usp=share_link&quot;,\r\n        &quot;title&quot;: &quot;&amp;#8211; Flexibility&quot;\r\n      },\r\n      {\r\n        &quot;url&quot;: &quot;https://drive.google.com/open?id=11_sR8X13lmPcvlT3POfMW3044f3wZdra&quot;,\r\n        &quot;title&quot;: &quot;&amp;#8211; Pronouns&quot;\r\n      }\r\n    ]\r\n\r\nI got it using `curl -Lfs &quot;https://motivatedsisters.com/2019/07/08/arabic-review-sr-rahat-basit/&quot; | rg -o &#39;&lt;li&gt;.*?href=&quot;(.*?)&quot;.*?&lt;/a&gt; (.*?)&lt;\\/li&gt;&#39; -r &#39;{&quot;url&quot;: &quot;$1&quot;, &quot;title&quot;: &quot;$2&quot;}&#39; | jq -s &#39;.&#39;`.\r\n\r\nI have a command in my machine named `unescape_html`, a python scipt to unescape the html (replace &amp;#8211; with appropriate character).\r\n\r\nHow can I apply this function on each of the titles using `jq`.\r\n\r\nFor example:\r\n\r\nI want to run:\r\n\r\n    unescape_html &quot;&amp;#8211; Flexibility&quot;\r\n    unescape_html &quot;&amp;#8211; Pronouns&quot;\r\n\r\nThe expected output is:\r\n\r\n    [\r\n      {\r\n        &quot;url&quot;: &quot;https://drive.google.com/file/d/1tO-qVknlH0PLK9CblQsyd568ZiptdKff/view?usp=share_link&quot;,\r\n        &quot;title&quot;: &quot;– Flexibility&quot;\r\n      },\r\n      {\r\n        &quot;url&quot;: &quot;https://drive.google.com/open?id=11_sR8X13lmPcvlT3POfMW3044f3wZdra&quot;,\r\n        &quot;title&quot;: &quot;– Pronouns&quot;\r\n      }\r\n    ]\r\n\r\n**Update 1:**\r\n\r\nIf `jq` doesn&#39;t have that feature, then i am also fine that the command is applied on `rg`.\r\n\r\nI mean, can i run `unescape_html` on `$2` on the line:\r\n\r\n    rg -o &#39;&lt;li&gt;.*?href=&quot;(.*?)&quot;.*?&lt;/a&gt; (.*?)&lt;\\/li&gt;&#39; -r &#39;{&quot;url&quot;: &quot;$1&quot;, &quot;title&quot;: &quot;$2&quot;}&#39;\r\n\r\nAny other bash approach to solve this problem is also fine. The point is, i need to run `unescape_html` on `title`, so that i get the expected output.\r\n\r\n**Update 2:**\r\n\r\nThe following command:\r\n\r\n    curl -Lfs &quot;https://motivatedsisters.com/2019/07/08/arabic-review-sr-rahat-basit/&quot; | rg -o &#39;&lt;li&gt;.*?href=&quot;(.*?)&quot;.*?&lt;/a&gt; (.*?)&lt;\\/li&gt;&#39; -r &#39;{&quot;url&quot;: &quot;$1&quot;, &quot;title&quot;: &quot;$2&quot;}&#39; | jq -s &#39;.&#39; | jq &#39;map(.title |= @sh &quot;unescape_html \\(.)&quot;)&#39;\r\n\r\ngives:\r\n\r\n    [\r\n      {\r\n        &quot;url&quot;: &quot;https://drive.google.com/file/d/1tO-qVknlH0PLK9CblQsyd568ZiptdKff/view?usp=share_link&quot;,\r\n        &quot;title&quot;: &quot;unescape_html &#39;&amp;#8211; Flexibility&#39;&quot;\r\n      },\r\n      {\r\n        &quot;url&quot;: &quot;https://drive.google.com/open?id=11_sR8X13lmPcvlT3POfMW3044f3wZdra&quot;,\r\n        &quot;title&quot;: &quot;unescape_html &#39;&amp;#8211; Pronouns&#39;&quot;\r\n      }\r\n    ]\r\n\r\nJust not evaluating the commands.\r\n\r\nThe following command works:\r\n\r\n    curl -Lfs &quot;https://motivatedsisters.com/2019/07/08/arabic-review-sr-rahat-basit/&quot; | rg -o &#39;&lt;li&gt;.*?href=&quot;(.*?)&quot;.*?&lt;/a&gt; (.*?)&lt;\\/li&gt;&#39; -r &#39;{&quot;url&quot;: &quot;$1&quot;, &quot;title&quot;: &quot;$2&quot;}&#39; | jq -s &#39;.&#39; | jq &#39;map(.title |= sub(&quot;&amp;#8211;&quot;; &quot;–&quot;))&#39;\r\n\r\nBut it only works for `&amp;#8211;`. It will not work for other reserved characters.\r\n\r\n**Update 3:**\r\n\r\nThe following command:\r\n\r\n    curl -Lfs &quot;https://motivatedsisters.com/2019/07/08/arabic-review-sr-rahat-basit/&quot; | rg -o &#39;&lt;li&gt;.*?href=&quot;(.*?)&quot;.*?&lt;/a&gt; (.*?)&lt;\\/li&gt;&#39; -r &#39;{&quot;url&quot;: &quot;$1&quot;, &quot;title&quot;: &quot;$2&quot;}&#39; | jq -s &#39;.&#39; | jq -r &#39;.[] | &quot;unescape_html \\(.title | @sh)&quot;&#39; | bash\r\n\r\nis giving:\r\n\r\n    – Flexibility\r\n    – Pronouns\r\n\r\nSo, it is applying the bash function. Now I need to format is so that the urls are come with the title in json format.",
        "link": "https://stackoverflow.com/questions/78252129/run-an-external-command-within-jq-to-manipulate-each-values-of-a-particular-key",
        "title": "Run an external command within jq to manipulate each values of a particular key"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 252240,
                    "reputation": 26806,
                    "user_id": 530160,
                    "user_type": "registered",
                    "accept_rate": 69,
                    "profile_image": "https://i.sstatic.net/xRnFS.jpg?s=256",
                    "display_name": "Nick ODell",
                    "link": "https://stackoverflow.com/users/530160/nick-odell"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1711930671,
                "post_id": 78253195,
                "comment_id": 137958376,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 13789219,
                    "reputation": 53538,
                    "user_id": 9952196,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/cd1a3f93172eb89e221c98e35e6e22b3?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Shawn",
                    "link": "https://stackoverflow.com/users/9952196/shawn"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1711934265,
                "post_id": 78253195,
                "comment_id": 137958556,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1569642,
                    "reputation": 115,
                    "user_id": 1457613,
                    "user_type": "registered",
                    "accept_rate": 43,
                    "profile_image": "https://www.gravatar.com/avatar/0c0223ebb4bd490d2c28a631da0f8cce?s=256&d=identicon&r=PG",
                    "display_name": "user1457613",
                    "link": "https://stackoverflow.com/users/1457613/user1457613"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1711963115,
                "post_id": 78253195,
                "comment_id": 137960567,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1569642,
                    "reputation": 115,
                    "user_id": 1457613,
                    "user_type": "registered",
                    "accept_rate": 43,
                    "profile_image": "https://www.gravatar.com/avatar/0c0223ebb4bd490d2c28a631da0f8cce?s=256&d=identicon&r=PG",
                    "display_name": "user1457613",
                    "link": "https://stackoverflow.com/users/1457613/user1457613"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1711963864,
                "post_id": 78253195,
                "comment_id": 137960636,
                "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": 1717347751,
                "post_id": 78253195,
                "comment_id": 138511257,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1712130404,
                "creation_date": 1712130404,
                "answer_id": 78266070,
                "question_id": 78253195,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "To convert all values of an array, you need to [`map`](https://jqlang.github.io/jq/manual/#map-map_values) its elements:\r\n\r\n```\r\n.DailyForecasts | map(.Day.RainProbability)\r\n```\r\n\r\n`map(f)` is equivalent to `[.[]|f]`, so the above can be rewritten to the equivalent:\r\n\r\n```\r\n[.DailyForecasts.[].Day.RainProbability]\r\n```\r\n\r\nOutput:\r\n\r\n```json\r\n[\r\n  2,\r\n  1,\r\n  7,\r\n  6,\r\n  9\r\n]\r\n```\r\n\r\nSimilarly for your second query:\r\n\r\n```\r\n.DailyForecasts | map(.AirAndPollen[1].Value)\r\n```\r\n\r\nor\r\n\r\n```\r\n[.DailyForecasts.[].AirAndPollen[1].Value]\r\n```\r\n\r\nOutput:\r\n\r\n```json\r\n[\r\n  12,\r\n  12,\r\n  13,\r\n  29,\r\n  69\r\n]\r\n```\r\n\r\nNote that your code is very sensitive to the order of the elements in the array. It looks like you are interested in the &quot;Grass&quot; value (the second element in the array, `.[1]`), so I would suggest to filter for this element specifically:\r\n\r\n```\r\n.DailyForecasts\r\n| map(.AirAndPollen.[] | select(.Name==&quot;Grass&quot;).Value)\r\n```",
                "title": "JQ Parse not returning indexed array just numbers"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": -1,
        "last_activity_date": 1712130404,
        "creation_date": 1711930459,
        "last_edit_date": 1711971270,
        "question_id": 78253195,
        "body_markdown": "I have a multi-nested weather dump (Accuweather):\r\nI am trying to get an indexed response/array ([0,...]) to sort - json and/or bash of the values. But my queries are only getting numbers-space separated. My queries in the two examples are ok in that they are getting to the correct position in the JSON, and the correct values, but just returning numbers.\r\nThe same when querying a string value, with or without quotes (-r).\r\n\r\nYes, I suppose I could loop through the output, I am just learning jq and know there must be something I am missing in the query to accomplish this. Help please.\r\n\r\nEx: 1 2 3 4 5 spaces only no &#39;[ ]&#39; \r\n\r\n**Query 1:**\r\n\r\n```sh\r\ndrp=$(cat &quot;$HOME/directory/file&quot; | jq &#39;.DailyForecasts[].Day.RainProbability | .&#39;)\r\n```\r\n\r\nJSON: -- The query above works as far as returns the correct value/integer output, this is a partial of 5 array sets. Just only returning digits, so: 1 number number number number, not returning in array form.  \r\n\r\n```json\r\n&quot;Day&quot;: {\r\n  &quot;Icon&quot;: 2,\r\n  &quot;IconPhrase&quot;: &quot;Mostly sunny&quot;,\r\n  &quot;HasPrecipitation&quot;: false,\r\n  &quot;ShortPhrase&quot;: &quot;Mostly sunny and breezy&quot;,\r\n  &quot;LongPhrase&quot;: &quot;Mostly sunny and breezy&quot;,\r\n  &quot;PrecipitationProbability&quot;: 1,\r\n  &quot;ThunderstormProbability&quot;: 0,\r\n  &quot;RainProbability&quot;: 1,\r\n  &quot;SnowProbability&quot;: 0,\r\n  &quot;IceProbability&quot;: 0,\r\n  &quot;Wind&quot;: {\r\n    &quot;Speed&quot;: {\r\n      &quot;Value&quot;: 15,\r\n      &quot;Unit&quot;: &quot;mi/h&quot;,\r\n      &quot;UnitType&quot;: 9,\r\n...\r\n}\t\r\n```\r\n\r\n**Query 2:**\r\n\r\n```sh\r\napg=$(cat &quot;$HOME/directory/file&quot; |\r\n jq &#39;.DailyForecasts[].AirAndPollen | .[1] | .Value | .&#39;)\r\n```\r\n\r\nI&#39;ve tried to map, etc, number of ways (ex. going for the grass value here).\r\n\r\nJSON: -- Same description as Query 1: returning 5 values not in array form. 12, next iteration, etc. \r\n\r\n```json\r\n&quot;AirAndPollen&quot;: [\r\n  {\r\n    &quot;Name&quot;: &quot;AirQuality&quot;,\r\n    &quot;Value&quot;: 44,\r\n    &quot;Category&quot;: &quot;Good&quot;,\r\n    &quot;CategoryValue&quot;: 1,\r\n    &quot;Type&quot;: &quot;Ozone&quot;\r\n  },\r\n  {\r\n    &quot;Name&quot;: &quot;Grass&quot;,\r\n    &quot;Value&quot;: 12,\r\n    &quot;Category&quot;: &quot;Moderate&quot;,\r\n    &quot;CategoryValue&quot;: 2\r\n  },\r\n... \r\n]\r\n```\r\n\r\n**The FULL json:**\r\n\r\n```json\r\n{&quot;Headline&quot;:{&quot;EffectiveDate&quot;:&quot;2024-04-03T08:00:00-05:00&quot;,&quot;EffectiveEpochDate&quot;:1712149200,&quot;Severity&quot;:7,&quot;Text&quot;:&quot;Not as hot Wednesday&quot;,&quot;Category&quot;:&quot;cooler&quot;,&quot;EndDate&quot;:&quot;2024-04-03T20:00:00-05:00&quot;,&quot;EndEpochDate&quot;:1712192400,&quot;MobileLink&quot;:&quot;http://www.accuweather.com/en/us/mcallen-tx/78501/daily-weather-forecast/335730?lang=en-us&quot;,&quot;Link&quot;:&quot;http://www.accuweather.com/en/us/mcallen-tx/78501/daily-weather-forecast/335730?lang=en-us&quot;},&quot;DailyForecasts&quot;:[{&quot;Date&quot;:&quot;2024-03-31T07:00:00-05:00&quot;,&quot;EpochDate&quot;:1711886400,&quot;Sun&quot;:{&quot;Rise&quot;:&quot;2024-03-31T07:24:00-05:00&quot;,&quot;EpochRise&quot;:1711887840,&quot;Set&quot;:&quot;2024-03-31T19:50:00-05:00&quot;,&quot;EpochSet&quot;:1711932600},&quot;Moon&quot;:{&quot;Rise&quot;:&quot;2024-03-31T01:03:00-05:00&quot;,&quot;EpochRise&quot;:1711864980,&quot;Set&quot;:&quot;2024-03-31T11:24:00-05:00&quot;,&quot;EpochSet&quot;:1711902240,&quot;Phase&quot;:&quot;WaningGibbous&quot;,&quot;Age&quot;:21},&quot;Temperature&quot;:{&quot;Minimum&quot;:{&quot;Value&quot;:73.0,&quot;Unit&quot;:&quot;F&quot;,&quot;UnitType&quot;:18},&quot;Maximum&quot;:{&quot;Value&quot;:88.0,&quot;Unit&quot;:&quot;F&quot;,&quot;UnitType&quot;:18}},&quot;RealFeelTemperature&quot;:{&quot;Minimum&quot;:{&quot;Value&quot;:74.0,&quot;Unit&quot;:&quot;F&quot;,&quot;UnitType&quot;:18,&quot;Phrase&quot;:&quot;Pleasant&quot;},&quot;Maximum&quot;:{&quot;Value&quot;:93.0,&quot;Unit&quot;:&quot;F&quot;,&quot;UnitType&quot;:18,&quot;Phrase&quot;:&quot;Hot&quot;}},&quot;RealFeelTemperatureShade&quot;:{&quot;Minimum&quot;:{&quot;Value&quot;:74.0,&quot;Unit&quot;:&quot;F&quot;,&quot;UnitType&quot;:18,&quot;Phrase&quot;:&quot;Pleasant&quot;},&quot;Maximum&quot;:{&quot;Value&quot;:90.0,&quot;Unit&quot;:&quot;F&quot;,&quot;UnitType&quot;:18,&quot;Phrase&quot;:&quot;Hot&quot;}},&quot;HoursOfSun&quot;:3.1,&quot;DegreeDaySummary&quot;:{&quot;Heating&quot;:{&quot;Value&quot;:0.0,&quot;Unit&quot;:&quot;F&quot;,&quot;UnitType&quot;:18},&quot;Cooling&quot;:{&quot;Value&quot;:15.0,&quot;Unit&quot;:&quot;F&quot;,&quot;UnitType&quot;:18}},&quot;AirAndPollen&quot;:[{&quot;Name&quot;:&quot;AirQuality&quot;,&quot;Value&quot;:78,&quot;Category&quot;:&quot;Moderate&quot;,&quot;CategoryValue&quot;:2,&quot;Type&quot;:&quot;Ozone&quot;},{&quot;Name&quot;:&quot;Grass&quot;,&quot;Value&quot;:12,&quot;Category&quot;:&quot;Moderate&quot;,&quot;CategoryValue&quot;:2},{&quot;Name&quot;:&quot;Mold&quot;,&quot;Value&quot;:3250,&quot;Category&quot;:&quot;Low&quot;,&quot;CategoryValue&quot;:1},{&quot;Name&quot;:&quot;Ragweed&quot;,&quot;Value&quot;:5,&quot;Category&quot;:&quot;Low&quot;,&quot;CategoryValue&quot;:1},{&quot;Name&quot;:&quot;Tree&quot;,&quot;Value&quot;:50,&quot;Category&quot;:&quot;Moderate&quot;,&quot;CategoryValue&quot;:2},{&quot;Name&quot;:&quot;UVIndex&quot;,&quot;Value&quot;:4,&quot;Category&quot;:&quot;Moderate&quot;,&quot;CategoryValue&quot;:2}],&quot;Day&quot;:{&quot;Icon&quot;:4,&quot;IconPhrase&quot;:&quot;Intermittent clouds&quot;,&quot;HasPrecipitation&quot;:false,&quot;ShortPhrase&quot;:&quot;Breezy with clouds and sun&quot;,&quot;LongPhrase&quot;:&quot;A warm breeze with intervals of clouds and sunshine&quot;,&quot;PrecipitationProbability&quot;:2,&quot;ThunderstormProbability&quot;:0,&quot;RainProbability&quot;:2,&quot;SnowProbability&quot;:0,&quot;IceProbability&quot;:0,&quot;Wind&quot;:{&quot;Speed&quot;:{&quot;Value&quot;:15.0,&quot;Unit&quot;:&quot;mi/h&quot;,&quot;UnitType&quot;:9},&quot;Direction&quot;:{&quot;Degrees&quot;:153,&quot;Localized&quot;:&quot;SSE&quot;,&quot;English&quot;:&quot;SSE&quot;}},&quot;WindGust&quot;:{&quot;Speed&quot;:{&quot;Value&quot;:27.6,&quot;Unit&quot;:&quot;mi/h&quot;,&quot;UnitType&quot;:9},&quot;Direction&quot;:{&quot;Degrees&quot;:170,&quot;Localized&quot;:&quot;S&quot;,&quot;English&quot;:&quot;S&quot;}},&quot;TotalLiquid&quot;:{&quot;Value&quot;:0.0,&quot;Unit&quot;:&quot;in&quot;,&quot;UnitType&quot;:1},&quot;Rain&quot;:{&quot;Value&quot;:0.0,&quot;Unit&quot;:&quot;in&quot;,&quot;UnitType&quot;:1},&quot;Snow&quot;:{&quot;Value&quot;:0.0,&quot;Unit&quot;:&quot;in&quot;,&quot;UnitType&quot;:1},&quot;Ice&quot;:{&quot;Value&quot;:0.0,&quot;Unit&quot;:&quot;in&quot;,&quot;UnitType&quot;:1},&quot;HoursOfPrecipitation&quot;:0.0,&quot;HoursOfRain&quot;:0.0,&quot;HoursOfSnow&quot;:0.0,&quot;HoursOfIce&quot;:0.0,&quot;CloudCover&quot;:85,&quot;Evapotranspiration&quot;:{&quot;Value&quot;:0.12,&quot;Unit&quot;:&quot;in&quot;,&quot;UnitType&quot;:1},&quot;SolarIrradiance&quot;:{&quot;Value&quot;:2900.4,&quot;Unit&quot;:&quot;W/m&#178;&quot;,&quot;UnitType&quot;:33},&quot;RelativeHumidity&quot;:{&quot;Minimum&quot;:58,&quot;Maximum&quot;:88,&quot;Average&quot;:68},&quot;WetBulbTemperature&quot;:{&quot;Minimum&quot;:{&quot;Value&quot;:71.0,&quot;Unit&quot;:&quot;F&quot;,&quot;UnitType&quot;:18},&quot;Maximum&quot;:{&quot;Value&quot;:77.0,&quot;Unit&quot;:&quot;F&quot;,&quot;UnitType&quot;:18},&quot;Average&quot;:{&quot;Value&quot;:74.0,&quot;Unit&quot;:&quot;F&quot;,&quot;UnitType&quot;:18}},&quot;WetBulbGlobeTemperature&quot;:{&quot;Minimum&quot;:{&quot;Value&quot;:72.0,&quot;Unit&quot;:&quot;F&quot;,&quot;UnitType&quot;:18},&quot;Maximum&quot;:{&quot;Value&quot;:82.0,&quot;Unit&quot;:&quot;F&quot;,&quot;UnitType&quot;:18},&quot;Average&quot;:{&quot;Value&quot;:78.0,&quot;Unit&quot;:&quot;F&quot;,&quot;UnitType&quot;:18}}},&quot;Night&quot;:{&quot;Icon&quot;:36,&quot;IconPhrase&quot;:&quot;Intermittent clouds&quot;,&quot;HasPrecipitation&quot;:false,&quot;ShortPhrase&quot;:&quot;Breezy early; clearing, humid&quot;,&quot;LongPhrase&quot;:&quot;Breezy in the evening; otherwise, turning out clear and humid&quot;,&quot;PrecipitationProbability&quot;:3,&quot;ThunderstormProbability&quot;:0,&quot;RainProbability&quot;:3,&quot;SnowProbability&quot;:0,&quot;IceProbability&quot;:0,&quot;Wind&quot;:{&quot;Speed&quot;:{&quot;Value&quot;:16.1,&quot;Unit&quot;:&quot;mi/h&quot;,&quot;UnitType&quot;:9},&quot;Direction&quot;:{&quot;Degrees&quot;:148,&quot;Localized&quot;:&quot;SSE&quot;,&quot;English&quot;:&quot;SSE&quot;}},&quot;WindGust&quot;:{&quot;Speed&quot;:{&quot;Value&quot;:32.2,&quot;Unit&quot;:&quot;mi/h&quot;,&quot;UnitType&quot;:9},&quot;Direction&quot;:{&quot;Degrees&quot;:150,&quot;Localized&quot;:&quot;SSE&quot;,&quot;English&quot;:&quot;SSE&quot;}},&quot;TotalLiquid&quot;:{&quot;Value&quot;:0.0,&quot;Unit&quot;:&quot;in&quot;,&quot;UnitType&quot;:1},&quot;Rain&quot;:{&quot;Value&quot;:0.0,&quot;Unit&quot;:&quot;in&quot;,&quot;UnitType&quot;:1},&quot;Snow&quot;:{&quot;Value&quot;:0.0,&quot;Unit&quot;:&quot;in&quot;,&quot;UnitType&quot;:1},&quot;Ice&quot;:{&quot;Value&quot;:0.0,&quot;Unit&quot;:&quot;in&quot;,&quot;UnitType&quot;:1},&quot;HoursOfPrecipitation&quot;:0.0,&quot;HoursOfRain&quot;:0.0,&quot;HoursOfSnow&quot;:0.0,&quot;HoursOfIce&quot;:0.0,&quot;CloudCover&quot;:75,&quot;Evapotranspiration&quot;:{&quot;Value&quot;:0.03,&quot;Unit&quot;:&quot;in&quot;,&quot;UnitType&quot;:1},&quot;SolarIrradiance&quot;:{&quot;Value&quot;:35.0,&quot;Unit&quot;:&quot;W/m&#178;&quot;,&quot;UnitType&quot;:33},&quot;RelativeHumidity&quot;:{&quot;Minimum&quot;:76,&quot;Maximum&quot;:92,&quot;Average&quot;:83},&quot;WetBulbTemperature&quot;:{&quot;Minimum&quot;:{&quot;Value&quot;:72.0,&quot;Unit&quot;:&quot;F&quot;,&quot;UnitType&quot;:18},&quot;Maximum&quot;:{&quot;Value&quot;:74.0,&quot;Unit&quot;:&quot;F&quot;,&quot;UnitType&quot;:18},&quot;Average&quot;:{&quot;Value&quot;:73.0,&quot;Unit&quot;:&quot;F&quot;,&quot;UnitType&quot;:18}},&quot;WetBulbGlobeTemperature&quot;:{&quot;Minimum&quot;:{&quot;Value&quot;:74.0,&quot;Unit&quot;:&quot;F&quot;,&quot;UnitType&quot;:18},&quot;Maximum&quot;:{&quot;Value&quot;:75.0,&quot;Unit&quot;:&quot;F&quot;,&quot;UnitType&quot;:18},&quot;Average&quot;:{&quot;Value&quot;:74.0,&quot;Unit&quot;:&quot;F&quot;,&quot;UnitType&quot;:18}}},&quot;Sources&quot;:[&quot;AccuWeather&quot;],&quot;MobileLink&quot;:&quot;http://www.accuweather.com/en/us/mcallen-tx/78501/daily-weather-forecast/335730?lang=en-us&quot;,&quot;Link&quot;:&quot;http://www.accuweather.com/en/us/mcallen-tx/78501/daily-weather-forecast/335730?lang=en-us&quot;},{&quot;Date&quot;:&quot;2024-04-01T07:00:00-05:00&quot;,&quot;EpochDate&quot;:1711972800,&quot;Sun&quot;:{&quot;Rise&quot;:&quot;2024-04-01T07:23:00-05:00&quot;,&quot;EpochRise&quot;:1711974180,&quot;Set&quot;:&quot;2024-04-01T19:50:00-05:00&quot;,&quot;EpochSet&quot;:1712019000},&quot;Moon&quot;:{&quot;Rise&quot;:&quot;2024-04-01T02:02:00-05:00&quot;,&quot;EpochRise&quot;:1711954920,&quot;Set&quot;:&quot;2024-04-01T12:21:00-05:00&quot;,&quot;EpochSet&quot;:1711992060,&quot;Phase&quot;:&quot;Last&quot;,&quot;Age&quot;:22},&quot;Temperature&quot;:{&quot;Minimum&quot;:{&quot;Value&quot;:72.0,&quot;Unit&quot;:&quot;F&quot;,&quot;UnitType&quot;:18},&quot;Maximum&quot;:{&quot;Value&quot;:93.0,&quot;Unit&quot;:&quot;F&quot;,&quot;UnitType&quot;:18}},&quot;RealFeelTemperature&quot;:{&quot;Minimum&quot;:{&quot;Value&quot;:75.0,&quot;Unit&quot;:&quot;F&quot;,&quot;UnitType&quot;:18,&quot;Phrase&quot;:&quot;Pleasant&quot;},&quot;Maximum&quot;:{&quot;Value&quot;:97.0,&quot;Unit&quot;:&quot;F&quot;,&quot;UnitType&quot;:18,&quot;Phrase&quot;:&quot;Hot&quot;}},&quot;RealFeelTemperatureShade&quot;:{&quot;Minimum&quot;:{&quot;Value&quot;:75.0,&quot;Unit&quot;:&quot;F&quot;,&quot;UnitType&quot;:18,&quot;Phrase&quot;:&quot;Pleasant&quot;},&quot;Maximum&quot;:{&quot;Value&quot;:94.0,&quot;Unit&quot;:&quot;F&quot;,&quot;UnitType&quot;:18,&quot;Phrase&quot;:&quot;Hot&quot;}},&quot;HoursOfSun&quot;:8.4,&quot;DegreeDaySummary&quot;:{&quot;Heating&quot;:{&quot;Value&quot;:0.0,&quot;Unit&quot;:&quot;F&quot;,&quot;UnitType&quot;:18},&quot;Cooling&quot;:{&quot;Value&quot;:18.0,&quot;Unit&quot;:&quot;F&quot;,&quot;UnitType&quot;:18}},&quot;AirAndPollen&quot;:[{&quot;Name&quot;:&quot;AirQuality&quot;,&quot;Value&quot;:80,&quot;Category&quot;:&quot;Moderate&quot;,&quot;CategoryValue&quot;:2,&quot;Type&quot;:&quot;Ozone&quot;},{&quot;Name&quot;:&quot;Grass&quot;,&quot;Value&quot;:12,&quot;Category&quot;:&quot;Moderate&quot;,&quot;CategoryValue&quot;:2},{&quot;Name&quot;:&quot;Mold&quot;,&quot;Value&quot;:3250,&quot;Category&quot;:&quot;Low&quot;,&quot;CategoryValue&quot;:1},{&quot;Name&quot;:&quot;Ragweed&quot;,&quot;Value&quot;:5,&quot;Category&quot;:&quot;Low&quot;,&quot;CategoryValue&quot;:1},{&quot;Name&quot;:&quot;Tree&quot;,&quot;Value&quot;:50,&quot;Category&quot;:&quot;Moderate&quot;,&quot;CategoryValue&quot;:2},{&quot;Name&quot;:&quot;UVIndex&quot;,&quot;Value&quot;:10,&quot;Category&quot;:&quot;Very High&quot;,&quot;CategoryValue&quot;:4}],&quot;Day&quot;:{&quot;Icon&quot;:3,&quot;IconPhrase&quot;:&quot;Partly sunny&quot;,&quot;HasPrecipitation&quot;:false,&quot;ShortPhrase&quot;:&quot;Partly sunny; breezy, humid&quot;,&quot;LongPhrase&quot;:&quot;Breezy and humid with sunshine and some clouds&quot;,&quot;PrecipitationProbability&quot;:1,&quot;ThunderstormProbability&quot;:0,&quot;RainProbability&quot;:1,&quot;SnowProbability&quot;:0,&quot;IceProbability&quot;:0,&quot;Wind&quot;:{&quot;Speed&quot;:{&quot;Value&quot;:18.4,&quot;Unit&quot;:&quot;mi/h&quot;,&quot;UnitType&quot;:9},&quot;Direction&quot;:{&quot;Degrees&quot;:160,&quot;Localized&quot;:&quot;SSE&quot;,&quot;English&quot;:&quot;SSE&quot;}},&quot;WindGust&quot;:{&quot;Speed&quot;:{&quot;Value&quot;:41.4,&quot;Unit&quot;:&quot;mi/h&quot;,&quot;UnitType&quot;:9},&quot;Direction&quot;:{&quot;Degrees&quot;:168,&quot;Localized&quot;:&quot;SSE&quot;,&quot;English&quot;:&quot;SSE&quot;}},&quot;TotalLiquid&quot;:{&quot;Value&quot;:0.0,&quot;Unit&quot;:&quot;in&quot;,&quot;UnitType&quot;:1},&quot;Rain&quot;:{&quot;Value&quot;:0.0,&quot;Unit&quot;:&quot;in&quot;,&quot;UnitType&quot;:1},&quot;Snow&quot;:{&quot;Value&quot;:0.0,&quot;Unit&quot;:&quot;in&quot;,&quot;UnitType&quot;:1},&quot;Ice&quot;:{&quot;Value&quot;:0.0,&quot;Unit&quot;:&quot;in&quot;,&quot;UnitType&quot;:1},&quot;HoursOfPrecipitation&quot;:0.0,&quot;HoursOfRain&quot;:0.0,&quot;HoursOfSnow&quot;:0.0,&quot;HoursOfIce&quot;:0.0,&quot;CloudCover&quot;:37,&quot;Evapotranspiration&quot;:{&quot;Value&quot;:0.19,&quot;Unit&quot;:&quot;in&quot;,&quot;UnitType&quot;:1},&quot;SolarIrradiance&quot;:{&quot;Value&quot;:7608.0,&quot;Unit&quot;:&quot;W/m&#178;&quot;,&quot;UnitType&quot;:33},&quot;RelativeHumidity&quot;:{&quot;Minimum&quot;:47,&quot;Maximum&quot;:87,&quot;Average&quot;:64},&quot;WetBulbTemperature&quot;:{&quot;Minimum&quot;:{&quot;Value&quot;:73.0,&quot;Unit&quot;:&quot;F&quot;,&quot;UnitType&quot;:18},&quot;Maximum&quot;:{&quot;Value&quot;:78.0,&quot;Unit&quot;:&quot;F&quot;,&quot;UnitType&quot;:18},&quot;Average&quot;:{&quot;Value&quot;:76.0,&quot;Unit&quot;:&quot;F&quot;,&quot;UnitType&quot;:18}},&quot;WetBulbGlobeTemperature&quot;:{&quot;Minimum&quot;:{&quot;Value&quot;:75.0,&quot;Unit&quot;:&quot;F&quot;,&quot;UnitType&quot;:18},&quot;Maximum&quot;:{&quot;Value&quot;:85.0,&quot;Unit&quot;:&quot;F&quot;,&quot;UnitType&quot;:18},&quot;Average&quot;:{&quot;Value&quot;:81.0,&quot;Unit&quot;:&quot;F&quot;,&quot;UnitType&quot;:18}}},&quot;Night&quot;:{&quot;Icon&quot;:35,&quot;IconPhrase&quot;:&quot;Partly cloudy&quot;,&quot;HasPrecipitation&quot;:false,&quot;ShortPhrase&quot;:&quot;Partly cloudy, warm and humid&quot;,&quot;LongPhrase&quot;:&quot;Warm and humid with patchy clouds&quot;,&quot;PrecipitationProbability&quot;:13,&quot;ThunderstormProbability&quot;:3,&quot;RainProbability&quot;:13,&quot;SnowProbability&quot;:0,&quot;IceProbability&quot;:0,&quot;Wind&quot;:{&quot;Speed&quot;:{&quot;Value&quot;:10.4,&quot;Unit&quot;:&quot;mi/h&quot;,&quot;UnitType&quot;:9},&quot;Direction&quot;:{&quot;Degrees&quot;:98,&quot;Localized&quot;:&quot;E&quot;,&quot;English&quot;:&quot;E&quot;}},&quot;WindGust&quot;:{&quot;Speed&quot;:{&quot;Value&quot;:27.6,&quot;Unit&quot;:&quot;mi/h&quot;,&quot;UnitType&quot;:9},&quot;Direction&quot;:{&quot;Degrees&quot;:146,&quot;Localized&quot;:&quot;SE&quot;,&quot;English&quot;:&quot;SE&quot;}},&quot;TotalLiquid&quot;:{&quot;Value&quot;:0.0,&quot;Unit&quot;:&quot;in&quot;,&quot;UnitType&quot;:1},&quot;Rain&quot;:{&quot;Value&quot;:0.0,&quot;Unit&quot;:&quot;in&quot;,&quot;UnitType&quot;:1},&quot;Snow&quot;:{&quot;Value&quot;:0.0,&quot;Unit&quot;:&quot;in&quot;,&quot;UnitType&quot;:1},&quot;Ice&quot;:{&quot;Value&quot;:0.0,&quot;Unit&quot;:&quot;in&quot;,&quot;UnitType&quot;:1},&quot;HoursOfPrecipitation&quot;:0.0,&quot;HoursOfRain&quot;:0.0,&quot;HoursOfSnow&quot;:0.0,&quot;HoursOfIce&quot;:0.0,&quot;CloudCover&quot;:45,&quot;Evapotranspiration&quot;:{&quot;Value&quot;:0.02,&quot;Unit&quot;:&quot;in&quot;,&quot;UnitType&quot;:1},&quot;SolarIrradiance&quot;:{&quot;Value&quot;:36.2,&quot;Unit&quot;:&quot;W/m&#178;&quot;,&quot;UnitType&quot;:33},&quot;RelativeHumidity&quot;:{&quot;Minimum&quot;:72,&quot;Maximum&quot;:93,&quot;Average&quot;:84},&quot;WetBulbTemperature&quot;:{&quot;Minimum&quot;:{&quot;Value&quot;:71.0,&quot;Unit&quot;:&quot;F&quot;,&quot;UnitType&quot;:18},&quot;Maximum&quot;:{&quot;Value&quot;:75.0,&quot;Unit&quot;:&quot;F&quot;,&quot;UnitType&quot;:18},&quot;Average&quot;:{&quot;Value&quot;:73.0,&quot;Unit&quot;:&quot;F&quot;,&quot;UnitType&quot;:18}},&quot;WetBulbGlobeTemperature&quot;:{&quot;Minimum&quot;:{&quot;Value&quot;:74.0,&quot;Unit&quot;:&quot;F&quot;,&quot;UnitType&quot;:18},&quot;Maximum&quot;:{&quot;Value&quot;:79.0,&quot;Unit&quot;:&quot;F&quot;,&quot;UnitType&quot;:18},&quot;Average&quot;:{&quot;Value&quot;:76.0,&quot;Unit&quot;:&quot;F&quot;,&quot;UnitType&quot;:18}}},&quot;Sources&quot;:[&quot;AccuWeather&quot;],&quot;MobileLink&quot;:&quot;http://www.accuweather.com/en/us/mcallen-tx/78501/daily-weather-forecast/335730?day=1&amp;lang=en-us&quot;,&quot;Link&quot;:&quot;http://www.accuweather.com/en/us/mcallen-tx/78501/daily-weather-forecast/335730?day=1&amp;lang=en-us&quot;},{&quot;Date&quot;:&quot;2024-04-02T07:00:00-05:00&quot;,&quot;EpochDate&quot;:1712059200,&quot;Sun&quot;:{&quot;Rise&quot;:&quot;2024-04-02T07:22:00-05:00&quot;,&quot;EpochRise&quot;:1712060520,&quot;Set&quot;:&quot;2024-04-02T19:51:00-05:00&quot;,&quot;EpochSet&quot;:1712105460},&quot;Moon&quot;:{&quot;Rise&quot;:&quot;2024-04-02T02:59:00-05:00&quot;,&quot;EpochRise&quot;:1712044740,&quot;Set&quot;:&quot;2024-04-02T13:25:00-05:00&quot;,&quot;EpochSet&quot;:1712082300,&quot;Phase&quot;:&quot;WaningCrescent&quot;,&quot;Age&quot;:23},&quot;Temperature&quot;:{&quot;Minimum&quot;:{&quot;Value&quot;:60.0,&quot;Unit&quot;:&quot;F&quot;,&quot;UnitType&quot;:18},&quot;Maximum&quot;:{&quot;Value&quot;:94.0,&quot;Unit&quot;:&quot;F&quot;,&quot;UnitType&quot;:18}},&quot;RealFeelTemperature&quot;:{&quot;Minimum&quot;:{&quot;Value&quot;:56.0,&quot;Unit&quot;:&quot;F&quot;,&quot;UnitType&quot;:18,&quot;Phrase&quot;:&quot;Cool&quot;},&quot;Maximum&quot;:{&quot;Value&quot;:93.0,&quot;Unit&quot;:&quot;F&quot;,&quot;UnitType&quot;:18,&quot;Phrase&quot;:&quot;Hot&quot;}},&quot;RealFeelTemperatureShade&quot;:{&quot;Minimum&quot;:{&quot;Value&quot;:56.0,&quot;Unit&quot;:&quot;F&quot;,&quot;UnitType&quot;:18,&quot;Phrase&quot;:&quot;Cool&quot;},&quot;Maximum&quot;:{&quot;Value&quot;:90.0,&quot;Unit&quot;:&quot;F&quot;,&quot;UnitType&quot;:18,&quot;Phrase&quot;:&quot;Hot&quot;}},&quot;HoursOfSun&quot;:4.1,&quot;DegreeDaySummary&quot;:{&quot;Heating&quot;:{&quot;Value&quot;:0.0,&quot;Unit&quot;:&quot;F&quot;,&quot;UnitType&quot;:18},&quot;Cooling&quot;:{&quot;Value&quot;:12.0,&quot;Unit&quot;:&quot;F&quot;,&quot;UnitType&quot;:18}},&quot;AirAndPollen&quot;:[{&quot;Name&quot;:&quot;AirQuality&quot;,&quot;Value&quot;:75,&quot;Category&quot;:&quot;Moderate&quot;,&quot;CategoryValue&quot;:2,&quot;Type&quot;:&quot;Ozone&quot;},{&quot;Name&quot;:&quot;Grass&quot;,&quot;Value&quot;:13,&quot;Category&quot;:&quot;Moderate&quot;,&quot;CategoryValue&quot;:2},{&quot;Name&quot;:&quot;Mold&quot;,&quot;Value&quot;:4388,&quot;Category&quot;:&quot;Low&quot;,&quot;CategoryValue&quot;:1},{&quot;Name&quot;:&quot;Ragweed&quot;,&quot;Value&quot;:6,&quot;Category&quot;:&quot;Low&quot;,&quot;CategoryValue&quot;:1},{&quot;Name&quot;:&quot;Tree&quot;,&quot;Value&quot;:55,&quot;Category&quot;:&quot;Moderate&quot;,&quot;CategoryValue&quot;:2},{&quot;Name&quot;:&quot;UVIndex&quot;,&quot;Value&quot;:8,&quot;Category&quot;:&quot;Very High&quot;,&quot;CategoryValue&quot;:4}],&quot;Day&quot;:{&quot;Icon&quot;:6,&quot;IconPhrase&quot;:&quot;Mostly cloudy&quot;,&quot;HasPrecipitation&quot;:false,&quot;ShortPhrase&quot;:&quot;Mostly cloudy and breezy&quot;,&quot;LongPhrase&quot;:&quot;Mostly cloudy, breezy and less humid&quot;,&quot;PrecipitationProbability&quot;:7,&quot;ThunderstormProbability&quot;:0,&quot;RainProbability&quot;:7,&quot;SnowProbability&quot;:0,&quot;IceProbability&quot;:0,&quot;Wind&quot;:{&quot;Speed&quot;:{&quot;Value&quot;:16.1,&quot;Unit&quot;:&quot;mi/h&quot;,&quot;UnitType&quot;:9},&quot;Direction&quot;:{&quot;Degrees&quot;:1,&quot;Localized&quot;:&quot;N&quot;,&quot;English&quot;:&quot;N&quot;}},&quot;WindGust&quot;:{&quot;Speed&quot;:{&quot;Value&quot;:33.4,&quot;Unit&quot;:&quot;mi/h&quot;,&quot;UnitType&quot;:9},&quot;Direction&quot;:{&quot;Degrees&quot;:360,&quot;Localized&quot;:&quot;N&quot;,&quot;English&quot;:&quot;N&quot;}},&quot;TotalLiquid&quot;:{&quot;Value&quot;:0.0,&quot;Unit&quot;:&quot;in&quot;,&quot;UnitType&quot;:1},&quot;Rain&quot;:{&quot;Value&quot;:0.0,&quot;Unit&quot;:&quot;in&quot;,&quot;UnitType&quot;:1},&quot;Snow&quot;:{&quot;Value&quot;:0.0,&quot;Unit&quot;:&quot;in&quot;,&quot;UnitType&quot;:1},&quot;Ice&quot;:{&quot;Value&quot;:0.0,&quot;Unit&quot;:&quot;in&quot;,&quot;UnitType&quot;:1},&quot;HoursOfPrecipitation&quot;:0.0,&quot;HoursOfRain&quot;:0.0,&quot;HoursOfSnow&quot;:0.0,&quot;HoursOfIce&quot;:0.0,&quot;CloudCover&quot;:76,&quot;Evapotranspiration&quot;:{&quot;Value&quot;:0.21,&quot;Unit&quot;:&quot;in&quot;,&quot;UnitType&quot;:1},&quot;SolarIrradiance&quot;:{&quot;Value&quot;:4941.3,&quot;Unit&quot;:&quot;W/m&#178;&quot;,&quot;UnitType&quot;:33},&quot;RelativeHumidity&quot;:{&quot;Minimum&quot;:17,&quot;Maximum&quot;:79,&quot;Average&quot;:36},&quot;WetBulbTemperature&quot;:{&quot;Minimum&quot;:{&quot;Value&quot;:61.0,&quot;Unit&quot;:&quot;F&quot;,&quot;UnitType&quot;:18},&quot;Maximum&quot;:{&quot;Value&quot;:70.0,&quot;Unit&quot;:&quot;F&quot;,&quot;UnitType&quot;:18},&quot;Average&quot;:{&quot;Value&quot;:65.0,&quot;Unit&quot;:&quot;F&quot;,&quot;UnitType&quot;:18}},&quot;WetBulbGlobeTemperature&quot;:{&quot;Minimum&quot;:{&quot;Value&quot;:72.0,&quot;Unit&quot;:&quot;F&quot;,&quot;UnitType&quot;:18},&quot;Maximum&quot;:{&quot;Value&quot;:77.0,&quot;Unit&quot;:&quot;F&quot;,&quot;UnitType&quot;:18},&quot;Average&quot;:{&quot;Value&quot;:74.0,&quot;Unit&quot;:&quot;F&quot;,&quot;UnitType&quot;:18}}},&quot;Night&quot;:{&quot;Icon&quot;:33,&quot;IconPhrase&quot;:&quot;Clear&quot;,&quot;HasPrecipitation&quot;:false,&quot;ShortPhrase&quot;:&quot;Clear and cooler&quot;,&quot;LongPhrase&quot;:&quot;Clear and cooler&quot;,&quot;PrecipitationProbability&quot;:10,&quot;ThunderstormProbability&quot;:0,&quot;RainProbability&quot;:10,&quot;SnowProbability&quot;:0,&quot;IceProbability&quot;:0,&quot;Wind&quot;:{&quot;Speed&quot;:{&quot;Value&quot;:11.5,&quot;Unit&quot;:&quot;mi/h&quot;,&quot;UnitType&quot;:9},&quot;Direction&quot;:{&quot;Degrees&quot;:15,&quot;Localized&quot;:&quot;NNE&quot;,&quot;English&quot;:&quot;NNE&quot;}},&quot;WindGust&quot;:{&quot;Speed&quot;:{&quot;Value&quot;:18.4,&quot;Unit&quot;:&quot;mi/h&quot;,&quot;UnitType&quot;:9},&quot;Direction&quot;:{&quot;Degrees&quot;:7,&quot;Localized&quot;:&quot;N&quot;,&quot;English&quot;:&quot;N&quot;}},&quot;TotalLiquid&quot;:{&quot;Value&quot;:0.0,&quot;Unit&quot;:&quot;in&quot;,&quot;UnitType&quot;:1},&quot;Rain&quot;:{&quot;Value&quot;:0.0,&quot;Unit&quot;:&quot;in&quot;,&quot;UnitType&quot;:1},&quot;Snow&quot;:{&quot;Value&quot;:0.0,&quot;Unit&quot;:&quot;in&quot;,&quot;UnitType&quot;:1},&quot;Ice&quot;:{&quot;Value&quot;:0.0,&quot;Unit&quot;:&quot;in&quot;,&quot;UnitType&quot;:1},&quot;HoursOfPrecipitation&quot;:0.0,&quot;HoursOfRain&quot;:0.0,&quot;HoursOfSnow&quot;:0.0,&quot;HoursOfIce&quot;:0.0,&quot;CloudCover&quot;:0,&quot;Evapotranspiration&quot;:{&quot;Value&quot;:0.07,&quot;Unit&quot;:&quot;in&quot;,&quot;UnitType&quot;:1},&quot;SolarIrradiance&quot;:{&quot;Value&quot;:42.0,&quot;Unit&quot;:&quot;W/m&#178;&quot;,&quot;UnitType&quot;:33},&quot;RelativeHumidity&quot;:{&quot;Minimum&quot;:24,&quot;Maximum&quot;:59,&quot;Average&quot;:44},&quot;WetBulbTemperature&quot;:{&quot;Minimum&quot;:{&quot;Value&quot;:52.0,&quot;Unit&quot;:&quot;F&quot;,&quot;UnitType&quot;:18},&quot;Maximum&quot;:{&quot;Value&quot;:59.0,&quot;Unit&quot;:&quot;F&quot;,&quot;UnitType&quot;:18},&quot;Average&quot;:{&quot;Value&quot;:56.0,&quot;Unit&quot;:&quot;F&quot;,&quot;UnitType&quot;:18}},&quot;WetBulbGlobeTemperature&quot;:{&quot;Minimum&quot;:{&quot;Value&quot;:57.0,&quot;Unit&quot;:&quot;F&quot;,&quot;UnitType&quot;:18},&quot;Maximum&quot;:{&quot;Value&quot;:71.0,&quot;Unit&quot;:&quot;F&quot;,&quot;UnitType&quot;:18},&quot;Average&quot;:{&quot;Value&quot;:63.0,&quot;Unit&quot;:&quot;F&quot;,&quot;UnitType&quot;:18}}},&quot;Sources&quot;:[&quot;AccuWeather&quot;],&quot;MobileLink&quot;:&quot;http://www.accuweather.com/en/us/mcallen-tx/78501/daily-weather-forecast/335730?day=2&amp;lang=en-us&quot;,&quot;Link&quot;:&quot;http://www.accuweather.com/en/us/mcallen-tx/78501/daily-weather-forecast/335730?day=2&amp;lang=en-us&quot;},{&quot;Date&quot;:&quot;2024-04-03T07:00:00-05:00&quot;,&quot;EpochDate&quot;:1712145600,&quot;Sun&quot;:{&quot;Rise&quot;:&quot;2024-04-03T07:21:00-05:00&quot;,&quot;EpochRise&quot;:1712146860,&quot;Set&quot;:&quot;2024-04-03T19:51:00-05:00&quot;,&quot;EpochSet&quot;:1712191860},&quot;Moon&quot;:{&quot;Rise&quot;:&quot;2024-04-03T03:51:00-05:00&quot;,&quot;EpochRise&quot;:1712134260,&quot;Set&quot;:&quot;2024-04-03T14:31:00-05:00&quot;,&quot;EpochSet&quot;:1712172660,&quot;Phase&quot;:&quot;WaningCrescent&quot;,&quot;Age&quot;:24},&quot;Temperature&quot;:{&quot;Minimum&quot;:{&quot;Value&quot;:56.0,&quot;Unit&quot;:&quot;F&quot;,&quot;UnitType&quot;:18},&quot;Maximum&quot;:{&quot;Value&quot;:83.0,&quot;Unit&quot;:&quot;F&quot;,&quot;UnitType&quot;:18}},&quot;RealFeelTemperature&quot;:{&quot;Minimum&quot;:{&quot;Value&quot;:54.0,&quot;Unit&quot;:&quot;F&quot;,&quot;UnitType&quot;:18,&quot;Phrase&quot;:&quot;Cool&quot;},&quot;Maximum&quot;:{&quot;Value&quot;:83.0,&quot;Unit&quot;:&quot;F&quot;,&quot;UnitType&quot;:18,&quot;Phrase&quot;:&quot;Very Warm&quot;}},&quot;RealFeelTemperatureShade&quot;:{&quot;Minimum&quot;:{&quot;Value&quot;:54.0,&quot;Unit&quot;:&quot;F&quot;,&quot;UnitType&quot;:18,&quot;Phrase&quot;:&quot;Cool&quot;},&quot;Maximum&quot;:{&quot;Value&quot;:80.0,&quot;Unit&quot;:&quot;F&quot;,&quot;UnitType&quot;:18,&quot;Phrase&quot;:&quot;Pleasant&quot;}},&quot;HoursOfSun&quot;:12.5,&quot;DegreeDaySummary&quot;:{&quot;Heating&quot;:{&quot;Value&quot;:0.0,&quot;Unit&quot;:&quot;F&quot;,&quot;UnitType&quot;:18},&quot;Cooling&quot;:{&quot;Value&quot;:4.0,&quot;Unit&quot;:&quot;F&quot;,&quot;UnitType&quot;:18}},&quot;AirAndPollen&quot;:[{&quot;Name&quot;:&quot;AirQuality&quot;,&quot;Value&quot;:73,&quot;Category&quot;:&quot;Moderate&quot;,&quot;CategoryValue&quot;:2,&quot;Type&quot;:&quot;Ozone&quot;},{&quot;Name&quot;:&quot;Grass&quot;,&quot;Value&quot;:29,&quot;Category&quot;:&quot;High&quot;,&quot;CategoryValue&quot;:3},{&quot;Name&quot;:&quot;Mold&quot;,&quot;Value&quot;:5704,&quot;Category&quot;:&quot;Low&quot;,&quot;CategoryValue&quot;:1},{&quot;Name&quot;:&quot;Ragweed&quot;,&quot;Value&quot;:7,&quot;Category&quot;:&quot;Low&quot;,&quot;CategoryValue&quot;:1},{&quot;Name&quot;:&quot;Tree&quot;,&quot;Value&quot;:357,&quot;Category&quot;:&quot;High&quot;,&quot;CategoryValue&quot;:3},{&quot;Name&quot;:&quot;UVIndex&quot;,&quot;Value&quot;:10,&quot;Category&quot;:&quot;Very High&quot;,&quot;CategoryValue&quot;:4}],&quot;Day&quot;:{&quot;Icon&quot;:1,&quot;IconPhrase&quot;:&quot;Sunny&quot;,&quot;HasPrecipitation&quot;:false,&quot;ShortPhrase&quot;:&quot;Sunny and not as hot&quot;,&quot;LongPhrase&quot;:&quot;Not as hot but pleasant with plenty of sunshine&quot;,&quot;PrecipitationProbability&quot;:6,&quot;ThunderstormProbability&quot;:0,&quot;RainProbability&quot;:6,&quot;SnowProbability&quot;:0,&quot;IceProbability&quot;:0,&quot;Wind&quot;:{&quot;Speed&quot;:{&quot;Value&quot;:10.4,&quot;Unit&quot;:&quot;mi/h&quot;,&quot;UnitType&quot;:9},&quot;Direction&quot;:{&quot;Degrees&quot;:357,&quot;Localized&quot;:&quot;N&quot;,&quot;English&quot;:&quot;N&quot;}},&quot;WindGust&quot;:{&quot;Speed&quot;:{&quot;Value&quot;:18.4,&quot;Unit&quot;:&quot;mi/h&quot;,&quot;UnitType&quot;:9},&quot;Direction&quot;:{&quot;Degrees&quot;:346,&quot;Localized&quot;:&quot;NNW&quot;,&quot;English&quot;:&quot;NNW&quot;}},&quot;TotalLiquid&quot;:{&quot;Value&quot;:0.0,&quot;Unit&quot;:&quot;in&quot;,&quot;UnitType&quot;:1},&quot;Rain&quot;:{&quot;Value&quot;:0.0,&quot;Unit&quot;:&quot;in&quot;,&quot;UnitType&quot;:1},&quot;Snow&quot;:{&quot;Value&quot;:0.0,&quot;Unit&quot;:&quot;in&quot;,&quot;UnitType&quot;:1},&quot;Ice&quot;:{&quot;Value&quot;:0.0,&quot;Unit&quot;:&quot;in&quot;,&quot;UnitType&quot;:1},&quot;HoursOfPrecipitation&quot;:0.0,&quot;HoursOfRain&quot;:0.0,&quot;HoursOfSnow&quot;:0.0,&quot;HoursOfIce&quot;:0.0,&quot;CloudCover&quot;:0,&quot;Evapotranspiration&quot;:{&quot;Value&quot;:0.22,&quot;Unit&quot;:&quot;in&quot;,&quot;UnitType&quot;:1},&quot;SolarIrradiance&quot;:{&quot;Value&quot;:7924.6,&quot;Unit&quot;:&quot;W/m&#178;&quot;,&quot;UnitType&quot;:33},&quot;RelativeHumidity&quot;:{&quot;Minimum&quot;:23,&quot;Maximum&quot;:56,&quot;Average&quot;:33},&quot;WetBulbTemperature&quot;:{&quot;Minimum&quot;:{&quot;Value&quot;:53.0,&quot;Unit&quot;:&quot;F&quot;,&quot;UnitType&quot;:18},&quot;Maximum&quot;:{&quot;Value&quot;:59.0,&quot;Unit&quot;:&quot;F&quot;,&quot;UnitType&quot;:18},&quot;Average&quot;:{&quot;Value&quot;:57.0,&quot;Unit&quot;:&quot;F&quot;,&quot;UnitType&quot;:18}},&quot;WetBulbGlobeTemperature&quot;:{&quot;Minimum&quot;:{&quot;Value&quot;:58.0,&quot;Unit&quot;:&quot;F&quot;,&quot;UnitType&quot;:18},&quot;Maximum&quot;:{&quot;Value&quot;:71.0,&quot;Unit&quot;:&quot;F&quot;,&quot;UnitType&quot;:18},&quot;Average&quot;:{&quot;Value&quot;:66.0,&quot;Unit&quot;:&quot;F&quot;,&quot;UnitType&quot;:18}}},&quot;Night&quot;:{&quot;Icon&quot;:34,&quot;IconPhrase&quot;:&quot;Mostly clear&quot;,&quot;HasPrecipitation&quot;:false,&quot;ShortPhrase&quot;:&quot;Mainly clear&quot;,&quot;LongPhrase&quot;:&quot;Mainly clear&quot;,&quot;PrecipitationProbability&quot;:10,&quot;ThunderstormProbability&quot;:0,&quot;RainProbability&quot;:10,&quot;SnowProbability&quot;:0,&quot;IceProbability&quot;:0,&quot;Wind&quot;:{&quot;Speed&quot;:{&quot;Value&quot;:6.9,&quot;Unit&quot;:&quot;mi/h&quot;,&quot;UnitType&quot;:9},&quot;Direction&quot;:{&quot;Degrees&quot;:131,&quot;Localized&quot;:&quot;SE&quot;,&quot;English&quot;:&quot;SE&quot;}},&quot;WindGust&quot;:{&quot;Speed&quot;:{&quot;Value&quot;:13.8,&quot;Unit&quot;:&quot;mi/h&quot;,&quot;UnitType&quot;:9},&quot;Direction&quot;:{&quot;Degrees&quot;:47,&quot;Localized&quot;:&quot;NE&quot;,&quot;English&quot;:&quot;NE&quot;}},&quot;TotalLiquid&quot;:{&quot;Value&quot;:0.0,&quot;Unit&quot;:&quot;in&quot;,&quot;UnitType&quot;:1},&quot;Rain&quot;:{&quot;Value&quot;:0.0,&quot;Unit&quot;:&quot;in&quot;,&quot;UnitType&quot;:1},&quot;Snow&quot;:{&quot;Value&quot;:0.0,&quot;Unit&quot;:&quot;in&quot;,&quot;UnitType&quot;:1},&quot;Ice&quot;:{&quot;Value&quot;:0.0,&quot;Unit&quot;:&quot;in&quot;,&quot;UnitType&quot;:1},&quot;HoursOfPrecipitation&quot;:0.0,&quot;HoursOfRain&quot;:0.0,&quot;HoursOfSnow&quot;:0.0,&quot;HoursOfIce&quot;:0.0,&quot;CloudCover&quot;:11,&quot;Evapotranspiration&quot;:{&quot;Value&quot;:0.03,&quot;Unit&quot;:&quot;in&quot;,&quot;UnitType&quot;:1},&quot;SolarIrradiance&quot;:{&quot;Value&quot;:45.2,&quot;Unit&quot;:&quot;W/m&#178;&quot;,&quot;UnitType&quot;:33},&quot;RelativeHumidity&quot;:{&quot;Minimum&quot;:30,&quot;Maximum&quot;:79,&quot;Average&quot;:60},&quot;WetBulbTemperature&quot;:{&quot;Minimum&quot;:{&quot;Value&quot;:53.0,&quot;Unit&quot;:&quot;F&quot;,&quot;UnitType&quot;:18},&quot;Maximum&quot;:{&quot;Value&quot;:57.0,&quot;Unit&quot;:&quot;F&quot;,&quot;UnitType&quot;:18},&quot;Average&quot;:{&quot;Value&quot;:54.0,&quot;Unit&quot;:&quot;F&quot;,&quot;UnitType&quot;:18}},&quot;WetBulbGlobeTemperature&quot;:{&quot;Minimum&quot;:{&quot;Value&quot;:56.0,&quot;Unit&quot;:&quot;F&quot;,&quot;UnitType&quot;:18},&quot;Maximum&quot;:{&quot;Value&quot;:67.0,&quot;Unit&quot;:&quot;F&quot;,&quot;UnitType&quot;:18},&quot;Average&quot;:{&quot;Value&quot;:60.0,&quot;Unit&quot;:&quot;F&quot;,&quot;UnitType&quot;:18}}},&quot;Sources&quot;:[&quot;AccuWeather&quot;],&quot;MobileLink&quot;:&quot;http://www.accuweather.com/en/us/mcallen-tx/78501/daily-weather-forecast/335730?day=3&amp;lang=en-us&quot;,&quot;Link&quot;:&quot;http://www.accuweather.com/en/us/mcallen-tx/78501/daily-weather-forecast/335730?day=3&amp;lang=en-us&quot;},{&quot;Date&quot;:&quot;2024-04-04T07:00:00-05:00&quot;,&quot;EpochDate&quot;:1712232000,&quot;Sun&quot;:{&quot;Rise&quot;:&quot;2024-04-04T07:20:00-05:00&quot;,&quot;EpochRise&quot;:1712233200,&quot;Set&quot;:&quot;2024-04-04T19:52:00-05:00&quot;,&quot;EpochSet&quot;:1712278320},&quot;Moon&quot;:{&quot;Rise&quot;:&quot;2024-04-04T04:37:00-05:00&quot;,&quot;EpochRise&quot;:1712223420,&quot;Set&quot;:&quot;2024-04-04T15:40:00-05:00&quot;,&quot;EpochSet&quot;:1712263200,&quot;Phase&quot;:&quot;WaningCrescent&quot;,&quot;Age&quot;:25},&quot;Temperature&quot;:{&quot;Minimum&quot;:{&quot;Value&quot;:58.0,&quot;Unit&quot;:&quot;F&quot;,&quot;UnitType&quot;:18},&quot;Maximum&quot;:{&quot;Value&quot;:85.0,&quot;Unit&quot;:&quot;F&quot;,&quot;UnitType&quot;:18}},&quot;RealFeelTemperature&quot;:{&quot;Minimum&quot;:{&quot;Value&quot;:56.0,&quot;Unit&quot;:&quot;F&quot;,&quot;UnitType&quot;:18,&quot;Phrase&quot;:&quot;Cool&quot;},&quot;Maximum&quot;:{&quot;Value&quot;:89.0,&quot;Unit&quot;:&quot;F&quot;,&quot;UnitType&quot;:18,&quot;Phrase&quot;:&quot;Very Warm&quot;}},&quot;RealFeelTemperatureShade&quot;:{&quot;Minimum&quot;:{&quot;Value&quot;:56.0,&quot;Unit&quot;:&quot;F&quot;,&quot;UnitType&quot;:18,&quot;Phrase&quot;:&quot;Cool&quot;},&quot;Maximum&quot;:{&quot;Value&quot;:82.0,&quot;Unit&quot;:&quot;F&quot;,&quot;UnitType&quot;:18,&quot;Phrase&quot;:&quot;Very Warm&quot;}},&quot;HoursOfSun&quot;:11.3,&quot;DegreeDaySummary&quot;:{&quot;Heating&quot;:{&quot;Value&quot;:0.0,&quot;Unit&quot;:&quot;F&quot;,&quot;UnitType&quot;:18},&quot;Cooling&quot;:{&quot;Value&quot;:6.0,&quot;Unit&quot;:&quot;F&quot;,&quot;UnitType&quot;:18}},&quot;AirAndPollen&quot;:[{&quot;Name&quot;:&quot;AirQuality&quot;,&quot;Value&quot;:76,&quot;Category&quot;:&quot;Moderate&quot;,&quot;CategoryValue&quot;:2,&quot;Type&quot;:&quot;Ozone&quot;},{&quot;Name&quot;:&quot;Grass&quot;,&quot;Value&quot;:69,&quot;Category&quot;:&quot;High&quot;,&quot;CategoryValue&quot;:3},{&quot;Name&quot;:&quot;Mold&quot;,&quot;Value&quot;:7415,&quot;Category&quot;:&quot;Moderate&quot;,&quot;CategoryValue&quot;:2},{&quot;Name&quot;:&quot;Ragweed&quot;,&quot;Value&quot;:6,&quot;Category&quot;:&quot;Low&quot;,&quot;CategoryValue&quot;:1},{&quot;Name&quot;:&quot;Tree&quot;,&quot;Value&quot;:1202,&quot;Category&quot;:&quot;High&quot;,&quot;CategoryValue&quot;:3},{&quot;Name&quot;:&quot;UVIndex&quot;,&quot;Value&quot;:10,&quot;Category&quot;:&quot;Very High&quot;,&quot;CategoryValue&quot;:4}],&quot;Day&quot;:{&quot;Icon&quot;:2,&quot;IconPhrase&quot;:&quot;Mostly sunny&quot;,&quot;HasPrecipitation&quot;:false,&quot;ShortPhrase&quot;:&quot;Mostly sunny&quot;,&quot;LongPhrase&quot;:&quot;Mostly sunny&quot;,&quot;PrecipitationProbability&quot;:9,&quot;ThunderstormProbability&quot;:0,&quot;RainProbability&quot;:9,&quot;SnowProbability&quot;:0,&quot;IceProbability&quot;:0,&quot;Wind&quot;:{&quot;Speed&quot;:{&quot;Value&quot;:9.2,&quot;Unit&quot;:&quot;mi/h&quot;,&quot;UnitType&quot;:9},&quot;Direction&quot;:{&quot;Degrees&quot;:115,&quot;Localized&quot;:&quot;ESE&quot;,&quot;English&quot;:&quot;ESE&quot;}},&quot;WindGust&quot;:{&quot;Speed&quot;:{&quot;Value&quot;:20.7,&quot;Unit&quot;:&quot;mi/h&quot;,&quot;UnitType&quot;:9},&quot;Direction&quot;:{&quot;Degrees&quot;:81,&quot;Localized&quot;:&quot;E&quot;,&quot;English&quot;:&quot;E&quot;}},&quot;TotalLiquid&quot;:{&quot;Value&quot;:0.0,&quot;Unit&quot;:&quot;in&quot;,&quot;UnitType&quot;:1},&quot;Rain&quot;:{&quot;Value&quot;:0.0,&quot;Unit&quot;:&quot;in&quot;,&quot;UnitType&quot;:1},&quot;Snow&quot;:{&quot;Value&quot;:0.0,&quot;Unit&quot;:&quot;in&quot;,&quot;UnitType&quot;:1},&quot;Ice&quot;:{&quot;Value&quot;:0.0,&quot;Unit&quot;:&quot;in&quot;,&quot;UnitType&quot;:1},&quot;HoursOfPrecipitation&quot;:0.0,&quot;HoursOfRain&quot;:0.0,&quot;HoursOfSnow&quot;:0.0,&quot;HoursOfIce&quot;:0.0,&quot;CloudCover&quot;:11,&quot;Evapotranspiration&quot;:{&quot;Value&quot;:0.21,&quot;Unit&quot;:&quot;in&quot;,&quot;UnitType&quot;:1},&quot;SolarIrradiance&quot;:{&quot;Value&quot;:7955.3,&quot;Unit&quot;:&quot;W/m&#178;&quot;,&quot;UnitType&quot;:33},&quot;RelativeHumidity&quot;:{&quot;Minimum&quot;:26,&quot;Maximum&quot;:76,&quot;Average&quot;:41},&quot;WetBulbTemperature&quot;:{&quot;Minimum&quot;:{&quot;Value&quot;:55.0,&quot;Unit&quot;:&quot;F&quot;,&quot;UnitType&quot;:18},&quot;Maximum&quot;:{&quot;Value&quot;:62.0,&quot;Unit&quot;:&quot;F&quot;,&quot;UnitType&quot;:18},&quot;Average&quot;:{&quot;Value&quot;:60.0,&quot;Unit&quot;:&quot;F&quot;,&quot;UnitType&quot;:18}},&quot;WetBulbGlobeTemperature&quot;:{&quot;Minimum&quot;:{&quot;Value&quot;:59.0,&quot;Unit&quot;:&quot;F&quot;,&quot;UnitType&quot;:18},&quot;Maximum&quot;:{&quot;Value&quot;:74.0,&quot;Unit&quot;:&quot;F&quot;,&quot;UnitType&quot;:18},&quot;Average&quot;:{&quot;Value&quot;:69.0,&quot;Unit&quot;:&quot;F&quot;,&quot;UnitType&quot;:18}}},&quot;Night&quot;:{&quot;Icon&quot;:33,&quot;IconPhrase&quot;:&quot;Clear&quot;,&quot;HasPrecipitation&quot;:false,&quot;ShortPhrase&quot;:&quot;Clear&quot;,&quot;LongPhrase&quot;:&quot;Clear&quot;,&quot;PrecipitationProbability&quot;:5,&quot;ThunderstormProbability&quot;:0,&quot;RainProbability&quot;:5,&quot;SnowProbability&quot;:0,&quot;IceProbability&quot;:0,&quot;Wind&quot;:{&quot;Speed&quot;:{&quot;Value&quot;:9.2,&quot;Unit&quot;:&quot;mi/h&quot;,&quot;UnitType&quot;:9},&quot;Direction&quot;:{&quot;Degrees&quot;:127,&quot;Localized&quot;:&quot;SE&quot;,&quot;English&quot;:&quot;SE&quot;}},&quot;WindGust&quot;:{&quot;Speed&quot;:{&quot;Value&quot;:20.7,&quot;Unit&quot;:&quot;mi/h&quot;,&quot;UnitType&quot;:9},&quot;Direction&quot;:{&quot;Degrees&quot;:89,&quot;Localized&quot;:&quot;E&quot;,&quot;English&quot;:&quot;E&quot;}},&quot;TotalLiquid&quot;:{&quot;Value&quot;:0.0,&quot;Unit&quot;:&quot;in&quot;,&quot;UnitType&quot;:1},&quot;Rain&quot;:{&quot;Value&quot;:0.0,&quot;Unit&quot;:&quot;in&quot;,&quot;UnitType&quot;:1},&quot;Snow&quot;:{&quot;Value&quot;:0.0,&quot;Unit&quot;:&quot;in&quot;,&quot;UnitType&quot;:1},&quot;Ice&quot;:{&quot;Value&quot;:0.0,&quot;Unit&quot;:&quot;in&quot;,&quot;UnitType&quot;:1},&quot;HoursOfPrecipitation&quot;:0.0,&quot;HoursOfRain&quot;:0.0,&quot;HoursOfSnow&quot;:0.0,&quot;HoursOfIce&quot;:0.0,&quot;CloudCover&quot;:0,&quot;Evapotranspiration&quot;:{&quot;Value&quot;:0.03,&quot;Unit&quot;:&quot;in&quot;,&quot;UnitType&quot;:1},&quot;SolarIrradiance&quot;:{&quot;Value&quot;:48.5,&quot;Unit&quot;:&quot;W/m&#178;&quot;,&quot;UnitType&quot;:33},&quot;RelativeHumidity&quot;:{&quot;Minimum&quot;:37,&quot;Maximum&quot;:80,&quot;Average&quot;:65},&quot;WetBulbTemperature&quot;:{&quot;Minimum&quot;:{&quot;Value&quot;:54.0,&quot;Unit&quot;:&quot;F&quot;,&quot;UnitType&quot;:18},&quot;Maximum&quot;:{&quot;Value&quot;:58.0,&quot;Unit&quot;:&quot;F&quot;,&quot;UnitType&quot;:18},&quot;Average&quot;:{&quot;Value&quot;:57.0,&quot;Unit&quot;:&quot;F&quot;,&quot;UnitType&quot;:18}},&quot;WetBulbGlobeTemperature&quot;:{&quot;Minimum&quot;:{&quot;Value&quot;:58.0,&quot;Unit&quot;:&quot;F&quot;,&quot;UnitType&quot;:18},&quot;Maximum&quot;:{&quot;Value&quot;:66.0,&quot;Unit&quot;:&quot;F&quot;,&quot;UnitType&quot;:18},&quot;Average&quot;:{&quot;Value&quot;:62.0,&quot;Unit&quot;:&quot;F&quot;,&quot;UnitType&quot;:18}}},&quot;Sources&quot;:[&quot;AccuWeather&quot;],&quot;MobileLink&quot;:&quot;http://www.accuweather.com/en/us/mcallen-tx/78501/daily-weather-forecast/335730?day=4&amp;lang=en-us&quot;,&quot;Link&quot;:&quot;http://www.accuweather.com/en/us/mcallen-tx/78501/daily-weather-forecast/335730?day=4&amp;lang=en-us&quot;}]}\r\n```\r\n",
        "link": "https://stackoverflow.com/questions/78253195/jq-parse-not-returning-indexed-array-just-numbers",
        "title": "JQ Parse not returning indexed array just numbers"
    },
    {
        "tags": [
            "yaml",
            "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": 4,
                "creation_date": 1712069280,
                "post_id": 78262117,
                "comment_id": 137973668,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 26839391,
                    "reputation": 389,
                    "user_id": 20426148,
                    "user_type": "registered",
                    "profile_image": "https://lh3.googleusercontent.com/a/ALm5wu0TcHQFj-LEUsi2BcqGowziE67Lgi_E3LMObQ0=k-s256",
                    "display_name": "michaelt",
                    "link": "https://stackoverflow.com/users/20426148/michaelt"
                },
                "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": 1712075726,
                "post_id": 78262117,
                "comment_id": 137974824,
                "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": 1712083547,
                "post_id": 78262117,
                "comment_id": 137976008,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1712105457,
                "post_id": 78262117,
                "comment_id": 137978485,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1712129957,
                "creation_date": 1712129957,
                "answer_id": 78266023,
                "question_id": 78262117,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "&gt; [jq](https://github.com/jqlang/jq) is a lightweight and flexible command-line *JSON* processor akin to sed,awk,grep, and friends for *JSON* data.\r\n\r\nWhile YAML is a superset of JSON (any JSON document is also a valid YAML document), the reverse is not true. This means you cannot process generic YAML files with jq, but you need a tool that can handle YAML. One such tool is [yq](https://github.com/mikefarah/yq):\r\n\r\n&gt; a lightweight and portable command-line YAML, JSON and XML processor. yq uses jq like syntax but works with yaml files as well as json, xml, properties, csv and tsv.\r\n\r\nSince it uses a jq like syntax, you can simply swap the command:\r\n\r\n```\r\nhelm show chart … -n test | yq .\r\n```\r\n",
                "title": "parse error while passing helm show chart to jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1712129957,
        "creation_date": 1712069022,
        "last_edit_date": 1712083567,
        "question_id": 78262117,
        "body_markdown": "Hi I am getting a parse error when i perform the following command\r\n\r\n    helm show chart https://artifactory.vvr.com/artifactory/helm-release-local/jaeger/jaeger-assembly/jaeger-assembly-1.0.0.tgz -n test | jq .\r\n    \r\n    parse error: Invalid numeric literal at line 1, column 11\r\n\r\nthe output of helm show command is below\r\n\r\n    apiVersion: v1\r\n    appVersion: 1.0.0\r\n    dependencies:\r\n    - name: jaeger\r\n      repository: https://dependencies.vvr.com/artifactory/helm//jaegertracing\r\n      version: 0.44.0\r\n    description: aeger Assembly\r\n    name: jaeger-assembly\r\n    version: 1.0.0\r\n\r\nany idea why it is showing a parse error and how can i fix so that the helm show chart output can be parsed to json as i need to retrieve the version attribute\r\n\r\n",
        "link": "https://stackoverflow.com/questions/78262117/parse-error-while-passing-helm-show-chart-to-jq",
        "title": "parse error while passing helm show chart to jq"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1712161573,
                "last_edit_date": 1712161573,
                "creation_date": 1712101649,
                "answer_id": 78264532,
                "question_id": 78264525,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "here is how you can do this using the jq command line tool \r\n\r\n    cat input.json | jq &#39;walk(if type == &quot;object&quot; and has(&quot;food&quot;) then .food += {&quot;extra_cheese&quot;: true} else . end)&#39;\r\n",
                "title": "How can I modify a specific object structure at any location in a larger JSON object using `jq`?"
            },
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1712101879,
                "creation_date": 1712101879,
                "answer_id": 78264541,
                "question_id": 78264525,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Using `walk` would be one way:\r\n```sh\r\nwalk(select(objects | has(&quot;food&quot;)).food.extra_cheese = true)\r\n```\r\n[Demo](https://jqplay.org/s/1qWzQ0iEUiX)\r\n\r\nUsing `..` would be another:\r\n```sh\r\n(.. | objects | select(has(&quot;food&quot;))).food.extra_cheese = true\r\n```\r\n[Demo](https://jqplay.org/s/YqZ2RQA9HXJ)\r\n\r\n---\r\n\r\nIf you wanted to import and add the object `{&quot;extra_cheese&quot;: true}` from outside, use the `--argjson` option:\r\n```\r\njq --argjson new &#39;{&quot;extra_cheese&quot;: true}&#39; &#39;‌... .food += $new&#39; file.json",
                "title": "How can I modify a specific object structure at any location in a larger JSON object using `jq`?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1712161573,
        "creation_date": 1712101510,
        "question_id": 78264525,
        "body_markdown": "Say I have this JSON:\r\n\r\n```\r\n{\r\n  &quot;lunch&quot;: {\r\n    &quot;time&quot;: &quot;11 am&quot;,\r\n    &quot;food&quot;: {\r\n      &quot;is_pizza&quot;: true\r\n    }\r\n  },\r\n  &quot;snacks&quot;: [\r\n    {\r\n      &quot;time&quot;: &quot;2 pm&quot;,\r\n      &quot;food&quot;: {\r\n        &quot;is_pizza&quot;: true\r\n      }\r\n    },\r\n    {\r\n      &quot;time&quot;: &quot;3:30 pm&quot;,\r\n      &quot;food&quot;: {\r\n        &quot;is_pizza&quot;: true\r\n      }\r\n    }\r\n  ],\r\n  &quot;dinner&quot;: {\r\n    &quot;time&quot;: &quot;6 pm&quot;,\r\n    &quot;food&quot;: {\r\n      &quot;is_pizza&quot;: true\r\n    }\r\n  }\r\n}\r\n```\r\n\r\nNow I want to go through and *wherever* I see `&quot;food&quot;` object, add a the same key-value pair:\r\n\r\n```\r\n{\r\n  &quot;lunch&quot;: {\r\n    &quot;time&quot;: &quot;11 am&quot;,\r\n    &quot;food&quot;: {\r\n      &quot;is_pizza&quot;: true,\r\n      &quot;extra_cheese&quot;: true\r\n    }\r\n  },\r\n  &quot;snacks&quot;: [\r\n    {\r\n      &quot;time&quot;: &quot;2 pm&quot;,\r\n      &quot;food&quot;: {\r\n        &quot;is_pizza&quot;: true,\r\n        &quot;extra_cheese&quot;: true\r\n      }\r\n    },\r\n    {\r\n      &quot;time&quot;: &quot;3:30 pm&quot;,\r\n      &quot;food&quot;: {\r\n        &quot;is_pizza&quot;: true,\r\n        &quot;extra_cheese&quot;: true\r\n      }\r\n    }\r\n  ],\r\n  &quot;dinner&quot;: {\r\n    &quot;time&quot;: &quot;6 pm&quot;,\r\n    &quot;food&quot;: {\r\n      &quot;is_pizza&quot;: true,\r\n      &quot;extra_cheese&quot;: true\r\n    }\r\n  }\r\n}\r\n```\r\n\r\nHow can I do that in `jq`?\r\n",
        "link": "https://stackoverflow.com/questions/78264525/how-can-i-modify-a-specific-object-structure-at-any-location-in-a-larger-json-ob",
        "title": "How can I modify a specific object structure at any location in a larger JSON object using `jq`?"
    },
    {
        "tags": [
            "json",
            "jq",
            "jsonnet"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 1263399,
                    "reputation": 8291,
                    "user_id": 1221208,
                    "user_type": "registered",
                    "accept_rate": 86,
                    "profile_image": "https://www.gravatar.com/avatar/697e778614181fc3808d2bcafffe9980?s=256&d=identicon&r=PG",
                    "display_name": "Diego D",
                    "link": "https://stackoverflow.com/users/1221208/diego-d"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1712129247,
                "post_id": 78265746,
                "comment_id": 137980464,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1712149507,
                "last_edit_date": 1712149507,
                "creation_date": 1712129233,
                "answer_id": 78265948,
                "question_id": 78265746,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "To access `notebook_task` -  since `tasks` is an array you can use `array[]` syntax:\r\n\r\n```\r\njq &#39;.settings.tasks[].notebook_task&#39; yourfile.json\r\n```\r\n\r\nor \r\n```\r\njq &#39;.settings.tasks[].notebook_task.base_parameters&#39; yourfile.json\r\n```\r\n\r\nif you want to update a value inside it&#39;s the same idea\r\n\r\n````\r\njq &#39;.settings.tasks[].notebook_task.base_parameters.project = &quot;app2&quot;&#39; yourfile.json\r\n````",
                "title": "JSON Query - &#39;jq&#39; how do I get / update an object from an array or list"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -1,
        "last_activity_date": 1720036194,
        "creation_date": 1712127050,
        "last_edit_date": 1720036194,
        "question_id": 78265746,
        "body_markdown": "I have the below code in which I need to get/update the values of an object. I am able to get ```jq -r .settings.tasks``` What I need is to get and update values of ```base_parameters``` under ```notebook_task``` and it&#39;s objects project/path using ```jq``` utility.\r\n\r\n```\r\n&quot;settings&quot;: {\r\n   &quot;tasks&quot;: [\r\n\r\n      {\r\n\r\n        &quot;email_notifications&quot;: {},\r\n\r\n        &quot;job_cluster_key&quot;:&quot;artifactory_download_job_cluster&quot;,\r\n\r\n        &quot;max_retries&quot;:0,\r\n\r\n        &quot;min_retry_interval_millis&quot;:900000,\r\n\r\n        &quot;notebook_task&quot;: {\r\n\r\n          &quot;base_parameters&quot;: {\r\n\r\n            &quot;project&quot;:&quot;app1&quot;,\r\n\r\n            &quot;path&quot;:&quot;dir1/source1/file\r\n\r\n```",
        "link": "https://stackoverflow.com/questions/78265746/json-query-jq-how-do-i-get-update-an-object-from-an-array-or-list",
        "title": "JSON Query - &#39;jq&#39; how do I get / update an object from an array or list"
    },
    {
        "tags": [
            "python",
            "json",
            "python-3.x",
            "jq",
            "langchain"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1712676006,
                "creation_date": 1712676006,
                "answer_id": 78299501,
                "question_id": 78296361,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I think the following jq program will generate your desired output format. I had to make a few assumptions, because `source` is nowhere to be found in your input and your output doc is not valid JSON.\r\n\r\n```\r\nto_entries | map({\r\n    page_content: .value.page_data,\r\n    metadata: (.value | {\r\n        source: &quot;/content/json_data.json&quot;,\r\n        page_name,\r\n        page_url\r\n    } + {seq_num:(.key+1)})\r\n})\r\n```\r\n\r\nor\r\n\r\n```\r\nto_entries | map((.value | {\r\n    page_content: .page_data,\r\n    metadata: {\r\n        source: &quot;/content/json_data.json&quot;,\r\n        page_name,\r\n        page_url\r\n    }\r\n}) * { metadata: { seq_num: (.key+1) } })\r\n```\r\n\r\n\r\nOutput:\r\n\r\n```json\r\n[\r\n  {\r\n    &quot;page_content&quot;: &quot;Content about homepage&quot;,\r\n    &quot;metadata&quot;: {\r\n      &quot;source&quot;: &quot;/content/json_data.json&quot;,\r\n      &quot;page_name&quot;: &quot;Homepage&quot;,\r\n      &quot;page_url&quot;: &quot;https://mywebsite.com/homepage&quot;,\r\n      &quot;seq_num&quot;: 1\r\n    }\r\n  },\r\n  {\r\n    &quot;page_content&quot;: &quot;Content about Contact US&quot;,\r\n    &quot;metadata&quot;: {\r\n      &quot;source&quot;: &quot;/content/json_data.json&quot;,\r\n      &quot;page_name&quot;: &quot;Contact US&quot;,\r\n      &quot;page_url&quot;: &quot;https://mywebsite.com/contactus&quot;,\r\n      &quot;seq_num&quot;: 1\r\n    }\r\n  }\r\n]\r\n```",
                "title": "How to Upload JSON Keys to the &quot;metadata&quot; Attribute in the LangChain JSONLoader Using JQ Package?"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": -1,
        "last_activity_date": 1712676006,
        "creation_date": 1712642317,
        "last_edit_date": 1712642866,
        "question_id": 78296361,
        "body_markdown": "The primary objective of this activity is to display a summarized response alongside the document source in the LangChain QA bot.\r\n\r\nWithin my input JSON data, there are three keys: `page_name`, `page_data`, and `page_url`. I aim to save the content under `page_data` in the `page_content` attribute of LangChain&#39;s Document class using jq package. Additionally, I intend to store `page_name` and `page_url` in the metadata. Could you guide me on how to accomplish this?\r\n\r\n```python\r\n    from langchain_community.document_loaders import JSONLoader\r\n\r\n    ### data exported from MongoDB database\r\n\r\n    json_data = \r\n    [\r\n      {\r\n        &quot;_id&quot;: {\r\n          &quot;$oid&quot;: &quot;65ed5d18b251090135c27d98&quot;\r\n        },\r\n        &quot;page_name&quot;: &quot;Homepage&quot;,\r\n        &quot;page_data&quot;: &quot;Content about homepage&quot;,\r\n        &quot;page_url&quot;: &quot;https://mywebsite.com/homepage&quot;\r\n      },\r\n      {\r\n        &quot;_id&quot;: {\r\n          &quot;$oid&quot;: &quot;65ed5d2fb251090135c27d99&quot;\r\n        },\r\n        &quot;page_name&quot;: &quot;Contact US&quot;,\r\n        &quot;page_data&quot;: &quot;Content about Contact US&quot;,\r\n        &quot;page_url&quot;: &quot;https://mywebsite.com/contactus&quot;\r\n      }\r\n    ]\r\n\r\n    ### LangChain JSON loader Class\r\n\r\n    loader = JSONLoader(\r\n        file_path=&quot;/content/web_data.json&quot;,\r\n        jq_schema=&#39;.[].page_data&#39;,\r\n        text_content=False)\r\n    \r\n    docs = loader.load()\r\n\r\n    print(docs) --&gt;\r\n\r\n    [Document(page_content=&quot;Content about homepage&quot;, metadata={&#39;source&#39;: &#39;/content/json_data.json&#39;, &#39;seq_num&#39;: 1}),\r\n     Document(page_content=&quot;Content about Contact US&quot;, metadata={&#39;source&#39;: &#39;/content/json_data.json&#39;, &#39;seq_num&#39;: 2})]\r\n```\r\n\r\nFinal docs should look like this :\r\n\r\n    [Document(page_content=&quot;Content about homepage&quot;, metadata={&#39;source&#39;: &#39;/content/json_data.json&#39;, &#39;seq_num&#39;: 1, &#39;page_name&#39;: &#39;Homepage&#39;,&quot;page_url&quot;: &quot;https://mywebsite.com/homepage&quot;}),\r\n     Document(page_content=&quot;Content about Contact US&quot;, metadata={&#39;source&#39;: &#39;/content/json_data.json&#39;, &#39;seq_num&#39;: 2,&quot;page_name&quot;: &quot;Contact US&quot;,&quot;page_url&quot;: &quot;https://mywebsite.com/contactus&quot;})]",
        "link": "https://stackoverflow.com/questions/78296361/how-to-upload-json-keys-to-the-metadata-attribute-in-the-langchain-jsonloader",
        "title": "How to Upload JSON Keys to the &quot;metadata&quot; Attribute in the LangChain JSONLoader Using JQ Package?"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1712756367,
                "last_edit_date": 1712756367,
                "creation_date": 1712756058,
                "answer_id": 78304820,
                "question_id": 78304807,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "A key needs an `.` in front of it, then since it&#39;s in a variable, use `[]`.\r\n\r\n\r\n```\r\njq --arg key b &#39;.[$key] |= (. * 999)&#39; input\r\n```\r\n\r\nGives:\r\n```json\r\n{\r\n  &quot;a&quot;: 1,\r\n  &quot;b&quot;: 1998,\r\n  &quot;c&quot;: 3\r\n}\r\n```\r\n\r\n\r\nYou can also replace `|= . * ` with the `*=` operator:\r\n```\r\njq --arg key b &#39;.[$key] *= 999&#39; input\r\n```\r\n\r\n----------\r\n\r\nYour first attempt didn&#39;t work since you need `[]` instead off `()`\r\n\r\nThe second one failed because wrapping it in a  string literal will create a string `.b`, that&#39;s not something you can update using `|=`.",
                "title": "How to update value in json object with key as argument (using `jq`)"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1712756367,
        "creation_date": 1712755902,
        "question_id": 78304807,
        "body_markdown": "Using `jq` I want to update a value in a json object.\r\nThe key of the value to be updated is passed as an argument.\r\n\r\n*Input*\r\n```json\r\n{\r\n  &quot;a&quot;: 1,\r\n  &quot;b&quot;: 2,\r\n  &quot;c&quot;: 3\r\n}\r\n```\r\n\r\n*Expected output with argument: key=b*\r\n```json\r\n{\r\n  &quot;a&quot;: 1,\r\n  &quot;b&quot;: 42,\r\n  &quot;c&quot;: 3\r\n}\r\n```\r\n\r\nI tried to do:\r\n```jq\r\njq --arg key b &#39;.($key) |= . + 40&#39;\r\njq --arg key b &#39;&quot;.\\($key)&quot; |= . + 40&#39;\r\n```\r\n\r\nBoth attempts result in errors:\r\n- `syntax error, unexpected &#39;(&#39;`\r\n- `Invalid path expression with result &quot;.b&quot;`\r\n\r\nHow can I solve this problem?\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/78304807/how-to-update-value-in-json-object-with-key-as-argument-using-jq",
        "title": "How to update value in json object with key as argument (using `jq`)"
    },
    {
        "tags": [
            "json",
            "jq",
            "jsonlines"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1712768225,
                "creation_date": 1712768225,
                "answer_id": 78305953,
                "question_id": 78305924,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Almost there\r\n```\r\njq -c &#39;.Documents[]&#39; response.json\r\n```\r\n&lt;sup&gt;[Online demo](https://jqplay.org/s/z43MDGiKi4F)&lt;/sup&gt;",
                "title": "How to convert one line JSON to JSONLINES format using jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1712809610,
        "creation_date": 1712767823,
        "last_edit_date": 1712809610,
        "question_id": 78305924,
        "body_markdown": "I&#39;m trying to convert a big one line JSON file to a multiline JSONLINES file. I&#39;ve tried a bunch of commands and none of them are doing what I expect them to. This is the format of my data (input file: response.json) -\r\n\r\n```\r\n{&quot;_rid&quot;:&quot;12345&quot;,&quot;Documents&quot;:[{&quot;id&quot;: &quot;id-1&quot;, &quot;name&quot;: &quot;name-1&quot;, &quot;userId&quot;: &quot;userid-1&quot;, &quot;_rid&quot;: &quot;rid-1&quot;},{&quot;id&quot;: &quot;id-2&quot;, &quot;name&quot;: &quot;name-2&quot;, &quot;userId&quot;: &quot;userid-2&quot;, &quot;_rid&quot;: &quot;rid-2&quot;},{&quot;id&quot;: &quot;id-3&quot;, &quot;name&quot;: &quot;name-3&quot;, &quot;userId&quot;: &quot;userid-3&quot;, &quot;_rid&quot;: &quot;rid-3&quot;},....],&quot;_count&quot;:566}\r\n```\r\nI want to get rid of the unnecessary characters and make each record its own line. I want to get rid of the very first `_rid` but not the ones inside the individual records. My desired output looks like this -\r\n\r\n\r\n```\r\n{&quot;id&quot;: &quot;id-1&quot;, &quot;name&quot;: &quot;name-1&quot;, &quot;userId&quot;: &quot;userid-1&quot;, &quot;_rid&quot;: &quot;rid-1&quot;}\r\n{&quot;id&quot;: &quot;id-2&quot;, &quot;name&quot;: &quot;name-2&quot;, &quot;userId&quot;: &quot;userid-2&quot;, &quot;_rid&quot;: &quot;rid-2&quot;}\r\n{&quot;id&quot;: &quot;id-3&quot;, &quot;name&quot;: &quot;name-3&quot;, &quot;userId&quot;: &quot;userid-3&quot;, &quot;_rid&quot;: &quot;rid-3&quot;}\r\n....\r\n```\r\n\r\nThese are some queries I&#39;ve tried (I know some of these aren&#39;t going to work but I was desperate and tried so many things):\r\n\r\n```\r\njq --slurp &#39;.&#39; response.json &gt; output.jsonl\r\njq -c &#39;.[]&#39; | jq .&quot;Documents&quot; response.json &gt; output.jsonl\r\njq &#39;.[] | select(&quot;Documents&quot;)&#39; response.json &gt; output.jsonl\r\njq &#39;.[]&#39; | jq &#39;select(&quot;Documents&quot;)&#39; response.json &gt; output.jsonl\r\njq --slurp --compact-output &#39;map([ . ])&#39; response.json &gt; output.jsonl\r\n```\r\n\r\nHow do I do this using jq? Thanks!",
        "link": "https://stackoverflow.com/questions/78305924/how-to-convert-one-line-json-to-jsonlines-format-using-jq",
        "title": "How to convert one line JSON to JSONLINES format using jq?"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1712846266,
                "creation_date": 1712846266,
                "answer_id": 78311148,
                "question_id": 78311115,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "just wrap you jq query with syntax `[${request}]`\r\n\r\nfor sample \r\n\r\n```\r\njq &#39;[.list[] | .attributes.content[].id]&#39; input.json\r\n```\r\n\r\nin your case the request became \r\n\r\n```\r\n[.list[] | .attributes.content[].id]\r\n```",
                "title": "JQ extract array id of an object"
            },
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1712846338,
                "creation_date": 1712846338,
                "answer_id": 78311160,
                "question_id": 78311115,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can populate our own array:\r\n```\r\n[ .[][].attributes.content[]?.id ]\r\n```\r\n```json\r\n[&quot;AZER&quot;,&quot;WXC&quot;,&quot;QSD&quot;]\r\n```\r\n[Try it online][1]\r\n\r\n\r\n  [1]: https://jqplay.org/s/dp9DPh9-YTX",
                "title": "JQ extract array id of an object"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1712846453,
                "creation_date": 1712846453,
                "answer_id": 78311175,
                "question_id": 78311115,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "In general, just wrap your query that produces a stream of the desired values into array brackets, and the output is an array of those values.\r\n```sh\r\n[.list[] | .attributes.content[].id]\r\n```\r\n[Demo](https://jqplay.org/s/6yqBoihiYv2)\r\n\r\nNote that there&#39;s also a shortcut to `[ .[] … ]` called `map(…)`:\r\n```sh\r\n.list | map(.attributes.content[].id)\r\n```\r\n[Demo](https://jqplay.org/s/HHV2_S5vHh3)\r\n\r\nBoth output:\r\n```json\r\n[\r\n  &quot;AZER&quot;,\r\n  &quot;WXC&quot;,\r\n  &quot;QSD&quot;\r\n]\r\n```\r\n\r\nUse the `--compact-output` (or `-c`) flag, to remove irrelevant whitespace, thus compacting the output into a single line: `[&quot;AZER&quot;,&quot;WXC&quot;,&quot;QSD&quot;]`",
                "title": "JQ extract array id of an object"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1712847364,
                "creation_date": 1712847364,
                "answer_id": 78311278,
                "question_id": 78311115,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If you just want to extract all `&quot;id&quot;` values into an array, streaming is also an option.\r\n```\r\n[ tostream | select((.[0][-1]==&quot;id&quot;) and (.|length==2)) | .[1] ]\r\n```\r\nTry it on [jqplay.org](https://jqplay.org/s/8nHoxnCwlEW &quot;Click me!&quot;).",
                "title": "JQ extract array id of an object"
            }
        ],
        "is_answered": true,
        "answer_count": 4,
        "score": 0,
        "last_activity_date": 1712847364,
        "creation_date": 1712845971,
        "last_edit_date": 1712846317,
        "question_id": 78311115,
        "body_markdown": "I have this input data :\r\n\r\n```\r\n{\r\n    &quot;list&quot;: {\r\n        &quot;1&quot;: {\r\n            &quot;attributes&quot;: {\r\n                &quot;content&quot;: [],\r\n                &quot;pageable&quot;: {\r\n                    &quot;pageNumber&quot;: 0,\r\n                    &quot;pageSize&quot;: 10\r\n                }\r\n            }\r\n        },\r\n        &quot;2&quot;: {\r\n            &quot;attributes&quot;: {\r\n                &quot;content&quot;: [\r\n                    {\r\n                        &quot;id&quot;: &quot;AZER&quot;\r\n                    }\r\n                ],\r\n                &quot;pageable&quot;: {\r\n                    &quot;pageNumber&quot;: 0,\r\n                    &quot;pageSize&quot;: 10\r\n                }\r\n            }\r\n        },\r\n        &quot;3&quot;: {\r\n            &quot;attributes&quot;: {\r\n                &quot;content&quot;: [\r\n                    {\r\n                        &quot;id&quot;: &quot;WXC&quot;\r\n                    },\r\n                    {\r\n                        &quot;id&quot;: &quot;QSD&quot;\r\n                    }\r\n                ],\r\n                &quot;pageable&quot;: {\r\n                    &quot;pageNumber&quot;: 0,\r\n                    &quot;pageSize&quot;: 10\r\n                }\r\n            }\r\n        }\r\n    }\r\n}\r\n```\r\n\r\nI need to use JQ to extract the id values into a new array, I try this:\r\n\r\n`.list[] | .attributes.content[].id`\r\n\r\nthat&#39;s my results:\r\n\r\n```\r\n&quot;AZER&quot;\r\n\r\n&quot;WXC&quot;\r\n\r\n&quot;QSD&quot;\r\n```\r\nIt&#39;s what i want but in 3 line and i need to have it in array\r\nHow can i make this results in an array like this:\r\n\r\n```\r\n[&quot;AZER&quot;,&quot;WXC&quot;,&quot;QSD&quot;]\r\n```",
        "link": "https://stackoverflow.com/questions/78311115/jq-extract-array-id-of-an-object",
        "title": "JQ extract array id of an object"
    },
    {
        "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": 2,
                "creation_date": 1712942107,
                "post_id": 78317715,
                "comment_id": 138072533,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1712940676,
                "creation_date": 1712940676,
                "answer_id": 78317730,
                "question_id": 78317715,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Try this:\r\n``` sh\r\njq &#39;map(&quot;\\(.ParameterKey)=\\(.ParameterValue)&quot;) | join(&quot;;&quot;)&#39;\r\n```",
                "title": "how to parse json parameter file to semicolon separated string"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -1,
        "last_activity_date": 1712943008,
        "creation_date": 1712940481,
        "last_edit_date": 1712943008,
        "question_id": 78317715,
        "body_markdown": "I have this json file for parameters \r\n```\r\n[\r\n  {\r\n    &quot;ParameterKey&quot;: &quot;code&quot;,\r\n    &quot;ParameterValue&quot;: &quot;ab&quot;\r\n  },\r\n  {\r\n    &quot;ParameterKey&quot;: &quot;env&quot;,\r\n    &quot;ParameterValue&quot;: &quot;prod&quot;\r\n  },\r\n  {\r\n    &quot;ParameterKey&quot;: &quot;api&quot;,\r\n    &quot;ParameterValue&quot;: &quot;testapi&quot;\r\n  },\r\n  {\r\n    &quot;ParameterKey&quot;: &quot;name&quot;,\r\n    &quot;ParameterValue&quot;: &quot;new&quot;\r\n  }\r\n]\r\n```\r\nhow can I  parse this using jq into the following  output \r\n\r\ncode=ab;env=prod;api=testapi;name=new\r\n\r\ntried to parse using jq but I am not getting the correct output as shown above\r\n\r\n\r\nThanks\r\n\r\n",
        "link": "https://stackoverflow.com/questions/78317715/how-to-parse-json-parameter-file-to-semicolon-separated-string",
        "title": "how to parse json parameter file to semicolon separated string"
    },
    {
        "tags": [
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1713004603,
                "post_id": 78320282,
                "comment_id": 138076807,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 4952624,
                    "reputation": 592,
                    "user_id": 3986123,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/a4641cab430a5bd62b259ac861ad0ad1?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Roop Kumar",
                    "link": "https://stackoverflow.com/users/3986123/roop-kumar"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1713004930,
                "post_id": 78320282,
                "comment_id": 138076827,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 28860457,
                    "reputation": 99,
                    "user_id": 22104373,
                    "user_type": "registered",
                    "profile_image": "https://lh3.googleusercontent.com/a/AAcHTtcprW3-mP2_aDZGpfk-Wa0LYmTuBN3SQ7q1uEC8=k-s256",
                    "display_name": "ntriisii",
                    "link": "https://stackoverflow.com/users/22104373/ntriisii"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1713005183,
                "post_id": 78320282,
                "comment_id": 138076845,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 7712415,
                    "reputation": 65767,
                    "user_id": 5841306,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/Civ0G.jpg?s=256",
                    "display_name": "Barbaros &#214;zhan",
                    "link": "https://stackoverflow.com/users/5841306/barbaros-%c3%96zhan"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1713005306,
                "post_id": 78320282,
                "comment_id": 138076854,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 4952624,
                    "reputation": 592,
                    "user_id": 3986123,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/a4641cab430a5bd62b259ac861ad0ad1?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Roop Kumar",
                    "link": "https://stackoverflow.com/users/3986123/roop-kumar"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1713005546,
                "post_id": 78320282,
                "comment_id": 138076874,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1713006037,
                "creation_date": 1713006037,
                "answer_id": 78320352,
                "question_id": 78320282,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "In your filter, the part `. { . + {` is not valid in jq.\r\n\r\nTry one of the following filters:\r\n```sh\r\n.[] |= (.url = &quot;http://&quot; + .host + .path)\r\n```\r\n```sh\r\nmap(.url = &quot;http://&quot; + .host + .path)\r\n```\r\n```sh\r\n.[] |= (.url = &quot;http://\\(.host)\\(.path)&quot;)\r\n```\r\n```sh\r\nmap(.url = &quot;http://\\(.host)\\(.path)&quot;)\r\n```\r\n\r\nThese filters can be wrapped as-is into single quotes: `jq &#39;…&#39;`. If you prefer double quotes, you need to escape certain characters (like you did with `\\&quot;`).",
                "title": "how to update each object in a json array using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1713006037,
        "creation_date": 1713004053,
        "last_edit_date": 1713005472,
        "question_id": 78320282,
        "body_markdown": "I have an array of objects that looks like this: \r\n```json\r\n[\r\n\t{&quot;host&quot;: &quot;1.exampl.com&quot;, &quot;path&quot;: &quot;/dir1/file.html&quot;},\r\n\t{&quot;host&quot;: &quot;2.exampl.com&quot;, &quot;path&quot;: &quot;/dir2/file.html&quot;},\r\n\t{&quot;host&quot;: &quot;3.exampl.com&quot;, &quot;path&quot;: &quot;/dir3/file.html&quot;}\r\n]\r\n\r\n```\r\n\r\nand I want to add a new key in each of those objects, which will create the URL using the host and path, so I would look like this: \r\n\r\n```json\r\n[\r\n\t{&quot;host&quot;: &quot;1.exampl.com&quot;, &quot;path&quot;: &quot;/dir1/file.html&quot;, &quot;url&quot;: &quot;http://1.example.com/dir1/file.html&quot;},\r\n\t{&quot;host&quot;: &quot;2.exampl.com&quot;, &quot;path&quot;: &quot;/dir2/file.html&quot;, &quot;url&quot;: &quot;http://2.example.com/dir2/file.html&quot;},\r\n\t{&quot;host&quot;: &quot;3.exampl.com&quot;, &quot;path&quot;: &quot;/dir3/file.html&quot;, &quot;url&quot;: &quot;http://3.example.com/dir3/file.html&quot;}\r\n]\r\n```\r\n\r\nhow can I do that using `jq`. \r\n\r\nI tried doing `&quot;.[] |= . { . + {\\&quot;url\\&quot;: \\&quot;http://\\&quot; + .host + .path } }&quot;` \r\nbut this didn&#39;t work and it returned this error:\r\n`jq: error: syntax error, unexpected &#39;}&#39;, expecting $end (Unix shell quoting issues?) at &lt;top-level&gt;, line 1:`\r\n",
        "link": "https://stackoverflow.com/questions/78320282/how-to-update-each-object-in-a-json-array-using-jq",
        "title": "how to update each object in a json array using jq"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1713146251,
                "last_edit_date": 1713146251,
                "creation_date": 1713143139,
                "answer_id": 78325688,
                "question_id": 78325655,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "&gt; I am even unclear how to select elements with `.ref` in a hard-coded list, e.g. this returns elements that have `ref == 32`: `.[] | select(.ref == 32)`\r\n&gt; But I do not know how to select records that have `ref` in the list `[32,45]`.\r\n\r\nIn this case, just compare the `.ref` value to a stream of static values: `.[] | select(.ref == (32,45))`.\r\n\r\nWith longer lists, you could improve on its efficiency by having `any` control the comparisons, so that on the first match it could break out and immediately continue with the next item: `.[] | select(any(.ref; . == (32,438)))`. Since jq 1.6, this pattern is implemented by the `IN` shortcut: `.[] | select(IN(.ref; 32,438))`.\r\n\r\n&gt; `select ref from table where key = 42`\r\n\r\n`map(select(.key == 42).ref)` will give you the array `[27,438]`.\r\n\r\n&gt; `select * from table where ref in (…)`\r\n\r\nSave the previous result array into a variable using `as`, then iterate over this reference to get its items as a stream:\r\n\r\n```sh\r\nmap(select(.key == 42).ref) as $refs | .[] | select(.ref == $refs[])\r\n# or\r\nmap(select(.key == 42).ref) as $refs | .[] | select(IN(.ref; $refs[]))\r\n```\r\n```json\r\n{\r\n  &quot;id&quot;: 3,\r\n  &quot;ref&quot;: 27,\r\n  &quot;key&quot;: 13\r\n}\r\n{\r\n  &quot;id&quot;: 4,\r\n  &quot;ref&quot;: 27,\r\n  &quot;key&quot;: 42\r\n}\r\n{\r\n  &quot;id&quot;: 5,\r\n  &quot;ref&quot;: 438,\r\n  &quot;key&quot;: 42\r\n}\r\n```\r\n[Demo](https://jqplay.org/s/wyAGmpF1e_c) or [Demo](https://jqplay.org/s/21zAgJlVsrQ)\r\n\r\nTo instead receive an array of items, just replace `.[] | …` with `map(…)`.\r\n\r\n---\r\n\r\nAnother approach could be to group the input array&#39;s items by their `.ref` value, then unpack each group if there&#39;s at least one item having `.key == 42`. Note that due to the initial grouping, the order of the output items might be different.\r\n\r\n```sh\r\ngroup_by(.ref)[] | select(any(.key == 42))[]\r\n```\r\n[Demo](https://jqplay.org/s/kJle9sfXyDN)\r\n\r\nTo instead receive an array of items, wrap the whole filter into brackets: `[…]`.\r\n",
                "title": "How to filter elements in a document using another results of another filter?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1713146251,
        "creation_date": 1713141784,
        "question_id": 78325655,
        "body_markdown": "This may be simpler to explain with an example. Consider the following simple json:\r\n\r\n```\r\n[\r\n  {&quot;id&quot;: 1, &quot;ref&quot;:32, &quot;key&quot;:10},\r\n  {&quot;id&quot;: 2, &quot;ref&quot;:32, &quot;key&quot;:75},\r\n  {&quot;id&quot;: 3, &quot;ref&quot;:27, &quot;key&quot;:13},\r\n  {&quot;id&quot;: 4, &quot;ref&quot;:27, &quot;key&quot;:42},\r\n  {&quot;id&quot;: 5, &quot;ref&quot;:438, &quot;key&quot;:42}\r\n]\r\n```\r\n\r\nI want to select using `jq` all elements that have a `ref` such that there is an element with that `ref` and `key` equal to `42`. \r\n\r\n```SQL\r\nselect * from table where ref in (select ref from table where key = 42)\r\n```\r\n\r\nI am totally stumped. I have managed to get the array of such ref `&#39;[.[]|select(.key==42).ref]&#39;`\r\n\r\nI am even unclear how to select elements with `.ref` in a hard-coded  list, e.g. \r\n\r\nthis returns elements that have `ref == 32`: `.[] | select(.ref == 32)` \r\n\r\nBut I do not know how to select records that have `ref` in the list `[32,45]`. \r\n\r\n",
        "link": "https://stackoverflow.com/questions/78325655/how-to-filter-elements-in-a-document-using-another-results-of-another-filter",
        "title": "How to filter elements in a document using another results of another filter?"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1713207379,
                "post_id": 78330476,
                "comment_id": 138094691,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1713387631,
                "creation_date": 1713387631,
                "answer_id": 78343743,
                "question_id": 78330476,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "```\r\n.host_config.&quot;$b&quot;.config2\r\n```\r\n\r\ncontains the literal key `$b` and will not be interpolated, the same way that `&quot;$a&quot;` is a string literal containing a dollar and the letter &#39;a&#39;. To get the key name from the variable value, use the brackets:\r\n\r\n```\r\n.host_config[$b].config2\r\n```",
                "title": "Query/update json file where key has multiple dots in name"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1713568252,
                "creation_date": 1713568252,
                "answer_id": 78356524,
                "question_id": 78330476,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here is the correct way to achieve the update of the config2 values dynamically based on the hostname using a for loop in bash with the right jq syntax:\r\n\r\n\r\n```\r\nfor i in 1 2 3; do\r\n   host=&quot;host${i}.reg.fqdn.com&quot;\r\n   jq --arg a &quot;$i&quot; --arg b &quot;$host&quot; &#39;.host_config[$b].config2 = $a&#39; sample.json &gt; temp.json &amp;&amp; mv temp.json sample.json\r\ndone\r\n```\r\n\r\nExplanation:\r\n\r\n`--arg a &quot;$i&quot;`: This sets the variable a to the value of $i (which in your loop goes from 1 to 3).\r\n\r\n`--arg b &quot;$host&quot;`: This sets the variable b to the hostname string like `host1.reg.fqdn.com`.\r\n\r\n`.host_config[$b].config2 = $a`: This uses the value of $b to dynamically access the correct host object in host_config and sets its config2 property to the value of $a.\r\nThe changes are written to temp.json to ensure that each command execution works on an updated file. After running the command, temp.json is moved to overwrite sample.json, effectively saving the changes.",
                "title": "Query/update json file where key has multiple dots in name"
            }
        ],
        "is_answered": false,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1713568252,
        "creation_date": 1713207041,
        "question_id": 78330476,
        "body_markdown": "Given test file: sample.json:\r\n\r\n```\r\n{\r\n  &quot;host_config&quot;: {\r\n    &quot;host1.reg.fqdn.com&quot;: {\r\n      &quot;config1&quot;: &quot;AAA&quot;,\r\n      &quot;config2&quot;: &quot;000&quot;\r\n},\r\n    &quot;host2.reg.fqdn.com&quot;: {\r\n      &quot;config1&quot;: &quot;BBB&quot;,\r\n      &quot;config2&quot;: &quot;000&quot;\r\n},\r\n    &quot;host3.reg.fqdn.com&quot;: {\r\n      &quot;config1&quot;: &quot;CCC&quot;,\r\n      &quot;config2&quot;: &quot;000&quot;\r\n     }\r\n  }\r\n}\r\n```\r\n\r\nI need to update &quot;config2&quot; for each of the hostname keys but i cannot seem to get the correct jq syntax using the --arg var definition format for the hostnames.   (using jq1.6)\r\n\r\n\r\n```\r\njq &#39;.host_config.&quot;host1.reg.fqdn.com&quot;.config2=1&#39; sample.json                 good!\r\njq --arg a &quot;1&quot; &#39;.host_config.&quot;host1.reg.fqdn.com&quot;.config2=$a&#39; sample.json    good!\r\n```\r\n\r\n```\r\njq --arg a &quot;1&quot; --arg b &quot;host1.reg.fqdn.com&quot; &#39;.host_config.&quot;$b&quot;.config2=$a&#39; sample.json  \r\ncompletes but does not sub in &quot;host1.reg.fqdn.com&quot; for b - it creates new key under .host_config like:  \r\n  &quot;$b&quot;: {\r\n    &quot;config2&quot;: &quot;1&quot;\r\n  }\r\n```\r\n\r\n```\r\njq --arg a &quot;1&quot; --arg b &quot;host1.reg.fqdn.com&quot; &#39;.host_config.&#39;$b&#39;.config2=$a&#39; sample.json  =\\&gt; jq error\r\njq --arg a &quot;1&quot; --arg b &quot;host1.reg.fqdn.com&quot; &#39;.host_config.[$b].config2=$a&#39; sample.json  =\\&gt; jq error\r\njq --arg a &quot;1&quot; --arg b &quot;host1.reg.fqdn.com&quot; &#39;.host_config.[&#39;$b&#39;].config2=$a&#39; sample.json  =\\&gt; jq error\r\njq --arg a &quot;1&quot; --arg b &quot;host1.reg.fqdn.com&quot; &#39;.host_config.[&quot;$b&quot;].config2=$a&#39; sample.json  =\\&gt; jq error\r\njq --arg a &quot;1&quot; --arg b &quot;host1.reg.fqdn.com&quot; &#39;.host_config.&#39;&quot;$b&quot;&#39;.config2=$a&#39; sample.json =\\&gt; jq error\r\njq --arg a &quot;1&quot; --arg b &quot;host1.reg.fqdn.com&quot; &#39;.host_config.&quot;&#39;$b&#39;&quot;.config2=$a&#39; sample.json =\\&gt; completes but\r\ncreates:\r\n  &quot;&quot;: {\r\n    &quot;config2&quot;: &quot;1&quot;\r\n  }\r\n\r\n```\r\nUltimately what I want to do is something like:\r\n```\r\nfor i in 1..3 ; do\r\n   jq --arg a &quot;$i&quot; --arg b &quot;host${i}.reg.fqdn.com&quot; &#39;.host_config.&quot;$b&quot;.config2=$a&#39; sample.json\r\ndone\r\n```\r\n",
        "link": "https://stackoverflow.com/questions/78330476/query-update-json-file-where-key-has-multiple-dots-in-name",
        "title": "Query/update json file where key has multiple dots in name"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 230492,
                    "reputation": 33658,
                    "user_id": 494134,
                    "user_type": "registered",
                    "accept_rate": 66,
                    "profile_image": "https://i.sstatic.net/3XHKr.png?s=256",
                    "display_name": "John Gordon",
                    "link": "https://stackoverflow.com/users/494134/john-gordon"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1713309047,
                "post_id": 78337654,
                "comment_id": 138107405,
                "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": 1713327577,
                "post_id": 78337654,
                "comment_id": 138108492,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 39208,
                    "reputation": 267964,
                    "user_id": 112968,
                    "user_type": "registered",
                    "accept_rate": 68,
                    "profile_image": "https://i.sstatic.net/zHTaT.png?s=256",
                    "display_name": "knittl",
                    "link": "https://stackoverflow.com/users/112968/knittl"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1713440868,
                "post_id": 78337654,
                "comment_id": 138123700,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1713983314,
                "last_edit_date": 1713983314,
                "creation_date": 1713568035,
                "answer_id": 78356516,
                "question_id": 78337654,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "```\r\njq --argjson services &quot;$services&quot; &#39;\r\n   .|=\r\n    (\r\n      .metadata.name as $name |\r\n         | .spec.template.spec.containers[]?.volumeMounts[]? \r\n      . += { subPath: ($services[] | select(.key == $name).subPath // .subPath) }\r\n    )\r\n&#39; deployment.json &gt; updated_deployment.json\r\n\r\n```\r\n\r\nEDIT\r\n\r\nAddressing Multiple Entries with the same key\r\n\r\nWhen multiple entries in `$services` have the same key and you want to handle all corresponding `subPath` values. You could transform the `$services` input to group them by key, and then iterate over these groups when updating the JSON\r\n\r\nTransform\r\nCreates a new structure where each key is associated with a list of subPath\r\n\r\n`grouped_services=$(echo $services | jq &#39;group_by(.key) | map({key: .[0].key, subPaths: map(.subPath)})&#39;)\r\n`\r\n\r\nSecond command\r\n```\r\njq --argjson services &quot;$grouped_services&quot; &#39;\r\n  .spec.template.spec.containers[].volumeMounts[] |=\r\n    (\r\n      .name as $name |\r\n      . + { mountPath: ($services[] | select(.key == $name).subPaths[] // .mountPath) }\r\n    )\r\n&#39; deployment.json &gt; updated_deployment.json\r\n```\r\n`group_by(.key)`: This jq function groups your service entries by their key, making it easier to handle entries under the same key.D\r\n\r\n`map({key: .[0].key, subPaths: map(.subPath)})`: This reformats the grouped data so each group has a single key and an array of subPath values (subPaths).\r\n\r\n`select(.key == $name).subPaths[]: `This part of the jq filter selects the grouped entry matching the name (used as a key) and iterates over all subPath values. If no match is found, it defaults to the existing mountPath.",
                "title": "How to use json data from an existing object to update an other object?"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1713812860,
                "creation_date": 1713812860,
                "answer_id": 78368405,
                "question_id": 78337654,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "A simple bash loop based answer\r\n```\r\nfor i in $services |jq -r &#39;.key&#39;|uniq);\r\ndo\r\n  pair=$(echo $services| jq -r --arg i &quot;$i&quot; &#39;select(.key==$i).subPath&#39;\r\n    for j in $pair;\r\n      do \r\n        cat $i-deployment.json | \r\n        jq -r --arg subPath $j \\\r\n        &#39;(.spec.template.spec.containers[].volumeMounts+=[{subPath: $subPath}])&#39; | sponge $i-deployment.json\r\n      done\r\ndone\r\n```",
                "title": "How to use json data from an existing object to update an other object?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1713983314,
        "creation_date": 1713308334,
        "last_edit_date": 1713808556,
        "question_id": 78337654,
        "body_markdown": "Here is my first input (recorded as bash var $services)\r\nIt can contain multiple key based values.\r\n```\r\n[\r\n{\r\n  &quot;key&quot;: &quot;movies-wikibase-jobrunner&quot;,\r\n  &quot;subPath&quot;: &quot;LocalSettings.php&quot;,\r\n  &quot;cm&quot;: &quot;movies-wikibase-jobrunner-localsettings-override-php&quot;\r\n},\r\n{\r\n  &quot;key&quot;: &quot;movies-wikibase-jobrunner&quot;,\r\n  &quot;subPath&quot;: &quot;jobrunner-entrypoint.sh&quot;,\r\n  &quot;cm&quot;: &quot;movies-wikibase-jobrunner-jobrunner-entrypoint-sh&quot;\r\n\r\n},\r\n{\r\n  &quot;key&quot;: &quot;movies-wikibase-wdqs-frontend&quot;,\r\n  &quot;subPath&quot;: &quot;wdqs_front_index.html&quot;,\r\n  &quot;cm&quot;: &quot;movies-wikibase-wdqs-frontend-index-html&quot;\r\n}\r\n]\r\n\r\n```\r\nI&#39;d like to use **subPath** to update deployment.json.\r\n\r\n```\r\n{\r\n &quot;spec&quot;: {\r\n  &quot;template&quot;: {\r\n   &quot;spec&quot;: {\r\n    &quot;containers&quot;: [\r\n     {\r\n      &quot;volumeMounts&quot;: [\r\n       {\r\n        &quot;mountPath&quot;: &quot;/usr/share/nginx/html/index.html&quot;,\r\n        &quot;name&quot;: &quot;movies-wikibase-wdqs-frontend-index-html&quot;,\r\n        &quot;subPath&quot;: &quot;wdqs_front_index.html&quot;\r\n}]}]}}}}\r\n```\r\n\r\nI tried to pass **subPath** as a bash argument to jq but nothing works\r\n\r\n```\r\ncat deployment.json | jq -r --arg services $services                                \r\n  &#39;.spec.template.spec.containers[].volumeMounts[]? |=\r\n   { mountPath: .mountPath, name: (.key, subPath: $services\r\n  |select(.key==&quot;movies-wikibase-wdqs-frontend&quot;).subPath) }&#39;\r\n```\r\n\r\nHow can I achieve this, and is this the good way?",
        "link": "https://stackoverflow.com/questions/78337654/how-to-use-json-data-from-an-existing-object-to-update-an-other-object",
        "title": "How to use json data from an existing object to update an other object?"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1713317060,
                "last_edit_date": 1713317060,
                "creation_date": 1713315723,
                "answer_id": 78337877,
                "question_id": 78337845,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "&gt; everything from &quot;east&quot; key of common.json + &quot;common&quot; key of common.json + the &quot;common&quot; key of pi.json + the &quot;east&quot; key of pi.json\r\n\r\nAre there always two inputs or could there be more? Also, does the order of addition matter? Note that in case of collision, the latter overwrites the former.\r\n\r\nIf order matters, and you have two inputs only, just address them after `--slurp`ing them into an array by using `first` and `last` (or `.[0]` and `.[1]`):\r\n```sh\r\njq -s &#39;first.east + first.common + last.common + last.east&#39;\r\n```\r\n[Demo](https://jqplay.org/s/0zx6RO-cPPX)\r\n\r\nAlternatively, consider using `input` to access the second input (note that there&#39;s no need to `--slurp` with `input`):\r\n```sh\r\njq &#39;.east + .common + (input | .common + .east)&#39;\r\n```\r\n[Demo](https://jqplay.org/s/eLeKz4HuvXI)\r\n\r\nWith more than two inputs, use `inputs` instead to address all of the remaining inputs at once, and `reduce` to iterate over them. Note that this way, you only control the order of the first input as well as collectively that of all the others.\r\n```sh\r\njq &#39;reduce inputs as $i (.east + .common; . + $i.common + $i.east)&#39;\r\n```\r\n[Demo](https://jqplay.org/s/4VYBZdoxCrZ)\r\n\r\nIf there&#39;s just one relevant order (or it doesn&#39;t matter at all), you can return to `--slurp`, `map`, and `add`:\r\n```sh\r\njq -s &#39;map(.east, .common) | add&#39;\r\n```\r\n[Demo](https://jqplay.org/s/nnQ8wvMDhfF)\r\n\r\n",
                "title": "bash + jq: trying to read two json files and structure a new one"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1713559744,
                "creation_date": 1713559744,
                "answer_id": 78356115,
                "question_id": 78337845,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "### If you want want .east and .west\r\n\r\nYou can use `--slurpfile` to name your json files. `-n` is needed since you&#39;re naming and not passing files\r\n\r\n```sh\r\njq -n --slurpfile common common.json --slurpfile pi pi.json \\\r\n  &#39;($common[] * $pi[]) as $combined|$combined|del(.common)|map_values(.+$combined.common)&#39;\r\n```\r\n\r\nwith comments:\r\n\r\n```sh\r\n# merge keys from both files and bind to variable $combined\r\n($common[] * $pi[]) as $combined\r\n|$combined|del(.common)\r\n# update every key to include $combined.common \r\n|map_values(.+$combined.common)\r\n```\r\n\r\nOutput\r\n\r\n```json\r\n{\r\n  &quot;east&quot;: {\r\n    &quot;Direction&quot;: &quot;East&quot;,\r\n    &quot;App-Env&quot;: &quot;my-pi&quot;,\r\n    &quot;SentinelValue&quot;: 1713311902,\r\n    &quot;Hello&quot;: &quot;ABC&quot;,\r\n    &quot;MyUri&quot;: &quot;www.myuri.com&quot;\r\n  },\r\n  &quot;west&quot;: {\r\n    &quot;Direction&quot;: &quot;West&quot;,\r\n    &quot;App-Env&quot;: &quot;my-piw&quot;,\r\n    &quot;SentinelValue&quot;: 1713311902,\r\n    &quot;Hello&quot;: &quot;ABC&quot;,\r\n    &quot;MyUri&quot;: &quot;www.myuri.com&quot;\r\n  }\r\n}\r\n```",
                "title": "bash + jq: trying to read two json files and structure a new one"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1713559744,
        "creation_date": 1713314866,
        "last_edit_date": 1713330103,
        "question_id": 78337845,
        "body_markdown": "I have the following json files:\r\n\r\ncommon.json\r\n\r\n```\r\n{\r\n    &quot;common&quot;: {\r\n        &quot;Hello&quot;: &quot;ABC&quot;\r\n    },\r\n    &quot;east&quot;: {\r\n        &quot;Direction&quot;: &quot;East&quot;\r\n    },\r\n    &quot;west&quot;: {\r\n        &quot;Direction&quot;: &quot;West&quot;\r\n    }\r\n}\r\n```\r\n\r\npi.json\r\n```\r\n{\r\n    &quot;common&quot;: {\r\n       &quot;MyUri&quot;: &quot;www.myuri.com&quot;\r\n    },\r\n    &quot;east&quot;: {\r\n        &quot;App-Env&quot;: &quot;my-pi&quot;,\r\n        &quot;SentinelValue&quot;: 1713311902\r\n    },\r\n    &quot;west&quot;: {\r\n        &quot;App-Env&quot;: &quot;my-piw&quot;,\r\n        &quot;SentinelValue&quot;: 1713311902\r\n    }\r\n}\r\n```\r\n\r\nbasically I want to create a new json file where everything from &quot;east&quot; key of common.json + &quot;common&quot; key of common.json + the &quot;common&quot; key of pi.json + the &quot;east&quot; key of pi.json are moved to one json file.\r\n\r\nI have the following script that is not working the way I thought it would:\r\n\r\n```\r\n  jq_input_files=(&quot;common.json&quot; &quot;pi.json&quot;)\r\n\r\n  jq --slurp &#39;map({\r\n                 ((.common | keys_unsorted[])): .common[],\r\n                 ((.east | keys_unsorted[])): .east[]\r\n             }) | add&#39; &quot;${jq_input_files[@]}&quot; &gt; &quot;test.json&quot;\r\n```\r\n\r\nThe content of test.json from this script is:\r\n\r\n```\r\n{\r\n  &quot;MyUri&quot;: &quot;www.myuri.com&quot;,\r\n  &quot;App-Env&quot;: my-pi,\r\n  &quot;SentinelValue&quot;: 1713311902\r\n}\r\n```\r\n\r\nThe output I wanted for test.json is: \r\n```\r\n{\r\n  &quot;MyUri&quot;: &quot;www.myuri.com&quot;,\r\n  &quot;App-Env&quot;: 1713311902,\r\n  &quot;SentinelValue&quot;: 1713311902,\r\n  &quot;Hello&quot;: &quot;ABC&quot;,\r\n  &quot;Direction&quot;: &quot;East&quot;\r\n}\r\n```\r\n\r\nThe two main issues I cant figure out:\r\n\r\n1) It seems that nothing is being pulled from my common.json file even though both files are passed in.\r\n2) It seems that App-Env is now being updated with the same value as my sentinelValue which I do not want to happen.",
        "link": "https://stackoverflow.com/questions/78337845/bash-jq-trying-to-read-two-json-files-and-structure-a-new-one",
        "title": "bash + jq: trying to read two json files and structure a new one"
    },
    {
        "tags": [
            "json",
            "select",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1713351900,
                "creation_date": 1713351900,
                "answer_id": 78340508,
                "question_id": 78340421,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Traverse to each potential object, e.g. using `.[].value[&quot;if&quot;, &quot;pcp&quot;, &quot;proto&quot;]`, and update its items using either `map_values` or another level of iteration (reliable since jq 1.7) by filtering for their items that match the condition, `.selected == 1` in this case:\r\n```sh\r\n.[].value[&quot;if&quot;, &quot;pcp&quot;, &quot;proto&quot;] |= map_values(select(.selected == 1))\r\n# or\r\n.[].value[&quot;if&quot;, &quot;pcp&quot;, &quot;proto&quot;][] |= select(.selected == 1)\r\n```\r\n```json\r\n[\r\n  {\r\n    &quot;key&quot;: &quot;0eb660b0-555a-469e-be04-8c3584108f9b&quot;,\r\n    &quot;value&quot;: {\r\n      &quot;if&quot;: {\r\n        &quot;igb2&quot;: {\r\n          &quot;value&quot;: &quot;igb2 (64:62:66:22:6e:d1) [tagged]&quot;,\r\n          &quot;selected&quot;: 1\r\n        }\r\n      },\r\n      &quot;tag&quot;: &quot;20&quot;,\r\n      &quot;pcp&quot;: {\r\n        &quot;0&quot;: {\r\n          &quot;value&quot;: &quot;Best Effort (0, default)&quot;,\r\n          &quot;selected&quot;: 1\r\n        }\r\n      },\r\n      &quot;proto&quot;: {\r\n        &quot;&quot;: {\r\n          &quot;value&quot;: &quot;Auto&quot;,\r\n          &quot;selected&quot;: 1\r\n        }\r\n      },\r\n      &quot;descr&quot;: &quot;USERS: PCs und Handies  &quot;,\r\n      &quot;vlanif&quot;: &quot;vlan0.20&quot;\r\n    }\r\n  }\r\n]\r\n```\r\n[Demo 1](https://jqplay.org/s/TFcbTEngw-t),\r\n[Demo 2](https://jqplay.org/s/SqMjyO-kHRN)\r\n",
                "title": "Select one of several subattributes dependent on its content"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1713382447,
        "creation_date": 1713351131,
        "last_edit_date": 1713382447,
        "question_id": 78340421,
        "body_markdown": "I have a JSON Output describing the configuration of an OPNSense Firewall.\r\n\r\nI want to condense the output into something more useful. Consider the following element of a list of VLANs\r\n\r\n```\r\n[\r\n  {\r\n    &quot;key&quot;: &quot;0eb660b0-555a-469e-be04-8c3584108f9b&quot;,\r\n    &quot;value&quot;: {\r\n      &quot;if&quot;: {\r\n        &quot;igb1&quot;: {\r\n          &quot;value&quot;: &quot;igb1 (64:62:66:22:6e:d0) [UNTAGGED]&quot;,\r\n          &quot;selected&quot;: 0\r\n        },\r\n        &quot;igb2&quot;: {\r\n          &quot;value&quot;: &quot;igb2 (64:62:66:22:6e:d1) [tagged]&quot;,\r\n          &quot;selected&quot;: 1\r\n        }\r\n      },\r\n      &quot;tag&quot;: &quot;20&quot;,\r\n      &quot;pcp&quot;: {\r\n        &quot;1&quot;: {\r\n          &quot;value&quot;: &quot;Background (1, lowest)&quot;,\r\n          &quot;selected&quot;: 0\r\n        },\r\n        &quot;0&quot;: {\r\n          &quot;value&quot;: &quot;Best Effort (0, default)&quot;,\r\n          &quot;selected&quot;: 1\r\n        },\r\n        &quot;2&quot;: {\r\n          &quot;value&quot;: &quot;Excellent Effort (2)&quot;,\r\n          &quot;selected&quot;: 0\r\n        }\r\n      },\r\n      &quot;proto&quot;: {\r\n        &quot;&quot;: {\r\n          &quot;value&quot;: &quot;Auto&quot;,\r\n          &quot;selected&quot;: 1\r\n        },\r\n        &quot;802.1q&quot;: {\r\n          &quot;value&quot;: &quot;802.1Q&quot;,\r\n          &quot;selected&quot;: 0\r\n        },\r\n        &quot;802.1ad&quot;: {\r\n          &quot;value&quot;: &quot;802.1ad&quot;,\r\n          &quot;selected&quot;: 0\r\n        }\r\n      },\r\n      &quot;descr&quot;: &quot;USERS: PCs und Handies  &quot;,\r\n      &quot;vlanif&quot;: &quot;vlan0.20&quot;\r\n    }\r\n  }\r\n]\r\n\r\n```\r\nI would like to see only the content for `if`, `pcp` or `proto`, which have `selected ==1`. Whether I get their key or their value is anther problem.  The result could look like this:\r\n\r\n\r\n```\r\n[\r\n  {\r\n    &quot;key&quot;: &quot;0eb660b0-555a-469e-be04-8c3584108f9b&quot;,\r\n    &quot;value&quot;: {\r\n      &quot;if&quot;: {\r\n        &quot;igb2&quot;: {\r\n          &quot;value&quot;: &quot;igb2 (64:62:66:22:6e:d1) [tagged]&quot;,\r\n          &quot;selected&quot;: 1\r\n        }\r\n      },\r\n      &quot;tag&quot;: &quot;20&quot;,\r\n      &quot;pcp&quot;: {\r\n        &quot;0&quot;: {\r\n          &quot;value&quot;: &quot;Best Effort (0, default)&quot;,\r\n          &quot;selected&quot;: 1\r\n        }\r\n      },\r\n      &quot;proto&quot;: {\r\n        &quot;&quot;: {\r\n          &quot;value&quot;: &quot;Auto&quot;,\r\n          &quot;selected&quot;: 1\r\n        }\r\n      },\r\n      &quot;descr&quot;: &quot;USERS: PCs und Handies  &quot;,\r\n      &quot;vlanif&quot;: &quot;vlan0.20&quot;\r\n    }\r\n  }\r\n]\r\n\r\n```\r\n\r\nSee [online](https://jqplay.org/s/0xZdiS05Wsq)\r\n\r\n\r\n\r\nI tried all variants of `select` which occured to me. But i don&#39;t know how to select a subattribute and not the whole object.\r\n\r\n",
        "link": "https://stackoverflow.com/questions/78340421/select-one-of-several-subattributes-dependent-on-its-content",
        "title": "Select one of several subattributes dependent on its content"
    },
    {
        "tags": [
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 6313442,
                    "reputation": 45115,
                    "user_id": 5625547,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/oqCND.jpg?s=256",
                    "display_name": "0stone0",
                    "link": "https://stackoverflow.com/users/5625547/0stone0"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1713367717,
                "post_id": 78342087,
                "comment_id": 138115181,
                "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": 1713367756,
                "post_id": 78342087,
                "comment_id": 138115189,
                "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": 1713367829,
                "post_id": 78342087,
                "comment_id": 138115204,
                "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": 1713367914,
                "post_id": 78342087,
                "comment_id": 138115225,
                "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": 1713368168,
                "post_id": 78342087,
                "comment_id": 138115279,
                "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": 1713368254,
                "post_id": 78342087,
                "comment_id": 138115297,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 980746,
                    "reputation": 8704,
                    "user_id": 1000510,
                    "user_type": "registered",
                    "accept_rate": 76,
                    "profile_image": "https://i.sstatic.net/Bhpgn.png?s=256",
                    "display_name": "Basit",
                    "link": "https://stackoverflow.com/users/1000510/basit"
                },
                "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": 1713368501,
                "post_id": 78342087,
                "comment_id": 138115340,
                "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": 1713369329,
                "post_id": 78342087,
                "comment_id": 138115498,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "is_answered": false,
        "answer_count": 0,
        "score": 0,
        "last_activity_date": 1713370428,
        "creation_date": 1713367091,
        "last_edit_date": 1713367457,
        "question_id": 78342087,
        "body_markdown": "Here is my structure:\r\n\r\n[![enter image description here][1]][1]\r\n\r\nI am trying to print some values in a JSON file. Here is the `service-data.json`:\r\n```lang-json\r\n{\r\n    &quot;service_name&quot;: &quot;nphies-support.service&quot;,\r\n    &quot;description&quot;: &quot;nphies-support-service Spring Boot Application&quot;,\r\n    &quot;user&quot;: &quot;aceusr&quot;,\r\n    &quot;working_directory&quot;: &quot;/home/aceusr/deployment/nphies/nphies-support&quot;,\r\n    &quot;java_home&quot;: &quot;/usr/lib/jvm/jdk-21.0.1&quot;,\r\n    &quot;jar_file&quot;: &quot;nphies-support-service.jar&quot;\r\n}\r\n```\r\nI am reading this JSON in a bash script using jq:\r\n\r\n    #!/bin/bash\r\n \r\n    echo &quot;$0 script starting&quot;\r\n \r\n    # test if the jq is installed\r\n    test_json=$(echo &quot;{ }&quot; | jq)\r\n    if [ &quot;$test_json&quot; != &quot;{}&quot; ]; \r\n    then\r\n        echo &quot;jq not installed&quot;\r\n        exit 1\r\n    fi\r\n \r\n    #read json into variable json\r\n    json=$(cat service-data.json)\r\n \r\n    #converting json objects to bash variable\r\n    declare $(echo $json | jq -r &#39;to_entries | .[] | &quot;export \\(.key)=\\(.value)&quot;&#39;)\r\n    echo &quot;service_name = $service_name&quot;\r\n    echo &quot;description = $description&quot;\r\n    echo &quot;user = $user&quot;\r\n    echo &quot;working_directory = $working_directory&quot;\r\n    echo &quot;java_home = $java_home&quot;\r\n    echo &quot;jar_file = $jar_file&quot;\r\n \r\n    #use the -r option to output the result as raw text, without quotes. \r\n    description1=$(echo $json | jq -r &#39;.description&#39;)\r\n    echo &quot;description1 = $description1&quot;\r\n \r\n    exit 0 \r\n\r\nThis JSON is an object so I am using declare function to convert JSON into bash script variables.\r\n\r\nFor description it is only printing `nphies-support-service` instead of `nphies-support-service Spring Boot Application`. Looks like it is breaking on first space. \r\n\r\nBut when I read the same field using the syntax `name=$(echo $json | jq -r &#39;.description&#39;)` it prints the whole text. \r\n\r\n[![enter image description here][2]][2]\r\n\r\nWhy is it not printing the whole text in iteration? What do I do so it prints whole text for description variable?\r\n\r\n  [1]: https://i.sstatic.net/gMZKf.png\r\n  [2]: https://i.sstatic.net/8Vn5W.png\r\n\r\n",
        "link": "https://stackoverflow.com/questions/78342087/jq-not-printing-full-string-with-spaces-in-bash-script",
        "title": "jq not printing full string with spaces in Bash script"
    },
    {
        "tags": [
            "windows",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1713383523,
                "creation_date": 1713383523,
                "answer_id": 78343486,
                "question_id": 78343435,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "`del` is a function and needs `()`. There is also no need to quote (or escape) the keys.\r\n\r\nUse `del(.key1, .key2, .key3)` as the filter\r\n\r\n\r\n----------\r\n\r\n\r\n```json\r\n&gt; jq-windows-amd64.exe &quot;del(.alternate_error_pages, .autocomplete, .browser.app_window_placement.DevToolsApp)&quot; json\r\n{\r\n  &quot;account_tracker_service_last_update&quot;: &quot;13351819478658924&quot;,\r\n  &quot;announcement_notification_service_first_run_time&quot;: &quot;13272713839385778&quot;,\r\n  &quot;browser&quot;: {\r\n    &quot;app_window_placement&quot;: {},\r\n    &quot;clear_data&quot;: {\r\n      &quot;time_period&quot;: 4\r\n    },\r\n    &quot;last_clear_browsing_data_tab&quot;: 1\r\n  }\r\n}\r\n```",
                "title": "Delete keys in nested json file on windows shell script"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1713383523,
        "creation_date": 1713382684,
        "question_id": 78343435,
        "body_markdown": "I want to delete some keys and its values in a nested json file on windows in a shell .cmd script, but get errors.\r\nLooks like a quoting issue and more.\r\n\r\nInput file:\r\n\r\n```lang-json\r\n{\r\n  &quot;account_tracker_service_last_update&quot;: &quot;13351819478658924&quot;,\r\n  &quot;alternate_error_pages&quot;: {\r\n    &quot;backup&quot;: true,\r\n    &quot;enabled&quot;: false\r\n  },\r\n  &quot;announcement_notification_service_first_run_time&quot;: &quot;13272713839385778&quot;,\r\n  &quot;autocomplete&quot;: {\r\n    &quot;retention_policy_last_version&quot;: 120\r\n  },\r\n  &quot;browser&quot;: {\r\n    &quot;app_window_placement&quot;: {\r\n      &quot;DevToolsApp&quot;: {\r\n        &quot;always_on_top&quot;: false,\r\n        &quot;work_area_top&quot;: 0\r\n      }\r\n    },\r\n    &quot;clear_data&quot;: {\r\n      &quot;time_period&quot;: 4\r\n    },\r\n    &quot;last_clear_browsing_data_tab&quot;: 1\r\n  }\r\n}\r\n```\r\n\r\n\r\nI want to remove some more keys but started with just one: `alternate_error_pages`\r\n\r\nTried `jq-win64.exe &quot;del[\\&quot;.alternate_error_pages\\&quot;]&quot; example.json` and got: \r\n\r\njq: error: del/0 is not defined at &lt;top-level&gt;, line 1: \r\ndel[&quot;.alternate_error_pages&quot;]\r\njq: 1 compile error\r\n\r\n\r\nNext: `jq-win64.exe &quot;del(.name=\\&quot;alternate_error_pages\\&quot;)&quot; example.json` but get:\r\n\r\njq: error (at example.json:23): Invalid path expression with result {&quot;account_tracker_service_...\r\n\r\nI tried a few more things but these are gone from my script already.\r\n\r\nWhat I really want to achieve is to remove these keys:\r\n\r\n```\r\n.alternate_error_pages\r\n.autocomplete\r\n.browser.app_window_placement.DevToolsApp\r\n```\r\n\r\nBut I did not manage to remove one single top level key.",
        "link": "https://stackoverflow.com/questions/78343435/delete-keys-in-nested-json-file-on-windows-shell-script",
        "title": "Delete keys in nested json file on windows shell script"
    },
    {
        "tags": [
            "json",
            "windows",
            "jq",
            "cmder"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 9629731,
                    "reputation": 51350,
                    "user_id": 10248678,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d8f818402f22d485b135a3b685ef908e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "oguz ismail",
                    "link": "https://stackoverflow.com/users/10248678/oguz-ismail"
                },
                "edited": false,
                "score": 3,
                "creation_date": 1713405824,
                "post_id": 78344013,
                "comment_id": 138119323,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 3949817,
                    "reputation": 193,
                    "user_id": 3260727,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/fda1121a6e03c097f95aa9cbac8a0231?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "NewJackSwing4Ever",
                    "link": "https://stackoverflow.com/users/3260727/newjackswing4ever"
                },
                "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": 1713447054,
                "post_id": 78344013,
                "comment_id": 138124929,
                "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": 1713457484,
                "post_id": 78344013,
                "comment_id": 138127116,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 3949817,
                    "reputation": 193,
                    "user_id": 3260727,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/fda1121a6e03c097f95aa9cbac8a0231?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "NewJackSwing4Ever",
                    "link": "https://stackoverflow.com/users/3260727/newjackswing4ever"
                },
                "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": 1713531745,
                "post_id": 78344013,
                "comment_id": 138135684,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 3949817,
                    "reputation": 193,
                    "user_id": 3260727,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/fda1121a6e03c097f95aa9cbac8a0231?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "NewJackSwing4Ever",
                    "link": "https://stackoverflow.com/users/3260727/newjackswing4ever"
                },
                "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": 1713564586,
                "post_id": 78344013,
                "comment_id": 138140581,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1713556767,
                "creation_date": 1713556767,
                "answer_id": 78355946,
                "question_id": 78344013,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Some things that might help:\r\n\r\n* Single quote your commands\r\n* Use `map()` instead of `.[]` for nested or complicated commands\r\n* `{key}` is the same as `{key:.key}` \r\n\r\n```sh\r\njq &#39;.[]|{accountNumber,brand,city,state}&#39; sample.json\r\n# is the same as\r\njq &#39;map({accountNumber,brand,city,state})[]&#39; sample.json\r\n```\r\n\r\nExample showing when to use `map()` over `.[]`:  \r\nmap returns an array so you can pipe another map command right after it\r\n\r\n```sh\r\njq &#39;map({accountNumber,city,state})|map(.+{location:&quot;\\(.city), \\(.state)&quot;})&#39; sample.json\r\n```\r\n",
                "title": "How to execute multi attribute selection jq command on a external json file from windows cmder"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1713566711,
                "creation_date": 1713566711,
                "answer_id": 78356448,
                "question_id": 78344013,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The comments aided me in solving my question. \r\n\r\nI learned there were different command-line environments requiring slight different syntax for extracting specific attributes or handling filter selections.\r\n \r\n1. cmder.exe (or standard command prompt)\r\n\r\n    `jq &quot;.[] | select(.city == \\&quot;Miami\\&quot;) | {accountNumber, brand, city, state}&quot;` sample.json\r\n\r\n2. mintty.exe (Git Bash or Similar)\r\n\r\n    `jq &#39;.[] | select(.city == &quot;Miami&quot;) | {accountNumber, brand, city, state}&#39;` sample.json\r\n\r\n3. Powershell.exe\r\n\r\n    `jq &#39;.[] | select(.city == \\&quot;Miami\\&quot;) | {accountNumber, brand, city, state}&#39;` sample.json\r\n\r\nAlso, while not a complex nested I still tried using the map function and saw it worked the same as a commenter said and better prep for additional complex mapping later. \r\n\r\n**Using map() over .[]:**\r\n 1. cmder.exe (or standard command prompt)\r\n\r\n    `jq &quot;map({accountNumber,brand,city,state})[] | select(.city == \\&quot;Miami\\&quot;)&quot;` sample.json\r\n\r\n 2. mintty.exe (Git Bash or Similar)\r\n\r\n    `jq &#39;map({accountNumber,brand,city,state})[] | select(.city == &quot;Miami&quot;)&#39;` sample.json\r\n\r\n 3. Powershell.exe\r\n\r\n    `jq &#39;map({accountNumber,brand,city,state})[] | select(.city == \\&quot;Miami\\&quot;)&#39;` sample.json\r\n\r\n ",
                "title": "How to execute multi attribute selection jq command on a external json file from windows cmder"
            }
        ],
        "is_answered": false,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1713566711,
        "creation_date": 1713393165,
        "last_edit_date": 1713468903,
        "question_id": 78344013,
        "body_markdown": "I&#39;m attempting to use **windows cmder** to execute jq commands for command-line JSON processor to transform and output existing JSON files I have saved. \r\n\r\nGiven the the sample json\r\n\r\n    [\r\n      {\r\n        &quot;firstName&quot;: &quot;Doug&quot;,\r\n        &quot;accountNumber&quot;: &quot;123456&quot;,\r\n        &quot;language&quot;: &quot;en_US&quot;,\r\n        &quot;brand&quot;: &quot;Tide&quot;,\r\n        &quot;country&quot;: &quot;US&quot;,\r\n        &quot;branch&quot;: &quot;MIA&quot;,\r\n        &quot;city&quot;: &quot;Miami&quot;,\r\n        &quot;state&quot;: &quot;FL&quot;,\r\n        &quot;zipCode&quot;: &quot;33133&quot;\r\n      }\r\n    ]\r\n\r\nWhile I am able to output the files for simple filter output such the following:\r\n\r\n    cat sample.json | jq .[] --color-output\r\n\r\nor\r\n\r\n    jq .[] sample.json --color-output\r\n\r\nor a filter on a single attribute like country (any nested items within whenever present with dot notation)\r\n\r\n    jq .[].country sample.json --color-output\r\n\r\nUnfortunately, I am unable to perform any of the more complex actions such as extracting specific attributes or filtering for specific using online resources like [jqplay][1] which allow me to use \r\n\r\n    .[] | {accountNumber:.accountNumber, brand:.brand, city:.city, state:.state}\r\n\r\nWhen I try to perform this same type of command that worked on [jqplay][1] within cmder to transform the sample json data to display with only certain fields, I receive the following error. \r\n\r\n    jq &#39;.[] | {accountNumber:.accountNumber, brand:.brand, city:.city, state:.state}&#39; sample.json\r\n\r\n***error message: The filename, directory name, or volume label syntax is incorrect.***\r\n\r\nI looked through a few jq documentation resources such as the [jq manual][2] and [jq cheatsheet][3] and while I saw examples of how it suggest extracting attributes, I have not been able to get such filtering/transforming to work when referring to any of my sample JSON files like this but the files read in fine for the single attribute selection example I illustrated earlier. I imagine if I&#39;ve written incorrect syntax for cmder reading local or remote JSON files it will be easy for someone here to identify and help correct. I really want to be able to this on windows cmder like most things and not powershell or anything like that. \r\n\r\n\r\n  [1]: https://jqplay.org/\r\n  [2]: https://jqlang.github.io/jq/manual/#basic-filters\r\n  [3]: https://lzone.de/#/LZone%20Cheat%20Sheets/Scripting/jq",
        "link": "https://stackoverflow.com/questions/78344013/how-to-execute-multi-attribute-selection-jq-command-on-a-external-json-file-from",
        "title": "How to execute multi attribute selection jq command on a external json file from windows cmder"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 1042959,
                    "reputation": 668672,
                    "user_id": 1048572,
                    "user_type": "registered",
                    "accept_rate": 77,
                    "profile_image": "https://www.gravatar.com/avatar/7f2c4de95e8f4f8f5a71c3aaf0ed312a?s=256&d=identicon&r=PG",
                    "display_name": "Bergi",
                    "link": "https://stackoverflow.com/users/1048572/bergi"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1713789232,
                "post_id": 78366187,
                "comment_id": 138157802,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1713790469,
                "last_edit_date": 1713790469,
                "creation_date": 1713789296,
                "answer_id": 78366281,
                "question_id": 78366187,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "&gt; I need a filter, that changes the value of the parent (ID 100) to OK, when 110s value is not empty and 120, 130 and 140s value is OK. Please note: due to software requirements, I need to use jq v1.5\r\n\r\nHere&#39;s one way using `from_entries` to generate an index object from the `.sub` array that can be queried:\r\n```sh\r\nmap(                                                        # for all items\r\n  if .sub | map(.key = .id) | from_entries                  # create an index\r\n    | [.&quot;110&quot; != &quot;OK&quot;, .[&quot;120&quot;,&quot;130&quot;,&quot;140&quot;] == &quot;OK&quot;] | all  # match condition\r\n  then .value = &quot;OK&quot;\r\n  else .\r\n  end\r\n)\r\n```\r\n[Demo](https://jqplay.org/s/w9uHpahq5HW)\r\n\r\n---\r\n\r\n&gt; I need a filter, that changes the value of the parent (ID 100) to OK, when every child with input type &quot;Text&quot; has no empty value and every input type &quot;ChecklistState&quot; has value OK. ( -&gt; 110 not empty, 120, 130 and 140 &quot;OK&quot;)\r\n\r\nIn this case, I&#39;d apply `all` directly onto the `.sub` array with the modified conditions.\r\n```sh\r\nmap(\r\n  if .sub | all(\r\n    .input == &quot;Text&quot; and .value != &quot;&quot; or\r\n    .input == &quot;ChecklistState&quot; and .value == &quot;OK&quot;\r\n  )\r\n  then .value = &quot;OK&quot;\r\n  else .\r\n  end\r\n)\r\n```\r\n[Demo](https://jqplay.org/s/Cdkuugn-zRW)\r\n\r\n---\r\nOutput:\r\n```json\r\n[\r\n  {\r\n    &quot;id&quot;: &quot;100&quot;,\r\n    &quot;input&quot;: &quot;ChecklistState&quot;,\r\n    &quot;value&quot;: &quot;OK&quot;,\r\n    &quot;sub&quot;: [\r\n      {\r\n        &quot;id&quot;: &quot;110&quot;,\r\n        &quot;input&quot;: &quot;Text&quot;,\r\n        &quot;value&quot;: &quot;foo&quot;,\r\n        &quot;sub&quot;: []\r\n      },\r\n      {\r\n        &quot;id&quot;: &quot;120&quot;,\r\n        &quot;input&quot;: &quot;ChecklistState&quot;,\r\n        &quot;value&quot;: &quot;OK&quot;,\r\n        &quot;sub&quot;: []\r\n      },\r\n      {\r\n        &quot;id&quot;: &quot;130&quot;,\r\n        &quot;input&quot;: &quot;ChecklistState&quot;,\r\n        &quot;value&quot;: &quot;OK&quot;,\r\n        &quot;sub&quot;: []\r\n      },\r\n      {\r\n        &quot;id&quot;: &quot;140&quot;,\r\n        &quot;input&quot;: &quot;ChecklistState&quot;,\r\n        &quot;value&quot;: &quot;OK&quot;,\r\n        &quot;sub&quot;: []\r\n      }\r\n    ]\r\n  }\r\n]\r\n```\r\n",
                "title": "Changing parent value, when child meet specific conditions"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1713793186,
        "creation_date": 1713788471,
        "last_edit_date": 1713793186,
        "question_id": 78366187,
        "body_markdown": "I&#39;m currently struggling with some jq, hope somebody can help.\r\nGiven is the following JSON structure:\r\n\r\n```lang-json\r\n[\r\n\t{\r\n\t\t&quot;id&quot;: &quot;100&quot;,\r\n\t\t&quot;input&quot;: &quot;ChecklistState&quot;,\r\n\t\t&quot;value&quot;: &quot;-&quot;,\r\n\t\t&quot;sub&quot;: [\r\n\t\t\t{\r\n\t\t\t\t&quot;id&quot;: &quot;110&quot;,\r\n\t\t\t\t&quot;input&quot;: &quot;Text&quot;,\r\n\t\t\t\t&quot;value&quot;: &quot;foo&quot;,\r\n\t\t\t\t&quot;sub&quot;: []\r\n\t\t\t},\r\n\t\t\t{\r\n\t\t\t\t&quot;id&quot;: &quot;120&quot;,\r\n\t\t\t\t&quot;input&quot;: &quot;ChecklistState&quot;,\r\n\t\t\t\t&quot;value&quot;: &quot;OK&quot;,\r\n\t\t\t\t&quot;sub&quot;: []\r\n\t\t\t},\r\n\t\t\t{\r\n\t\t\t\t&quot;id&quot;: &quot;130&quot;,\r\n\t\t\t\t&quot;input&quot;: &quot;ChecklistState&quot;,\r\n\t\t\t\t&quot;value&quot;: &quot;OK&quot;,\r\n\t\t\t\t&quot;sub&quot;: []\r\n\t\t\t},\r\n\t\t\t{\r\n\t\t\t\t&quot;id&quot;: &quot;140&quot;,\r\n\t\t\t\t&quot;input&quot;: &quot;ChecklistState&quot;,\r\n\t\t\t\t&quot;value&quot;: &quot;OK&quot;,\r\n\t\t\t\t&quot;sub&quot;: []\r\n\t\t\t}\r\n\t\t]\r\n\t}\r\n]\r\n```\r\n\r\n\r\nI need a filter, that changes `&quot;value&quot;` to `&quot;OK&quot;` of the parent (`&quot;id&quot;: &quot;100&quot;`), when every _child_ in `&quot;sub&quot;` with `&quot;input&quot;` value `&quot;Text&quot;` has no empty `&quot;value&quot;` and every `&quot;input&quot;` value `&quot;ChecklistState&quot;` has value `&quot;OK&quot;`. ( -&gt; 110 not empty, 120, 130 and 140 &quot;OK&quot;)\r\n\r\nA generally usable filter (checking for the input) would be great, but I also wouldn&#39;t mind a solution, where I check for every child-ID individually.\r\n\r\nI&#39;ve tried accessing the values of the childs with\r\n`select(.sub[]?.id==&quot;xxx&quot;).value`\r\nand concatenating that in an if-then-else-end-Block, however the results was, that the conditions seemed not to work.\r\n\r\nPlease note: due to software requirements, I need to use jq v1.5",
        "link": "https://stackoverflow.com/questions/78366187/changing-parent-value-when-child-meet-specific-conditions",
        "title": "Changing parent value, when child meet specific conditions"
    },
    {
        "tags": [
            "json",
            "windows",
            "jq",
            "cmder"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1713811737,
                "post_id": 78368160,
                "comment_id": 138161449,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1744204172,
                "last_edit_date": 1744204172,
                "creation_date": 1713893924,
                "answer_id": 78374168,
                "question_id": 78368160,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "`.[]` iterates the elements of an array and returns a stream of JSON entities. You cannot take a stream of JSON entities and claim it is valid JSON; `{&quot;a&quot;:1},{&quot;b&quot;:2}` is not valid JSON nor a valid stream. `[{&quot;a&quot;:1},{&quot;b&quot;:2}]` is a valid JSON document containing a single array.\r\n\r\nIf you want to return an array, use `map(f)` to apply the filter `f` to every element in the array. `map(f)` is equivalent to `[.[] | f]` (and in fact [implemented as such](https://github.com/jqlang/jq/blob/e4d0b12d7d5b91e6bb1d2d233018bc63ed28e3ae/src/builtin.jq#L3)).\r\n\r\n```\r\nmap(select(.location == &quot;New York&quot; or .location == &quot;Los Angeles&quot;))\r\n```",
                "title": "How to get JQ to retain comma separation between matched records in the output"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1744204172,
        "creation_date": 1713809488,
        "question_id": 78368160,
        "body_markdown": "I&#39;m attempting to use windows cmder.exe (or standard command prompt) to execute jq commands for command-line JSON processor to transform and output existing JSON files I have saved. I&#39;ve had success with returning data but now I&#39;m curious about why there are no commas separating the matched records. \r\n\r\nGiven the the sample json\r\n\r\n    [\r\n    \t{\r\n    \t  &quot;name&quot;: &quot;Bob&quot;,\r\n    \t  &quot;location&quot;: &quot;New York&quot;\r\n    \t},\r\n    \t{\r\n    \t  &quot;name&quot;: &quot;Adam&quot;,\r\n    \t  &quot;location&quot;: &quot;Los Angeles&quot;\r\n    \t},\r\n    \t{\r\n    \t  &quot;name&quot;: &quot;Jill&quot;,\r\n    \t  &quot;location&quot;: &quot;Chicago&quot;\r\n    \t}\r\n    ]\r\n\r\nWhen I retrieve matches for locations of New York and Los Angeles..\r\n\r\n    jq &quot;.[] | select((.location == \\&quot;New York\\&quot;) or select(.location == \\&quot;Los Angeles\\&quot;))&quot; sample.json\r\n\r\nI see the output:\r\n\r\n    {\r\n      &quot;name&quot;: &quot;Bob&quot;,\r\n      &quot;location&quot;: &quot;New York&quot;\r\n    }\r\n    {\r\n      &quot;name&quot;: &quot;Adam&quot;,\r\n      &quot;location&quot;: &quot;Los Angeles&quot;\r\n    }\r\n\r\nMy goal is interchangeably depending on my needs either (a) display results via the command line or (b) output to a new file such as\r\n\r\n    jq &quot;.[] | select((.location == \\&quot;New York\\&quot;) or select(.location == \\&quot;Los Angeles\\&quot;))&quot; sample.json &gt; newsample.json\r\n\r\nSo I need a fix in order to see the expected look below without physically changing the original sample.json file:\r\n\r\n    {\r\n      &quot;name&quot;: &quot;Bob&quot;,\r\n      &quot;location&quot;: &quot;New York&quot;\r\n    },\r\n    {\r\n      &quot;name&quot;: &quot;Adam&quot;,\r\n      &quot;location&quot;: &quot;Los Angeles&quot;\r\n    }\r\n\r\nor even this if it&#39;s possible\r\n\r\n    [\r\n      {\r\n          &quot;name&quot;: &quot;Bob&quot;,\r\n          &quot;location&quot;: &quot;New York&quot;\r\n      },\r\n      {\r\n          &quot;name&quot;: &quot;Adam&quot;,\r\n          &quot;location&quot;: &quot;Los Angeles&quot;\r\n      }\r\n    ]\r\n\r\n   ",
        "link": "https://stackoverflow.com/questions/78368160/how-to-get-jq-to-retain-comma-separation-between-matched-records-in-the-output",
        "title": "How to get JQ to retain comma separation between matched records in the output"
    },
    {
        "tags": [
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 15204726,
                    "reputation": 18070,
                    "user_id": 10971581,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/XPQr1.png?s=256",
                    "display_name": "jhnc",
                    "link": "https://stackoverflow.com/users/10971581/jhnc"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1713851436,
                "post_id": 78368831,
                "comment_id": 138164579,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1713901957,
                "last_edit_date": 1713901957,
                "creation_date": 1713841436,
                "answer_id": 78369698,
                "question_id": 78368831,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If the following does not match your expectations entirely, then hopefully you&#39;ll be able to tweak it so that it does:\r\n```\r\ndef prune(cond):\r\n  def prune_object: \r\n    . as $in \r\n    | reduce keys_unsorted[] as $k ({};   # preserve ordering\r\n        if ($k|cond) then .[$k] = $in[$k]\r\n        else [$in[$k] | prune(cond)] as $x\r\n        | if $x == [] then .\r\n          else .[$k] = $x[0]\r\n          end\r\n        end )\r\n    | select(. != {});\r\n  if type == &quot;object&quot; then prune_object\r\n  elif type == &quot;array&quot; \r\n  then map(prune(cond))\r\n  | select(. != [])\r\n  elif type == &quot;string&quot; then select(cond)\r\n  else empty\r\n  end;\r\n\r\nprune(test&quot;foo&quot;))\r\n```\r\n\r\nThis formulation has the advantage that you can easily specify similar alternatives, e.g. \r\n\r\n   prune(. == &quot;foo&quot;)\r\n\r\nor \r\n\r\n   prune( startswith(&quot;foo&quot;) )\r\n\r\nor \r\n\r\n   prune( test(&quot;foo&quot;; &quot;i&quot;) )\r\n\r\n\r\n",
                "title": "Filter json to keep sub-content that matches a given pattern anywhere in the key or value"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1713868687,
                "last_edit_date": 1713868687,
                "creation_date": 1713845504,
                "answer_id": 78369848,
                "question_id": 78368831,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Because I don&#39;t know how to write proper `jq` code:\r\n\r\n```\r\njq --stream -c &lt; file.json |\r\ngrep -e &#39;foo&#39; -e &#39;]]$&#39; |\r\njq -n &#39;fromstream(inputs)&#39;\r\n```\r\nor:\r\n\r\n```\r\njq --stream -n &lt; file.json &#39;\r\n    fromstream(\r\n        inputs | select(\r\n            (length == 1)\r\n            or any(\r\n                (.[0][], .[1]) | strings;\r\n                test(&quot;foo&quot;)\r\n            )\r\n        )\r\n    )\r\n&#39;\r\n```\r\n\r\n---\r\n\r\ninput:\r\n```\r\n{\r\n &quot;a&quot;: &quot;foo&quot;,\r\n &quot;b&quot;: &quot;bar&quot;,\r\n &quot;c&quot;: {\r\n  &quot;d&quot;: &quot;foo&quot;,\r\n  &quot;e&quot;: &quot;bar&quot;\r\n },\r\n &quot;aa&quot;: {\r\n  &quot;foo&quot;: [\r\n   1,\r\n   2,\r\n   3\r\n  ],\r\n  &quot;bar&quot;: {\r\n   &quot;foo&quot;: false\r\n  },\r\n  &quot;delete-this&quot;: {\r\n   &quot;not&quot;: &quot;wanted&quot;\r\n  }\r\n },\r\n &quot;delete-all&quot;: {\r\n   &quot;x&quot;: {\r\n     &quot;a&quot;: {\r\n       &quot;b&quot;: {\r\n         &quot;c&quot;: 1\r\n       }\r\n     }\r\n   },\r\n   &quot;y&quot;: {\r\n      &quot;a&quot;: [\r\n        {\r\n          &quot;b&quot;: [\r\n            1\r\n          ]\r\n        }\r\n      ]\r\n   }\r\n },\r\n &quot;keep-part&quot;: [\r\n  &quot;foo&quot;,\r\n  &quot;bar&quot;\r\n ]\r\n}\r\n```\r\n\r\noutput:\r\n```\r\n{\r\n  &quot;a&quot;: &quot;foo&quot;,\r\n  &quot;c&quot;: {\r\n    &quot;d&quot;: &quot;foo&quot;\r\n  },\r\n  &quot;aa&quot;: {\r\n    &quot;foo&quot;: [\r\n      1,\r\n      2,\r\n      3\r\n    ],\r\n    &quot;bar&quot;: {\r\n      &quot;foo&quot;: false\r\n    }\r\n  },\r\n  &quot;keep-part&quot;: [\r\n    &quot;foo&quot;\r\n  ]\r\n}\r\n",
                "title": "Filter json to keep sub-content that matches a given pattern anywhere in the key or value"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1713872220,
                "last_edit_date": 1713872220,
                "creation_date": 1713848522,
                "answer_id": 78369963,
                "question_id": 78368831,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here is a way:\r\n```\r\ndef f:\r\n  def g:\r\n    def h: type == &quot;string&quot; and test(&quot;foo&quot;) | not;\r\n    del(getpath(\r\n      paths(scalars, select(IN([], {}))) | select(all(h))\r\n    ) | select(h));\r\n  . as $in | g | if . != $in then f end;\r\nf\r\n```\r\n&lt;sup&gt;[Online demo](https://jqplay.org/s/lyS56xmKvke)&lt;/sup&gt;",
                "title": "Filter json to keep sub-content that matches a given pattern anywhere in the key or value"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 1,
        "last_activity_date": 1713901957,
        "creation_date": 1713819301,
        "question_id": 78368831,
        "body_markdown": "Suppose I have a json file. I want to filter this file to only output content where a given pattern appears in anywhere in the full path or leaf node value. For example, suppose the json file has below content:\r\n```\r\n{\r\n&#160;&quot;a&quot;: &quot;foo&quot;,\r\n&#160;&quot;b&quot;: &quot;bar&quot;,\r\n&#160;&quot;c&quot;: {\r\n&#160;&#160;&quot;d&quot;: &quot;foo&quot;,\r\n&#160;&#160;&quot;e&quot;: &quot;bar&quot;\r\n&#160;},\r\n&#160;&quot;aa&quot;: {\r\n&#160;&#160;&quot;foo&quot;: [\r\n&#160;&#160;&#160;1,\r\n&#160;&#160;&#160;2,\r\n&#160;&#160;&#160;3\r\n&#160;&#160;],\r\n&#160;&#160;&quot;bar&quot;: {\r\n&#160;&#160;&#160;&quot;foo&quot;: false\r\n&#160;&#160;}\r\n&#160;}\r\n}\r\n```\r\n\r\nAnd the pattern is &quot;foo&quot;. Then, the output should be as follows.\r\n```\r\n{\r\n&#160;&quot;a&quot;: &quot;foo&quot;,\r\n&#160;&quot;c&quot;: {\r\n&#160;&#160;&quot;d&quot;: &quot;foo&quot;\r\n&#160;},\r\n&#160;&quot;aa&quot;: {\r\n&#160;&#160;&quot;foo&quot;: [\r\n&#160;&#160;&#160;1,\r\n&#160;&#160;&#160;2,\r\n&#160;&#160;&#160;3\r\n&#160;&#160;],\r\n&#160;&#160;&quot;bar&quot;: {\r\n&#160;&#160;&#160;&quot;foo&quot;: false\r\n&#160;&#160;}\r\n&#160;}\r\n}\r\n```\r\n\r\nSo, what should the `jq` command be?",
        "link": "https://stackoverflow.com/questions/78368831/filter-json-to-keep-sub-content-that-matches-a-given-pattern-anywhere-in-the-key",
        "title": "Filter json to keep sub-content that matches a given pattern anywhere in the key or value"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1713897432,
                "creation_date": 1713897432,
                "answer_id": 78374407,
                "question_id": 78374396,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "One way would be to `reduce` over all `inputs`, and successively build up the result object. Use the `--null-input` (or `-n`) flag for that:\r\n```sh\r\njq -n &#39;reduce inputs as $i ({}; .[$i.name] = $i.version)&#39; input.json\r\n```\r\n[Demo](https://jqplay.org/s/n97zE-xQEfJ)\r\n\r\nAnother one would be to create a `map` of objects for each item, then `add` them all together into a result object. Use the `--slurp` (or `-s`) flag for that:\r\n```sh\r\njq -s &#39;map({(.name): .version}) | add&#39; input.json\r\n```\r\n[Demo](https://jqplay.org/s/pIahEmF6-VS)\r\n\r\nOutput:\r\n```json\r\n{\r\n  &quot;abc&quot;: &quot;1234&quot;,\r\n  &quot;xyz&quot;: &quot;6789&quot;\r\n}\r\n```",
                "title": "JQ transformation"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1713897432,
        "creation_date": 1713897294,
        "question_id": 78374396,
        "body_markdown": "Suppose I have a json object like this\r\n\r\n        {\r\n      &quot;name&quot;: &quot;abc&quot;,\r\n      &quot;version&quot;: &quot;1234&quot;\r\n    }\r\n    {\r\n      &quot;name&quot;: &quot;xyz&quot;,\r\n      &quot;version&quot;: &quot;6789&quot;\r\n    }\r\n\r\nI want it to transform it to \r\n\r\n    {\r\n    &quot;abc&quot;: &quot;1234&quot;,\r\n    &quot;xyz&quot; : &quot;6789&quot;\r\n    }\r\n\r\nI have tried map and reduce. But cant wrap my head around",
        "link": "https://stackoverflow.com/questions/78374396/jq-transformation",
        "title": "JQ transformation"
    },
    {
        "tags": [
            "jq",
            "purely-functional"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1713969064,
                "post_id": 78379111,
                "comment_id": 138180084,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2350596,
                    "reputation": 1,
                    "user_id": 2059555,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/ae88e1160db5cea83cf6627bceeeb5a4?s=256&d=identicon&r=PG",
                    "display_name": "Chip Seraphine",
                    "link": "https://stackoverflow.com/users/2059555/chip-seraphine"
                },
                "reply_to_user": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1713970330,
                "post_id": 78379111,
                "comment_id": 138180348,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1713994100,
                "creation_date": 1713994100,
                "answer_id": 78381306,
                "question_id": 78379111,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "&gt; Does jq map function change the input object?\r\n\r\nNo.  In fact, values are never changed.  jq is a purely functional language, though its scoping rules might make it seem otherwise to anyone not familiar with them.\r\n\r\nWhen we write expressions like `{} | .x = 1 | .x = 2` it might look as though the input object is being modified, and inserting `debug` statements will show that the value associated with &quot;x&quot; changes from null to 1 and then 2. So consider:\r\n```\r\njq -nc &#39;{}\r\n | . as $zero\r\n | .x = 1 | . as $one\r\n | .x = 2 | . as $two \r\n | ($zero, $one, $two)&#39;\r\n{}\r\n{&quot;x&quot;:1}\r\n{&quot;x&quot;:2}\r\n```\r\n\r\n\r\n  \r\n\r\n",
                "title": "Does jq map function change the input object?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1713999079,
        "creation_date": 1713968002,
        "last_edit_date": 1713999079,
        "question_id": 78379111,
        "body_markdown": "The docs certainly make it sound like it does not.  But, I can&#39;t think of any way to explain the behavior below.  What am I doing wrong?\r\n\r\nOn some cluster data, I am trying to show the total number of cpus being used out of the total available. I want to iterate through the array of objects in `o.json` and compute the difference between two values (`.cpus.total - .cpus.allocated`) and display the sum of those deltas as well as the sum of one of the values (`.cpus.total`).\r\n\r\nSo `.[].cpus.total` will spit out a list of integers:\r\n\r\n```lang-bash\r\n$ cat /tmp/o.json | jq -c &#39;[.[].cpus.total]|add&#39;\r\n2764\r\n```\r\n\r\nBut when I do the same thing after a map statement, it errors:\r\n\r\n```lang-bash\r\n$ cat /tmp/o.json | jq -c &#39;[(map(.cpus.total - .cpus.allocated) | add), &quot;/&quot;, [.[].cpus.total]|add]&#39;\r\njq: error (at &lt;stdin&gt;:13762): Cannot iterate over number (2556)\r\n```\r\n\r\nThat error makes it sound like &quot;add&quot; wanted an array but didn&#39;t get one. And sure enough, forcing it into an array (and then taking the zero&#39;th value, because it is just an integer) works:\r\n\r\n```lang-bash\r\n$ cat /tmp/o.json | jq -c &#39;[(map(.cpus.total - .cpus.allocated) | add), &quot;/&quot;, [[.[].cpus.total]|add][0] ]&#39;\r\n[2556,&quot;/&quot;,2764]\r\n```\r\n\r\nAt this point I have working code but I don&#39;t understand why I needed that extra set of square brackets to get it to go, but _only_ if there is a map earlier in the program. What gives?",
        "link": "https://stackoverflow.com/questions/78379111/does-jq-map-function-change-the-input-object",
        "title": "Does jq map function change the input object?"
    },
    {
        "tags": [
            "bash",
            "insert",
            "key",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 2435703,
                    "reputation": 27493,
                    "user_id": 2125671,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/13a492143ab4a2575b5a1f500691193c?s=256&d=identicon&r=PG",
                    "display_name": "Philippe",
                    "link": "https://stackoverflow.com/users/2125671/philippe"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1713996443,
                "post_id": 78381387,
                "comment_id": 138183883,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1613587,
                    "reputation": 786618,
                    "user_id": 1491895,
                    "user_type": "registered",
                    "accept_rate": 69,
                    "profile_image": "https://www.gravatar.com/avatar/82f9e178a16364bf561d0ed4da09a35d?s=256&d=identicon&r=PG",
                    "display_name": "Barmar",
                    "link": "https://stackoverflow.com/users/1491895/barmar"
                },
                "edited": false,
                "score": 3,
                "creation_date": 1713997512,
                "post_id": 78381387,
                "comment_id": 138183985,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1613587,
                    "reputation": 786618,
                    "user_id": 1491895,
                    "user_type": "registered",
                    "accept_rate": 69,
                    "profile_image": "https://www.gravatar.com/avatar/82f9e178a16364bf561d0ed4da09a35d?s=256&d=identicon&r=PG",
                    "display_name": "Barmar",
                    "link": "https://stackoverflow.com/users/1491895/barmar"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1713997565,
                "post_id": 78381387,
                "comment_id": 138183989,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1713997985,
                "post_id": 78381387,
                "comment_id": 138184009,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1714014918,
                "creation_date": 1714014918,
                "answer_id": 78382071,
                "question_id": 78381387,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The use of &quot; around `$md` is causing JQ to interpret your input as a string literal instead of expanding the variables \r\n\r\nAccess the variable directly without quotes\r\n\r\n`jq --arg md &quot;blablabla&quot; &#39;. + {&quot;content&quot;: $md}&#39; blog.json`\r\n\r\noutput\r\n```\r\n{\r\n  &quot;foo&quot;: &quot;bar&quot;,\r\n  &quot;content&quot;: &quot;blablabla&quot;\r\n}",
                "title": "pass arguments to jq when inserting key not interpolated"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1714014918,
        "creation_date": 1713995517,
        "question_id": 78381387,
        "body_markdown": "When I run\r\n\r\n    jq --arg md &quot;blablabla&quot; &#39;. +={&#39;content&#39;: &quot;$md&quot;}&#39; blog.json\r\n\r\nin `blog.json`\r\n\r\n    {\r\n    &quot;foo&quot;: &quot;bar&quot;\r\n    }\r\n\r\nI get\r\n\r\n    {\r\n      &quot;foo&quot;: &quot;bar&quot;,\r\n      &quot;content&quot;: &quot;$md&quot;\r\n    }\r\n\r\nThe **desired** output would be:\r\n\r\n    {\r\n      &quot;foo&quot;: &quot;bar&quot;,\r\n      &quot;content&quot;: &quot;blablabla&quot;\r\n    }\r\n\r\n",
        "link": "https://stackoverflow.com/questions/78381387/pass-arguments-to-jq-when-inserting-key-not-interpolated",
        "title": "pass arguments to jq when inserting key not interpolated"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1714035110,
                "post_id": 78383239,
                "comment_id": 138187293,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1714035738,
                "post_id": 78383239,
                "comment_id": 138187400,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1714038009,
                "creation_date": 1714038009,
                "answer_id": 78383695,
                "question_id": 78383239,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Your code works fine with jq 1.7. If you&#39;re using jq 1.6 you need this:\r\n``` sh\r\njq -nre &#39;inputs.slot&#39;\r\n```",
                "title": "jq doesn&#39;t return non-zero for empty input"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1714038030,
        "creation_date": 1714033358,
        "last_edit_date": 1714038030,
        "question_id": 78383239,
        "body_markdown": "I have this line of code that works as expected:\r\n\r\n    echo &#39;{&quot;slot&quot;:&quot;we&quot;}&#39; | jq -re &#39;.slot&#39; || exit 1\r\n\r\nhowever this code doesn&#39;t raise an error even though I would expect so:\r\n\r\n    echo &#39; &#39; | jq -re &#39;.slot&#39; || exit 1\r\n\r\nand neither does this:\r\n\r\n    echo &#39;&#39; | jq -re &#39;.slot&#39; || exit 1\r\n\r\n\r\nhow can I make sure that it raises an error if `slot` key is not found? What I mean is that in both last two examples the exit code is 0\r\n\r\n[![enter image description here][1]][1]\r\n\r\n\r\n  [1]: https://i.sstatic.net/UhbmA.png",
        "link": "https://stackoverflow.com/questions/78383239/jq-doesnt-return-non-zero-for-empty-input",
        "title": "jq doesn&#39;t return non-zero for empty input"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1714148624,
                "last_edit_date": 1714148624,
                "creation_date": 1714145933,
                "answer_id": 78391577,
                "question_id": 78391549,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "When performing an [update assignment](https://jqlang.github.io/jq/manual/#update-assignment) `|=`, the context of the RHS is matched to the one from the LHS. Thus, with `.items[].value |= .name`, the evaluation of `.name` is based on the (at that point not yet existing) value of `.value`, and can produce nothing but `null`.\r\n\r\nUsing just the [pipe combinator](https://jqlang.github.io/jq/manual/#pipe) `|` as in `.items[] | (.value = .name)` provides both `.value` and `.name` with the right context, but the previous context (the document level you want to return) is lost, so the local context (the items without the surrounding array) becomes the result.\r\n\r\nTo access different contexts (here, for reading and writing) while keeping another outer one, update on a level that is common to both (the reading and the writing context), and traverse as necessary inside the applied filter on the RHS (going into `.value` and `.name` in this case).\r\n\r\nUsing your latter attempt, individually updating each item of the `.items` array:\r\n```sh\r\n.items[] |= (.value = .name)\r\n```\r\n[Demo](https://jqplay.org/s/6ECoNis2WDM)\r\n\r\nOr having a `map` filter update the entire array at once:\r\n```sh\r\n.items |= map(.value = .name)\r\n```\r\n[Demo](https://jqplay.org/s/3eY0azkmIiv)\r\n\r\nIn the end, both perform the same operations of course, resulting in:\r\n```json\r\n{\r\n  &quot;items&quot;: [\r\n    {\r\n      &quot;name&quot;: &quot;first&quot;,\r\n      &quot;value&quot;: &quot;first&quot;\r\n    },\r\n    {\r\n      &quot;name&quot;: &quot;second&quot;,\r\n      &quot;value&quot;: &quot;second&quot;\r\n    }\r\n  ]\r\n}\r\n```\r\n",
                "title": "copy a value to another entry in the same element"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -1,
        "last_activity_date": 1714148624,
        "creation_date": 1714145660,
        "last_edit_date": 1714145804,
        "question_id": 78391549,
        "body_markdown": "There are plenty of examples of updating a value in a nested entry in jq, but I think I have a unique question, because the value I want to provide is already in another part of the same entry.\r\n\r\nGiven the following input:\r\n\r\n```\r\n{\r\n  &quot;items&quot;: [\r\n    {\r\n      &quot;name&quot;: &quot;first&quot;\r\n    },\r\n    {\r\n      &quot;name&quot;: &quot;second&quot;\r\n    }\r\n  ]\r\n}\r\n```\r\n\r\nI want to produce this output:\r\n\r\n```\r\n{\r\n  &quot;items&quot;: [\r\n    {\r\n      &quot;name&quot;: &quot;first&quot;,\r\n      &quot;value&quot;: &quot;first&quot;\r\n    },\r\n    {\r\n      &quot;name&quot;: &quot;second&quot;,\r\n      &quot;value&quot;: &quot;second&quot;\r\n    }\r\n  ]\r\n}\r\n```\r\n\r\nIn other words, I want to copy the value of `.name` to the value of `.value` for each entry in `items[]`.\r\n\r\nAssignment is easy enough if the value is static. `jq &#39;.items[].value |= &quot;x&quot;`\r\n\r\nBut since the value is dynamic, I always get stuck either at the wrong context level:\r\n\r\n```\r\n$ jq &#39;.items[].value|=.name&#39; &lt;&lt;&lt; &#39;{&quot;items&quot;:[{&quot;name&quot;: &quot;first&quot;},{&quot;name&quot;: &quot;second&quot;}]}&#39;\r\n{\r\n  &quot;items&quot;: [\r\n    {\r\n      &quot;name&quot;: &quot;first&quot;,\r\n      &quot;value&quot;: null\r\n    },\r\n    {\r\n      &quot;name&quot;: &quot;second&quot;,\r\n      &quot;value&quot;: null\r\n    }\r\n  ]\r\n}\r\n```\r\n\r\nOr with the wrong output context:\r\n\r\n```\r\njq &#39;.items[]|(.value=.name)&#39; &lt;&lt;&lt; &#39;{&quot;items&quot;:[{&quot;name&quot;: &quot;first&quot;},{&quot;name&quot;: &quot;second&quot;}]}&#39;\r\n{\r\n  &quot;name&quot;: &quot;first&quot;,\r\n  &quot;value&quot;: &quot;first&quot;\r\n}\r\n{\r\n  &quot;name&quot;: &quot;second&quot;,\r\n  &quot;value&quot;: &quot;second&quot;\r\n}\r\n```\r\n\r\nHow can I make the change within the entries, for each entry, but still output the whole thing from the top level?",
        "link": "https://stackoverflow.com/questions/78391549/copy-a-value-to-another-entry-in-the-same-element",
        "title": "copy a value to another entry in the same element"
    },
    {
        "tags": [
            "jenkins",
            "curl",
            "cmd",
            "jq",
            "multiline"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 21805552,
                    "reputation": 843,
                    "user_id": 16104038,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d20db130000ed43b5546d5273ddde2a5?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "rzickler",
                    "link": "https://stackoverflow.com/users/16104038/rzickler"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1714168095,
                "post_id": 78393001,
                "comment_id": 138204771,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1516883,
                    "reputation": 14419,
                    "user_id": 1417694,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/adedbee0609fe9349993fedfd446acdc?s=256&d=identicon&r=PG",
                    "display_name": "Squashman",
                    "link": "https://stackoverflow.com/users/1417694/squashman"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1714169160,
                "post_id": 78393001,
                "comment_id": 138204845,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 9045527,
                    "reputation": 38872,
                    "user_id": 6738015,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/FYDxX.jpg?s=256",
                    "display_name": "Compo",
                    "link": "https://stackoverflow.com/users/6738015/compo"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1714170287,
                "post_id": 78393001,
                "comment_id": 138204960,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1714399259,
                "creation_date": 1714399259,
                "answer_id": 78403253,
                "question_id": 78393001,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The following worked for me:\r\n```\r\n@echo off\r\nfor /f &quot;usebackq delims=&quot; %%i in (`echo xyz`) do (set response=%%i)\r\necho &quot;ID = %response%&quot;\r\n```\r\nThe things I did differently:\r\n\r\n - Enabled the back quote option\r\n - Put the command within back quotes\r\n - Use &quot;echo &quot;xyz&quot; instead of curl piped into jq.",
                "title": "Storing output of a curl jq to environment variable in windows cmd"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1714511744,
                "last_edit_date": 1714511744,
                "creation_date": 1714423812,
                "answer_id": 78405124,
                "question_id": 78393001,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The below worked. Just put the curl in &#39;&#39;\r\n\r\n    @echo off ^\r\n    for /F &quot;delims=&quot; %%i in (&#39;curl -X GET &quot;http://localhost:8080/test&quot; ^| jq -r &quot;.integrations.[0].id&quot;&#39;) do (set &quot;response=%%i&quot;) ^\r\n    echo ID = %response% ^\r\nendlocal",
                "title": "Storing output of a curl jq to environment variable in windows cmd"
            }
        ],
        "is_answered": false,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1714511744,
        "creation_date": 1714166155,
        "last_edit_date": 1714171014,
        "question_id": 78393001,
        "body_markdown": "I want to save the output of ```curl -X GET &quot;http://localhost:8080/test&quot; ^| jq -r &quot;.integrations.[0].id&quot;``` to an environment variable within a jenkins batch command in Windows8 so that I can use it in subsequent commands.\r\n\r\nHow to do that?\r\n\r\nI tried this but did not work.\r\n\r\n```shela\r\n@echo off ^\r\nfor /F &quot;delims=&quot; %%i in (&quot;curl -X GET &quot;http://localhost:8080/test&quot; ^| jq -r &quot;.integrations.[0].id&quot;&quot;) do (set &quot;response=%%i&quot;) ^\r\necho ID = %response% ^\r\nendlocal\r\n```",
        "link": "https://stackoverflow.com/questions/78393001/storing-output-of-a-curl-jq-to-environment-variable-in-windows-cmd",
        "title": "Storing output of a curl jq to environment variable in windows cmd"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1714277877,
                "creation_date": 1714277877,
                "answer_id": 78397055,
                "question_id": 78397008,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "This produces your expected output:\r\n```\r\nmap_values(map(select(.val2 == &quot;bar1&quot;)))\r\n```\r\n&lt;sup&gt;[Online demo](https://jqplay.org/s/7eASj3_dGYQ)&lt;/sup&gt;",
                "title": "Filtering nested objects using JQ"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1714287486,
        "creation_date": 1714275987,
        "last_edit_date": 1714287486,
        "question_id": 78397008,
        "body_markdown": "For a given json:\r\n```json\r\n{\r\n  &quot;source_1&quot;: [\r\n    {\r\n      &quot;val1&quot;: &quot;foo1&quot;,\r\n      &quot;val2&quot;: &quot;bar1&quot;\r\n    },\r\n    {\r\n      &quot;val1&quot;: &quot;foo2&quot;,\r\n      &quot;val2&quot;: &quot;bar2&quot;\r\n    }\r\n  ],\r\n  &quot;source_2&quot;: [\r\n    {\r\n      &quot;val1&quot;: &quot;foo1&quot;,\r\n      &quot;val2&quot;: &quot;bar1&quot;\r\n    },\r\n    {\r\n      &quot;val1&quot;: &quot;foo3&quot;,\r\n      &quot;val2&quot;: &quot;bar3&quot;\r\n    }\r\n  ]\r\n}\r\n```\r\nI would like to search it recursively where `val2` equals `bar1` but return it in this format:\r\n```json\r\n{\r\n  &quot;source_1&quot;: [\r\n    {\r\n      &quot;val1&quot;: &quot;foo1&quot;,\r\n      &quot;val2&quot;: &quot;bar1&quot;\r\n    }\r\n  ],\r\n  &quot;source_2&quot;: [\r\n    {\r\n      &quot;val1&quot;: &quot;foo1&quot;,\r\n      &quot;val2&quot;: &quot;bar1&quot;\r\n    }\r\n  ]\r\n}\r\n```",
        "link": "https://stackoverflow.com/questions/78397008/filtering-nested-objects-using-jq",
        "title": "Filtering nested objects using JQ"
    },
    {
        "tags": [
            "jq",
            "reformatting"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1714646394,
                "last_edit_date": 1714646394,
                "creation_date": 1714381169,
                "answer_id": 78401569,
                "question_id": 78401284,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Either [collect](https://jqlang.github.io/jq/manual/#array-construction) your stream to an array again or use `map` (which is [implemented exactly like that](https://github.com/jqlang/jq/blob/ed8f7154f4e3e0a8b01e6778de2633aabbb623f8/src/builtin.jq#L3): it constructs a new array and collects the stream after applying the specified function/filter: `def map(f): [.[] | f];`). You are even collecting to an array for your `fvAp` property:\r\n\r\n```\r\n[\r\n  .imdata[].fvTenant | {\r\n    fvTenant: .attributes.name,\r\n    fvAp: [.children[].fvAp]\r\n  }\r\n]\r\n```\r\n\r\nWith [`map`](https://jqlang.github.io/jq/manual/#map-map_values):\r\n\r\n```\r\n.imdata\r\n| map(.fvTenant | {\r\n  fvTenant: .attributes.name,\r\n  fvAp: (.children | map(.fvAp))\r\n})\r\n```",
                "title": "How can I reformat multiple levels of JSON using JQ?"
            },
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1714447847,
                "last_edit_date": 1714447847,
                "creation_date": 1714442261,
                "answer_id": 78405897,
                "question_id": 78401284,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Finally got it figured, thanks to @knittl the suggestions and example using **map**. Using the following, I was able to get very close to my target output.  For those who want to experiment, you can see the result on https://jqplay.org/s/HpUiVJAd00u\r\n\r\n```\r\n.imdata\r\n| map(.fvTenant | {\r\n  fvTenant: .attributes.name,\r\n  fvAp: (.children\r\n    | map(.fvAp |{\r\n      fvAp: .attributes.name,\r\n      fvAEPg: (.children | map(.fvAEPg |{\r\n        fvAEPg: .attributes.name,\r\n        fvRsCons: ([.children[].fvRsCons.attributes.tnVzBrCPName | values] ),\r\n        fvRsProv: ([.children[].fvRsProv.attributes.tnVzBrCPName | values] )\r\n      }))\r\n    })\r\n  )\r\n})\r\n```\r\nI guess my next challenge is to get it working with the alternate method using **collections** that was suggested.  If I manage it, I&#39;ll update this",
                "title": "How can I reformat multiple levels of JSON using JQ?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1714646394,
        "creation_date": 1714377925,
        "question_id": 78401284,
        "body_markdown": "I suspect I&#39;ve set myself an impossible task, and have made some small progress looking at similar questions posted on this forum, but this one has me stumped.\r\n\r\nSo here&#39;s my source JSON.\r\n\r\n```\r\n{\r\n  &quot;totalCount&quot;: &quot;3&quot;,\r\n  &quot;imdata&quot;: [\r\n    {\r\n      &quot;fvTenant&quot;: {\r\n        &quot;attributes&quot;: {\r\n          &quot;dn&quot;: &quot;uni/tn-Tenant10&quot;,\r\n          &quot;name&quot;: &quot;Tenant10&quot;\r\n        },\r\n        &quot;children&quot;: [\r\n          {\r\n            &quot;fvAp&quot;: {\r\n              &quot;attributes&quot;: {\r\n                &quot;name&quot;: &quot;2Tier_AP&quot;\r\n              },\r\n              &quot;children&quot;: [\r\n                {\r\n                  &quot;fvAEPg&quot;: {\r\n                    &quot;attributes&quot;: {\r\n                      &quot;name&quot;: &quot;WebServers_EPG&quot;\r\n                    },\r\n                    &quot;children&quot;: [\r\n                      {\r\n                        &quot;fvRsCons&quot;: {\r\n                          &quot;attributes&quot;: {\r\n                            &quot;tnVzBrCPName&quot;: &quot;AppServices_Ct&quot;\r\n                          },\r\n                          &quot;children&quot;: [\r\n                            {\r\n                              &quot;fvCollectionCont&quot;: {\r\n                                &quot;attributes&quot;: {\r\n                                  &quot;collectionDn&quot;: &quot;uni/tn-common/brc-AppServices_Ct&quot;,\r\n                                  &quot;name&quot;: &quot;&quot;,\r\n                                  &quot;nameAlias&quot;: &quot;&quot;\r\n                                }\r\n                              }\r\n                            }\r\n                          ]\r\n                        }\r\n                      }\r\n                    ]\r\n                  }\r\n                },\r\n                {\r\n                  &quot;fvAEPg&quot;: {\r\n                    &quot;attributes&quot;: {\r\n                      &quot;name&quot;: &quot;AppServers_EPG&quot;\r\n                    },\r\n                    &quot;children&quot;: [\r\n                      {\r\n                        &quot;fvRsProv&quot;: {\r\n                          &quot;attributes&quot;: {\r\n                            &quot;tnVzBrCPName&quot;: &quot;AppServices_Ct&quot;\r\n                          },\r\n                          &quot;children&quot;: [\r\n                            {\r\n                              &quot;fvCollectionCont&quot;: {\r\n                                &quot;attributes&quot;: {\r\n                                  &quot;collectionDn&quot;: &quot;uni/tn-common/brc-AppServices_Ct&quot;,\r\n                                  &quot;name&quot;: &quot;&quot;,\r\n                                  &quot;nameAlias&quot;: &quot;&quot;\r\n                                }\r\n                              }\r\n                            }\r\n                          ]\r\n                        }\r\n                      }\r\n                    ]\r\n                  }\r\n                }\r\n              ]\r\n            }\r\n          }\r\n        ]\r\n      }\r\n    },\r\n    {\r\n      &quot;fvTenant&quot;: {\r\n        &quot;attributes&quot;: {\r\n          &quot;dn&quot;: &quot;uni/tn-Tenant18&quot;,\r\n          &quot;name&quot;: &quot;Tenant18&quot;\r\n        },\r\n        &quot;children&quot;: [\r\n          {\r\n            &quot;fvAp&quot;: {\r\n              &quot;attributes&quot;: {\r\n                &quot;name&quot;: &quot;3Tier_AP&quot;\r\n              },\r\n              &quot;children&quot;: [\r\n                {\r\n                  &quot;fvAEPg&quot;: {\r\n                    &quot;attributes&quot;: {\r\n                      &quot;name&quot;: &quot;DBServers_EPG&quot;\r\n                    },\r\n                    &quot;children&quot;: [\r\n                      {\r\n                        &quot;fvRsCustQosPol&quot;: {\r\n                          &quot;attributes&quot;: {}\r\n                        }\r\n                      },\r\n                      {\r\n                        &quot;fvRsBd&quot;: {\r\n                          &quot;attributes&quot;: {},\r\n                          &quot;children&quot;: [\r\n                            {\r\n                              &quot;fvSubnetBDDefCont&quot;: {\r\n                                &quot;attributes&quot;: {\r\n                                  &quot;bddefDn&quot;: &quot;uni/bd-[uni/tn-Tenant18/BD-App_BD]-isSvc-no&quot;,\r\n                                  &quot;name&quot;: &quot;&quot;,\r\n                                  &quot;nameAlias&quot;: &quot;&quot;\r\n                                }\r\n                              }\r\n                            }\r\n                          ]\r\n                        }\r\n                      }\r\n                    ]\r\n                  }\r\n                },\r\n                {\r\n                  &quot;fvAEPg&quot;: {\r\n                    &quot;attributes&quot;: {\r\n                      &quot;name&quot;: &quot;AppServers_EPG&quot;\r\n                    },\r\n                    &quot;children&quot;: [\r\n                      {\r\n                        &quot;fvRsCons&quot;: {\r\n                          &quot;attributes&quot;: {\r\n                            &quot;tnVzBrCPName&quot;: &quot;MgmtServices_Ct&quot;\r\n                          },\r\n                          &quot;children&quot;: [\r\n                            {\r\n                              &quot;fvCollectionCont&quot;: {\r\n                                &quot;attributes&quot;: {\r\n                                  &quot;collectionDn&quot;: &quot;uni/tn-Tenant18/brc-MgmtServices_Ct&quot;,\r\n                                  &quot;name&quot;: &quot;&quot;,\r\n                                  &quot;nameAlias&quot;: &quot;&quot;\r\n                                }\r\n                              }\r\n                            }\r\n                          ]\r\n                        }\r\n                      },\r\n                      {\r\n                        &quot;fvRsCons&quot;: {\r\n                          &quot;attributes&quot;: {\r\n                            &quot;tnVzBrCPName&quot;: &quot;DBServices_Ct&quot;\r\n                          },\r\n                          &quot;children&quot;: [\r\n                            {\r\n                              &quot;fvCollectionCont&quot;: {\r\n                                &quot;attributes&quot;: {\r\n                                  &quot;collectionDn&quot;: &quot;uni/tn-common/brc-DBServices_Ct&quot;,\r\n                                  &quot;name&quot;: &quot;&quot;,\r\n                                  &quot;nameAlias&quot;: &quot;&quot;\r\n                                }\r\n                              }\r\n                            }\r\n                          ]\r\n                        }\r\n                      },\r\n                      {\r\n                        &quot;fvRsProv&quot;: {\r\n                          &quot;attributes&quot;: {\r\n                            &quot;tnVzBrCPName&quot;: &quot;AppServices_Ct&quot;\r\n                          },\r\n                          &quot;children&quot;: [\r\n                            {\r\n                              &quot;fvCollectionCont&quot;: {\r\n                                &quot;attributes&quot;: {\r\n                                  &quot;collectionDn&quot;: &quot;uni/tn-Tenant18/brc-AppServices_Ct&quot;,\r\n                                  &quot;name&quot;: &quot;&quot;,\r\n                                  &quot;nameAlias&quot;: &quot;&quot;\r\n                                }\r\n                              }\r\n                            }\r\n                          ]\r\n                        }\r\n                      },\r\n                      {\r\n                        &quot;fvRsProv&quot;: {\r\n                          &quot;attributes&quot;: {\r\n                            &quot;tnVzBrCPName&quot;: &quot;MgmtServices_Ct&quot;\r\n                          },\r\n                          &quot;children&quot;: [\r\n                            {\r\n                              &quot;fvCollectionCont&quot;: {\r\n                                &quot;attributes&quot;: {\r\n                                  &quot;collectionDn&quot;: &quot;uni/tn-Tenant18/brc-MgmtServices_Ct&quot;,\r\n                                  &quot;name&quot;: &quot;&quot;,\r\n                                  &quot;nameAlias&quot;: &quot;&quot;\r\n                                }\r\n                              }\r\n                            }\r\n                          ]\r\n                        }\r\n                      }\r\n                    ]\r\n                  }\r\n                },\r\n                {\r\n                  &quot;fvAEPg&quot;: {\r\n                    &quot;attributes&quot;: {\r\n                      &quot;name&quot;: &quot;WebServers_EPG&quot;\r\n                    },\r\n                    &quot;children&quot;: [\r\n                      {\r\n                        &quot;fvRsCons&quot;: {\r\n                          &quot;attributes&quot;: {\r\n                            &quot;tnVzBrCPName&quot;: &quot;MgmtServices_Ct&quot;\r\n                          },\r\n                          &quot;children&quot;: [\r\n                            {\r\n                              &quot;fvCollectionCont&quot;: {\r\n                                &quot;attributes&quot;: {\r\n                                  &quot;collectionDn&quot;: &quot;uni/tn-Tenant18/brc-MgmtServices_Ct&quot;,\r\n                                  &quot;name&quot;: &quot;&quot;,\r\n                                  &quot;nameAlias&quot;: &quot;&quot;\r\n                                }\r\n                              }\r\n                            }\r\n                          ]\r\n                        }\r\n                      },\r\n                      {\r\n                        &quot;fvRsCons&quot;: {\r\n                          &quot;attributes&quot;: {\r\n                            &quot;tnVzBrCPName&quot;: &quot;AppServices_Ct&quot;\r\n                          },\r\n                          &quot;children&quot;: [\r\n                            {\r\n                              &quot;fvCollectionCont&quot;: {\r\n                                &quot;attributes&quot;: {\r\n                                  &quot;collectionDn&quot;: &quot;uni/tn-Tenant18/brc-AppServices_Ct&quot;,\r\n                                  &quot;name&quot;: &quot;&quot;,\r\n                                  &quot;nameAlias&quot;: &quot;&quot;\r\n                                }\r\n                              }\r\n                            }\r\n                          ]\r\n                        }\r\n                      },\r\n                      {\r\n                        &quot;fvRsProv&quot;: {\r\n                          &quot;attributes&quot;: {\r\n                            &quot;tnVzBrCPName&quot;: &quot;MgmtServices_Ct&quot;\r\n                          },\r\n                          &quot;children&quot;: [\r\n                            {\r\n                              &quot;fvCollectionCont&quot;: {\r\n                                &quot;attributes&quot;: {\r\n                                  &quot;collectionDn&quot;: &quot;uni/tn-Tenant18/brc-MgmtServices_Ct&quot;,\r\n                                  &quot;name&quot;: &quot;&quot;,\r\n                                  &quot;nameAlias&quot;: &quot;&quot;\r\n                                }\r\n                              }\r\n                            }\r\n                          ]\r\n                        }\r\n                      }\r\n                    ]\r\n                  }\r\n                }\r\n              ]\r\n            }\r\n          }\r\n        ]\r\n      }\r\n    },\r\n    {\r\n      &quot;fvTenant&quot;: {\r\n        &quot;attributes&quot;: {\r\n          &quot;dn&quot;: &quot;uni/tn-Tenant17&quot;,\r\n          &quot;name&quot;: &quot;Tenant17&quot;\r\n        },\r\n        &quot;children&quot;: [\r\n          {\r\n            &quot;fvAp&quot;: {\r\n              &quot;attributes&quot;: {\r\n                &quot;name&quot;: &quot;2Tier_AP&quot;\r\n              },\r\n              &quot;children&quot;: [\r\n                {\r\n                  &quot;fvAEPg&quot;: {\r\n                    &quot;attributes&quot;: {\r\n                      &quot;name&quot;: &quot;WebServers_EPG&quot;\r\n                    },\r\n                    &quot;children&quot;: [\r\n                      {\r\n                        &quot;fvRsDomAtt&quot;: {\r\n                          &quot;attributes&quot;: {\r\n                            &quot;tDn&quot;: &quot;uni/phys-T17:MappedVLANs_PhysDom&quot;\r\n                          }\r\n                        }\r\n                      },\r\n                      {\r\n                        &quot;fvRsCustQosPol&quot;: {\r\n                          &quot;attributes&quot;: {}\r\n                        }\r\n                      },\r\n                      {\r\n                        &quot;fvRsBd&quot;: {\r\n                          &quot;attributes&quot;: {},\r\n                          &quot;children&quot;: [\r\n                            {\r\n                              &quot;fvSubnetBDDefCont&quot;: {\r\n                                &quot;attributes&quot;: {\r\n                                  &quot;bddefDn&quot;: &quot;uni/bd-[uni/tn-Tenant17/BD-Web_BD]-isSvc-no&quot;,\r\n                                  &quot;name&quot;: &quot;&quot;,\r\n                                  &quot;nameAlias&quot;: &quot;&quot;\r\n                                }\r\n                              }\r\n                            }\r\n                          ]\r\n                        }\r\n                      }\r\n                    ]\r\n                  }\r\n                },\r\n                {\r\n                  &quot;fvAEPg&quot;: {\r\n                    &quot;attributes&quot;: {\r\n                      &quot;name&quot;: &quot;AppServers_EPG&quot;\r\n                    },\r\n                    &quot;children&quot;: [\r\n                      {\r\n                        &quot;fvRsCons&quot;: {\r\n                          &quot;attributes&quot;: {\r\n                            &quot;tnVzBrCPName&quot;: &quot;Any.IP_Ct&quot;\r\n                          },\r\n                          &quot;children&quot;: [\r\n                            {\r\n                              &quot;fvCollectionCont&quot;: {\r\n                                &quot;attributes&quot;: {\r\n                                  &quot;collectionDn&quot;: &quot;uni/tn-common/brc-Any.IP_Ct&quot;,\r\n                                  &quot;name&quot;: &quot;&quot;,\r\n                                  &quot;nameAlias&quot;: &quot;&quot;\r\n                                }\r\n                              }\r\n                            }\r\n                          ]\r\n                        }\r\n                      }\r\n                    ]\r\n                  }\r\n                }\r\n              ]\r\n            }\r\n          },\r\n          {\r\n            &quot;fvAp&quot;: {\r\n              &quot;attributes&quot;: {\r\n                &quot;name&quot;: &quot;3Tier_AP&quot;\r\n              },\r\n              &quot;children&quot;: [\r\n                {\r\n                  &quot;fvAEPg&quot;: {\r\n                    &quot;attributes&quot;: {\r\n                      &quot;name&quot;: &quot;DBServers_EPG&quot;\r\n                    },\r\n                    &quot;children&quot;: [\r\n                      {\r\n                        &quot;fvRsProv&quot;: {\r\n                          &quot;attributes&quot;: {\r\n                            &quot;tnVzBrCPName&quot;: &quot;DBServices_Ct&quot;\r\n                          },\r\n                          &quot;children&quot;: [\r\n                            {\r\n                              &quot;fvCollectionCont&quot;: {\r\n                                &quot;attributes&quot;: {\r\n                                  &quot;collectionDn&quot;: &quot;uni/tn-common/brc-DBServices_Ct&quot;,\r\n                                  &quot;name&quot;: &quot;&quot;,\r\n                                  &quot;nameAlias&quot;: &quot;&quot;\r\n                                }\r\n                              }\r\n                            }\r\n                          ]\r\n                        }\r\n                      }\r\n                    ]\r\n                  }\r\n                },\r\n                {\r\n                  &quot;fvAEPg&quot;: {\r\n                    &quot;attributes&quot;: {\r\n                      &quot;name&quot;: &quot;AppServers_EPG&quot;\r\n                    },\r\n                    &quot;children&quot;: [\r\n                      {\r\n                        &quot;fvRsCons&quot;: {\r\n                          &quot;attributes&quot;: {\r\n                            &quot;tnVzBrCPName&quot;: &quot;DBServices_Ct&quot;\r\n                          },\r\n                          &quot;children&quot;: [\r\n                            {\r\n                              &quot;fvCollectionCont&quot;: {\r\n                                &quot;attributes&quot;: {\r\n                                  &quot;collectionDn&quot;: &quot;uni/tn-common/brc-DBServices_Ct&quot;,\r\n                                  &quot;name&quot;: &quot;&quot;,\r\n                                  &quot;nameAlias&quot;: &quot;&quot;\r\n                                }\r\n                              }\r\n                            }\r\n                          ]\r\n                        }\r\n                      },\r\n                      {\r\n                        &quot;fvRsCons&quot;: {\r\n                          &quot;attributes&quot;: {\r\n                            &quot;tnVzBrCPName&quot;: &quot;MgmtServices_Ct&quot;\r\n                          },\r\n                          &quot;children&quot;: [\r\n                            {\r\n                              &quot;fvCollectionCont&quot;: {\r\n                                &quot;attributes&quot;: {\r\n                                  &quot;collectionDn&quot;: &quot;uni/tn-Tenant17/brc-MgmtServices_Ct&quot;,\r\n                                  &quot;name&quot;: &quot;&quot;,\r\n                                  &quot;nameAlias&quot;: &quot;&quot;\r\n                                }\r\n                              }\r\n                            }\r\n                          ]\r\n                        }\r\n                      },\r\n                      {\r\n                        &quot;fvRsProv&quot;: {\r\n                          &quot;attributes&quot;: {\r\n                            &quot;tnVzBrCPName&quot;: &quot;AppServices_Ct&quot;\r\n                          },\r\n                          &quot;children&quot;: [\r\n                            {\r\n                              &quot;fvCollectionCont&quot;: {\r\n                                &quot;attributes&quot;: {\r\n                                  &quot;collectionDn&quot;: &quot;uni/tn-Tenant17/brc-AppServices_Ct&quot;,\r\n                                  &quot;name&quot;: &quot;&quot;,\r\n                                  &quot;nameAlias&quot;: &quot;&quot;\r\n                                }\r\n                              }\r\n                            }\r\n                          ]\r\n                        }\r\n                      },\r\n                      {\r\n                        &quot;fvRsProv&quot;: {\r\n                          &quot;attributes&quot;: {\r\n                            &quot;tnVzBrCPName&quot;: &quot;MgmtServices_Ct&quot;\r\n                          },\r\n                          &quot;children&quot;: [\r\n                            {\r\n                              &quot;fvCollectionCont&quot;: {\r\n                                &quot;attributes&quot;: {\r\n                                  &quot;collectionDn&quot;: &quot;uni/tn-Tenant17/brc-MgmtServices_Ct&quot;,\r\n                                  &quot;name&quot;: &quot;&quot;,\r\n                                  &quot;nameAlias&quot;: &quot;&quot;\r\n                                }\r\n                              }\r\n                            }\r\n                          ]\r\n                        }\r\n                      }\r\n                    ]\r\n                  }\r\n                },\r\n                {\r\n                  &quot;fvAEPg&quot;: {\r\n                    &quot;attributes&quot;: {\r\n                      &quot;name&quot;: &quot;WebServers_EPG&quot;\r\n                    },\r\n                    &quot;children&quot;: [\r\n                      {\r\n                        &quot;fvRsCons&quot;: {\r\n                          &quot;attributes&quot;: {\r\n                            &quot;tnVzBrCPName&quot;: &quot;MgmtServices_Ct&quot;\r\n                          },\r\n                          &quot;children&quot;: [\r\n                            {\r\n                              &quot;fvCollectionCont&quot;: {\r\n                                &quot;attributes&quot;: {\r\n                                  &quot;collectionDn&quot;: &quot;uni/tn-Tenant17/brc-MgmtServices_Ct&quot;,\r\n                                  &quot;name&quot;: &quot;&quot;,\r\n                                  &quot;nameAlias&quot;: &quot;&quot;\r\n                                }\r\n                              }\r\n                            }\r\n                          ]\r\n                        }\r\n                      },\r\n                      {\r\n                        &quot;fvRsCons&quot;: {\r\n                          &quot;attributes&quot;: {\r\n                            &quot;tnVzBrCPName&quot;: &quot;AppServices_Ct&quot;\r\n                          },\r\n                          &quot;children&quot;: [\r\n                            {\r\n                              &quot;fvCollectionCont&quot;: {\r\n                                &quot;attributes&quot;: {\r\n                                  &quot;collectionDn&quot;: &quot;uni/tn-Tenant17/brc-AppServices_Ct&quot;,\r\n                                  &quot;name&quot;: &quot;&quot;,\r\n                                  &quot;nameAlias&quot;: &quot;&quot;\r\n                                }\r\n                              }\r\n                            }\r\n                          ]\r\n                        }\r\n                      },\r\n                      {\r\n                        &quot;fvRsProv&quot;: {\r\n                          &quot;attributes&quot;: {\r\n                            &quot;tnVzBrCPName&quot;: &quot;MgmtServices_Ct&quot;\r\n                          },\r\n                          &quot;children&quot;: [\r\n                            {\r\n                              &quot;fvCollectionCont&quot;: {\r\n                                &quot;attributes&quot;: {\r\n                                  &quot;collectionDn&quot;: &quot;uni/tn-Tenant17/brc-MgmtServices_Ct&quot;,\r\n                                  &quot;name&quot;: &quot;&quot;,\r\n                                  &quot;nameAlias&quot;: &quot;&quot;\r\n                                }\r\n                              }\r\n                            }\r\n                          ]\r\n                        }\r\n                      }\r\n                    ]\r\n                  }\r\n                }\r\n              ]\r\n            }\r\n          }\r\n        ]\r\n      }\r\n    }\r\n  ]\r\n}\r\n```\r\n\r\nI need to turn this into something more readable, ideally, I&#39;d like it to look like this (the following is valid JSON, but I&#39;m not fussy if it is not strictly accurate - the general format is the important thing)\r\n\r\n```\r\n[\r\n   {\r\n      &quot;fvTenant&quot;: &quot;Tenant10&quot;,\r\n      &quot;fvAp&quot;: [\r\n         {\r\n            &quot;2Tier_AP&quot;: {\r\n               &quot;fvAEPg&quot;: [\r\n                  {\r\n                     &quot;WebServers_EPG&quot;: {\r\n                        &quot;fvRsCons&quot;: [\r\n                           &quot;AppServices_Ct&quot;\r\n                        ],\r\n                        &quot;fvRsProv&quot;: []\r\n                     },\r\n                     &quot;AppServers_EPG&quot;: {\r\n                        &quot;fvRsCons&quot;: [],\r\n                        &quot;fvRsProv&quot;: [\r\n                           &quot;AppServices_Ct&quot;\r\n                        ]\r\n                     }\r\n                  }\r\n               ]\r\n            }\r\n         }\r\n      ]\r\n   },\r\n   {\r\n      &quot;fvTenant&quot;: &quot;Tenant18&quot;,\r\n      &quot;fvAp&quot;: [\r\n         {\r\n            &quot;3Tier_AP&quot;: {\r\n               &quot;fvAEPg&quot;: [\r\n                  {\r\n                     &quot;DBServers_EPG&quot;: {\r\n                        &quot;fvRsCons&quot;: [],\r\n                        &quot;fvRsProv&quot;: []\r\n                     },\r\n                     &quot;AppServers_EPG&quot;: {\r\n                        &quot;fvRsCons&quot;: [\r\n                           &quot;MgmtServices_Ct&quot;,\r\n                           &quot;DBServices_Ct&quot;\r\n                        ],\r\n                        &quot;fvRsProv&quot;: [\r\n                           &quot;AppServices_Ct&quot;,\r\n                           &quot;MgmtServices_Ct&quot;\r\n                        ]\r\n                     },\r\n                     &quot;WebServers_EPG&quot;: {\r\n                        &quot;fvRsCons&quot;: [\r\n                           &quot;MgmtServices_Ct&quot;,\r\n                           &quot;AppServices_Ct&quot;\r\n                        ],\r\n                        &quot;fvRsProv&quot;: [\r\n                           &quot;MgmtServices_Ct&quot;\r\n                        ]\r\n                     }\r\n                  }\r\n               ]\r\n            }\r\n         }\r\n      ]\r\n   },\r\n   {\r\n      &quot;fvTenant&quot;: &quot;Tenant17&quot;,\r\n      &quot;fvAp&quot;: [\r\n         {\r\n            &quot;2Tier_AP&quot;: {\r\n               &quot;fvAEPg&quot;: [\r\n                  {\r\n                     &quot;WebServers_EPG&quot;: {\r\n                        &quot;fvRsCons&quot;: [],\r\n                        &quot;fvRsProv&quot;: []\r\n                     },\r\n                     &quot;AppServers_EPG&quot;: {\r\n                        &quot;fvRsCons&quot;: [\r\n                           &quot;Any.IP_Ct&quot;\r\n                        ],\r\n                        &quot;fvRsProv&quot;: []\r\n                     }\r\n                  }\r\n               ]\r\n            }\r\n         },\r\n         {\r\n            &quot;3Tier_AP&quot;: {\r\n               &quot;fvAEPg&quot;: [\r\n                  {\r\n                     &quot;DBServers_EPG&quot;: {\r\n                        &quot;fvRsCons&quot;: [\r\n                           &quot;DBServices_Ct&quot;,\r\n                           &quot;MgmtServices_Ct&quot;\r\n                        ],\r\n                        &quot;fvRsProv&quot;: [\r\n                           &quot;AppServices_Ct&quot;,\r\n                           &quot;MgmtServices_Ct&quot;\r\n                        ]\r\n                     },\r\n                     &quot;AppServers_EPG&quot;: {\r\n                        &quot;fvRsCons&quot;: [\r\n                           &quot;DBServices_Ct&quot;,\r\n                           &quot;MgmtServices_Ct&quot;\r\n                        ],\r\n                        &quot;fvRsProv&quot;: [\r\n                           &quot;AppServices_Ct&quot;,\r\n                           &quot;MgmtServices_Ct&quot;\r\n                        ]\r\n                     },\r\n                     &quot;WebServers_EPG&quot;: {\r\n                        &quot;fvRsCons&quot;: [\r\n                           &quot;MgmtServices_Ct&quot;,\r\n                           &quot;AppServices_Ct&quot;\r\n                        ],\r\n                        &quot;fvRsProv&quot;: [\r\n                           &quot;MgmtServices_Ct&quot;\r\n                        ]\r\n                     }\r\n                  }\r\n               ]\r\n            }\r\n         }\r\n      ]\r\n   }\r\n]\r\n```\r\n\r\nI&#39;ve managed to separate out the &quot;fvTenant&quot; key and value, and get the &quot;fvAp&quot; into an array using jqplay - here&#39;s my attempt https://jqplay.org/s/tNIPrGaEI96\r\n\r\n```\r\njq &#39;.imdata[].fvTenant | {fvTenant: .attributes.name, fvAp: [.children[].fvAp]} &#39;\r\n```\r\ngives me the following:\r\n```\r\n{&quot;fvTenant&quot;:&quot;Tenant10&quot;,&quot;fvAp&quot;:[{&quot;attributes&quot;:{&quot;name&quot;:&quot;2Tier_AP&quot;},&quot;children&quot;:[{&quot;fvAEPg&quot;:{&quot;attributes&quot;:{&quot;name&quot;:&quot;WebServers_EPG&quot;},&quot;children&quot;:[{&quot;fvRsCons&quot;:{&quot;attributes&quot;:{&quot;tnVzBrCPName&quot;:&quot;AppServices_Ct&quot;},&quot;children&quot;:[{&quot;fvCollectionCont&quot;:{&quot;attributes&quot;:{&quot;collectionDn&quot;:&quot;uni/tn-common/brc-AppServices_Ct&quot;,&quot;name&quot;:&quot;&quot;,&quot;nameAlias&quot;:&quot;&quot;}}}]}}]}},{&quot;fvAEPg&quot;:{&quot;attributes&quot;:{&quot;name&quot;:&quot;AppServers_EPG&quot;},&quot;children&quot;:[{&quot;fvRsProv&quot;:{&quot;attributes&quot;:{&quot;tnVzBrCPName&quot;:&quot;AppServices_Ct&quot;},&quot;children&quot;:[{&quot;fvCollectionCont&quot;:{&quot;attributes&quot;:{&quot;collectionDn&quot;:&quot;uni/tn-common/brc-AppServices_Ct&quot;,&quot;name&quot;:&quot;&quot;,&quot;nameAlias&quot;:&quot;&quot;}}}]}}]}}]}]}\r\n{&quot;fvTenant&quot;:&quot;Tenant18&quot;,&quot;fvAp&quot;:[{&quot;attributes&quot;:{&quot;name&quot;:&quot;3Tier_AP&quot;},&quot;children&quot;:[{&quot;fvAEPg&quot;:{&quot;attributes&quot;:{&quot;name&quot;:&quot;DBServers_EPG&quot;},&quot;children&quot;:[{&quot;fvRsCustQosPol&quot;:{&quot;attributes&quot;:{}}},{&quot;fvRsBd&quot;:{&quot;attributes&quot;:{},&quot;children&quot;:[{&quot;fvSubnetBDDefCont&quot;:{&quot;attributes&quot;:{&quot;bddefDn&quot;:&quot;uni/bd-[uni/tn-Tenant18/BD-App_BD]-isSvc-no&quot;,&quot;name&quot;:&quot;&quot;,&quot;nameAlias&quot;:&quot;&quot;}}}]}}]}},{&quot;fvAEPg&quot;:{&quot;attributes&quot;:{&quot;name&quot;:&quot;AppServers_EPG&quot;},&quot;children&quot;:[{&quot;fvRsCons&quot;:{&quot;attributes&quot;:{&quot;tnVzBrCPName&quot;:&quot;MgmtServices_Ct&quot;},&quot;children&quot;:[{&quot;fvCollectionCont&quot;:{&quot;attributes&quot;:{&quot;collectionDn&quot;:&quot;uni/tn-Tenant18/brc-MgmtServices_Ct&quot;,&quot;name&quot;:&quot;&quot;,&quot;nameAlias&quot;:&quot;&quot;}}}]}},{&quot;fvRsCons&quot;:{&quot;attributes&quot;:{&quot;tnVzBrCPName&quot;:&quot;DBServices_Ct&quot;},&quot;children&quot;:[{&quot;fvCollectionCont&quot;:{&quot;attributes&quot;:{&quot;collectionDn&quot;:&quot;uni/tn-common/brc-DBServices_Ct&quot;,&quot;name&quot;:&quot;&quot;,&quot;nameAlias&quot;:&quot;&quot;}}}]}},{&quot;fvRsProv&quot;:{&quot;attributes&quot;:{&quot;tnVzBrCPName&quot;:&quot;AppServices_Ct&quot;},&quot;children&quot;:[{&quot;fvCollectionCont&quot;:{&quot;attributes&quot;:{&quot;collectionDn&quot;:&quot;uni/tn-Tenant18/brc-AppServices_Ct&quot;,&quot;name&quot;:&quot;&quot;,&quot;nameAlias&quot;:&quot;&quot;}}}]}},{&quot;fvRsProv&quot;:{&quot;attributes&quot;:{&quot;tnVzBrCPName&quot;:&quot;MgmtServices_Ct&quot;},&quot;children&quot;:[{&quot;fvCollectionCont&quot;:{&quot;attributes&quot;:{&quot;collectionDn&quot;:&quot;uni/tn-Tenant18/brc-MgmtServices_Ct&quot;,&quot;name&quot;:&quot;&quot;,&quot;nameAlias&quot;:&quot;&quot;}}}]}}]}},{&quot;fvAEPg&quot;:{&quot;attributes&quot;:{&quot;name&quot;:&quot;WebServers_EPG&quot;},&quot;children&quot;:[{&quot;fvRsCons&quot;:{&quot;attributes&quot;:{&quot;tnVzBrCPName&quot;:&quot;MgmtServices_Ct&quot;},&quot;children&quot;:[{&quot;fvCollectionCont&quot;:{&quot;attributes&quot;:{&quot;collectionDn&quot;:&quot;uni/tn-Tenant18/brc-MgmtServices_Ct&quot;,&quot;name&quot;:&quot;&quot;,&quot;nameAlias&quot;:&quot;&quot;}}}]}},{&quot;fvRsCons&quot;:{&quot;attributes&quot;:{&quot;tnVzBrCPName&quot;:&quot;AppServices_Ct&quot;},&quot;children&quot;:[{&quot;fvCollectionCont&quot;:{&quot;attributes&quot;:{&quot;collectionDn&quot;:&quot;uni/tn-Tenant18/brc-AppServices_Ct&quot;,&quot;name&quot;:&quot;&quot;,&quot;nameAlias&quot;:&quot;&quot;}}}]}},{&quot;fvRsProv&quot;:{&quot;attributes&quot;:{&quot;tnVzBrCPName&quot;:&quot;MgmtServices_Ct&quot;},&quot;children&quot;:[{&quot;fvCollectionCont&quot;:{&quot;attributes&quot;:{&quot;collectionDn&quot;:&quot;uni/tn-Tenant18/brc-MgmtServices_Ct&quot;,&quot;name&quot;:&quot;&quot;,&quot;nameAlias&quot;:&quot;&quot;}}}]}}]}}]}]}\r\n{&quot;fvTenant&quot;:&quot;Tenant17&quot;,&quot;fvAp&quot;:[{&quot;attributes&quot;:{&quot;name&quot;:&quot;2Tier_AP&quot;},&quot;children&quot;:[{&quot;fvAEPg&quot;:{&quot;attributes&quot;:{&quot;name&quot;:&quot;WebServers_EPG&quot;},&quot;children&quot;:[{&quot;fvRsDomAtt&quot;:{&quot;attributes&quot;:{&quot;tDn&quot;:&quot;uni/phys-T17:MappedVLANs_PhysDom&quot;}}},{&quot;fvRsCustQosPol&quot;:{&quot;attributes&quot;:{}}},{&quot;fvRsBd&quot;:{&quot;attributes&quot;:{},&quot;children&quot;:[{&quot;fvSubnetBDDefCont&quot;:{&quot;attributes&quot;:{&quot;bddefDn&quot;:&quot;uni/bd-[uni/tn-Tenant17/BD-Web_BD]-isSvc-no&quot;,&quot;name&quot;:&quot;&quot;,&quot;nameAlias&quot;:&quot;&quot;}}}]}}]}},{&quot;fvAEPg&quot;:{&quot;attributes&quot;:{&quot;name&quot;:&quot;AppServers_EPG&quot;},&quot;children&quot;:[{&quot;fvRsCons&quot;:{&quot;attributes&quot;:{&quot;tnVzBrCPName&quot;:&quot;Any.IP_Ct&quot;},&quot;children&quot;:[{&quot;fvCollectionCont&quot;:{&quot;attributes&quot;:{&quot;collectionDn&quot;:&quot;uni/tn-common/brc-Any.IP_Ct&quot;,&quot;name&quot;:&quot;&quot;,&quot;nameAlias&quot;:&quot;&quot;}}}]}}]}}]},{&quot;attributes&quot;:{&quot;name&quot;:&quot;3Tier_AP&quot;},&quot;children&quot;:[{&quot;fvAEPg&quot;:{&quot;attributes&quot;:{&quot;name&quot;:&quot;DBServers_EPG&quot;},&quot;children&quot;:[{&quot;fvRsProv&quot;:{&quot;attributes&quot;:{&quot;tnVzBrCPName&quot;:&quot;DBServices_Ct&quot;},&quot;children&quot;:[{&quot;fvCollectionCont&quot;:{&quot;attributes&quot;:{&quot;collectionDn&quot;:&quot;uni/tn-common/brc-DBServices_Ct&quot;,&quot;name&quot;:&quot;&quot;,&quot;nameAlias&quot;:&quot;&quot;}}}]}}]}},{&quot;fvAEPg&quot;:{&quot;attributes&quot;:{&quot;name&quot;:&quot;AppServers_EPG&quot;},&quot;children&quot;:[{&quot;fvRsCons&quot;:{&quot;attributes&quot;:{&quot;tnVzBrCPName&quot;:&quot;DBServices_Ct&quot;},&quot;children&quot;:[{&quot;fvCollectionCont&quot;:{&quot;attributes&quot;:{&quot;collectionDn&quot;:&quot;uni/tn-common/brc-DBServices_Ct&quot;,&quot;name&quot;:&quot;&quot;,&quot;nameAlias&quot;:&quot;&quot;}}}]}},{&quot;fvRsCons&quot;:{&quot;attributes&quot;:{&quot;tnVzBrCPName&quot;:&quot;MgmtServices_Ct&quot;},&quot;children&quot;:[{&quot;fvCollectionCont&quot;:{&quot;attributes&quot;:{&quot;collectionDn&quot;:&quot;uni/tn-Tenant17/brc-MgmtServices_Ct&quot;,&quot;name&quot;:&quot;&quot;,&quot;nameAlias&quot;:&quot;&quot;}}}]}},{&quot;fvRsProv&quot;:{&quot;attributes&quot;:{&quot;tnVzBrCPName&quot;:&quot;AppServices_Ct&quot;},&quot;children&quot;:[{&quot;fvCollectionCont&quot;:{&quot;attributes&quot;:{&quot;collectionDn&quot;:&quot;uni/tn-Tenant17/brc-AppServices_Ct&quot;,&quot;name&quot;:&quot;&quot;,&quot;nameAlias&quot;:&quot;&quot;}}}]}},{&quot;fvRsProv&quot;:{&quot;attributes&quot;:{&quot;tnVzBrCPName&quot;:&quot;MgmtServices_Ct&quot;},&quot;children&quot;:[{&quot;fvCollectionCont&quot;:{&quot;attributes&quot;:{&quot;collectionDn&quot;:&quot;uni/tn-Tenant17/brc-MgmtServices_Ct&quot;,&quot;name&quot;:&quot;&quot;,&quot;nameAlias&quot;:&quot;&quot;}}}]}}]}},{&quot;fvAEPg&quot;:{&quot;attributes&quot;:{&quot;name&quot;:&quot;WebServers_EPG&quot;},&quot;children&quot;:[{&quot;fvRsCons&quot;:{&quot;attributes&quot;:{&quot;tnVzBrCPName&quot;:&quot;MgmtServices_Ct&quot;},&quot;children&quot;:[{&quot;fvCollectionCont&quot;:{&quot;attributes&quot;:{&quot;collectionDn&quot;:&quot;uni/tn-Tenant17/brc-MgmtServices_Ct&quot;,&quot;name&quot;:&quot;&quot;,&quot;nameAlias&quot;:&quot;&quot;}}}]}},{&quot;fvRsCons&quot;:{&quot;attributes&quot;:{&quot;tnVzBrCPName&quot;:&quot;AppServices_Ct&quot;},&quot;children&quot;:[{&quot;fvCollectionCont&quot;:{&quot;attributes&quot;:{&quot;collectionDn&quot;:&quot;uni/tn-Tenant17/brc-AppServices_Ct&quot;,&quot;name&quot;:&quot;&quot;,&quot;nameAlias&quot;:&quot;&quot;}}}]}},{&quot;fvRsProv&quot;:{&quot;attributes&quot;:{&quot;tnVzBrCPName&quot;:&quot;MgmtServices_Ct&quot;},&quot;children&quot;:[{&quot;fvCollectionCont&quot;:{&quot;attributes&quot;:{&quot;collectionDn&quot;:&quot;uni/tn-Tenant17/brc-MgmtServices_Ct&quot;,&quot;name&quot;:&quot;&quot;,&quot;nameAlias&quot;:&quot;&quot;}}}]}}]}}]}]}\r\n```\r\nIt seems I need to process the fvAp array in a similar way, but I&#39;ve not had any success isolating the array to process it.\r\nOpen to any suggestions.\r\n",
        "link": "https://stackoverflow.com/questions/78401284/how-can-i-reformat-multiple-levels-of-json-using-jq",
        "title": "How can I reformat multiple levels of JSON using JQ?"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1714407346,
                "creation_date": 1714407346,
                "answer_id": 78403963,
                "question_id": 78403902,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "After you `selected` the correct name, you&#39;ll need to continue `select`&#39;ing on the `.spec.containers` to find the one with `name === &quot;mysql&quot;` and then select the `.resources.limits.cpu` from that object:\r\n\r\n```\r\n.items[] | select(.metadata.name == $_NAME) | (.spec.containers[] | select(.name == &quot;mysql&quot;).resources?.limits?.cpu)\r\n```\r\n\r\nWill output:\r\n```none\r\n&quot;2100m&quot;\r\n```\r\n\r\n\r\n----------\r\n\r\n#### [Online JqPlay Demo](https://jqplay.org/s/T0qUH9tkbsu)",
                "title": "Problem with JQ selecting specific keys based on selecting"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1714407346,
        "creation_date": 1714406638,
        "question_id": 78403902,
        "body_markdown": "I have a problem with JQ where I can&#39;t get the correct fields. I have don&#39;t so many tutorials but can&#39;t seem to get this. I am trying to get only the &quot;cpu&quot; for the &quot;mysql&quot; container, but I keep getting both &quot;sidecar, and mysql&quot;. Honestly I think it is my misunderstanding of JQ so please feel free to point out what I am misunderstanding.\r\n\r\nI keep getting the following but should ONLY see &quot;2100m&quot;:\r\n\r\n    null\r\n    2100m\r\n\r\n\r\n***jq -r --arg _NAME &quot;mysql-innodb-cluster-0&quot;*** #Only get the container with this specific name\r\n\r\n***&#39;.items[]***                                  #Work on all items\r\n\r\n***| select(.metadata.name == $_NAME )***        #Work on the container that has this name\r\n\r\n***| .spec.containers***                         #Get the specific key, which will be an object here.\r\n\r\n***select(.[].name==&quot;sidecar&quot; | not )***       #Now that you have the Container Array only use the one that IS NOT named &quot;sidecar&quot;\r\n\r\n***| .[].resources.limits.cpu &#39;***               #you now have the MySQL container get ONLY it&#39;s &quot;cpu&quot; value.\r\n\r\n\r\nCommand I use:\r\n\r\n    jq -r --arg _NAME &quot;mysql-innodb-cluster-0&quot; &#39;.items[] | select(.metadata.name == $_NAME ) | .spec.containers | select(.[].name==&quot;sidecar&quot; | not ) | .[].resources.limits.cpu &#39; --raw-output /tmp/test.json\r\n\r\n&lt;hr/&gt;\r\n\r\ntest.json\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;name&quot;: &quot;mysql-innodb-cluster-0&quot;\r\n      },\r\n      &quot;spec&quot;: {\r\n        &quot;containers&quot;: [\r\n          {\r\n            &quot;name&quot;: &quot;sidecar&quot;,\r\n            &quot;resources&quot;: {}\r\n          },\r\n          {\r\n            &quot;name&quot;: &quot;mysql&quot;,\r\n            &quot;resources&quot;: {\r\n              &quot;limits&quot;: {\r\n                &quot;cpu&quot;: &quot;2100m&quot;,\r\n                &quot;memory&quot;: &quot;5G&quot;\r\n              }\r\n            }\r\n          }\r\n        ]\r\n      }\r\n    }\r\n     ],\r\n    &quot;kind&quot;: &quot;List&quot;\r\n    }\r\n\r\n",
        "link": "https://stackoverflow.com/questions/78403902/problem-with-jq-selecting-specific-keys-based-on-selecting",
        "title": "Problem with JQ selecting specific keys based on selecting"
    },
    {
        "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": 4,
                "creation_date": 1714535603,
                "post_id": 78411838,
                "comment_id": 138238068,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 5,
                "is_accepted": true,
                "score": 5,
                "last_activity_date": 1714538540,
                "last_edit_date": 1714538540,
                "creation_date": 1714534595,
                "answer_id": 78411906,
                "question_id": 78411838,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If you omit the trailing comma in the initial production, you get a stream of inputs that jq can collect into an array using the `--slurp` (or `-s`) flag:\r\n```sh\r\nfor k in &quot;${!mymap[@]}&quot;; do \r\n  opt=&quot;{\\&quot;OptionName\\&quot;:\\&quot;${k}\\&quot;, \\&quot;Value\\&quot;:\\&quot;${mymap[$k]}\\&quot;}&quot;\r\n  echo &quot;$opt&quot;                            # no comma here --^\r\ndone | jq -s . &gt; option.json\r\n```\r\n\r\nHowever, you can also have jq do the JSON composition in the first place, guaranteeing valid JSON encoding even with challenging values (such as double quotes, etc.). For example, I&#39;d use the `--args` option to import the bash array&#39;s keys and values as positional parameters, and the `$ARGS` builtin to access them:\r\n```sh\r\ndeclare -A mymap=([name]=&quot;test&quot; [age]=&quot;13&quot;)\r\n\r\njq -n &#39;\r\n  $ARGS.positional | [_nwise(length/2)] | transpose\r\n  | map({OptionName: first, Value: last})\r\n&#39; --args &quot;${!mymap[@]}&quot; &quot;${mymap[@]}&quot; &gt; option.json\r\n```\r\n\r\nAs @oguz pointed out, newer versions of bash can also expand arrays to their keys and values in our desired alternating order by using `&quot;${mymap[@]@k}&quot;`. The full jq filter would then just read:\r\n```sh\r\njq -n &#39;$ARGS.positional | [_nwise(2) | {OptionName: first, Value: last}]&#39; \\\r\n  --args &quot;${mymap[@]@k}&quot;\r\n```",
                "title": "How to append records to a json object file in bash"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1714584322,
                "last_edit_date": 1714584322,
                "creation_date": 1714549567,
                "answer_id": 78412598,
                "question_id": 78411838,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Sure it&#39;s better to use `jq` if you work with json but in case when `jq` is not available `printf` can be used, like this:\r\n\r\n    declare -A arr=([key1]=val1 [key2]=val2)\r\n    \r\n    items=$(\r\n        for key in &quot;${!arr[@]}&quot;; {\r\n            val=${arr[$key]}\r\n            printf &#39;{&quot;%s&quot;: &quot;%s&quot;},\\n&#39; &quot;$key&quot; &quot;$val&quot;\r\n        }\r\n    )\r\n    \r\n    echo &quot;[${items%,*}]&quot;\r\n    [{&quot;key2&quot;: &quot;val2&quot;},\r\n    {&quot;key1&quot;: &quot;val1&quot;}]\r\n\r\nHere is I&#39;m using `jq` to validate the result:\r\n\r\n    $ echo &quot;[${items%,*}]&quot; | jq\r\n    [\r\n      {\r\n        &quot;key2&quot;: &quot;val2&quot;\r\n      },\r\n      {\r\n        &quot;key1&quot;: &quot;val1&quot;\r\n      }\r\n    ]\r\n\r\nNote this syntax `${items%,*}` it will print `$items` without last comma which is crucial for json. \r\n\r\nBut yes, some tricky values like the one from comments may ruin everything and must be worked around:\r\n\r\n    declare -A arr=([key1]=val1 [key2]=val2 [key3]=&#39;foo &quot;bar \\ bar&quot;&#39;)\r\n    \r\n    items=$(\r\n        for key in ${!arr[@]}; {\r\n            printf -vval -- &#39;%q&#39; &quot;${arr[$key]}&quot;\r\n            printf -vkey -- &#39;%q&#39;       &quot;$key&quot;\r\n            printf &#39;{&quot;%s&quot;: &quot;%s&quot;},\\n&#39;  &quot;${key//&#39;\\ &#39;/ }&quot; &quot;${val//&#39;\\ &#39;/ }&quot;\r\n        }\r\n    )\r\n    \r\n    echo &quot;[${items%,*}]&quot; | jq\r\n    [\r\n      {\r\n        &quot;key2&quot;: &quot;val2&quot;\r\n      },\r\n      {\r\n        &quot;key3&quot;: &quot;foo \\&quot;bar \\\\ bar\\&quot;&quot;\r\n      },\r\n      {\r\n        &quot;key1&quot;: &quot;val1&quot;\r\n      }\r\n    ]",
                "title": "How to append records to a json object file in bash"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1714572870,
                "creation_date": 1714572870,
                "answer_id": 78414181,
                "question_id": 78411838,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "A reimplementation of [Ivan&#39;s solution](https://stackoverflow.com/a/78412598/8656552) that preserves your formatting -\r\n```\r\n$: mymap=( [name]=test [age]=13 )\r\n$: fmt=&#39;%s  {\\n    &quot;OptionName&quot;: &quot;%s&quot;,\\n    &quot;Value&quot;: &quot;%s&quot;\\n  }&#39;\r\n$: for k in ${!mymap[@]}; do printf -v list &quot;$fmt&quot; &quot;${list:+$list,$&#39;\\n&#39;}&quot; &quot;$k&quot; &quot;${mymap[$k]}&quot;; done\r\n$: printf &#39;[\\n%s\\n]\\n&#39; &quot;$list&quot;\r\n[\r\n  {\r\n    &quot;OptionName&quot;: &quot;age&quot;,\r\n    &quot;Value&quot;: &quot;13&quot;\r\n  },\r\n  {\r\n    &quot;OptionName&quot;: &quot;name&quot;,\r\n    &quot;Value&quot;: &quot;test&quot;\r\n  }\r\n]\r\n\r\n```\r\nBut I point again to Glenn&#39;s comment - it&#39;s easy for odd data to break.",
                "title": "How to append records to a json object file in bash"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 1,
        "last_activity_date": 1714584322,
        "creation_date": 1714532412,
        "question_id": 78411838,
        "body_markdown": "I need to loop through a dictionary and append records to a json object file option.json \r\nthe code I have is \r\n\r\n    for K in &quot;${!MYMAP[@]}&quot;; do \r\n        opt=&quot;{\r\n            \\&quot;OptionName\\&quot;:\\&quot;${K}\\&quot;,\r\n            \\&quot;Value\\&quot;:\\&quot;${MYMAP[$K]}\\&quot;\r\n            },&quot;\r\n        echo $opt &gt;&gt; option.json\r\n    done \r\nBut this produce option.json as below \r\n\r\n    {\r\n        &quot;OptionName&quot;: &quot;name&quot;,\r\n        &quot;Value&quot;: &quot;test&quot;\r\n    },\r\n    {\r\n        &quot;OptionName&quot;: &quot;age&quot;,\r\n        &quot;Value&quot;: &quot;13&quot;\r\n    }\r\nHow do i make the option.json a json object and appending each {} inside the object, so my option.json would look like below \r\n\r\n    [\r\n        {\r\n            &quot;OptionName&quot;: &quot;name&quot;,\r\n            &quot;Value&quot;: &quot;test&quot;\r\n        },\r\n        {\r\n            &quot;OptionName&quot;: &quot;age&quot;,\r\n            &quot;Value&quot;: &quot;13&quot;\r\n        }\r\n    ]",
        "link": "https://stackoverflow.com/questions/78411838/how-to-append-records-to-a-json-object-file-in-bash",
        "title": "How to append records to a json object file in bash"
    },
    {
        "tags": [
            "json",
            "jq",
            "ndjson"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1714598453,
                "creation_date": 1714598453,
                "answer_id": 78416018,
                "question_id": 78415979,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The `combinations` function outputs all combinations of input elements. This will pair every `id` with every `color`:\r\n\r\n```\r\n$ jq -cr &#39;[[.id], [.colors[].color]] | combinations&#39; test.json\r\n[&quot;one&quot;,&quot;blue&quot;]\r\n[&quot;one&quot;,&quot;red&quot;]\r\n[&quot;two&quot;,&quot;green&quot;]\r\n\r\n$ jq -r &#39;[[.id], [.colors[].color]] | combinations | join(&quot; &quot;)&#39; test.json\r\none blue\r\none red\r\ntwo green\r\n```",
                "title": "How to get jq to output a long dataset?"
            },
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1714632923,
                "last_edit_date": 1714632923,
                "creation_date": 1714598578,
                "answer_id": 78416024,
                "question_id": 78415979,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The most direct approach:\r\n\r\n    jq -r &#39;.id + &quot; &quot; + .colors[].color&#39; my.ndjson\r\n\r\n\r\nSince you mentioned `@tsv`, and since @tsv output has various potential advantages, you may also wish to consider:\r\n\r\n    .id as $id | .colors[] | [$id, .color] | @tsv\r\n\r\nOr, as @oguz_ismail suggested, if you don&#39;t want to use `as` at all:\r\n\r\n    [.id]+(.colors[]|[.color])|@tsv",
                "title": "How to get jq to output a long dataset?"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1714599367,
                "creation_date": 1714599367,
                "answer_id": 78416066,
                "question_id": 78415979,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Came up with a version here too but had to chain a few calls of jq together to make it work too, just basically pulled the parts out into new JSON objects and then parsing those and joining similar to what answer @John Kugleman posted there too (maybe not as elegant :D).\r\n\r\n`cat test.json | jq &#39;.[] | {&quot;id&quot;: .id, &quot;color&quot;: .colors[].color}&#39; | jq -r &#39;[.[]]|join(&quot; &quot;)&#39;`\r\n\r\noutput like:\r\n\r\n```\r\none blue\r\none red\r\ntwo green\r\n```",
                "title": "How to get jq to output a long dataset?"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 1,
        "last_activity_date": 1714632923,
        "creation_date": 1714597643,
        "last_edit_date": 1714600196,
        "question_id": 78415979,
        "body_markdown": "Suppose I have this ndjson:\r\n\r\n```\r\n{&quot;id&quot;: &quot;one&quot;, &quot;colors&quot;: [{&quot;color&quot;: &quot;blue&quot;}, {&quot;color&quot;: &quot;red&quot;}]}\r\n{&quot;id&quot;: &quot;two&quot;, &quot;colors&quot;: [{&quot;color&quot;: &quot;green&quot;}]}\r\n```\r\n\r\nHow do I get the output below?\r\n\r\n```\r\none blue\r\none red\r\ntwo green\r\n```\r\n\r\nHere is a failed attempt:\r\n\r\n```\r\n$ cat tmp/test.json  | jq -r &#39;.id, .colors[].color&#39;\r\none\r\nblue\r\nred\r\ntwo\r\ngreen\r\n```\r\n\r\nHere is a second failed attempt:\r\n\r\n```\r\n$ cat tmp/test.json  | jq -r &#39;[.id, .colors[].color]|@tsv&#39;\r\none\tblue\tred\r\ntwo\tgreen\r\n```",
        "link": "https://stackoverflow.com/questions/78415979/how-to-get-jq-to-output-a-long-dataset",
        "title": "How to get jq to output a long dataset?"
    },
    {
        "tags": [
            "json",
            "bash",
            "automation",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 13789219,
                    "reputation": 53538,
                    "user_id": 9952196,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/cd1a3f93172eb89e221c98e35e6e22b3?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Shawn",
                    "link": "https://stackoverflow.com/users/9952196/shawn"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1714706716,
                "post_id": 78422524,
                "comment_id": 138256816,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 13789219,
                    "reputation": 53538,
                    "user_id": 9952196,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/cd1a3f93172eb89e221c98e35e6e22b3?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Shawn",
                    "link": "https://stackoverflow.com/users/9952196/shawn"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1714706805,
                "post_id": 78422524,
                "comment_id": 138256821,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 27870957,
                    "reputation": 11,
                    "user_id": 21281486,
                    "user_type": "registered",
                    "profile_image": "https://lh3.googleusercontent.com/a/AGNmyxYpKm44_U7uYc5BSJF3FMj3b6NW0r6jcKBb8TUs=k-s256",
                    "display_name": "devlooper",
                    "link": "https://stackoverflow.com/users/21281486/devlooper"
                },
                "reply_to_user": {
                    "account_id": 13789219,
                    "reputation": 53538,
                    "user_id": 9952196,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/cd1a3f93172eb89e221c98e35e6e22b3?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Shawn",
                    "link": "https://stackoverflow.com/users/9952196/shawn"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1714706981,
                "post_id": 78422524,
                "comment_id": 138256831,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 39208,
                    "reputation": 267964,
                    "user_id": 112968,
                    "user_type": "registered",
                    "accept_rate": 68,
                    "profile_image": "https://i.sstatic.net/zHTaT.png?s=256",
                    "display_name": "knittl",
                    "link": "https://stackoverflow.com/users/112968/knittl"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1714721122,
                "post_id": 78422524,
                "comment_id": 138258058,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 39208,
                    "reputation": 267964,
                    "user_id": 112968,
                    "user_type": "registered",
                    "accept_rate": 68,
                    "profile_image": "https://i.sstatic.net/zHTaT.png?s=256",
                    "display_name": "knittl",
                    "link": "https://stackoverflow.com/users/112968/knittl"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1714721311,
                "post_id": 78422524,
                "comment_id": 138258095,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 32384,
                    "reputation": 127026,
                    "user_id": 89817,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/df253c3b6533949ea94f31f328f3e769?s=256&d=identicon&r=PG",
                    "display_name": "Gordon Davisson",
                    "link": "https://stackoverflow.com/users/89817/gordon-davisson"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1714752949,
                "post_id": 78422524,
                "comment_id": 138262767,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1714798697,
                "creation_date": 1714798697,
                "answer_id": 78427832,
                "question_id": 78422524,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "This should do the trick.\r\n\r\n```\r\n#!/bin/bash\r\n\r\nVPC_ID=vpc-05ae0495871281736\r\n\r\nNETWORK_INTERFACE=$(aws ec2 describe-network-interfaces --filters Name=vpc-id,Values=&quot;${VPC_ID}&quot; --output json | jq -r &#39;[.NetworkInterfaces[] | {AvailabilityZone, Description, Groups}]&#39;)\r\n\r\necho $NETWORK_INTERFACE\r\n```\r\n\r\nSubstitute your own value for `VPC_ID`.\r\n\r\nBased on your sample output I have filtered out the fields `AvailabilityZone`, `Description` and `Groups`.\r\n\r\nThe output from the script will just be a single line of valid JSON. You can prettify that by passing it through `jq .`.\r\n\r\nFor example:\r\n\r\n```\r\n[\r\n  {\r\n    &quot;AvailabilityZone&quot;: &quot;eu-west-2c&quot;,\r\n    &quot;Description&quot;: &quot;test&quot;,\r\n    &quot;Groups&quot;: [\r\n      {\r\n        &quot;GroupName&quot;: &quot;VNC&quot;,\r\n        &quot;GroupId&quot;: &quot;sg-030848ac470abe56f&quot;\r\n      }\r\n    ]\r\n  },\r\n  {\r\n    &quot;AvailabilityZone&quot;: &quot;eu-west-2c&quot;,\r\n    &quot;Description&quot;: &quot;&quot;,\r\n    &quot;Groups&quot;: [\r\n      {\r\n        &quot;GroupName&quot;: &quot;MOSH&quot;,\r\n        &quot;GroupId&quot;: &quot;sg-06dff26a1939d90d7&quot;\r\n      },\r\n      {\r\n        &quot;GroupName&quot;: &quot;http(s)&quot;,\r\n        &quot;GroupId&quot;: &quot;sg-048d4d5554f4a7da6&quot;\r\n      }\r\n    ]\r\n  }\r\n]\r\n\r\n```",
                "title": "export json output to environment variable missing commas in Bash"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1714939409,
        "creation_date": 1714706202,
        "last_edit_date": 1714939409,
        "question_id": 78422524,
        "body_markdown": "\r\n```\r\n[{\r\n&quot;Availab]ilityZone&quot;: &quot;ap-east-1a&quot; \r\n  &quot;Description&quot;: &quot;AWS_FOO&quot; \r\n  &quot;Groups&quot;: [\r\n    {\r\n      &quot;GroupName&quot;: &quot;AWS_FOO&quot; \r\n      &quot;GroupId&quot;: &quot;sg-AWS_FOO&quot;\r\n    } \r\n    {\r\n      &quot;GroupName&quot;: &quot;AWS_FOO&quot; \r\n      &quot;GroupId&quot;: &quot;sg-AWS_FOO&quot;\r\n    }\r\n  ] \r\n }\r\n {\r\n&quot;Availab]ilityZone&quot;: &quot;ap-east-1a&quot; \r\n  &quot;Description&quot;: &quot;AWAWS_FOOAWS_FOO&quot; \r\n  &quot;Groups&quot;: [\r\n    {\r\n      &quot;GroupName&quot;: &quot;AWS_FOO-eAWS_FOOAWS_FOO&quot; \r\n      &quot;GroupId&quot;: &quot;sAWS_FOO&quot;\r\n    } \r\n    {\r\n      &quot;GroupName&quot;: &quot;AWS_FOO&quot; \r\n      &quot;GroupId&quot;: &quot;AWS_FOO&quot;\r\n    }\r\n  ] \r\n}]\r\n```\r\n\r\nI am tring to write a automation script that required to use aws cli to find the values,\r\n\r\n```\r\nNETWORK_INTERFACE=$(aws ec2 describe-network-interfaces --filters Name=vpc-id,Values=&quot;${VPC_ID}&quot; --output json | jq -r &#39;.NetworkInterfaces[]&#39;)\r\n```\r\n\r\nHowever, when I echo $NETWORK_INTERFACE the output will missing all commas &quot;,&quot; , make it not a valid json format and cannot use jq to further action\r\n\r\n\r\nI tried using IFS, sed but the result is not what I expected\r\n\r\nMy expected output is valid json like\r\n\r\n```\r\n[{\r\n&quot;Availab]ilityZone&quot;: &quot;ap-east-1a&quot;,\r\n  &quot;Description&quot;: &quot;AWS_FOO&quot; ,\r\n  &quot;Groups&quot;: [\r\n    {\r\n      &quot;GroupName&quot;: &quot;AWS_FOO&quot; ,\r\n      &quot;GroupId&quot;: &quot;sg-AWS_FOO&quot;,\r\n    } ,\r\n    {\r\n      &quot;GroupName&quot;: &quot;AWS_FOO&quot; ,\r\n      &quot;GroupId&quot;: &quot;sg-AWS_FOO&quot;,\r\n    }\r\n  ]\r\n },\r\n {\r\n  &quot;Availab]ilityZone&quot;: &quot;ap-east-1a&quot;,\r\n  &quot;Description&quot;: &quot;AWAWS_FOOAWS_FOO&quot;,\r\n  &quot;Groups&quot;: [\r\n    {\r\n      &quot;GroupName&quot;: &quot;AWS_FOO-eAWS_FOOAWS_FOO&quot;,\r\n      &quot;GroupId&quot;: &quot;sAWS_FOO&quot;,\r\n    },\r\n    {\r\n      &quot;GroupName&quot;: &quot;AWS_FOO&quot;,\r\n      &quot;GroupId&quot;: &quot;AWS_FOO&quot;,\r\n    }\r\n  ] \r\n}]\r\n```",
        "link": "https://stackoverflow.com/questions/78422524/export-json-output-to-environment-variable-missing-commas-in-bash",
        "title": "export json output to environment variable missing commas in Bash"
    },
    {
        "tags": [
            "bash",
            "jenkins",
            "groovy",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 39208,
                    "reputation": 267964,
                    "user_id": 112968,
                    "user_type": "registered",
                    "accept_rate": 68,
                    "profile_image": "https://i.sstatic.net/zHTaT.png?s=256",
                    "display_name": "knittl",
                    "link": "https://stackoverflow.com/users/112968/knittl"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1714849835,
                "post_id": 78429844,
                "comment_id": 138270280,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 441603,
                    "reputation": 1395,
                    "user_id": 831785,
                    "user_type": "registered",
                    "accept_rate": 38,
                    "profile_image": "https://i.sstatic.net/kJvvy.jpg?s=256",
                    "display_name": "Mosbah",
                    "link": "https://stackoverflow.com/users/831785/mosbah"
                },
                "reply_to_user": {
                    "account_id": 39208,
                    "reputation": 267964,
                    "user_id": 112968,
                    "user_type": "registered",
                    "accept_rate": 68,
                    "profile_image": "https://i.sstatic.net/zHTaT.png?s=256",
                    "display_name": "knittl",
                    "link": "https://stackoverflow.com/users/112968/knittl"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1714850535,
                "post_id": 78429844,
                "comment_id": 138270331,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2435703,
                    "reputation": 27493,
                    "user_id": 2125671,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/13a492143ab4a2575b5a1f500691193c?s=256&d=identicon&r=PG",
                    "display_name": "Philippe",
                    "link": "https://stackoverflow.com/users/2125671/philippe"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1714863550,
                "post_id": 78429844,
                "comment_id": 138271175,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2032215,
                    "reputation": 6772,
                    "user_id": 1815577,
                    "user_type": "registered",
                    "accept_rate": 60,
                    "profile_image": "https://www.gravatar.com/avatar/ee78d71d8c39eaf0880a1e9ed7187a95?s=256&d=identicon&r=PG",
                    "display_name": "datawookie",
                    "link": "https://stackoverflow.com/users/1815577/datawookie"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1714886672,
                "post_id": 78429844,
                "comment_id": 138272134,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2032215,
                    "reputation": 6772,
                    "user_id": 1815577,
                    "user_type": "registered",
                    "accept_rate": 60,
                    "profile_image": "https://www.gravatar.com/avatar/ee78d71d8c39eaf0880a1e9ed7187a95?s=256&d=identicon&r=PG",
                    "display_name": "datawookie",
                    "link": "https://stackoverflow.com/users/1815577/datawookie"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1714887558,
                "post_id": 78429844,
                "comment_id": 138272178,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1714887484,
                "creation_date": 1714887484,
                "answer_id": 78431169,
                "question_id": 78429844,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Let&#39;s first establish that the `jq` command works.\r\n\r\n```\r\n#!/bin/bash\r\n\r\nURL=https://www.google.com\r\n\r\njq --arg url &quot;$URL&quot; &#39;.defaultOptions.environmentVariableEntries += [{&quot;key&quot;: &quot;URL&quot;, &quot;value&quot;: $url}]&#39; json.xctestplan\r\n```\r\n\r\nThe output is:\r\n\r\n```\r\n{\r\n  &quot;defaultOptions&quot;: {\r\n    &quot;environmentVariableEntries&quot;: [\r\n      {\r\n        &quot;key&quot;: &quot;OS_VERSION&quot;,\r\n        &quot;value&quot;: &quot;13&quot;\r\n      },\r\n      {\r\n        &quot;key&quot;: &quot;URL&quot;,\r\n        &quot;value&quot;: &quot;https://www.google.com&quot;\r\n      }\r\n    ]\r\n  }\r\n}\r\n```\r\n\r\nSo that appears to be doing what you want.\r\n\r\nI think I understand why you are wrapping your `jq` command in an `echo` command. Is that to allow you to redirect to the same file that you&#39;re reading from? Without the `echo` the input file would be truncated before reading commences.\r\n\r\nHow about updating your Jenkins command to something like this (untested):\r\n\r\n```\r\npipeline {\r\n    agent any\r\n    \r\n    environment {\r\n        URL = &#39;https://www.google.com&#39;\r\n    }\r\n    \r\n    stages {\r\n        stage(&#39;Update XCTestPlan&#39;) {\r\n            steps {\r\n                script {\r\n                    sh &quot;jq --arg url \\&quot;$URL\\&quot; &#39;.defaultOptions.environmentVariableEntries += [{\\&quot;key\\&quot;: \\&quot;URL\\&quot;, \\&quot;value\\&quot;: \\$url}]&#39; json.xctestplan &gt; json.xctestplan.tmp&quot;\r\n                    sh &quot;mv json.xctestplan.tmp json.xctestplan&quot;\r\n                }\r\n            }\r\n        }\r\n    }\r\n}\r\n```\r\n\r\nThat enables you to avoid using `echo` and so simplifies the quoting.\r\n\r\nAs a possible refinement you could combine the two `sh` commands using the `&amp;&amp;` operator.",
                "title": "Correctly escape environment variable to be used in Jenkins jq script"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -2,
        "last_activity_date": 1714887484,
        "creation_date": 1714843514,
        "question_id": 78429844,
        "body_markdown": "I have the following JSON:\r\n\r\n```\r\n{\r\n  &quot;defaultOptions&quot; : {\r\n    &quot;environmentVariableEntries&quot; : [\r\n      {\r\n        &quot;key&quot; : &quot;OS_VERSION&quot;,\r\n        &quot;value&quot; : &quot;13&quot;\r\n      }\r\n    ]\r\n  }\r\n}\r\n```\r\non Jenkins I have a step that writes some environment variables and in another step I need to insert those variables to `environmentVariableEntries` in the json above,\r\nhere is my code:\r\n```\r\nsh(script: &quot;echo \\$(jq --arg url \\&quot;$URL\\&quot; &#39;.defaultOptions.environmentVariableEntries += [{\\&quot;key\\&quot;: \\&quot;URL\\&quot;, \\&quot;value\\&quot;: \\$url}]&#39; json.xctestplan) &gt; json.xctestplan&quot;, returnStdout: true)\r\n```\r\nthis kind of works but have 2 issues:\r\n- it adds \\n to the end of the replaced URL\r\n- In some cases (special character ?) it throws:\r\n```\r\n++ jq --arg url &#39;https://redacted\r\n&#39; &#39;.defaultOptions.environmentVariableEntries += [{&quot;key&quot;: &quot;URL&quot;, &quot;value&quot;: [$url]}]&#39; json.xctestplan\r\njq: parse error: Invalid string: control characters from U+0000 through U+001F must be escaped at line 2, column 1\r\n+ echo\r\n```\r\n\r\nI tried to wrap the variable in [] without success.",
        "link": "https://stackoverflow.com/questions/78429844/correctly-escape-environment-variable-to-be-used-in-jenkins-jq-script",
        "title": "Correctly escape environment variable to be used in Jenkins jq script"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1715072988,
                "creation_date": 1715072988,
                "answer_id": 78441346,
                "question_id": 78441252,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can use `walk` to traverse the document, and update `|=` matching nodes (e.g. objects that have a `version` key) using a given filter (e.g. assigning the value of `.settings.image` to `.version`):\r\n\r\n```sh\r\nwalk(select(type == &quot;object&quot; and has(&quot;version&quot;)) |= (.version = .settings.image))\r\n```\r\n[Demo](https://jqplay.org/s/buuJaSKfHRE)",
                "title": "How to udpate a value in a nested and partly flattened object with jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1715072988,
        "creation_date": 1715071995,
        "question_id": 78441252,
        "body_markdown": "I need to override the property `version` with the value of `image`. The problem is, that the json document can have several forms, whereby parts of the nesting can be flattened:\r\n\r\n**Example Document 1**\r\n```json\r\n{\r\n  &quot;modulesContent&quot;: {\r\n    &quot;$edgeAgent&quot;: {\r\n      &quot;properties.desired.modules.event-bridge-redis&quot;: {\r\n        &quot;settings&quot;: {\r\n          &quot;image&quot;: &quot;redis:6.2.7&quot;,\r\n          &quot;createOptions&quot;: &quot;&quot;\r\n        },\r\n        &quot;type&quot;: &quot;docker&quot;,\r\n        &quot;status&quot;: &quot;running&quot;,\r\n        &quot;restartPolicy&quot;: &quot;always&quot;,\r\n        &quot;version&quot;: &quot;1.0&quot;\r\n      },\r\n      &quot;properties.desired.modules.event-bridge-metrics&quot;: {\r\n        &quot;settings&quot;: {\r\n          &quot;image&quot;: &quot;mcr.microsoft.com/azureiotedge-metrics-collector:1.19&quot;,\r\n          &quot;createOptions&quot;: &quot;&quot;\r\n        },\r\n        &quot;type&quot;: &quot;docker&quot;,\r\n        &quot;version&quot;: &quot;1.0&quot;,\r\n        &quot;status&quot;: &quot;running&quot;,\r\n        &quot;restartPolicy&quot;: &quot;always&quot;\r\n      }\r\n    },\r\n    &quot;$edgeHub&quot;: {\r\n    }\r\n  }\r\n}\r\n```\r\n\r\n**Example document 2**\r\n```json\r\n{\r\n  &quot;modulesContent&quot;: {\r\n    &quot;$edgeAgent&quot;: {\r\n      &quot;properties.desired.modules&quot;: {\r\n        &quot;event-bridge-redis&quot;: {\r\n          &quot;settings&quot;: {\r\n            &quot;image&quot;: &quot;redis:6.2.7&quot;,\r\n            &quot;createOptions&quot;: &quot;&quot;\r\n          },\r\n          &quot;type&quot;: &quot;docker&quot;,\r\n          &quot;status&quot;: &quot;running&quot;,\r\n          &quot;restartPolicy&quot;: &quot;always&quot;,\r\n          &quot;version&quot;: &quot;1.0&quot;\r\n        },\r\n        &quot;event-bridge-metrics&quot;: {\r\n          &quot;settings&quot;: {\r\n            &quot;image&quot;: &quot;mcr.microsoft.com/azureiotedge-metrics-collector:1.19&quot;,\r\n            &quot;createOptions&quot;: &quot;&quot;\r\n          },\r\n          &quot;type&quot;: &quot;docker&quot;,\r\n          &quot;version&quot;: &quot;1.0&quot;,\r\n          &quot;status&quot;: &quot;running&quot;,\r\n          &quot;restartPolicy&quot;: &quot;always&quot;\r\n        }\r\n      }\r\n    },\r\n    &quot;$edgeHub&quot;: {\r\n    }\r\n  }\r\n}\r\n```\r\n\r\n**Expected output of Example Document 1**\r\n```json\r\n{\r\n  &quot;modulesContent&quot;: {\r\n    &quot;$edgeAgent&quot;: {\r\n      &quot;properties.desired.modules.event-bridge-redis&quot;: {\r\n        &quot;settings&quot;: {\r\n          &quot;image&quot;: &quot;redis:6.2.7&quot;,\r\n          &quot;createOptions&quot;: &quot;&quot;\r\n        },\r\n        &quot;type&quot;: &quot;docker&quot;,\r\n        &quot;status&quot;: &quot;running&quot;,\r\n        &quot;restartPolicy&quot;: &quot;always&quot;,\r\n        &quot;version&quot;: &quot;redis:6.2.7&quot;\r\n      },\r\n      &quot;properties.desired.modules.event-bridge-metrics&quot;: {\r\n        &quot;settings&quot;: {\r\n          &quot;image&quot;: &quot;mcr.microsoft.com/azureiotedge-metrics-collector:1.19&quot;,\r\n          &quot;createOptions&quot;: &quot;&quot;\r\n        },\r\n        &quot;type&quot;: &quot;docker&quot;,\r\n        &quot;version&quot;: &quot;mcr.microsoft.com/azureiotedge-metrics-collector:1.19&quot;,\r\n        &quot;status&quot;: &quot;running&quot;,\r\n        &quot;restartPolicy&quot;: &quot;always&quot;\r\n      }\r\n    },\r\n    &quot;$edgeHub&quot;: {\r\n    }\r\n  }\r\n}\r\n```\r\n\r\n**Expected output of Example document 2**\r\n```json\r\n{\r\n  &quot;modulesContent&quot;: {\r\n    &quot;$edgeAgent&quot;: {\r\n      &quot;properties.desired.modules&quot;: {\r\n        &quot;event-bridge-redis&quot;: {\r\n          &quot;settings&quot;: {\r\n            &quot;image&quot;: &quot;redis:6.2.7&quot;,\r\n            &quot;createOptions&quot;: &quot;&quot;\r\n          },\r\n          &quot;type&quot;: &quot;docker&quot;,\r\n          &quot;status&quot;: &quot;running&quot;,\r\n          &quot;restartPolicy&quot;: &quot;always&quot;,\r\n          &quot;version&quot;: &quot;redis:6.2.7&quot;\r\n        },\r\n        &quot;event-bridge-metrics&quot;: {\r\n          &quot;settings&quot;: {\r\n            &quot;image&quot;: &quot;mcr.microsoft.com/azureiotedge-metrics-collector:1.19&quot;,\r\n            &quot;createOptions&quot;: &quot;&quot;\r\n          },\r\n          &quot;type&quot;: &quot;docker&quot;,\r\n          &quot;version&quot;: &quot;mcr.microsoft.com/azureiotedge-metrics-collector:1.19&quot;,\r\n          &quot;status&quot;: &quot;running&quot;,\r\n          &quot;restartPolicy&quot;: &quot;always&quot;\r\n        }\r\n      }\r\n    },\r\n    &quot;$edgeHub&quot;: {\r\n    }\r\n  }\r\n}\r\n```\r\n\r\nIs it possible to define a single jq query, which can handle several forms of nesting (from a flat form to a nested form) and so, that the form of the input is also preserved in the output?",
        "link": "https://stackoverflow.com/questions/78441252/how-to-udpate-a-value-in-a-nested-and-partly-flattened-object-with-jq",
        "title": "How to udpate a value in a nested and partly flattened object with jq?"
    },
    {
        "tags": [
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 39208,
                    "reputation": 267964,
                    "user_id": 112968,
                    "user_type": "registered",
                    "accept_rate": 68,
                    "profile_image": "https://i.sstatic.net/zHTaT.png?s=256",
                    "display_name": "knittl",
                    "link": "https://stackoverflow.com/users/112968/knittl"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1715583664,
                "post_id": 78446017,
                "comment_id": 138340324,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1715141654,
                "last_edit_date": 1715141654,
                "creation_date": 1715141123,
                "answer_id": 78446041,
                "question_id": 78446017,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "`true` cannot have a key `message`, so `.message?` returns nothing, and neither branch is executed. See for example https://stackoverflow.com/questions/69214919/why-is-jq-modify-and-if-then-else-not-working\r\n\r\nInstead, you can check to ensure that `.` is an `object`, as well as checking for the existence of the key, with `if type == &quot;object&quot; and .message?`. As shown below, this returns &quot;X&quot; only if the `message` key exists, and &quot;y&quot; if there is no `message` key, or if the value isn&#39;t an object.\r\n\r\n```\r\n\r\n$&#160;jq &#39;.value|if type == &quot;object&quot; and .message? then &quot;X&quot; else &quot;Y&quot; end&#39; &lt;&lt;&lt; &#39;{&quot;value&quot;:true}&#39;\r\n&quot;Y&quot;\r\n$&#160;jq &#39;.value|if type == &quot;object&quot; and .message? then &quot;X&quot; else &quot;Y&quot; end&#39; &lt;&lt;&lt; &#39;{&quot;value&quot;:{&quot;message&quot;: true}}&#39;\r\n&quot;X&quot;\r\n$&#160;jq &#39;.value|if type == &quot;object&quot; and .message? then &quot;X&quot; else &quot;Y&quot; end&#39; &lt;&lt;&lt; &#39;{&quot;value&quot;:{&quot;notmessage&quot;: true}}&#39;\r\n&quot;Y&quot;\r\n```",
                "title": "Why neither branch of if-statement is reached?"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1715580793,
                "creation_date": 1715580793,
                "answer_id": 78470359,
                "question_id": 78446017,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Use try/catch instead with `--arg` and `getpath`\r\n\r\n```sh\r\nJSON_SIMPLE=&#39;{&quot;value&quot;:true}&#39;\r\nJSON_NESTED=&#39;{&quot;value&quot;: {&quot;message&quot;: true}}&#39;\r\nJSON_EXPR=&#39;(if (getpath($fields|split(&quot;.&quot;))? != null) then &quot;X&quot; else &quot;Y&quot; end) // &quot;Y&quot;&#39;\r\n```\r\n\r\n```sh\r\necho &#39;{&quot;value&quot;:true}&#39; | \r\njq --arg fields value.message \\\r\n  &#39;(if (getpath($fields|split(&quot;.&quot;))? != null) then &quot;X&quot; else &quot;Y&quot; end) // &quot;Y&quot;&#39;\r\n```\r\n\r\n```console\r\n$ jq --arg fields value.message &quot;$JSON_EXPR&quot; &lt;&lt;&lt;&quot;$JSON_SIMPLE&quot;\r\n&quot;Y&quot;\r\n\r\n$ jq --arg fields value.doesnotexist &quot;$JSON_EXPR&quot; &lt;&lt;&lt;&quot;$JSON_SIMPLE&quot;\r\n&quot;Y&quot;\r\n\r\n$ jq --arg fields value.message &quot;$JSON_EXPR&quot; &lt;&lt;&lt;&quot;$JSON_NESTED&quot;                        \r\n&quot;X&quot;\r\n\r\n$ jq --arg fields value.doesnotexist &quot;$JSON_EXPR&quot; &lt;&lt;&lt;&quot;$JSON_NESTED&quot;\r\n&quot;Y&quot;\r\n```",
                "title": "Why neither branch of if-statement is reached?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 2,
        "last_activity_date": 1715580793,
        "creation_date": 1715140245,
        "question_id": 78446017,
        "body_markdown": "Since `.value` is `true`, which does not have an field `message`, I thought `.message?` should be evaluated to `false`. Then &quot;Y&quot; should be printed. Can you help me understand why neither &quot;X&quot; nor &quot;Y&quot; is printed?\r\n\r\n```\r\n$ jq &#39;.value|if .message? then &quot;X&quot; else &quot;Y&quot; end&#39; &lt;&lt;&lt; &#39;{&quot;value&quot;:true}&#39;\r\n```\r\n\r\nHow to revise the code so that if &quot;message&quot; is a field of the value of `.value`, then print &quot;X&quot;, otherwise print &quot;Y&quot;?",
        "link": "https://stackoverflow.com/questions/78446017/why-neither-branch-of-if-statement-is-reached",
        "title": "Why neither branch of if-statement is reached?"
    },
    {
        "tags": [
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 39208,
                    "reputation": 267964,
                    "user_id": 112968,
                    "user_type": "registered",
                    "accept_rate": 68,
                    "profile_image": "https://i.sstatic.net/zHTaT.png?s=256",
                    "display_name": "knittl",
                    "link": "https://stackoverflow.com/users/112968/knittl"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1716297169,
                "post_id": 78447656,
                "comment_id": 138412723,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 39208,
                    "reputation": 267964,
                    "user_id": 112968,
                    "user_type": "registered",
                    "accept_rate": 68,
                    "profile_image": "https://i.sstatic.net/zHTaT.png?s=256",
                    "display_name": "knittl",
                    "link": "https://stackoverflow.com/users/112968/knittl"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1716297317,
                "post_id": 78447656,
                "comment_id": 138412746,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1716297288,
                "creation_date": 1716297288,
                "answer_id": 78512139,
                "question_id": 78447656,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "It&#39;s not really possible, unless you recompile jq. The closest I can offer is the following, but you don&#39;t have access to the original error message:\r\n\r\n```\r\njq -R &#39;try fromjson catch error(&quot;my custom error&quot;)&#39;\r\n```",
                "title": "How to control jq error message when input is not valid json?"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1717693816,
                "creation_date": 1717693816,
                "answer_id": 78588157,
                "question_id": 78447656,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Assuming you are running from a bash shell, you could capture the error output and process it any way you want. In the example below I am putting &quot;xxx:&quot; in front of every line and sending the output to standard error:\r\n```\r\njq . &lt;&lt;&lt; &quot;invalid json&quot; 2&gt; tmpfile.$$\r\nsed -e &#39;s/\\(.*\\)/xxx:\\1/&#39; &lt; tmpfile.$$ 1&gt;&amp;2 \r\nrm -f tmpfile.$$\r\n```\r\n\r\n",
                "title": "How to control jq error message when input is not valid json?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1717693816,
        "creation_date": 1715162602,
        "question_id": 78447656,
        "body_markdown": "`jq` prints error message like the following when the input is invalid.\r\n\r\n```\r\n$ jq . &lt;&lt;&lt; &quot;xxx&quot;\r\nparse error: Invalid numeric literal at line 2, column 0\r\n```\r\n\r\nI want to control what is printed when the input json is not valid. For example, I may want to prepend something to the original error message. How can I achieve this with jq?\r\n\r\n```\r\nXXX:parse error: Invalid numeric literal at line 2, column 0\r\n```",
        "link": "https://stackoverflow.com/questions/78447656/how-to-control-jq-error-message-when-input-is-not-valid-json",
        "title": "How to control jq error message when input is not valid json?"
    },
    {
        "tags": [
            "github-actions",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 10402418,
                    "reputation": 14920,
                    "user_id": 7670262,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/3zdDY.jpg?s=256",
                    "display_name": "Azeem",
                    "link": "https://stackoverflow.com/users/7670262/azeem"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1715188145,
                "post_id": 78450153,
                "comment_id": 138305802,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 28907243,
                    "reputation": 13,
                    "user_id": 22141037,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/8cf7aa54c2ab5db54de5bca6199b4036?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "ASpaceWorm",
                    "link": "https://stackoverflow.com/users/22141037/aspaceworm"
                },
                "reply_to_user": {
                    "account_id": 10402418,
                    "reputation": 14920,
                    "user_id": 7670262,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/3zdDY.jpg?s=256",
                    "display_name": "Azeem",
                    "link": "https://stackoverflow.com/users/7670262/azeem"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1715188825,
                "post_id": 78450153,
                "comment_id": 138305897,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 10402418,
                    "reputation": 14920,
                    "user_id": 7670262,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/3zdDY.jpg?s=256",
                    "display_name": "Azeem",
                    "link": "https://stackoverflow.com/users/7670262/azeem"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1715218793,
                "post_id": 78450153,
                "comment_id": 138308875,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1715331462,
                "last_edit_date": 1715331462,
                "creation_date": 1715330737,
                "answer_id": 78458977,
                "question_id": 78450153,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "When you expand variables like this in a shell script in Github Actions, they are fully interpreted by the shell as if you had typed in those characters.\r\n\r\n```\r\n      #substitute production appsettings entries to temp json file\r\n      - name: App Settings Variable Substitution\r\n        shell: bash\r\n        run: | \r\n           cat ${{env.DOTNET_ROOT}}/myapp/appsettings.json | jq --arg my_secret ${{secrets.SQL_CONNECTION_STRING}} --arg email_secret ${{secrets.EMAIL_PASSWORD}} &#39;.Config.SiteDb = $my_secret | .Config.EmailPassword = $email_secret&#39; &gt; newfile.json\r\n```\r\nThis means that any characters in the variable that might be interpreted by the shell will cause problems:\r\n* Spaces will cause there to be multiple arguments instead of one.\r\n* Quote characters may be treated by the shell as the start or end of a quoted block rather than themselves, and radically changing the interpretation of the rest of the line.\r\n* Backslashes may be treated as escape characters.\r\n* `&gt;` and `&lt;` may be treated as redirections.\r\n* `|` may be treated as pipeline steps.\r\n* ...and many more.\r\n\r\nYour example will behave differently depending on what characters happen to be in the password.\r\n\r\n_If_ you can guarantee that the string contains no single quotes, you can wrap single quotes around it.\r\n\r\nA better alternative in most cases is to introduce environment variables. So, try something like this:\r\n\r\n```\r\n      #substitute production appsettings entries to temp json file\r\n      - name: App Settings Variable Substitution\r\n        shell: bash\r\n        run: | \r\n           cat ${{env.DOTNET_ROOT}}/myapp/appsettings.json | jq --arg my_secret &quot;$SQL_CONNECTION_STRING&quot; --arg email_secret &quot;$EMAIL_PASSWORD&quot; &#39;.Config.SiteDb = $my_secret | .Config.EmailPassword = $email_secret&#39; &gt; newfile.json\r\n        env:\r\n          SQL_CONNECTION_STRING: ${{secrets.SQL_CONNECTION_STRING}}\r\n          EMAIL_PASSWORD: ${{secrets.EMAIL_PASSWORD}}\r\n```\r\n\r\nThis time, the expansion `&quot;$SQL_CONNECTION_STRING&quot;` is done by the _shell_ and not by GHA, so it won&#39;t reinterpret the contents of the string as shell characters. (The expansions in the `env` block are just producing plain strings that are not processed by the shell, they are just inserted in the environment variables as-is.)\r\n\r\nOne downside of this is that the environment variables are visible to every process started in the shell. If this is unacceptable, you could start your script by using bash&#39;s `export -n VARIABLENAME` to remove those variables from the environment while keeping them as shell variables.",
                "title": "Github Actions not recognizing jq with --arg"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1715331462,
        "creation_date": 1715187825,
        "question_id": 78450153,
        "body_markdown": "I have a workflow that looks like the following:\r\n\r\n\r\n```\r\nname: Site - Build and Deploy FTP\r\n\r\non:\r\n  push:\r\n    branches: main\r\n    paths:\r\n      - &#39;src/Site/Site/**&#39;\r\n  workflow_dispatch:\r\n\r\njobs:\r\n  build:\r\n    runs-on: ubuntu-latest\r\n\r\n    steps:\r\n      - uses: actions/checkout@v4.1.4\r\n      \r\n      - name: Setup .NET Core\r\n        uses: actions/setup-dotnet@v4\r\n        with:\r\n          dotnet-version: &#39;6.0.x&#39;\r\n          include-prerelease: true\r\n          \r\n      - name: Install dependencies\r\n        working-directory: src/Site/Site\r\n        run: dotnet restore\r\n        \r\n      - name: Build with dotnet\r\n        working-directory: src/Site/Site\r\n        run: dotnet build --configuration Release\r\n        \r\n      - name: Publish\r\n        working-directory: src/Site/Site\r\n        run: dotnet publish -c Release -o ${{env.DOTNET_ROOT}}/myapp\r\n        \r\n      #substitute production appsettings entries to temp json file\r\n      - name: App Settings Variable Substitution\r\n        shell: bash\r\n        run: | \r\n           cat ${{env.DOTNET_ROOT}}/myapp/appsettings.json | jq --arg my_secret ${{secrets.SQL_CONNECTION_STRING}} --arg email_secret ${{secrets.EMAIL_PASSWORD}} &#39;.Config.SiteDb = $my_secret | .Config.EmailPassword = $email_secret&#39; &gt; newfile.json\r\n\r\n```\r\nIt was working up until two weeks ago when it started failing on the substitute appsettings step.  The weird part is that I didn&#39;t change anything in the workflow. Also, I have a nearly identical workflow for another portion of the project which succeeds every time(the only difference in the .yml files is that it runs on a different project and subs out different settings from its own appsettings.json file.) Generally it will fails with a 127 error code, but the cat command will write the appsettings.json file to the console, so it is finding that file properly, so it must be the jq command it is having a problem with.\r\n\r\nI tried removing the --arg options and substitution filters and replacing it with just &quot;jq &#39;.&#39;&quot; and that succeeds just fine. Then, I tried just doing &quot;jq &#39;.Config.SiteDb = 5 | .Config.EmailPassword = 9&#39; and that succeeds. So it seems like something with --arg is messing up on this particular runner?",
        "link": "https://stackoverflow.com/questions/78450153/github-actions-not-recognizing-jq-with-arg",
        "title": "Github Actions not recognizing jq with --arg"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq",
            "export-to-csv"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1715282045,
                "creation_date": 1715282045,
                "answer_id": 78456552,
                "question_id": 78456512,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Save the `.date`, and re-use it once traversed down into `.results`, either by using a variable ([Demo](https://jqplay.org/s/tUs6U_dOXA-)), or by concatenating with another filter ([Demo](https://jqplay.org/s/fiJlR0vmNAj)).\r\n```sh\r\njq -r &#39;.[] | . as {$date} | .results[] | [$date, .[]] | @csv&#39;\r\n# or\r\njq -r &#39;.[] | [.date] + (.results[] | [.[]]) | @csv&#39;\r\n```\r\n```\r\n&quot;date1&quot;,&quot;string11&quot;,&quot;string12&quot;,&quot;string13&quot;\r\n&quot;date1&quot;,&quot;string21&quot;,&quot;string22&quot;,&quot;string23&quot;\r\n&quot;date2&quot;,&quot;string11&quot;,&quot;string12&quot;,&quot;string13&quot;\r\n&quot;date2&quot;,&quot;string21&quot;,&quot;string22&quot;,&quot;string23&quot;\r\n```\r\nReplace the latter `.[]` with `.field1, .field2, .field3` to be explicit.\r\n",
                "title": "Using jq to parse multilevel json"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1715294058,
        "creation_date": 1715281716,
        "last_edit_date": 1715294058,
        "question_id": 78456512,
        "body_markdown": "I&#39;m trying to parse a JSON file that look like this:\r\n\r\n```lang-json\r\n[\r\n  {\r\n    &quot;date&quot;:&quot;date1&quot;,\r\n    &quot;results&quot;:\r\n      [  \r\n        {\r\n            &quot;field1&quot;:&quot;string11&quot;,\r\n            &quot;field2&quot;:&quot;string12&quot;,\r\n            &quot;field3&quot;:&quot;string13&quot;,\r\n        },\r\n        {\r\n            &quot;field1&quot;:&quot;string21&quot;,\r\n            &quot;field2&quot;:&quot;string22&quot;,\r\n            &quot;field3&quot;:&quot;string23&quot;,\r\n        }\r\n      ]\r\n  },\r\n  {\r\n    &quot;date&quot;:&quot;date2&quot;,\r\n    &quot;results&quot;:\r\n      [  \r\n        {\r\n            &quot;field1&quot;:&quot;string11&quot;,\r\n            &quot;field2&quot;:&quot;string12&quot;,\r\n            &quot;field3&quot;:&quot;string13&quot;,\r\n        },\r\n        {\r\n            &quot;field1&quot;:&quot;string21&quot;,\r\n            &quot;field2&quot;:&quot;string22&quot;,\r\n            &quot;field3&quot;:&quot;string23&quot;,\r\n        }\r\n      ]\r\n  }\r\n]\r\n\r\n```\r\nand I would like an output like this:\r\n\r\n\r\n```lang-csv\r\n08/05/2024,string11,string12,string13\r\n08/05/2024,string21,string22,string23\r\n09/05/2024,string11,string12,string13\r\n09/05/2024,string21,string22,string23\r\n```\r\n\r\n\r\nI tried:\r\n\r\n```lang-bash\r\njq -Mr &#39;.. | objects | select(has(&quot;field1&quot;)) | [.field1, .field2, .field3,] | @csv&#39; file.json\r\n```\r\n\r\nand got:\r\n\r\n```lang-csv\r\nstring11,string12,string13\r\nstring21,string22,string23\r\nstring11,string12,string13\r\nstring21,string22,string23\r\n```\r\n\r\nand tried:\r\n\r\n```lang-bash\r\njq -r &#39;.[] | [.date, .results[].field1, .results[].field2, .results[].field3] | @csv&#39; file.json\r\n```\r\n\r\nand got only the first line:\r\n\r\n```lang-csv\r\ndate1,string11,string12,string13\r\ndate2,string11,string12,string13\r\n```\r\n\r\nand I would like to have:\r\n\r\n```lang-csv\r\ndate1,string11,string12,string13\r\ndate1,string21,string22,string23\r\ndate2,string11,string12,string13\r\ndate2,string21,string22,string23\r\n```",
        "link": "https://stackoverflow.com/questions/78456512/using-jq-to-parse-multilevel-json",
        "title": "Using jq to parse multilevel json"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 289134,
                    "reputation": 389369,
                    "user_id": 589924,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/b2cf53d5a3d25f95c0db4e025aed4153?s=256&d=identicon&r=PG",
                    "display_name": "ikegami",
                    "link": "https://stackoverflow.com/users/589924/ikegami"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1715623143,
                "post_id": 78462479,
                "comment_id": 138346686,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1715379270,
                "creation_date": 1715379270,
                "answer_id": 78462737,
                "question_id": 78462479,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Either use the [Go implementation of jq](https://github.com/itchyny/gojq), which can parse `%z` correctly:\r\n```\r\ngojq &#39;\r\n  map(select(\r\n    .created_at | sub(&quot;\\\\.[0-9]+&quot;; &quot;&quot;)\r\n    | strptime(&quot;%FT%T%z&quot;) | now - mktime &lt;= 300\r\n  ))\r\n&#39;\r\n```\r\n\r\nOr manually interpret the (numeric) timezone (as `(+|-)HH[:]MM`), and do the math:\r\n```sh\r\nmap(select(\r\n  .created_at | sub(&quot;\\\\.[0-9]+&quot;; &quot;&quot;)\r\n  | ( capture(&quot;.{19}(?&lt;d&gt;[+-])(?&lt;h&gt;[0-9]{2}):?(?&lt;m&gt;[0-9]{2})&quot;)\r\n      | .d += &quot;1&quot; | .[] |= tonumber\r\n    ) as $tz\r\n  | strptime(&quot;%FT%T%z&quot;) | .[3] -= $tz.d * $tz.h | .[4] -= $tz.d * $tz.m\r\n  | now - mktime &lt;= 300\r\n))\r\n```",
                "title": "JQ - Using a non UTC date field and looking back a certain amount of time"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1715379270,
        "creation_date": 1715374057,
        "last_edit_date": 1715375617,
        "question_id": 78462479,
        "body_markdown": "I am trying to write a BASH+jq one liner to only return the entries that are less than 5 minutes old as I am writing automation to only look back 5 minutes (BASH).  Using the following JSON:\r\n\r\n```json\r\n[\r\n  {\r\n    &quot;id&quot;: 621024,\r\n    &quot;iid&quot;: 99999,\r\n    &quot;project_id&quot;: 999,\r\n    &quot;sha&quot;: &quot;faf897sd98fa987afsd98f7&quot;,\r\n    &quot;ref&quot;: &quot;master&quot;,\r\n    &quot;status&quot;: &quot;running&quot;,\r\n    &quot;source&quot;: &quot;push&quot;,\r\n    &quot;created_at&quot;: &quot;2024-05-10T16:32:01.072-04:00&quot;,\r\n    &quot;updated_at&quot;: &quot;2024-05-10T16:32:03.565-04:00&quot;,\r\n    &quot;web_url&quot;: &quot;https://gitlab/pipelines/9999&quot;,\r\n    &quot;name&quot;: null\r\n  },\r\n  {\r\n    &quot;id&quot;: 621023,\r\n    &quot;iid&quot;: 99999,\r\n    &quot;project_id&quot;: 999,\r\n    &quot;sha&quot;: &quot;faf897sd98fa987afsd98f7&quot;,\r\n    &quot;ref&quot;: &quot;master&quot;,\r\n    &quot;status&quot;: &quot;success&quot;,\r\n    &quot;source&quot;: &quot;push&quot;,\r\n    &quot;created_at&quot;: &quot;2024-05-10T16:31:47.951-04:00&quot;,\r\n    &quot;updated_at&quot;: &quot;2024-05-10T16:35:30.362-04:00&quot;,\r\n    &quot;web_url&quot;: &quot;https://gitlab/pipelines/9999&quot;,\r\n    &quot;name&quot;: null\r\n  },\r\n  {\r\n    &quot;id&quot;: 621020,\r\n    &quot;iid&quot;: 99999,\r\n    &quot;project_id&quot;: 999,\r\n    &quot;sha&quot;: &quot;faf897sd98fa987afsd98f7&quot;,\r\n    &quot;ref&quot;: &quot;master&quot;,\r\n    &quot;status&quot;: &quot;waiting_for_resource&quot;,\r\n    &quot;source&quot;: &quot;push&quot;,\r\n    &quot;created_at&quot;: &quot;2024-05-10T15:27:00.248-04:00&quot;,\r\n    &quot;updated_at&quot;: &quot;2024-05-10T15:30:14.172-04:00&quot;,\r\n    &quot;web_url&quot;: &quot;https://gitlab/pipelines/9999&quot;,\r\n    &quot;name&quot;: null\r\n  },\r\n  {\r\n    &quot;id&quot;: 621019,\r\n    &quot;iid&quot;: 99999,\r\n    &quot;project_id&quot;: 999,\r\n    &quot;sha&quot;: &quot;faf897sd98fa987afsd98f7&quot;,\r\n    &quot;ref&quot;: &quot;master&quot;,\r\n    &quot;status&quot;: &quot;success&quot;,\r\n    &quot;source&quot;: &quot;push&quot;,\r\n    &quot;created_at&quot;: &quot;2024-05-10T14:26:02.235-04:00&quot;,\r\n    &quot;updated_at&quot;: &quot;2024-05-10T14:29:45.406-04:00&quot;,\r\n    &quot;web_url&quot;: &quot;https://gitlab/pipelines/9999&quot;,\r\n    &quot;name&quot;: null\r\n  }\r\n]\r\n```\r\n\r\nMy challenge is that the date being returned for `created_at` is in EST\r\n\r\nI have been trying to use some of the traditional time functions/tools with jq but dont think its working because they expect the date to check against to be in UTC\r\n\r\nI know I can take off the milliseconds using something like \r\n\r\n`jq  &#39;.[] | .created_at |= .[0:19]&#39;`\r\n\r\nBut that still leaves me with a timestamp that is in EST. \r\n\r\n`&quot;created_at&quot;: &quot;2024-05-10T15:27:00&quot;`\r\n\r\nAll the documentation I read talks about needing the date to be in ISO 8601 to be parsable with some of date/time functions.  I dont know what to add to my jq that would subtract only selecting the entries that are less than 5 minutes old\r\n\r\nThis query fails:\r\n\r\n`jq  &#39;.[] | .created_at |= .[0:19] | select(.created_at | fromdate - 300)&#39;`\r\n\r\nwith error\r\n\r\n`jq: error (at &lt;stdin&gt;:55): date &quot;2024-05-10T16:32:01&quot; does not match format &quot;%Y-%m-%dT%H:%M:%SZ&quot;`\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/78462479/jq-using-a-non-utc-date-field-and-looking-back-a-certain-amount-of-time",
        "title": "JQ - Using a non UTC date field and looking back a certain amount of time"
    },
    {
        "tags": [
            "json",
            "append",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1715376578,
                "post_id": 78462605,
                "comment_id": 138326650,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1333474,
                    "reputation": 6585,
                    "user_id": 3503228,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/yIJbY.jpg?s=256",
                    "display_name": "Porcupine",
                    "link": "https://stackoverflow.com/users/3503228/porcupine"
                },
                "reply_to_user": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1715376714,
                "post_id": 78462605,
                "comment_id": 138326663,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1715376770,
                "post_id": 78462605,
                "comment_id": 138326669,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1333474,
                    "reputation": 6585,
                    "user_id": 3503228,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/yIJbY.jpg?s=256",
                    "display_name": "Porcupine",
                    "link": "https://stackoverflow.com/users/3503228/porcupine"
                },
                "reply_to_user": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1715376796,
                "post_id": 78462605,
                "comment_id": 138326671,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1333474,
                    "reputation": 6585,
                    "user_id": 3503228,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/yIJbY.jpg?s=256",
                    "display_name": "Porcupine",
                    "link": "https://stackoverflow.com/users/3503228/porcupine"
                },
                "reply_to_user": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1715382402,
                "post_id": 78462605,
                "comment_id": 138327066,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1715384932,
                "post_id": 78462605,
                "comment_id": 138327262,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1715378449,
                "creation_date": 1715378449,
                "answer_id": 78462693,
                "question_id": 78462605,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "As suggested by @pmf in the comments\r\n\r\n```\r\n$ Date=$(date +%Y-%m-%d)\r\n$ jq &#39;pick(.id,.title,.webpage_url,.channel,.duration_string,.upload_date)&#39; *.info.json \\\r\n  | jq --arg Date=&quot;$Date&quot; &#39;. += {&quot;date&quot;: $Date}&#39;\r\n```\r\n\r\n- Building upon above suggestion, following is more concise\r\n\r\n```\r\njq --arg Date &quot;$Date&quot; &#39;pick(.id,.title,.webpage_url,.channel,.duration_string,.upload_date) + {&quot;date&quot;: $Date}&#39; *.info.json\r\n```",
                "title": "jq - Append element after picking"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1715378449,
        "creation_date": 1715376203,
        "last_edit_date": 1715376663,
        "question_id": 78462605,
        "body_markdown": "# System Information\r\n\r\njq: 1.7\r\n\r\n# Pick\r\n\r\n- Following command works correctly as expected:\r\n\r\n```\r\njq &#39;pick(.id,.title,.webpage_url,.channel,.duration_string,.upload_date)&#39; *.info.json\r\n```\r\n\r\n```json\r\n{\r\n  &quot;id&quot;: &quot;uO8Sn0Xch1s&quot;,\r\n  &quot;title&quot;: &quot;A transformative new way of classifying foods &#127828;&#127829;&#127839; BBC&quot;,\r\n  &quot;webpage_url&quot;: &quot;https://www.youtube.com/watch?v=uO8Sn0Xch1s&quot;,\r\n  &quot;channel&quot;: &quot;BBC&quot;,\r\n  &quot;duration_string&quot;: &quot;4:19&quot;,\r\n  &quot;upload_date&quot;: &quot;20210701&quot;\r\n}\r\n```\r\n\r\n# Pick and Append\r\n\r\n```\r\n$ Date=$(date +%Y-%m-%d)\r\n$ jq &#39;pick(.id,.title,.webpage_url,.channel,.duration_string,.upload_date)&#39; *.info.json \\\r\n  | jq --arg Date=&quot;$Date&quot; &#39;. += {&quot;date&quot;: $Date}&#39;\r\n```\r\n\r\n```json\r\n{\r\n  &quot;id&quot;: &quot;uO8Sn0Xch1s&quot;,\r\n  &quot;title&quot;: &quot;A transformative new way of classifying foods &#127828;&#127829;&#127839; BBC&quot;,\r\n  &quot;webpage_url&quot;: &quot;https://www.youtube.com/watch?v=uO8Sn0Xch1s&quot;,\r\n  &quot;channel&quot;: &quot;BBC&quot;,\r\n  &quot;duration_string&quot;: &quot;4:19&quot;,\r\n  &quot;upload_date&quot;: &quot;20210701&quot;\r\n}\r\n```\r\n\r\n# Issue\r\n\r\n1. Pick and Append produces same output as Pick and is not appending date. Why and how can I correct this?\r\n2. also tried + instead of +=, both didn&#39;t work (but should work as per Reference 2)\r\n\r\n## Expected Output\r\n\r\n```json\r\n{\r\n  &quot;id&quot;: &quot;uO8Sn0Xch1s&quot;,\r\n  &quot;title&quot;: &quot;A transformative new way of classifying foods &#127828;&#127829;&#127839; BBC&quot;,\r\n  &quot;webpage_url&quot;: &quot;https://www.youtube.com/watch?v=uO8Sn0Xch1s&quot;,\r\n  &quot;channel&quot;: &quot;BBC&quot;,\r\n  &quot;duration_string&quot;: &quot;4:19&quot;,\r\n  &quot;upload_date&quot;: &quot;20210701&quot;,\r\n  &quot;date&quot;: &quot;2024-05-10&quot;\r\n}\r\n```\r\n\r\n# Reference\r\n\r\n- [How to add a field to a JSON object with the jq command? - Stack Overflow](https://stackoverflow.com/questions/49632521/how-to-add-a-field-to-a-json-object-with-the-jq-command)\r\n- [Add new element to existing JSON array with jq - Stack Overflow](https://stackoverflow.com/questions/42245288/add-new-element-to-existing-json-array-with-jq)",
        "link": "https://stackoverflow.com/questions/78462605/jq-append-element-after-picking",
        "title": "jq - Append element after picking"
    },
    {
        "tags": [
            "json",
            "jq",
            "quotes",
            "fromjson"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 374049,
                    "reputation": 15207,
                    "user_id": 724039,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/NsCwt.png?s=256",
                    "display_name": "Luuk",
                    "link": "https://stackoverflow.com/users/724039/luuk"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1715443596,
                "post_id": 78465261,
                "comment_id": 138331003,
                "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": 1715443667,
                "post_id": 78465261,
                "comment_id": 138331008,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1715450330,
                "last_edit_date": 1715450330,
                "creation_date": 1715448327,
                "answer_id": 78465513,
                "question_id": 78465261,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "`&quot;{\\&quot;F1\\&quot;:null,\\&quot;F2\\&quot;:\\&quot;text\\&quot;}&quot;` is in fact a valid JSON value. It&#39;s a JSON string that happens to contain valid JSON encoded as a string.\r\n\r\nYou can either use [`fromjson`](https://jqlang.github.io/jq/manual/#convert-to-from-json) as the initial filter in your jq program or use jq once to print the raw string contents:\r\n\r\n```\r\necho &#39;&quot;{\\&quot;F1\\&quot;:null,\\&quot;F2\\&quot;:\\&quot;text\\&quot;}&quot;&#39; | jq &#39;fromjson | ...&#39;\r\n```\r\n\r\nor\r\n\r\n```\r\necho &#39;&quot;{\\&quot;F1\\&quot;:null,\\&quot;F2\\&quot;:\\&quot;text\\&quot;}&quot;&#39; | jq -r . | jq &#39;...&#39;\r\n```",
                "title": "Unquote JSON data in CLI"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -1,
        "last_activity_date": 1715489866,
        "creation_date": 1715443266,
        "last_edit_date": 1715489866,
        "question_id": 78465261,
        "body_markdown": "I have a script, that returns quoted JSON data, like `&quot;{\\&quot;F1\\&quot;:null,\\&quot;F2\\&quot;:\\&quot;text\\&quot;...`\r\nHow can I evaluate it and return &quot;clear&quot; data to feed it into `jq`?",
        "link": "https://stackoverflow.com/questions/78465261/unquote-json-data-in-cli",
        "title": "Unquote JSON data in CLI"
    },
    {
        "tags": [
            "timestamp",
            "jq",
            "isodate"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1715639190,
                "creation_date": 1715639190,
                "answer_id": 78475019,
                "question_id": 78474940,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Well buried in git issues JQ does not support `%f` so there are a number of solutions to work around this.\r\n\r\nAs soon as I remove the .%f jq is able to parse the dates.\r\n\r\nFortunately in my case I can change the format to whatever I need it to be.",
                "title": "Using JQ to parse timestamp"
            },
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1715650006,
                "creation_date": 1715650006,
                "answer_id": 78475352,
                "question_id": 78474940,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "While the [Go implementation of jq](https://github.com/itchyny/gojq) actually *can* parse `%f` correctly:\r\n```sh\r\ngojq &#39;.time | strptime(&quot;%Y-%m-%d %H:%M:%S.%f&quot;) | strftime(&quot;%Y&quot;)&#39;\r\n```\r\nIf all you need is `%Y` from a date string that is already formatted starting with `%Y-`, just extract its first four characters:\r\n```sh\r\njq &#39;.time[:4]&#39;\r\n```\r\n[Demo](https://jqplay.org/s/DUA0jDswJt0)",
                "title": "Using JQ to parse timestamp"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1715654105,
        "creation_date": 1715637246,
        "last_edit_date": 1715654105,
        "question_id": 78474940,
        "body_markdown": "I am having some difficulty finding my error with JQ parsing this timestamp.\r\n```\r\n&quot;time&quot;: &quot;2024-05-13 16:43:06.928708&quot;\r\n```\r\n`.time| strptime(&quot;%Y-%m-%d %H:%M:%S.%f&quot;)| strftime(&quot;%Y&quot;)`\r\n\r\nIt clearly is not agreeing that I have this format, however this is exactly the format I&#39;m using in Python.\r\n\r\nhere is the error message received.\r\n`&quot;2024-05-13 16:43:06.928708&quot; does not match format &quot;%Y-%m-%d %H:%M:%S.%f&quot;`\r\n\r\nWhat gives, do I need some ticks somewhere?",
        "link": "https://stackoverflow.com/questions/78474940/using-jq-to-parse-timestamp",
        "title": "Using JQ to parse timestamp"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1715641974,
                "last_edit_date": 1715641974,
                "creation_date": 1715640887,
                "answer_id": 78475082,
                "question_id": 78475026,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You&#39;re looking for something like this:\r\n``` none\r\n(\r\n  .resources[] | \r\n  select(\r\n    .provider == &quot;provider[\\&quot;registry.terraform.io/eddycharly/kops\\&quot;]&quot; and\r\n    .type == &quot;kops_cluster&quot;\r\n  ) |\r\n  .instances[].attributes\r\n) |= (\r\n  .config_store = [{ base:.config_base }] |\r\n  del(.config_base)\r\n)\r\n```\r\nYou need to parenthesize the lefthand side of `|=` to retain the original structure.",
                "title": "Modify/delete nested/selected values with jq and output entire document"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1715641974,
        "creation_date": 1715639344,
        "last_edit_date": 1715640541,
        "question_id": 78475026,
        "body_markdown": "I&#39;m migrating between Terraform providers, and to resolve a bug I need to change the `tfstate` files which are huge JSON blobs. I&#39;ve distilled the file down to the most basic form, but I&#39;d like to change from:\r\n```\r\n{\r\n  &quot;resources&quot;: [\r\n    {\r\n      &quot;provider&quot;: &quot;something_else&quot;,\r\n      &quot;type&quot;: &quot;foo&quot;\r\n    },\r\n    {\r\n      &quot;provider&quot;: &quot;provider[\\&quot;registry.terraform.io/eddycharly/kops\\&quot;]&quot;,\r\n      &quot;type&quot;: &quot;kops_cluster&quot;,\r\n      &quot;instances&quot;: [{\r\n        &quot;attributes&quot;: {\r\n          &quot;another_attr&quot;: &quot;hello world&quot;,\r\n          &quot;config_base&quot;: &quot;s3://foo-bucket/bar-env&quot;,\r\n          &quot;config_store&quot;: &quot;&quot;\r\n        }\r\n      }]\r\n    },\r\n    {\r\n      &quot;provider&quot;: &quot;something_else&quot;,\r\n      &quot;type&quot;: &quot;foo&quot;\r\n    }\r\n  ]\r\n}\r\n\r\n```\r\n\r\nTo:\r\n```\r\n{\r\n  &quot;resources&quot;: [\r\n    {\r\n      &quot;provider&quot;: &quot;something_else&quot;,\r\n      &quot;type&quot;: &quot;foo&quot;\r\n    },\r\n    {\r\n      &quot;provider&quot;: &quot;provider[\\&quot;registry.terraform.io/eddycharly/kops\\&quot;]&quot;,\r\n      &quot;type&quot;: &quot;kops_cluster&quot;,\r\n      &quot;instances&quot;: [{\r\n        &quot;attributes&quot;: {\r\n          &quot;another_attr&quot;: &quot;hello world&quot;,\r\n          &quot;config_store&quot;: [{\r\n            &quot;base&quot;: &quot;s3://foo-bucket/bar-env&quot;\r\n          }]\r\n        }\r\n      }]\r\n    },\r\n    {\r\n      &quot;provider&quot;: &quot;something_else&quot;,\r\n      &quot;type&quot;: &quot;foo&quot;\r\n    }\r\n  ]\r\n}\r\n\r\n```\r\n\r\nTo this end I&#39;ve come up with the expression:\r\n```\r\n.resources[] | \r\nselect(\r\n  .provider == &quot;provider[\\&quot;registry.terraform.io/eddycharly/kops\\&quot;]&quot; and\r\n  .type == &quot;kops_cluster&quot;\r\n) |\r\n.instances[].attributes |\r\n.config_base as $config_base |\r\n.config_store |= [{ &quot;base&quot;:$config_base }] |\r\ndel(.config_base)\r\n```\r\n\r\nbut the resulting output is only the modified `.resources[].instances[].attributes` block, not the entire document, eg:\r\n\r\n```\r\n{\r\n  &quot;another_attr&quot;: &quot;hello world&quot;,\r\n  &quot;config_store&quot;: [\r\n    {\r\n      &quot;base&quot;: &quot;s3://foo-bucket/bar-env&quot;\r\n    }\r\n  ]\r\n}\r\n```\r\n\r\nHow can I rearrange this expression to output the entire document?",
        "link": "https://stackoverflow.com/questions/78475026/modify-delete-nested-selected-values-with-jq-and-output-entire-document",
        "title": "Modify/delete nested/selected values with jq and output entire document"
    }
]