[
    {
        "tags": [
            "json",
            "linux",
            "parsing",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 16081986,
                    "reputation": 460,
                    "user_id": 11608607,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b8873af89eb30af6a70c34d95cf93581?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "FlyingRissole",
                    "link": "https://stackoverflow.com/users/11608607/flyingrissole"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1610623200,
                "post_id": 65717880,
                "comment_id": 116193544,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 7,
                "is_accepted": true,
                "score": 7,
                "last_activity_date": 1610624947,
                "creation_date": 1610624947,
                "answer_id": 65718417,
                "question_id": 65717880,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "JQ&#39;s input and output are _streams_ of JSON entities. The items in those streams are not comma separated. Some JQ filters may emit more than one entity for each entity they read in. Some filters may not emit any entity for some of the entities that they read in.\r\n\r\nIn your case, your input is a stream of one object, and your output is a stream of multiple objects. This is because each single array input to the `[]` filter results in a stream of all of the items in the output. It sounds like you instead want your output to consist of one _array_ of objects. Here are two broad ways to do it.\r\n\r\n## 1. Use `map` instead of `[]`\r\n\r\n```\r\ncat myfile | jq &#39;.ipAddressTab | map(select(.status == &quot;reserved&quot;) | select(.type != &quot;network&quot;) | select(.type != &quot;gateway&quot;) | select(.type != &quot;broadcast&quot;))&#39;\r\n```\r\n\r\nThe parameter to `map` is another filter. It will be applied to each item in the array, and all the entities emitted by that filter will be gathered into one new array.\r\n\r\n## 2. Use `[ ... ]` to gather the results of a filter into an array\r\n\r\n```\r\ncat myfile | jq &#39;.ipAddressTab | [ .[] | select(.status == &quot;reserved&quot;) | select(.type != &quot;network&quot;) | select(.type != &quot;gateway&quot;) | select(.type != &quot;broadcast&quot;) ]&#39;\r\n```\r\n\r\nIt might seem like putting values between square brackets is just creating an array with one entry, but in fact what this syntax means is to evaluate the filter between the brackets, take the entire stream of output from that filter and make an array out of it.\r\n\r\nIn fact, this is exactly how `map` is itself defined. But it&#39;s useful to know, because it lets you see how you might use `[ ... ]` in other ways to capture a sequence of values.",
                "title": "Parsing json with JQ : Where are the comma?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 5,
        "last_activity_date": 1610624947,
        "creation_date": 1610622572,
        "question_id": 65717880,
        "body_markdown": "I&#39;ve this type of data :\r\n```\r\n{\r\n   &quot;cidr&quot; : &quot;X.X.X.X/27&quot;,\r\n   &quot;defaultGateway&quot; : &quot;X.X.X.X&quot;,\r\n   &quot;full&quot; : false,\r\n   &quot;id&quot; : &quot;X.X.X.X&quot;,\r\n   &quot;ipAddressTab&quot; : [\r\n      {\r\n         &quot;alias_domain&quot; : null,\r\n         &quot;alias_name&quot; : null,\r\n         &quot;description&quot; : &quot;This is the network address for X.X.X.X/27&quot;,\r\n         &quot;dnr_rr&quot; : null,\r\n         &quot;dns_domain&quot; : null,\r\n         &quot;environnement&quot; : null,\r\n         &quot;fdqn&quot; : null,\r\n         &quot;hostname&quot; : null,\r\n         &quot;ip&quot; : &quot;X.X.X.X&quot;,\r\n         &quot;requester&quot; : null,\r\n         &quot;status&quot; : &quot;reserved&quot;,\r\n         &quot;type&quot; : &quot;network&quot;\r\n      },\r\n      {\r\n         &quot;alias_domain&quot; : null,\r\n         &quot;alias_name&quot; : null,\r\n         &quot;description&quot; : &quot;This is the default gateway address for X.X.X.X/27&quot;,\r\n         &quot;dnr_rr&quot; : null,\r\n         &quot;dns_domain&quot; : null,\r\n         &quot;environnement&quot; : null,\r\n         &quot;fdqn&quot; : null,\r\n         &quot;hostname&quot; : null,\r\n         &quot;ip&quot; : &quot;X.X.X.X&quot;,\r\n         &quot;requester&quot; : null,\r\n         &quot;status&quot; : &quot;reserved&quot;,\r\n         &quot;type&quot; : &quot;gateway&quot;\r\n      },\r\n      {\r\n         &quot;alias_domain&quot; : &quot;toto.com&quot;,\r\n         &quot;alias_name&quot; : &quot;&quot;,\r\n         &quot;description&quot; : &quot;this is a test&quot;,\r\n         &quot;dns_domain&quot; : &quot;&quot;,\r\n         &quot;environnement&quot; : &quot;test&quot;,\r\n         &quot;fdqn&quot; : &quot;XXX&quot;,\r\n         &quot;hostname&quot; : &quot;XXX&quot;,\r\n         &quot;ip&quot; : &quot;X.X.X.X&quot;,\r\n         &quot;requester&quot; : &quot;XXX&quot;,\r\n         &quot;status&quot; : &quot;allocated&quot;,\r\n         &quot;type&quot; : &quot;VM&quot;\r\n      },\r\n      {\r\n         &quot;alias_domain&quot; : &quot;toto.com&quot;,\r\n         &quot;alias_name&quot; : &quot;&quot;,\r\n         &quot;description&quot; : &quot;this is a test&quot;,\r\n         &quot;dns_domain&quot; : &quot;&quot;,\r\n         &quot;environnement&quot; : &quot;test&quot;,\r\n         &quot;fdqn&quot; : &quot;XXX&quot;,\r\n         &quot;hostname&quot; : &quot;XXX&quot;,\r\n         &quot;ip&quot; : &quot;X.X.X.X&quot;,\r\n         &quot;requester&quot; : &quot;XXX&quot;,\r\n         &quot;status&quot; : &quot;allocated&quot;,\r\n         &quot;type&quot; : &quot;VM&quot;\r\n      },\r\n      {\r\n         &quot;ip&quot; : &quot;X.X.X.X&quot;,\r\n         &quot;status&quot; : &quot;reserved&quot;\r\n      },\r\n      {\r\n         &quot;ip&quot; : &quot;X.X.X.X&quot;,\r\n         &quot;status&quot; : &quot;reserved&quot;\r\n      },\r\n      {\r\n         &quot;ip&quot; : &quot;X.X.X.X&quot;,\r\n         &quot;status&quot; : &quot;reserved&quot;\r\n      },\r\n      {\r\n         &quot;ip&quot; : &quot;X.X.X.X&quot;,\r\n         &quot;status&quot; : &quot;reserved&quot;\r\n      },\r\n      {\r\n         &quot;alias_domain&quot; : null,\r\n         &quot;alias_name&quot; : null,\r\n         &quot;description&quot; : &quot;This is the broadcast address for X.X.X.X/27&quot;,\r\n         &quot;dnr_rr&quot; : null,\r\n         &quot;dns_domain&quot; : null,\r\n         &quot;environnement&quot; : null,\r\n         &quot;fdqn&quot; : null,\r\n         &quot;hostname&quot; : null,\r\n         &quot;ip&quot; : &quot;X.X.X.X&quot;,\r\n         &quot;requester&quot; : null,\r\n         &quot;status&quot; : &quot;reserved&quot;,\r\n         &quot;type&quot; : &quot;broadcast&quot;\r\n      }\r\n   ]\r\n}\r\n```\r\nI want to extract the IPs with &quot;reserved&quot; as status but without extractig the data for the gateway/network/broadcast IPs :\r\n\r\n```\r\ncat myfile | jq &#39;.ipAddressTab[] | select(.status == &quot;reserved&quot;) | select(.type != &quot;network&quot;) | select(.type != &quot;gateway&quot;) | select(.type != &quot;broadcast&quot;)&#39;\r\n```\r\n\r\nThe output is :\r\n```\r\n{\r\n  &quot;ip&quot;: &quot;X.X.X.X&quot;,\r\n  &quot;status&quot;: &quot;reserved&quot;\r\n}\r\n{\r\n  &quot;ip&quot;: &quot;X.X.X.X&quot;,\r\n  &quot;status&quot;: &quot;reserved&quot;\r\n}\r\n{\r\n  &quot;ip&quot;: &quot;X.X.X.X&quot;,\r\n  &quot;status&quot;: &quot;reserved&quot;\r\n}\r\n{\r\n  &quot;ip&quot;: &quot;X.X.X.X&quot;,\r\n  &quot;status&quot;: &quot;reserved&quot;\r\n}\r\n```\r\nBut where are the commas between each &quot; IP part &quot; ?\r\n\r\nOn my file, each part in Braces are separated by a comma :\r\n```\r\n {\r\n         &quot;ip&quot; : &quot;X.X.X.X&quot;,\r\n         &quot;status&quot; : &quot;reserved&quot;\r\n      }, &lt;=\r\n      {\r\n         &quot;ip&quot; : &quot;X.X.X.X&quot;,\r\n         &quot;status&quot; : &quot;reserved&quot;\r\n      }, &lt;=\r\n      {\r\n         &quot;ip&quot; : &quot;X.X.X.X&quot;,\r\n         &quot;status&quot; : &quot;reserved&quot;\r\n      }, &lt;=\r\n      {\r\n         &quot;ip&quot; : &quot;X.X.X.X&quot;,\r\n         &quot;status&quot; : &quot;reserved&quot;\r\n      }, &lt;=\r\n\r\n```\r\n\r\nThere is a way to keep them when I parse my file with jq ?\r\n\r\nThanks !",
        "link": "https://stackoverflow.com/questions/65717880/parsing-json-with-jq-where-are-the-comma",
        "title": "Parsing json with JQ : Where are the comma?"
    },
    {
        "tags": [
            "json",
            "linux",
            "parsing",
            "jq",
            "cat"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1610691516,
                "creation_date": 1610691516,
                "answer_id": 65731350,
                "question_id": 65720697,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "For this type of problem, |= is your friend.\r\n\r\nYou can choose between a straightforward approach, such as:\r\n```\r\n.ipAddressTab\r\n |= map(if .status == &quot;reserved&quot; \r\n           and .type != &quot;network&quot;\r\n           and .type != &quot;gateway&quot;\r\n           and .type != &quot;broadcast&quot;\r\n        then .status = &quot;available&quot; else . end)\r\n```\r\nor the more subtle:\r\n```\r\n(.ipAddressTab[]\r\n | select(.status == &quot;reserved&quot; and \r\n          .type != &quot;network&quot; and\r\n          .type != &quot;gateway&quot; and\r\n          .type != &quot;broadcast&quot;)\r\n).status = &quot;available&quot;\r\n```\r\n\r\nIncidentally, a DRYer version of either approach can be obtained by using `IN`: \r\n```\r\n.type | IN(&quot;network&quot;, &quot;gateway&quot;, &quot;broadcast&quot;) | not\r\n```",
                "title": "JQ : Change some values and display all the datas?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1610691516,
        "creation_date": 1610633839,
        "question_id": 65720697,
        "body_markdown": "I&#39;ve this data :\r\n```\r\n{\r\n   &quot;cidr&quot; : &quot;X.X.X.X/27&quot;,\r\n   &quot;defaultGateway&quot; : &quot;X.X.X.X&quot;,\r\n   &quot;full&quot; : false,\r\n   &quot;id&quot; : &quot;X.X.X.X&quot;,\r\n   &quot;ipAddressTab&quot; : [\r\n      {\r\n         &quot;alias_domain&quot; : null,\r\n         &quot;alias_name&quot; : null,\r\n         &quot;description&quot; : &quot;This is the network address for X.X.X.X/27&quot;,\r\n         &quot;dnr_rr&quot; : null,\r\n         &quot;dns_domain&quot; : null,\r\n         &quot;environnement&quot; : null,\r\n         &quot;fdqn&quot; : null,\r\n         &quot;hostname&quot; : null,\r\n         &quot;ip&quot; : &quot;X.X.X.X&quot;,\r\n         &quot;requester&quot; : null,\r\n         &quot;status&quot; : &quot;reserved&quot;,\r\n         &quot;type&quot; : &quot;network&quot;\r\n      },\r\n      {\r\n         &quot;alias_domain&quot; : null,\r\n         &quot;alias_name&quot; : null,\r\n         &quot;description&quot; : &quot;This is the default gateway address for X.X.X.X/27&quot;,\r\n         &quot;dnr_rr&quot; : null,\r\n         &quot;dns_domain&quot; : null,\r\n         &quot;environnement&quot; : null,\r\n         &quot;fdqn&quot; : null,\r\n         &quot;hostname&quot; : null,\r\n         &quot;ip&quot; : &quot;X.X.X.X&quot;,\r\n         &quot;requester&quot; : null,\r\n         &quot;status&quot; : &quot;reserved&quot;,\r\n         &quot;type&quot; : &quot;gateway&quot;\r\n      },\r\n      {\r\n         &quot;alias_domain&quot; : &quot;toto.com&quot;,\r\n         &quot;alias_name&quot; : &quot;&quot;,\r\n         &quot;description&quot; : &quot;this is a test&quot;,\r\n         &quot;dns_domain&quot; : &quot;&quot;,\r\n         &quot;environnement&quot; : &quot;test&quot;,\r\n         &quot;fdqn&quot; : &quot;XXX&quot;,\r\n         &quot;hostname&quot; : &quot;XXX&quot;,\r\n         &quot;ip&quot; : &quot;X.X.X.X&quot;,\r\n         &quot;requester&quot; : &quot;XXX&quot;,\r\n         &quot;status&quot; : &quot;allocated&quot;,\r\n         &quot;type&quot; : &quot;VM&quot;\r\n      },\r\n      {\r\n         &quot;alias_domain&quot; : &quot;toto.com&quot;,\r\n         &quot;alias_name&quot; : &quot;&quot;,\r\n         &quot;description&quot; : &quot;this is a test&quot;,\r\n         &quot;dns_domain&quot; : &quot;&quot;,\r\n         &quot;environnement&quot; : &quot;test&quot;,\r\n         &quot;fdqn&quot; : &quot;XXX&quot;,\r\n         &quot;hostname&quot; : &quot;XXX&quot;,\r\n         &quot;ip&quot; : &quot;X.X.X.X&quot;,\r\n         &quot;requester&quot; : &quot;XXX&quot;,\r\n         &quot;status&quot; : &quot;allocated&quot;,\r\n         &quot;type&quot; : &quot;VM&quot;\r\n      },\r\n      {\r\n         &quot;ip&quot; : &quot;X.X.X.X&quot;,\r\n         &quot;status&quot; : &quot;reserved&quot;\r\n      },\r\n      {\r\n         &quot;ip&quot; : &quot;X.X.X.X&quot;,\r\n         &quot;status&quot; : &quot;reserved&quot;\r\n      },\r\n      {\r\n         &quot;ip&quot; : &quot;X.X.X.X&quot;,\r\n         &quot;status&quot; : &quot;reserved&quot;\r\n      },\r\n      {\r\n         &quot;ip&quot; : &quot;X.X.X.X&quot;,\r\n         &quot;status&quot; : &quot;reserved&quot;\r\n      },\r\n      {\r\n         &quot;alias_domain&quot; : null,\r\n         &quot;alias_name&quot; : null,\r\n         &quot;description&quot; : &quot;This is the broadcast address for X.X.X.X/27&quot;,\r\n         &quot;dnr_rr&quot; : null,\r\n         &quot;dns_domain&quot; : null,\r\n         &quot;environnement&quot; : null,\r\n         &quot;fdqn&quot; : null,\r\n         &quot;hostname&quot; : null,\r\n         &quot;ip&quot; : &quot;X.X.X.X&quot;,\r\n         &quot;requester&quot; : null,\r\n         &quot;status&quot; : &quot;reserved&quot;,\r\n         &quot;type&quot; : &quot;broadcast&quot;\r\n      }\r\n   ]\r\n}\r\n```\r\n\r\nI want to change all status &quot;reserved&quot; as &quot;available&quot; without changing the status for the ip which have network, gateway or broadcast as status. So with jq I&#39;m able to select all I need without select the IPs with network, gateway or broadcast as status and change the status to available :\r\n```\r\ncat myfile |  jq &#39;.ipAddressTab[] | select(.status == &quot;reserved&quot;) | select(.type != &quot;network&quot;) | select(.type != &quot;gateway&quot;) | select(.type != &quot;broadcast&quot;) | .status = &quot;available&quot;&#39; \r\n```\r\n\r\nThe output :\r\n```\r\n{\r\n  &quot;ip&quot;: &quot;X.X.X.X&quot;,\r\n  &quot;status&quot;: &quot;available&quot;\r\n}\r\n{\r\n  &quot;ip&quot;: &quot;X.X.X.X&quot;,\r\n  &quot;status&quot;: &quot;available&quot;\r\n}\r\n{\r\n  &quot;ip&quot;: &quot;X.X.X.X&quot;,\r\n  &quot;status&quot;: &quot;available&quot;\r\n}\r\n{\r\n  &quot;ip&quot;: &quot;X.X.X.X&quot;,\r\n  &quot;status&quot;: &quot;available&quot;\r\n}\r\n\r\n```\r\nBut there is a way to do that in order to have this output :\r\n```\r\n{\r\n   &quot;cidr&quot; : &quot;X.X.X.X/27&quot;,\r\n   &quot;defaultGateway&quot; : &quot;X.X.X.X&quot;,\r\n   &quot;full&quot; : false,\r\n   &quot;id&quot; : &quot;X.X.X.X&quot;,\r\n   &quot;ipAddressTab&quot; : [\r\n      {\r\n         &quot;alias_domain&quot; : null,\r\n         &quot;alias_name&quot; : null,\r\n         &quot;description&quot; : &quot;This is the network address for X.X.X.X/27&quot;,\r\n         &quot;dnr_rr&quot; : null,\r\n         &quot;dns_domain&quot; : null,\r\n         &quot;environnement&quot; : null,\r\n         &quot;fdqn&quot; : null,\r\n         &quot;hostname&quot; : null,\r\n         &quot;ip&quot; : &quot;X.X.X.X&quot;,\r\n         &quot;requester&quot; : null,\r\n         &quot;status&quot; : &quot;reserved&quot;,\r\n         &quot;type&quot; : &quot;network&quot;\r\n      },\r\n      {\r\n         &quot;alias_domain&quot; : null,\r\n         &quot;alias_name&quot; : null,\r\n         &quot;description&quot; : &quot;This is the default gateway address for X.X.X.X/27&quot;,\r\n         &quot;dnr_rr&quot; : null,\r\n         &quot;dns_domain&quot; : null,\r\n         &quot;environnement&quot; : null,\r\n         &quot;fdqn&quot; : null,\r\n         &quot;hostname&quot; : null,\r\n         &quot;ip&quot; : &quot;X.X.X.X&quot;,\r\n         &quot;requester&quot; : null,\r\n         &quot;status&quot; : &quot;reserved&quot;,\r\n         &quot;type&quot; : &quot;gateway&quot;\r\n      },\r\n      {\r\n         &quot;alias_domain&quot; : &quot;toto.com&quot;,\r\n         &quot;alias_name&quot; : &quot;&quot;,\r\n         &quot;description&quot; : &quot;this is a test&quot;,\r\n         &quot;dns_domain&quot; : &quot;&quot;,\r\n         &quot;environnement&quot; : &quot;test&quot;,\r\n         &quot;fdqn&quot; : &quot;XXX&quot;,\r\n         &quot;hostname&quot; : &quot;XXX&quot;,\r\n         &quot;ip&quot; : &quot;X.X.X.X&quot;,\r\n         &quot;requester&quot; : &quot;XXX&quot;,\r\n         &quot;status&quot; : &quot;allocated&quot;,\r\n         &quot;type&quot; : &quot;VM&quot;\r\n      },\r\n      {\r\n         &quot;alias_domain&quot; : &quot;toto.com&quot;,\r\n         &quot;alias_name&quot; : &quot;&quot;,\r\n         &quot;description&quot; : &quot;this is a test&quot;,\r\n         &quot;dns_domain&quot; : &quot;&quot;,\r\n         &quot;environnement&quot; : &quot;test&quot;,\r\n         &quot;fdqn&quot; : &quot;XXX&quot;,\r\n         &quot;hostname&quot; : &quot;XXX&quot;,\r\n         &quot;ip&quot; : &quot;X.X.X.X&quot;,\r\n         &quot;requester&quot; : &quot;XXX&quot;,\r\n         &quot;status&quot; : &quot;allocated&quot;,\r\n         &quot;type&quot; : &quot;VM&quot;\r\n      },\r\n      {\r\n         &quot;ip&quot; : &quot;X.X.X.X&quot;,\r\n         &quot;status&quot; : &quot;available&quot;\r\n      },\r\n      {\r\n         &quot;ip&quot; : &quot;X.X.X.X&quot;,\r\n         &quot;status&quot; : &quot;available&quot;\r\n      },\r\n      {\r\n         &quot;ip&quot; : &quot;X.X.X.X&quot;,\r\n         &quot;status&quot; : &quot;available&quot;\r\n      },\r\n      {\r\n         &quot;ip&quot; : &quot;X.X.X.X&quot;,\r\n         &quot;status&quot; : &quot;available&quot;\r\n      },\r\n      {\r\n         &quot;alias_domain&quot; : null,\r\n         &quot;alias_name&quot; : null,\r\n         &quot;description&quot; : &quot;This is the broadcast address for X.X.X.X/27&quot;,\r\n         &quot;dnr_rr&quot; : null,\r\n         &quot;dns_domain&quot; : null,\r\n         &quot;environnement&quot; : null,\r\n         &quot;fdqn&quot; : null,\r\n         &quot;hostname&quot; : null,\r\n         &quot;ip&quot; : &quot;X.X.X.X&quot;,\r\n         &quot;requester&quot; : null,\r\n         &quot;status&quot; : &quot;reserved&quot;,\r\n         &quot;type&quot; : &quot;broadcast&quot;\r\n      }\r\n   ]\r\n}\r\n\r\n```\r\nDisplay all the data with the changes desired not just display the lines which should be changed ?",
        "link": "https://stackoverflow.com/questions/65720697/jq-change-some-values-and-display-all-the-datas",
        "title": "JQ : Change some values and display all the datas?"
    },
    {
        "tags": [
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 3533661,
                    "reputation": 80,
                    "user_id": 2952510,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/99787b374f7fc23a636c402f9c6fcdac?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Goldman7911",
                    "link": "https://stackoverflow.com/users/2952510/goldman7911"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1610638031,
                "post_id": 65721626,
                "comment_id": 116200831,
                "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": 1610638137,
                "post_id": 65721626,
                "comment_id": 116200888,
                "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": 1610638204,
                "post_id": 65721626,
                "comment_id": 116200922,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1610699311,
                "last_edit_date": 1610699311,
                "creation_date": 1610696186,
                "answer_id": 65732153,
                "question_id": 65721626,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "First, your two invocations of jq can be replaced by just one, as shown in the answer below.\r\n\r\nSecond, there are currently (at least) two `yq`s in the wild:\r\n* python-based yq (https://kislyuk.github.io/yq) - hereafter `python-yq`\r\n* go-based yq (https://github.com/mikefarah/yq)\r\n\r\nFor better and/or worse, version 4 of the go-based yq is significantly different from earlier versions, so if you want to use the current go-based version you may have to make adjustments accordingly. To simplify things (at least from my point of view), I will replace your `yq r -P -` by:\r\n\r\n    python-jq -y .\r\n\r\nThe following produces the output shown below.\r\n\r\n```\r\n&lt; cf_response.json \\\r\n  jq &#39;{name_zones:\r\n        {zone_name: .result[0].zone_name,\r\n         auth_key: &quot;XXX&quot;,\r\n          records:\r\n            [.result[]\r\n             | {name, type, content, ttl}\r\n               + if has(&quot;priority&quot;) \r\n                 then {priority} \r\n                 else null end] }} &#39;|\r\n  python-yq -y .\r\n\r\n```\r\n### Output\r\n\r\n```\r\nname_zones:\r\n  zone_name: test.com\r\n  auth_key: XXX\r\n  records:\r\n    - name: test.com\r\n      type: A\r\n      content: 111.111.111.111\r\n      ttl: 1\r\n    - name: test.com\r\n      type: TXT\r\n      content: google-site-verification=content\r\n      ttl: 1\r\n    - name: test.com\r\n      type: MX\r\n      content: smtp.test.com\r\n      ttl: 1\r\n      priority: 0\r\n```\r\n\r\n## auth_key\r\n\r\nIf you want to pass in the value of `auth_key` as a parameter to jq, you could use the command-line sequence `--arg auth_key XXX`, and then use `$auth_key` in the jq program.",
                "title": "Convert Cloudflare API response to yaml"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1610699311,
        "creation_date": 1610637167,
        "last_edit_date": 1610698492,
        "question_id": 65721626,
        "body_markdown": "When I retrieve all records for a hosted zone in [Cloudflare][1], e.g. of [response][2], I need to create from it the following yaml structure:\r\n\r\n    name_zones: # this line we create \r\n      .zone_name: # the value is taken from the response\r\n        auth_key: XXX # this line we create \r\n        records: # this line we create\r\n    # iterate over all records\r\n          - name: .name\r\n            type: .type\r\n            priority: .priority # create line if value set|exist\r\n            content: .content\r\n            ttl: .ttl # create line if value set|exist\r\n\r\ne.g. `jq` code which almost done this:  \r\n`jq &#39;.result[] | {name: .name, type: .type, content: .content, ttl: .ttl} + if has(&quot;priority&quot;) then {priority} else null end&#39; | jq -n &#39;.name_zone.zone_name.auth_key.records |= [inputs]&#39; | yq r -P -`  \r\n\r\nHow to pass or create the value of `zone_name` and `auth_key: XXX`?\r\n\r\n\r\n  [1]: https://api.cloudflare.com/#dns-records-for-a-zone-list-dns-records\r\n  [2]: https://jsoneditoronline.org/#left=cloud.97f9bb6785be4e799fb2a7560919f07f",
        "link": "https://stackoverflow.com/questions/65721626/convert-cloudflare-api-response-to-yaml",
        "title": "Convert Cloudflare API response to yaml"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1610640040,
                "last_edit_date": 1610640040,
                "creation_date": 1610637454,
                "answer_id": 65721714,
                "question_id": 65721713,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "# My variable call was not within the jq program\r\n\r\n\r\nThe here-string I&#39;m passing into `jq`\r\n```\r\n{ &quot;foo&quot;: $b }\r\n```\r\nis **not** &quot;the jq program&quot; mentioned in the manual&#39;s `--arg` description. The lone `.` was the entire program, and did not use the variable `$b`.\r\n\r\nI was trying to construct JSON from scratch by passing in my pattern on stdin. Instead, I should have provided the `--null-input` option, and replaced the `.` with the pattern I was attempting to pass in.\r\n\r\nDescription of `--null-input`\r\n\r\n&gt; &lt;ul&gt; &lt;li&gt;&lt;code&gt;--null-input&lt;/code&gt;/&lt;code&gt;-n&lt;/code&gt;:&lt;/li&gt; &lt;/ul&gt;\r\n&gt; &lt;p&gt;Don&#39;t read any input at all! Instead, the filter is run once  \r\n&gt; using &lt;code&gt;null&lt;/code&gt; as the input. This is useful when using jq as\r\n&gt; a   simple calculator or to construct JSON data from scratch.&lt;/p&gt;\r\n\r\n## Here&#39;s the correct invocation:\r\n```\r\n$ jq --arg b bar --null-input &#39;{ &quot;foo&quot;: $b }&#39;\r\n{\r\n  &quot;foo&quot;: &quot;bar&quot;\r\n}\r\n```",
                "title": "jq returns &quot;Invalid numeric literal&quot; with --arg"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1610640574,
        "creation_date": 1610637454,
        "last_edit_date": 1610640574,
        "question_id": 65721713,
        "body_markdown": "The command below is returning an error (jq version: 1.6):\r\n```\r\n$ jq --arg b bar . &lt;&lt;&lt; &#39;{ &quot;foo&quot;: $b }&#39;\r\nparse error: Invalid numeric literal at line 1, column 12\r\n```\r\n\r\n**Expected output:**\r\n```\r\n{\r\n  &quot;foo&quot;: &quot;bar&quot;\r\n}\r\n```\r\n\r\nThe [jq 1.6 manual][1] describes the `--arg` option thusly:\r\n&gt; &lt;ul&gt;&lt;li&gt;&lt;code&gt;--arg name value&lt;/code&gt;:&lt;/li&gt; &lt;/ul&gt; &lt;p&gt;This option passes a\r\n&gt; value to the jq program as a predefined   variable. If you run jq with\r\n&gt; &lt;code&gt;--arg foo bar&lt;/code&gt;, then &lt;code&gt;$foo&lt;/code&gt; is   available in\r\n&gt; the program and has the value &lt;code&gt;&quot;bar&quot;&lt;/code&gt;. Note that  \r\n&gt; &lt;code&gt;value&lt;/code&gt; will be treated as a string, so &lt;code&gt;--arg foo\r\n&gt; 123&lt;/code&gt; will   bind &lt;code&gt;$foo&lt;/code&gt; to &lt;code&gt;&quot;123&quot;&lt;/code&gt;.&lt;/p&gt;\r\n&gt; &lt;p&gt;Named arguments are also available to the jq program as  \r\n&gt; &lt;code&gt;$ARGS.named&lt;/code&gt;.&lt;/p&gt;\r\n\r\nMy usage appears correct. What&#39;s going on here?\r\n\r\n  [1]: https://stedolan.github.io/jq/manual/v1.6/",
        "link": "https://stackoverflow.com/questions/65721713/jq-returns-invalid-numeric-literal-with-arg",
        "title": "jq returns &quot;Invalid numeric literal&quot; with --arg"
    },
    {
        "tags": [
            "json",
            "sorting",
            "version",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 12,
                "is_accepted": true,
                "score": 12,
                "last_activity_date": 1610665287,
                "creation_date": 1610665287,
                "answer_id": 65728139,
                "question_id": 65728085,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Turn each component into a number, then sort on the array of integers.\r\n\r\n    jq &#39;sort_by(.TagVersion|split(&quot;.&quot;)|map(tonumber))&#39;\r\n\r\nOutput:\r\n\r\n    [\r\n      {\r\n        &quot;TagVersion&quot;: &quot;1.0.9&quot;\r\n      },\r\n      {\r\n        &quot;TagVersion&quot;: &quot;1.0.10&quot;\r\n      },\r\n      {\r\n        &quot;TagVersion&quot;: &quot;1.0.11&quot;\r\n      },\r\n      {\r\n        &quot;TagVersion&quot;: &quot;1.0.77&quot;\r\n      },\r\n      {\r\n        &quot;TagVersion&quot;: &quot;1.1.8&quot;\r\n      }\r\n    ]",
                "title": "jq sort by version as string"
            },
            {
                "up_vote_count": 10,
                "is_accepted": false,
                "score": 10,
                "last_activity_date": 1727702061,
                "last_edit_date": 1727702061,
                "creation_date": 1679075260,
                "answer_id": 75770668,
                "question_id": 65728085,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "This one allows you to use full [Semantic Versioning 2.0 ordering][1] including `-pre.release` suffixes.\r\n\r\n```bash\r\njq_semver_cmp=&#39;                                           \r\n  def opt(f):\r\n      . as $in | try f catch $in;\r\n  def semver_cmp:\r\n      sub(&quot;\\\\+.*$&quot;; &quot;&quot;)\r\n    | capture(&quot;^(?&lt;v&gt;[^-]+)(?:-(?&lt;p&gt;.*))?$&quot;) | [.v, .p // empty]\r\n    | map(split(&quot;.&quot;) | map(opt(tonumber)))\r\n    | .[1] |= (. // {});&#39;\r\n\r\njq &quot;$jq_semver_cmp&quot;&#39;sort_by(.TagVersion|semver_cmp)&#39;\r\n```\r\n\r\nAs it uses a couple tricks, I might explain it. In general, the `semver_cmp` function chomps the version string into a 2-level array that `jq`-natively sorts as desired. The array looks like this:\r\n```json\r\n &quot;0.1.0&quot;:         [[0,1,0],{}]\r\n &quot;0.1.0-alpha.2&quot;: [[0,1,0],[&quot;alpha&quot;, 2]]\r\n```\r\n\r\n1. `sub(&quot;\\\\+.*$&quot;; &quot;&quot;)` strips any eventual [metadata][2], that doesn&#39;t take part in the comparison.\r\n2. `capture(&quot;^(?&lt;v&gt;[^-]+)(?:-(?&lt;p&gt;.*))?$&quot;) | [.v, .p // empty]` splits the string into an array like `[&quot;x.y.z&quot;]` or `[&quot;x.y.z&quot;, &quot;pre.release&quot;]` if the [pre-release suffix][3] exists.\r\n3. `map(split(&quot;.&quot;) | map(opt(tonumber)))` splits these elements further by `.` and where possible, it converts the &quot;identifiers&quot; to numbers (to sort numerically).\r\n4. `.[1] |= (. // {})` is a little trick that adds an empty object as the 2nd element for plain version strings that don&#39;t have the suffix. [Objects  sort after arrays][4], which is what we need here.\r\n\r\nWith that sorted out, an input like this:\r\n```json\r\n[\r\n    { &quot;TagVersion&quot;: &quot;1.0.11&quot; },\r\n    { &quot;TagVersion&quot;: &quot;1.0.11-alpha.2&quot; },\r\n    { &quot;TagVersion&quot;: &quot;1.0.11-alpha&quot; }\r\n]\r\n```\r\nwill correctly end up like this - with the plain version sorted after the pre-release.\r\n```json\r\n[\r\n    { &quot;TagVersion&quot;: &quot;1.0.11-alpha&quot; },\r\n    { &quot;TagVersion&quot;: &quot;1.0.11-alpha.2&quot; },\r\n    { &quot;TagVersion&quot;: &quot;1.0.11&quot; }\r\n]\r\n```\r\n\r\n\r\n  [1]: https://semver.org/spec/v2.0.0.html#spec-item-11\r\n  [2]: https://semver.org/spec/v2.0.0.html#spec-item-10\r\n  [3]: https://semver.org/spec/v2.0.0.html#spec-item-9\r\n  [4]: https://jqlang.github.io/jq/manual/#sort-sort_by",
                "title": "jq sort by version as string"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 8,
        "last_activity_date": 1727702061,
        "creation_date": 1610664945,
        "last_edit_date": 1610693161,
        "question_id": 65728085,
        "body_markdown": "I&#39;m trying to sort the following json reponse to pick the latest version:\r\n\r\n```\r\n[\r\n    {\r\n        &quot;TagVersion&quot;: &quot;1.0.11&quot;\r\n    },\r\n    {\r\n        &quot;TagVersion&quot;: &quot;1.1.8&quot;\r\n    },\r\n    {\r\n        &quot;TagVersion&quot;: &quot;1.0.10&quot;,\r\n    },\r\n    {\r\n        &quot;TagVersion&quot;: &quot;1.0.9&quot;,\r\n    },\r\n    {\r\n        &quot;TagVersion&quot;: &quot;1.0.77&quot;\r\n    }\r\n]\r\n\r\n```\r\n\r\nCorrect sorting should be:\r\n\r\n\r\n```\r\n    {\r\n        &quot;TagVersion&quot;: &quot;1.0.9&quot;,\r\n    },\r\n    {\r\n        &quot;TagVersion&quot;: &quot;1.0.10&quot;,\r\n    },\r\n    {\r\n        &quot;TagVersion&quot;: &quot;1.0.11&quot;\r\n    },\r\n    {\r\n        &quot;TagVersion&quot;: &quot;1.0.77&quot;\r\n    },\r\n    {\r\n        &quot;TagVersion&quot;: &quot;1.1.8&quot;\r\n    }\r\n\r\n```\r\n\r\nI&#39;m currently able to do part of the job. It&#39;s working for simple cases (all version part major/minor/bug has the same number of digits). \r\n\r\n`jq -r [.[]]|max_by(.TagVersion|split(&quot;.&quot;) | map(tonumber)`\r\n\r\nThe best way to do it in my mind should be to add a multiplication the each part. Example:\r\n\r\n```\r\n# With condition than every &quot;part&quot; as a maximum of 2 digits. It won&#39;t work with 3 digits\r\n\r\n# Version 1.23.87\r\n\r\n1 * 1000 + 23 * 10 + 87 = 1317\r\n\r\n# Version 3.0.0\r\n1 * 1000 + 0 * 10 + 0 = 3000\r\n\r\n# Version 1.89.78\r\n1 * 1000 + 89*10 + 78 = 1968\r\n```\r\n\r\nDoes anybody have an idea to implement this? &#128578; ",
        "link": "https://stackoverflow.com/questions/65728085/jq-sort-by-version-as-string",
        "title": "jq sort by version as string"
    },
    {
        "tags": [
            "terraform",
            "jq",
            "aws-cli",
            "terraform-provider-aws",
            "hcl"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 90365,
                    "reputation": 240414,
                    "user_id": 248823,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/6605deca5924e84df1a4847f607b87c6?s=256&d=identicon&r=PG",
                    "display_name": "Marcin",
                    "link": "https://stackoverflow.com/users/248823/marcin"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1610692068,
                "post_id": 65731296,
                "comment_id": 116217412,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2649209,
                    "reputation": 57233,
                    "user_id": 2291321,
                    "user_type": "registered",
                    "accept_rate": 83,
                    "profile_image": "https://www.gravatar.com/avatar/fea90c708303be83a7490750e6dbe137?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "ydaetskcoR",
                    "link": "https://stackoverflow.com/users/2291321/ydaetskcor"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1610706422,
                "post_id": 65731296,
                "comment_id": 116222619,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 15274660,
                    "reputation": 520,
                    "user_id": 11020763,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/aFblr.jpg?s=256",
                    "display_name": "SNR",
                    "link": "https://stackoverflow.com/users/11020763/snr"
                },
                "reply_to_user": {
                    "account_id": 2649209,
                    "reputation": 57233,
                    "user_id": 2291321,
                    "user_type": "registered",
                    "accept_rate": 83,
                    "profile_image": "https://www.gravatar.com/avatar/fea90c708303be83a7490750e6dbe137?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "ydaetskcoR",
                    "link": "https://stackoverflow.com/users/2291321/ydaetskcor"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1610717387,
                "post_id": 65731296,
                "comment_id": 116227152,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2649209,
                    "reputation": 57233,
                    "user_id": 2291321,
                    "user_type": "registered",
                    "accept_rate": 83,
                    "profile_image": "https://www.gravatar.com/avatar/fea90c708303be83a7490750e6dbe137?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "ydaetskcoR",
                    "link": "https://stackoverflow.com/users/2291321/ydaetskcor"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1610719441,
                "post_id": 65731296,
                "comment_id": 116228093,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1610692290,
                "creation_date": 1610692290,
                "answer_id": 65731457,
                "question_id": 65731296,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "&gt; How can I convert this output into Map as below \r\n\r\nOne way would be to use jq as follows (assuming `cli-output-tags` is the name of the file holding the JSON array of arrays):\r\n```\r\njq -r -f &#39;&quot;{&quot;, (.[] | &quot;\\(.[0]) = \\&quot;\\(.[1])\\&quot;&quot;), &quot;}&quot;&#39; cli-output-tags\r\n```",
                "title": "Terraform - How to convert lists into map (How to fetch AMI tags using terraform)"
            },
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1610695133,
                "last_edit_date": 1610695133,
                "creation_date": 1610694606,
                "answer_id": 65731839,
                "question_id": 65731296,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You could use [zipmap](https://www.terraform.io/docs/configuration/functions/zipmap.html):\r\n\r\n```\r\noutput &quot;cli-output-tags&quot; {\r\n  value = zipmap(\r\n        jsondecode(data.local_file.read_tags.content)[*][0],\r\n        jsondecode(data.local_file.read_tags.content)[*][1]\r\n      )         \r\n}\r\n```\r\n\r\nThe code first changes string data from your file to json, then\r\ngets all first elements `[*][0]` (same for second elements `[*][1]`), and zips them into map. ",
                "title": "Terraform - How to convert lists into map (How to fetch AMI tags using terraform)"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1610807758,
        "creation_date": 1610691146,
        "last_edit_date": 1610807758,
        "question_id": 65731296,
        "body_markdown": "I am trying to fetch the tags of AMI using AWS CLI and want to reuse the values from the output.\r\nI have a terraform code below which is returning outputs in string format(Maybe not sure of format) which I want to convert into a map object.\r\n\r\n```\r\nvariable &quot;ami&quot; {\r\n  default = &quot;ami-xxxx&quot;\r\n}\r\n\r\nlocals {\r\n  tags = {\r\n  &quot;platform&quot;    = lookup(data.local_file.read_tags.content, &quot;platform&quot;, &quot;&quot;) #Expecting to get platform from Map of read_tags\r\n  }\r\n}\r\n\r\ndata &quot;template_file&quot; &quot;log_name&quot; {\r\n  template = &quot;${path.module}/output.log&quot;\r\n}\r\n\r\nresource &quot;null_resource&quot; &quot;ami_tags&quot; {\r\n  provisioner &quot;local-exec&quot; {\r\n    command = &quot;aws ec2 describe-tags --filters Name=resource-id,Values=${var.ami} --query Tags[*].[Key,Value] &gt; ${data.template_file.log_name.rendered}&quot;\r\n  }\r\n}\r\n\r\ndata &quot;local_file&quot; &quot;read_tags&quot; {\r\n  filename = &quot;${data.template_file.log_name.rendered}&quot;\r\n  depends_on = [&quot;null_resource.ami_tags&quot;]\r\n}\r\n\r\noutput &quot;tags&quot; {\r\n  value = local.tags\r\n}\r\n\r\noutput &quot;cli-output-tags&quot; {\r\n  value = &quot;${concat(data.local_file.read_tags.content)}&quot;\r\n}\r\n```  \r\noutput of **cli-output-tags** is below:\r\n```\r\n[\r\n    [\r\n        &quot;ENV&quot;,\r\n        &quot;DEV&quot;\r\n    ],\r\n    [\r\n        &quot;Name&quot;,\r\n        &quot;Base-AMI&quot;\r\n    ],\r\n    [\r\n        &quot;platform&quot;,\r\n        &quot;Linux&quot;\r\n    ]\r\n]\r\n```\r\nHow can I convert this output into Map as below using terraform/(jq command), or is there any other way to fetch required values directly from **cli-output-tags** output:\r\n\r\n```\r\n{\r\nENV  = &quot;DEV&quot;,\r\nName = &quot;Base-AMI&quot;,\r\nplatform = &quot;Linux&quot;\r\n}\r\n```\r\n\r\nI have also tried changing the CLI command a bit like below but still not able to fetch values as expected:\r\n```\r\n&#39;Tags[].{Key:Key,Value:Value}&#39;\r\n```\r\nResulted below output:\r\n```\r\n[\r\n    {\r\n        &quot;Key&quot;: &quot;ENV&quot;,\r\n        &quot;Value&quot;: &quot;DEV&quot;\r\n    },\r\n    {\r\n        &quot;Key&quot;: &quot;Name&quot;,\r\n        &quot;Value&quot;: &quot;Base-AMI&quot;\r\n    },\r\n    {\r\n        &quot;Key&quot;: &quot;platform&quot;,\r\n        &quot;Value&quot;: &quot;Linux&quot;\r\n    }\r\n]\r\n```",
        "link": "https://stackoverflow.com/questions/65731296/terraform-how-to-convert-lists-into-map-how-to-fetch-ami-tags-using-terraform",
        "title": "Terraform - How to convert lists into map (How to fetch AMI tags using terraform)"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1610701772,
                "post_id": 65732445,
                "comment_id": 116220664,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 253524,
                    "reputation": 745,
                    "user_id": 532297,
                    "user_type": "registered",
                    "accept_rate": 25,
                    "profile_image": "https://www.gravatar.com/avatar/554b8f9afa09b08991386fcf61e97c70?s=256&d=identicon&r=PG",
                    "display_name": "Djabx",
                    "link": "https://stackoverflow.com/users/532297/djabx"
                },
                "reply_to_user": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1610702517,
                "post_id": 65732445,
                "comment_id": 116220979,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1610703899,
                "last_edit_date": 1610703899,
                "creation_date": 1610703593,
                "answer_id": 65733699,
                "question_id": 65732445,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "With your jqplay example, the following jq program produces the output shown below:\r\n\r\n```\r\nreduce .[] as $o ({};\r\n  $o.projects as $projects\r\n  | reduce $o.bindings[] as $b (.;\r\n      $b.role as $role\r\n      | reduce $b.members[] as $member (.;\r\n          .[$member][$projects] += [$role])) )\r\n```\r\n\r\n### Output\r\n\r\n```\r\n{\r\n  &quot;userA&quot;: {\r\n    &quot;p1&quot;: [\r\n      &quot;admin&quot;,\r\n      &quot;user&quot;\r\n    ],\r\n    &quot;p2&quot;: [\r\n      &quot;viewer&quot;\r\n    ]\r\n  },\r\n  &quot;userB&quot;: {\r\n    &quot;p1&quot;: [\r\n      &quot;admin&quot;\r\n    ],\r\n    &quot;p2&quot;: [\r\n      &quot;viewer&quot;,\r\n      &quot;user&quot;\r\n    ]\r\n  }\r\n}\r\n```\r\n\r\n### More succinctly ...\r\n```\r\nreduce .[] as $o ({};\r\n  reduce $o.bindings[] as $b (.;\r\n    reduce $b.members[] as $member (.;\r\n      .[$member][$o.projects] += [$b.role])) )\r\n\r\n```",
                "title": "How to merge and reshape nested objects using JQ?"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1610713075,
                "last_edit_date": 1610713075,
                "creation_date": 1610703765,
                "answer_id": 65733737,
                "question_id": 65732445,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "With an up-to-date version of JQ, you can emulate a nested loop using [`reduce`](https://stedolan.github.io/jq/manual/#Reduce) as below to achieve this.\r\n```\r\nreduce .[] as { $bindings, $projects } ({};\r\n  reduce $bindings[] as { $members, $role } (.;\r\n    reduce $members[] as $member (.;\r\n      .[$member][$projects] += [ $role ]\r\n    )\r\n  )\r\n)\r\n```\r\n&lt;sup&gt;[Online demo](https://jqplay.org/s/KUTlF_UaEm)&lt;/sup&gt;",
                "title": "How to merge and reshape nested objects using JQ?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1610713075,
        "creation_date": 1610697648,
        "last_edit_date": 1610708926,
        "question_id": 65732445,
        "body_markdown": "Hy,\r\n\r\nI&#39;ve got data like this:\r\n\r\n```json\r\n[\r\n  {\r\n    &quot;bindings&quot;: [\r\n      {\r\n        &quot;members&quot;: [\r\n          &quot;userA&quot;,\r\n          &quot;userB&quot;\r\n        ],\r\n        &quot;role&quot;: &quot;admin&quot;\r\n      },\r\n      {\r\n        &quot;members&quot;: [\r\n          &quot;userA&quot;\r\n        ],\r\n        &quot;role&quot;: &quot;user&quot;\r\n      }\r\n    ],\r\n    &quot;projects&quot;: &quot;p1&quot;\r\n  },\r\n  { [...]\r\n  },\r\n]\r\n```\r\n\r\nI would like to transform it to this:\r\n\r\n```json\r\n{\r\n  &quot;userA&quot;: {\r\n    &quot;p1&quot;: [\r\n      &quot;admin&quot;,\r\n      &quot;user&quot;,\r\n    ],\r\n    &quot;p2&quot;: [\r\n      &quot;viewer&quot;\r\n    ]\r\n  },\r\n  &quot;userB&quot;: {\r\n    [...]\r\n  }\r\n}\r\n```\r\n\r\nI suppose I&#39;m close with this solution:\r\n```json\r\n.[] | .projects as $project | .bindings[] | .role as $role | .members[] as $user | { ($user):  {($project): [(.role)]} }\r\n```\r\n\r\n\r\nMy problem is the reduce, I&#39;m doing this:\r\n\r\n```json\r\n[ &lt;previous expression&gt; ] | reduce .[] as $x ({}; . * $x )\r\n```\r\n\r\nAnd it give me this:\r\n\r\n```json\r\n{\r\n  &quot;userA&quot;: {\r\n    &quot;p1&quot;: [\r\n      &quot;user&quot;\r\n    ],\r\n    &quot;p2&quot;: [\r\n      &quot;viewer&quot;\r\n    ]\r\n  },\r\n  [...]\r\n}\r\n```\r\n\r\nAs you can see, the list of roles, is not &quot;merged&quot;.\r\n\r\nHow can I merge list within object ?\r\n\r\nFor &quot;real&quot; data sample, please see here: https://jqplay.org/s/-MOej2i6Zh\r\n",
        "link": "https://stackoverflow.com/questions/65732445/how-to-merge-and-reshape-nested-objects-using-jq",
        "title": "How to merge and reshape nested objects using JQ?"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1610894708,
                "last_edit_date": 1610894708,
                "creation_date": 1610743981,
                "answer_id": 65743395,
                "question_id": 65735589,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "This should get you on your way:\r\n\r\n```\r\ndef id2value($id): .. | objects | select(.attribute_id == $id) | .attribute_value;\r\n\r\n.result[]\r\n| &quot;\\(.name): has a cover made of \\(.parts_list | id2value(17))&quot;\r\n```\r\n\r\nWith your input and using the -r command-line option, the above produces:\r\n```\r\nItem1: has a cover made of steel\r\nItem2: has a cover made of plastic\r\n\r\n```",
                "title": "jq build string from multiple levels"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": -1,
        "last_activity_date": 1610894720,
        "creation_date": 1610711410,
        "last_edit_date": 1610894720,
        "question_id": 65735589,
        "body_markdown": "I have the following JSON\r\n\r\n```[\r\n  {\r\n    &quot;count&quot;: 2,\r\n    &quot;load_arg&quot;: {\r\n      &quot;limit&quot;: 100\r\n    },\r\n    &quot;limit&quot;: 100,\r\n    &quot;result&quot;: [\r\n      {\r\n        &quot;id&quot;: 1234,\r\n        &quot;name&quot;: &quot;Item1&quot;,\r\n        &quot;parts_list&quot;: {\r\n          &quot;subattributes&quot;: {\r\n            &quot;1234&quot;: {\r\n              &quot;chassisid&quot;: 111236,\r\n              &quot;part_attributes&quot;: {\r\n                &quot;subattributes&quot;: {\r\n                  &quot;134322&quot;: {\r\n                    &quot;attribute_id&quot;: 27,\r\n                    &quot;attribute_value&quot;: 3\r\n                  }\r\n                }\r\n              }\r\n            },\r\n            &quot;1235&quot;: {\r\n              &quot;chassisid&quot;: 76,\r\n              &quot;part_attributes&quot;: {\r\n                &quot;subattributes&quot;: {\r\n                  &quot;192134&quot;: {\r\n                    &quot;attribute_id&quot;: 17,\r\n                    &quot;attribute_value&quot;: &quot;steel&quot;\r\n                  }\r\n                }\r\n              }\r\n            }\r\n          }\r\n        }\r\n      },\r\n      {\r\n        &quot;id&quot;: 4321,\r\n        &quot;name&quot;: &quot;Item2&quot;,\r\n        &quot;parts_list&quot;: {\r\n          &quot;subattributes&quot;: {\r\n            &quot;2212&quot;: {\r\n              &quot;chassisid&quot;: 93245,\r\n              &quot;part_attributes&quot;: {\r\n                &quot;subattributes&quot;: {\r\n                  &quot;76423&quot;: {\r\n                    &quot;attribute_id&quot;: 17,\r\n                    &quot;attribute_value&quot;: &quot;plastic&quot;\r\n                  }\r\n                }\r\n              }\r\n            },\r\n            &quot;65&quot;: {\r\n              &quot;chassisid&quot;: 2,\r\n              &quot;part_attributes&quot;: {\r\n                &quot;subattributes&quot;: {\r\n                  &quot;1285&quot;: {\r\n                    &quot;attribute_id&quot;: 27,\r\n                    &quot;attribute_value&quot;: 94\r\n                  }\r\n                }\r\n              }\r\n            }\r\n          }\r\n        }\r\n      }      \r\n    ],\r\n    &quot;offset&quot;: 0\r\n  }\r\n]\r\n```\r\nand I&#39;m trying to get jq to output the following from the results array\r\n\r\n    Item1: has a cover made of steel and requires part ID 27 to be 3\r\n    Item2: has a cover made of plastic and requires part ID 27 to be 94\r\n\r\nI know some basic jq queries but I&#39;m strugglig with grabbing a top level value and then building a string using some specific child values. In my JSON each result could have 10&#39;s of subattributes and not all of them are the same so I&#39;d need to search for the attribute ID 17\r\n\r\nEffectively I&#39;m trying to pull (pseudo code as I know it&#39;s not right)\r\n\r\n```\r\n.[].result[].name + &quot;: has a cover made of &quot; + .[].result[].parts_list.subattributes[].part_attributes[][] | select(.attribute_id == 17).attribute_value + &quot; and requires part ID 27 to be &quot; + [].result[].parts_list.subattributes[].part_attributes[][] | select(.attribute_id == 27).attribute_value\r\n```",
        "link": "https://stackoverflow.com/questions/65735589/jq-build-string-from-multiple-levels",
        "title": "jq build string from multiple levels"
    },
    {
        "tags": [
            "json",
            "shell",
            "csv",
            "select",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 166270,
                    "reputation": 135171,
                    "user_id": 390278,
                    "user_type": "registered",
                    "accept_rate": 86,
                    "profile_image": "https://www.gravatar.com/avatar/84715fec547362389d02f5be0ed12814?s=256&d=identicon&r=PG",
                    "display_name": "Jeff Mercado",
                    "link": "https://stackoverflow.com/users/390278/jeff-mercado"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1610753839,
                "post_id": 65744656,
                "comment_id": 116241072,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1610752148,
                "creation_date": 1610752148,
                "answer_id": 65744717,
                "question_id": 65744656,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I figured it out as soon as I posted the question. But please let me know if there&#39;s a better way to do this. \r\n```jq -r &#39;.assets[]|[.apis[].assetId, .apis[].activeContractsCount]|@csv&#39;```",
                "title": "Parsing parent and child element into a csv using jq"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1610753748,
                "creation_date": 1610753748,
                "answer_id": 65744893,
                "question_id": 65744656,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The following will produce exactly two columns, one for the &quot;assetID&quot; and one for the count:\r\n```\r\n.assets[].apis[]\r\n| [.assetId, .activeContractsCount]\r\n| @csv\r\n```\r\n",
                "title": "Parsing parent and child element into a csv using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1610753828,
        "creation_date": 1610751650,
        "last_edit_date": 1610753828,
        "question_id": 65744656,
        "body_markdown": "I have a big file that has lines as below. \r\n\r\n    {\r\n     &quot;total&quot;: 320,\r\n     &quot;assets&quot;: [\r\n       {\r\n         &quot;audit&quot;: {\r\n           &quot;created&quot;: {\r\n             &quot;date&quot;: &quot;2019-09-30T12:38:01.421Z&quot;\r\n           },\r\n           &quot;updated&quot;: {}\r\n         },\r\n         &quot;organizationId&quot;: &quot;12345678&quot;,\r\n         &quot;id&quot;: 211123898,\r\n         &quot;name&quot;: &quot;groupId:760c47ad-c9f2958be:assetId:8o-api&quot;,\r\n         &quot;exchangeAssetName&quot;: &quot;8O API&quot;,\r\n         &quot;groupId&quot;: &quot;760c47ad-c9f2958be&quot;,\r\n         &quot;assetId&quot;: &quot;8o-api&quot;,\r\n         &quot;apis&quot;: [\r\n           {\r\n             &quot;audit&quot;: {\r\n               &quot;created&quot;: {\r\n                 &quot;date&quot;: &quot;2019-09-30T12:38:03.139Z&quot;\r\n               },\r\n               &quot;updated&quot;: {\r\n                 &quot;date&quot;: &quot;2020-03-09T21:37:55.745Z&quot;\r\n               }\r\n             },\r\n   \t\t  &quot;organizationId&quot;: &quot;12345678&quot;,\r\n             &quot;id&quot;: 15822364,\r\n             &quot;groupId&quot;: &quot;760c47ad-c9f2958be&quot;,\r\n             &quot;assetId&quot;: &quot;8o-api&quot;,\r\n             &quot;assetVersion&quot;: &quot;1.0.0&quot;,\r\n             &quot;productVersion&quot;: &quot;v1&quot;,\r\n             &quot;description&quot;: null,\r\n             &quot;tags&quot;: [],\r\n             &quot;order&quot;: 1,\r\n             &quot;providerId&quot;: null,\r\n             &quot;deprecated&quot;: false,\r\n             &quot;lastActiveDate&quot;: &quot;2021-01-15T22:43:33.881Z&quot;,\r\n             &quot;isPublic&quot;: false,\r\n             &quot;stage&quot;: &quot;release&quot;,\r\n             &quot;lastActiveDelta&quot;: 7,\r\n             &quot;pinned&quot;: false,\r\n             &quot;activeContractsCount&quot;: 6,\r\n             &quot;autodiscoveryInstanceName&quot;: &quot;v1:15822364&quot;\r\n           }\r\n         ],\r\n         &quot;totalApis&quot;: 1,\r\n         &quot;autodiscoveryApiName&quot;: &quot;groupId:760c47ad-c9f2958be:assetId:8o-api&quot;\r\n       },\r\n     {\r\n         &quot;audit&quot;: {\r\n           &quot;created&quot;: {\r\n             &quot;date&quot;: &quot;2018-06-22T19:41:35.760Z&quot;\r\n           },\r\n           &quot;updated&quot;: {\r\n             &quot;date&quot;: &quot;2018-09-13T06:20:51.151Z&quot;\r\n           }\r\n         },\r\n         &quot;organizationId&quot;: &quot;760c47ad-c9f2958be&quot;,\r\n         &quot;id&quot;: 210914379,\r\n         &quot;name&quot;: &quot;hips-ts&quot;,\r\n         &quot;exchangeAssetName&quot;: &quot;hips-ts&quot;,\r\n         &quot;groupId&quot;: &quot;760c47ad-c9f2958be&quot;,\r\n         &quot;assetId&quot;: &quot;hips-ts&quot;,\r\n         &quot;apis&quot;: [\r\n           {\r\n             &quot;audit&quot;: {\r\n               &quot;created&quot;: {\r\n                 &quot;date&quot;: &quot;2018-06-22T19:41:35.759Z&quot;\r\n               },\r\n               &quot;updated&quot;: {\r\n                 &quot;date&quot;: &quot;2020-03-09T21:37:55.745Z&quot;\r\n               }\r\n             },\r\n             &quot;organizationId&quot;: &quot;760c47ad-c9f2958be&quot;,\r\n             &quot;id&quot;: 15470738,\r\n             &quot;groupId&quot;: &quot;760c47ad-c9f2958be&quot;,\r\n             &quot;assetId&quot;: &quot;hips-ts&quot;,\r\n             &quot;assetVersion&quot;: &quot;1.0.0&quot;,\r\n             &quot;productVersion&quot;: &quot;v1&quot;,\r\n             &quot;description&quot;: null,\r\n             &quot;tags&quot;: [],\r\n             &quot;order&quot;: 1,\r\n             &quot;providerId&quot;: null,\r\n             &quot;deprecated&quot;: false,\r\n             &quot;lastActiveDate&quot;: &quot;2021-01-15T22:43:30.004Z&quot;,\r\n             &quot;endpointUri&quot;: null,\r\n             &quot;isPublic&quot;: false,\r\n             &quot;stage&quot;: &quot;release&quot;,\r\n             &quot;lastActiveDelta&quot;: 11,\r\n             &quot;pinned&quot;: false,\r\n             &quot;activeContractsCount&quot;: 1,\r\n             &quot;autodiscoveryInstanceName&quot;: &quot;1-test&quot;\r\n           }\r\n         ],\r\n         &quot;totalApis&quot;: 1,\r\n         &quot;autodiscoveryApiName&quot;: &quot;hips-ts&quot;\r\n       }\r\n     ]\r\n    }\r\n\r\nI am trying to use jq to just get the ```assetId``` and the ```activeContractsCount``` from this in a comma separated way. \r\nSo my output for this text should be\r\n\r\n    8o-api, 6\r\n    hips-ts, 1\r\n\r\nI tried the following wiht jq ```jq -r &#39;[.assets[].assetId, .assets[].apis[].activeContractsCount]|@csv&#39;``` and I tried mapping too but nothing seems to stick. \r\nCan you help me here? Any help is appreciated. ",
        "link": "https://stackoverflow.com/questions/65744656/parsing-parent-and-child-element-into-a-csv-using-jq",
        "title": "Parsing parent and child element into a csv using jq"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1610765281,
                "creation_date": 1610765281,
                "answer_id": 65746008,
                "question_id": 65745171,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The problem statement appears to be under-specified, but the following seems to be either a solution or very close to one:\r\n```\r\njq -r &#39;.[] | .beans[] | &quot;\\(.bean) --&gt; \\(.dependencies[])&quot;&#39; input.json\r\n```",
                "title": "Reduce json bean descriptor to text"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1610765281,
        "creation_date": 1610755859,
        "question_id": 65745171,
        "body_markdown": "I wish to reduce with jq\r\n\r\n```json\r\n[ {\r\n  &quot;context&quot; : &quot;app:swagger,dev:8080&quot;,\r\n  &quot;parent&quot; : null,\r\n  &quot;beans&quot; : [ {\r\n    &quot;bean&quot; : &quot;app&quot;,\r\n    &quot;aliases&quot; : [ ],\r\n    &quot;scope&quot; : &quot;singleton&quot;,\r\n    &quot;type&quot; : &quot;com.example.App&quot;,\r\n    &quot;resource&quot; : &quot;null&quot;,\r\n    &quot;dependencies&quot; : [ &quot;environment&quot; ]\r\n  }, {\r\n    &quot;bean&quot; : &quot;environment&quot;,\r\n    &quot;aliases&quot; : [ ],\r\n    &quot;scope&quot; : &quot;singleton&quot;,\r\n    &quot;type&quot; : &quot;com.example.Environment&quot;,\r\n    &quot;resource&quot; : &quot;null&quot;,\r\n    &quot;dependencies&quot; : [  ]\r\n  }\r\n},\r\n...\r\n}]\r\n```\r\n\r\nto\r\n\r\n```\r\napp --&gt; environment\r\n...\r\n```\r\n\r\n",
        "link": "https://stackoverflow.com/questions/65745171/reduce-json-bean-descriptor-to-text",
        "title": "Reduce json bean descriptor to text"
    },
    {
        "tags": [
            "arrays",
            "json",
            "jq",
            "siblings"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1610769142,
                "creation_date": 1610769142,
                "answer_id": 65746337,
                "question_id": 65746336,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Okay, figured it out while creating a simpler test case for SO. I ended up having to use a variable, which I&#39;ve never used in `jq` before. If you know a simple way to do it without the variable, I&#39;d be keen to see it.\r\n\r\nThe above can be solved with:\r\n```\r\njq &#39;. as $top \r\n  | .[] \r\n  | select(\r\n      $top[.parentIndex? | values]\r\n        .name == &quot;Carol&quot;\r\n    )&#39; \r\n```\r\n\r\nWhat it does on each line is:\r\n1. Assign the initial input to `$top`. This is necessary because, at the time we&#39;re evaluating whether to `select` an individual object or not, we no longer have access to the whole array without a variable.\r\n2. Split the array into a stream of objects\r\n3. Select objects if...\r\n4. ... the object in the `$top` array at the position of this object&#39;s `parentIndex` ...\r\n5. ... has a `name` of `&quot;Carol&quot;`",
                "title": "How can I select an object from an array based on an index in a property of sibling object?"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1611024715,
                "last_edit_date": 1611024715,
                "creation_date": 1610805417,
                "answer_id": 65750466,
                "question_id": 65746336,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s a similar solution that only examines the first &quot;Carol&quot;:\r\n```\r\n(map(.name) | index(&quot;Carol&quot;)) as $ix\r\n| .[] \r\n| select( .parentIndex == $ix )\r\n| .name\r\n```\r\nOne notable feature of this approach\r\nis that if there is a possibility that there is more than one &quot;Carol&quot;\r\nand if it is desired to handle all these possibilities in the same\r\nway, then one has only to change the first line above to:\r\n\r\n    (map(.name) | indices(&quot;Carol&quot;))[] as $ix",
                "title": "How can I select an object from an array based on an index in a property of sibling object?"
            }
        ],
        "is_answered": false,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1611024715,
        "creation_date": 1610769142,
        "last_edit_date": 1610805478,
        "question_id": 65746336,
        "body_markdown": "I&#39;m trying to process some JSON with `jq` that looks similar to this:\r\n```\r\n[\r\n  {\r\n    &quot;name&quot;: &quot;Albert&quot;\r\n  },\r\n  {\r\n    &quot;name&quot;: &quot;Brian&quot;,\r\n    &quot;parentIndex&quot;: 0\r\n  },\r\n  {\r\n    &quot;name&quot;: &quot;Carol&quot;,\r\n    &quot;parentIndex&quot;: 0\r\n  },\r\n  {\r\n    &quot;name&quot;: &quot;Dwayne&quot;,\r\n    &quot;parentIndex&quot;: 2\r\n  },\r\n  {\r\n    &quot;name&quot;: &quot;Ethel&quot;,\r\n    &quot;parentIndex&quot;: 3\r\n  },\r\n  {\r\n    &quot;name&quot;: &quot;Francis&quot;,\r\n    &quot;parentIndex&quot;: 3\r\n  }\r\n]\r\n```\r\n\r\nI want to find all objects in the list with a particular `name`, e.g. `&quot;Carol&quot;`, then get their indices in the list, and then use those indices to get all the objects in the list which have those objects as their parent, based on their `parentIndex`. So, the above should return Dwayne&#39;s object.\r\n\r\nI know I can get the indices with this:\r\n```\r\njq &#39;[.[] | .name == &quot;Carol&quot;] | indices(true)&#39;\r\n```\r\nbut not sure how to use the indices to get objects out of the list.",
        "link": "https://stackoverflow.com/questions/65746336/how-can-i-select-an-object-from-an-array-based-on-an-index-in-a-property-of-sibl",
        "title": "How can I select an object from an array based on an index in a property of sibling object?"
    },
    {
        "tags": [
            "arrays",
            "json",
            "bash",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1610813307,
                "last_edit_date": 1610813307,
                "creation_date": 1610807859,
                "answer_id": 65750840,
                "question_id": 65750516,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Invoke JQ with the **-c** flag so that it prints each array in a single line.\r\n```\r\n$ readarray -t tags &lt; &lt;(jq -c &#39;.data.allPost.edges[].node.labels&#39; file)\r\n$ echo &quot;${tags[1]}&quot;\r\n[&quot;DATA SCIENCE&quot;,&quot;NLP&quot;,&quot;PYTHON&quot;]\r\n```",
                "title": "Read JSON arrays into a Bash array"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1610816235,
                "last_edit_date": 1610816235,
                "creation_date": 1610815842,
                "answer_id": 65752085,
                "question_id": 65750516,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Can be done with a single `jq` call and clever use of ASCII `RS` delimiter:\r\n\r\n```sh\r\n#!/usr/bin/env bash\r\n\r\njson_file_name=a.json\r\n\r\nread -r -d &#39;&#39; jqscript &lt;&lt;JQSCRIPT\r\n.data.allPost.edges[].node.slug + &quot;\\u001e&quot;,\r\n&quot;\\u0000&quot;,\r\n(\r\n  .data.allPost.edges[].node.labels | tostring\r\n) + &quot;\\u001e&quot;\r\nJQSCRIPT\r\n\r\n{\r\n  IFS=$&#39;\\x1e&#39; read -r -d &#39;&#39; -a slugs\r\n  IFS=$&#39;\\x1e&#39; read -r -d &#39;&#39; -a tags\r\n} &lt; &lt;(\r\n  jq -j &quot;$jqscript&quot; &quot;$json_file_name&quot;\r\n)\r\n\r\ndeclare -p slugs tags\r\n\r\necho &quot;${tags[1]}&quot;\r\n```",
                "title": "Read JSON arrays into a Bash array"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 3,
        "last_activity_date": 1610816235,
        "creation_date": 1610805694,
        "last_edit_date": 1610807996,
        "question_id": 65750516,
        "body_markdown": "I have the following json file:\r\n```json\r\n{\r\n  &quot;data&quot;: {\r\n    &quot;allPost&quot;: {\r\n      &quot;edges&quot;: [\r\n        {      \r\n          &quot;node&quot;: {\r\n            &quot;slug&quot;: &quot;fp-cheat-sheet&quot;,\r\n            &quot;labels&quot;: [\r\n              &quot;FUNCTIONAL PROGRAMMING&quot;,\r\n              &quot;HASKELL&quot;,\r\n              &quot;SCALA&quot;\r\n            ]\r\n          }\r\n        },\r\n        {\r\n          &quot;node&quot;: {\r\n            &quot;slug&quot;: &quot;nlp-101&quot;,\r\n            &quot;labels&quot;: [\r\n              &quot;DATA SCIENCE&quot;,\r\n              &quot;NLP&quot;,\r\n              &quot;PYTHON&quot;\r\n            ]\r\n          }\r\n        }\r\n      ]\r\n    }\r\n  }\r\n}\r\n```\r\n\r\nI am writing a shell script to extract info for each `edge`, using JQ. From each `edge`, which is an array, I am able to extract `slugs` which is a string, but not `labels` which is again an array:\r\n```bash\r\nreadarray -t slugs &lt; &lt;(cat ${json_file_name} | jq .data.allPost.edges[].node.slug)\r\n\r\nreadarray -t tags &lt; &lt;(cat ${json_file_name} | jq .data.allPost.edges[].node.labels)\r\n\r\necho ${slugs[1]}\r\n# successfully prints &#39;&quot;nlp-101&quot;&#39;\r\n\r\necho ${tags[1]}\r\n# wrongly prints &#39;&quot;FUNCTIONAL PROGRAMMING&quot;,&#39;\r\n\r\n```\r\n\r\nI want to extract labels for each post and print it in a file in the exact same format. e.g. for `echo ${tags[1]}` I want it to print:\r\n```\r\n [&quot;DATA SCIENCE&quot;, &quot;NLP&quot;, &quot;PYTHON&quot;]\r\n```\r\n\r\nHow can I fix the above code to extract labels from the above JSON as desired?",
        "link": "https://stackoverflow.com/questions/65750516/read-json-arrays-into-a-bash-array",
        "title": "Read JSON arrays into a Bash array"
    },
    {
        "tags": [
            "json",
            "batch-file",
            "cmd",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1610835863,
                "post_id": 65752370,
                "comment_id": 116259328,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 51042,
                    "reputation": 612,
                    "user_id": 152405,
                    "user_type": "registered",
                    "accept_rate": 85,
                    "profile_image": "https://www.gravatar.com/avatar/06ff727a98cbe70d156f81687e6b971f?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Sara",
                    "link": "https://stackoverflow.com/users/152405/sara"
                },
                "reply_to_user": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1610912340,
                "post_id": 65752370,
                "comment_id": 116276557,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 51042,
                    "reputation": 612,
                    "user_id": 152405,
                    "user_type": "registered",
                    "accept_rate": 85,
                    "profile_image": "https://www.gravatar.com/avatar/06ff727a98cbe70d156f81687e6b971f?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Sara",
                    "link": "https://stackoverflow.com/users/152405/sara"
                },
                "reply_to_user": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1610912653,
                "post_id": 65752370,
                "comment_id": 116276646,
                "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": 1610963103,
                "post_id": 65752370,
                "comment_id": 116288892,
                "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": 1610963117,
                "post_id": 65752370,
                "comment_id": 116288897,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 413135,
                    "reputation": 9599,
                    "user_id": 786593,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/02ca3156e5785370494410fc80f28a79?s=256&d=identicon&r=PG",
                    "display_name": "hostingutilities.com",
                    "link": "https://stackoverflow.com/users/786593/hostingutilities-com"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1611003135,
                "post_id": 65752370,
                "comment_id": 116306353,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": -2,
                "last_activity_date": 1610823328,
                "last_edit_date": 1610823328,
                "creation_date": 1610822624,
                "answer_id": 65753331,
                "question_id": 65752370,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Have you considered using [tag:findstr]?\r\n\r\n    %SystemRoot%\\System32\\findstr.exe /SRM &quot;\\&quot;event\\&quot;:\\&quot;abcd123\\&quot;&quot; &quot;C:\\Users\\me\\my-folder\\*.json&quot;\r\n\r\nPlease open a Command Prompt window, type `findstr /?`, press the &lt;Kbd&gt;ENTER&lt;/Kbd&gt; key, and read its usage information. *(You may want to consider the `/I` option too, for instance)*.\r\n\r\nYou could then use that within another for loop to propagate those files into a variable for your copy command.\r\n\r\n[tag:batch-file] example:\r\n\r\n```\r\n@For /F &quot;EOL=? Delims=&quot; %%G In (\r\n\t&#39;%SystemRoot%\\System32\\findstr.exe /SRM &quot;\\&quot;event\\&quot;:\\&quot;abcd123\\&quot;&quot; &quot;C:\\Users\\me\\my-folder\\*.json&quot;&#39;\r\n) Do @Copy /Y &quot;%%G&quot; &quot;S:\\omewhere Else&quot;\r\n```\r\n\r\n[tag:cmd] example:\r\n\r\n    For /F &quot;EOL=? Delims=&quot; %G In (&#39;%SystemRoot%\\System32\\findstr.exe /SRM &quot;\\&quot;event\\&quot;:\\&quot;abcd123\\&quot;&quot; &quot;C:\\Users\\me\\my-folder\\*.json&quot;&#39;) Do @Copy /Y &quot;%G&quot; &quot;S:\\omewhere Else&quot;",
                "title": "How can I write a batch file using jq to find json files with certain attribute and copy the to new location"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1611008518,
                "last_edit_date": 1611008518,
                "creation_date": 1610835642,
                "answer_id": 65755337,
                "question_id": 65752370,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Since there are probably more file names than will fit on the command line, this response will assume a shell loop through the file names will be necessary, as the question itself envisions. Since I&#39;m currently working with a bash shell, I&#39;ll present a bash solution, which hopefully can readily be translated to other shells.\r\n\r\nThe complication in the question is that the input file might contain one or more valid JSON values, or one or more comma-separated JSON values.  \r\n \r\nThe key to a simple solution using jq is jq&#39;s -e command-line option, since this sets the return code to 0 if and only if\r\n(a) the program ran normally; and (b) the last result was a truthy value.\r\n\r\nFor clarity, let&#39;s encapsulate the relevant selection criterion in two bash functions:\r\n```\r\n# If the input is a valid stream of JSON objects\r\nfunction try {\r\n  jq -e -n &#39;any( inputs | objects; select( .event == &quot;abcd123&quot;) | true)&#39; 2&gt; /dev/null &gt; /dev/null\r\n}\r\n\r\n\r\n# If the input is a valid JSON array whose elements are to be checked\r\nfunction try_array {\r\n  jq -e &#39;any( .[] | objects; select( .event == &quot;abcd123&quot;) | true)&#39; 2&gt; /dev/null &gt; /dev/null\r\n}\r\n\r\n```\r\n\r\nNow a comprehensive solution can be constructed along the following lines:\r\n\r\n```\r\nfind . -type f -maxdepth 1 -name &#39;*.json&#39; | while read -r f\r\ndo\r\n  &lt; &quot;$f&quot; try\r\n  if [ $? = 0 ] ; then\r\n      echo copy $f\r\n  elif [ $? = 5 ] ; then\r\n      (echo &#39;[&#39;; cat &quot;$f&quot;; echo &#39;]&#39;) | try_array\r\n      if [ $? = 0 ] ; then\r\n\t  echo copy $f\r\n      fi\r\n  fi\r\ndone\r\n```\r\n",
                "title": "How can I write a batch file using jq to find json files with certain attribute and copy the to new location"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1611008518,
        "creation_date": 1610817291,
        "last_edit_date": 1610912433,
        "question_id": 65752370,
        "body_markdown": "I have 100,000&#39;s of lined json files that I need to split out based on whether or not, they contain a certain value for an attribute and then I need to convert them into valid json that can be read in by another platform.  \r\n\r\nI&#39;m using a batch file to do this and I&#39;ve managed to convert them into valid json using the following:\r\n\r\n    for /r %%f in (*.json*) do jq -s -c &quot;.&quot; &quot;%%f&quot; &gt;&gt; &quot;C:\\Users\\me\\my-folder\\%%~nxf.json&quot;\r\n\r\nI just can&#39;t figure out how to only copy the files that contain a certain value. So logic should be:\r\n\r\n    Look at all the files in the folders and sub solders\r\n      If the file contains an attribute &quot;event&quot; with a value of &quot;abcd123&quot;\r\n      then: convert the file into valid json and persist it with the same filename over to location &quot;C:\\Users\\me\\my-folder\\&quot;\r\n      else: ignore it\r\n\r\n**Example of files it should select:**\r\n\r\n    {&quot;name&quot;:&quot;bob&quot;,&quot;event&quot;:&quot;abcd123&quot;}\r\nand\r\n\r\n    {&quot;name&quot;:&quot;ann&quot;,&quot;event&quot;:&quot;abcd123&quot;},{&quot;name&quot;:&quot;bob&quot;,&quot;event&quot;:&quot;8745LLL&quot;}\r\n\r\n**Example of files it should NOT select:**\r\n\r\n    {&quot;name&quot;:&quot;ann&quot;,&quot;event&quot;:&quot;778PPP&quot;}\r\nand\r\n\r\n    {&quot;name&quot;:&quot;ann&quot;,&quot;event&quot;:&quot;778PPP&quot;},{&quot;name&quot;:&quot;bob&quot;,&quot;event&quot;:&quot;8745LLL&quot;}\r\n \r\nWould love help to figure out the filtering part. ",
        "link": "https://stackoverflow.com/questions/65752370/how-can-i-write-a-batch-file-using-jq-to-find-json-files-with-certain-attribute",
        "title": "How can I write a batch file using jq to find json files with certain attribute and copy the to new location"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 2505165,
                    "reputation": 829,
                    "user_id": 2179112,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/dae92dd58d619263a99d1eaee40ad8bc?s=256&d=identicon&r=PG",
                    "display_name": "Heinrich",
                    "link": "https://stackoverflow.com/users/2179112/heinrich"
                },
                "reply_to_user": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1610840434,
                "post_id": 65755396,
                "comment_id": 116260259,
                "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": 1610851452,
                "post_id": 65755396,
                "comment_id": 116261960,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 9629731,
                    "reputation": 51350,
                    "user_id": 10248678,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d8f818402f22d485b135a3b685ef908e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "oguz ismail",
                    "link": "https://stackoverflow.com/users/10248678/oguz-ismail"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1610861206,
                "post_id": 65755396,
                "comment_id": 116263239,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1610851399,
                "last_edit_date": 1610851399,
                "creation_date": 1610837005,
                "answer_id": 65755502,
                "question_id": 65755396,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The simplest approach would probably be to check whether or not the input is an object.  Assuming the input must either be an object or an array of objects, you could do worse than:\r\n\r\n    if type == &quot;object&quot; then .size else map(.size)|max end\r\n\r\nIn your case, I gather you would want to precede this by `.[]`:\r\n\r\n\r\n    .[] | if type == &quot;object&quot; then .size else map(.size)|max end\r\n\r\nThis produces:\r\n\r\n    &quot;123&quot;\r\n    &quot;5&quot;\r\n\r\nOf course, if you want the numeric max, you would have to make suitable modifications.",
                "title": "jq: treat single object as 1-element array"
            },
            {
                "up_vote_count": 5,
                "is_accepted": false,
                "score": 4,
                "last_activity_date": 1610894144,
                "creation_date": 1610894144,
                "answer_id": 65761917,
                "question_id": 65755396,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "A terse solution to this problem is provided by the alternative operator `//` and the optional operator `?`:\r\n\r\n    jq .[] | (max? // .) | .size\r\n\r\n- If the result of `.[]` is an array, `max` returns the maximum element of the array.\r\n- Othewise, the result of `.[]` is not an array, `max` will fail, the `?` operator will suppress the error, and the `//` operator will return the `.` instead.\r\nIn both cases, a single sub-object containing a `size` key is returned.",
                "title": "jq: treat single object as 1-element array"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": -1,
        "last_activity_date": 1610894144,
        "creation_date": 1610836061,
        "last_edit_date": 1610890310,
        "question_id": 65755396,
        "body_markdown": "I have several .json files (or rather, .xml files pre-parsed by [xq/yq][1]) that I want to parse. Unfortunately, the element I want to read (`.size`) can be inside an extra array (in which case I&#39;d `select` one of them) or just a single object, as follows:\r\n\r\n    {\r\n      &quot;Obj1&quot;: {\r\n        &quot;size&quot;: &quot;123&quot;\r\n      },\r\n      &quot;Obj2&quot;: [\r\n        { &quot;size&quot;: &quot;3&quot; },\r\n        { &quot;size&quot;: &quot;5&quot; }\r\n      ]\r\n    }\r\n\r\nIn case of `Obj1`, the query `jq &#39;.[].size&#39;` yields &quot;123&quot;, as expected, but it fails for `Obj2` with the error *Cannot index array with string &#39;size&#39;*.\r\nIn case of `Obj2`, to get a single `size` value (e.g. the maximum one), the query `jq &#39;.[]|max.size` yields &quot;5&quot;, as expected. But this fails for `Obj1` with the error *object `{&quot;size&quot;:&quot;123&quot;}` cannot be iterated over*.\r\n\r\n**Is there an expression that treats the single sub-object `{&quot;size&quot;:&quot;123&quot;}` like an array with one element, or otherwise allow me to treat both cases with the same query?**\r\n\r\n  [1]: https://github.com/kislyuk/yq",
        "link": "https://stackoverflow.com/questions/65755396/jq-treat-single-object-as-1-element-array",
        "title": "jq: treat single object as 1-element array"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1610901838,
                "last_edit_date": 1610901838,
                "creation_date": 1610897109,
                "answer_id": 65762482,
                "question_id": 65762113,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "This indeed is easier with the alternative version of your `proxies.json`. All you need is to store proxies in a variable as reference, and retrieve proxy hosts from it while updating hosts.\r\n``` shell\r\njq &#39;input as { $proxies } | .hosts[] |= . + { proxy_host: $proxies[.proxy_hostid].host }&#39; hosts.json proxies.json\r\n```\r\n&lt;sup&gt;[Online demo](https://jqplay.org/s/6lbToIX3aS)&lt;/sup&gt;",
                "title": "Using `jq` to add key/value to a json file using another json file as a source"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1610901838,
        "creation_date": 1610895184,
        "last_edit_date": 1610895519,
        "question_id": 65762113,
        "body_markdown": "Been struggling with this for a while and I&#39;m no closer to a solution. I&#39;m not very experienced using `jq`.\r\n\r\nI&#39;d like to take the values from one json file and add them to another file when other values in the dict match. The example files below demonstrate what I&#39;d like more clearly than an explanation.\r\n\r\nhosts.json:\r\n\r\n```\r\n{\r\n  &quot;hosts&quot;: [\r\n    {\r\n      &quot;host&quot;: &quot;hosta.example.com&quot;,\r\n      &quot;hostid&quot;: &quot;101&quot;,\r\n      &quot;proxy_hostid&quot;: &quot;1&quot;\r\n    },\r\n    {\r\n      &quot;host&quot;: &quot;hostb.example.com&quot;,\r\n      &quot;hostid&quot;: &quot;102&quot;,\r\n      &quot;proxy_hostid&quot;: &quot;1&quot;\r\n    },\r\n    {\r\n      &quot;host&quot;: &quot;hostc.example.com&quot;,\r\n      &quot;hostid&quot;: &quot;103&quot;,\r\n      &quot;proxy_hostid&quot;: &quot;2&quot;\r\n    }\r\n  ]\r\n}\r\n```\r\n\r\nproxies.json:\r\n\r\n```\r\n{\r\n  &quot;proxies&quot;: [\r\n    {\r\n      &quot;host&quot;: &quot;proxy1.example.com&quot;,\r\n      &quot;proxyid&quot;: &quot;1&quot;\r\n    },\r\n    {\r\n      &quot;host&quot;: &quot;proxy2.example.com&quot;,\r\n      &quot;proxyid&quot;: &quot;2&quot;\r\n    }\r\n  ]\r\n}\r\n```\r\n\r\nI also have the above file available with proxyid as the key, if this makes it easier:\r\n\r\n```\r\n{\r\n  &quot;proxies&quot;: {\r\n    &quot;1&quot;: {\r\n      &quot;host&quot;: &quot;proxy1.example.com&quot;,\r\n      &quot;proxyid&quot;: &quot;1&quot;\r\n    },\r\n    &quot;2&quot;: {\r\n      &quot;host&quot;: &quot;proxy2.example.com&quot;,\r\n      &quot;proxyid&quot;: &quot;2&quot;\r\n    }\r\n  }\r\n}\r\n```\r\n\r\nUsing these json files above (from the Zabbix API), I&#39;d like to add the value of `.proxies[].host` (from `proxies.json`) as `.hosts[].proxy_host` (to `hosts.json`).\r\n\r\nThis would only be when `.hosts[].proxy_hostid` equals `.proxies[].proxyid`\r\n\r\nDesired output:\r\n\r\n```\r\n{\r\n  &quot;hosts&quot;: [\r\n    {\r\n      &quot;host&quot;: &quot;hosta.example.com&quot;,\r\n      &quot;hostid&quot;: &quot;101&quot;,\r\n      &quot;proxy_hostid&quot;: &quot;1&quot;,\r\n      &quot;proxy_host&quot;: &quot;proxy1.example.com&quot;\r\n    },\r\n    {\r\n      &quot;host&quot;: &quot;hostb.example.com&quot;,\r\n      &quot;hostid&quot;: &quot;102&quot;,\r\n      &quot;proxy_hostid&quot;: &quot;1&quot;,\r\n      &quot;proxy_host&quot;: &quot;proxy1.example.com&quot;\r\n    },\r\n    {\r\n      &quot;host&quot;: &quot;hostc.example.com&quot;,\r\n      &quot;hostid&quot;: &quot;103&quot;,\r\n      &quot;proxy_hostid&quot;: &quot;2&quot;,\r\n      &quot;proxy_host&quot;: &quot;proxy2.example.com&quot;\r\n    }\r\n  ]\r\n}\r\n\r\n```\r\n\r\nI&#39;ve tried many different ways of doing this, and think I need to use `jq -s` or `jq --slurpfile`, but I&#39;ve reached a lot of dead-ends and can&#39;t find a solution.\r\n\r\n`jq &#39;input as $p | map(.[].proxy_host = $p.proxies[].proxyid)&#39; hosts.json proxies.json`\r\n\r\nI think I would need something like this as well, but not sure how to use it.\r\n\r\n`if .hosts[].proxy_hostid == .proxies[].proxyid then .hosts[].proxy_host = .proxies[].host else empty end&#39;`\r\n\r\nI&#39;ve found these questions but they haven&#39;t helped :(\r\n\r\n* [How do I use a value as a key reference in jq?](https://stackoverflow.com/questions/61092531/how-do-i-use-a-value-as-a-key-reference-in-jq) &lt;- I think this one is the closest\r\n* [Lookup values from one JSON file and replace in another](https://stackoverflow.com/questions/54964527/lookup-values-from-one-json-file-and-replace-in-another)\r\n* [Using jq find key/value pair based on another key/value pair](https://stackoverflow.com/questions/60546107/using-jq-find-key-value-pair-based-on-another-key-value-pair)",
        "link": "https://stackoverflow.com/questions/65762113/using-jq-to-add-key-value-to-a-json-file-using-another-json-file-as-a-source",
        "title": "Using `jq` to add key/value to a json file using another json file as a source"
    },
    {
        "tags": [
            "bash",
            "azure",
            "jq",
            "azure-cli",
            "azure-cli2"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 4663062,
                    "reputation": 89888,
                    "user_id": 3776858,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/Cagbk.jpg?s=256",
                    "display_name": "Cyrus",
                    "link": "https://stackoverflow.com/users/3776858/cyrus"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1610905175,
                "post_id": 65763809,
                "comment_id": 116274245,
                "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": 2,
                "creation_date": 1610905294,
                "post_id": 65763809,
                "comment_id": 116274281,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2043236,
                    "reputation": 1797,
                    "user_id": 1823936,
                    "user_type": "registered",
                    "accept_rate": 53,
                    "profile_image": "https://i.sstatic.net/cJxCF.jpg?s=256",
                    "display_name": "Rezoan",
                    "link": "https://stackoverflow.com/users/1823936/rezoan"
                },
                "reply_to_user": {
                    "account_id": 4663062,
                    "reputation": 89888,
                    "user_id": 3776858,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/Cagbk.jpg?s=256",
                    "display_name": "Cyrus",
                    "link": "https://stackoverflow.com/users/3776858/cyrus"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1610905342,
                "post_id": 65763809,
                "comment_id": 116274300,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2043236,
                    "reputation": 1797,
                    "user_id": 1823936,
                    "user_type": "registered",
                    "accept_rate": 53,
                    "profile_image": "https://i.sstatic.net/cJxCF.jpg?s=256",
                    "display_name": "Rezoan",
                    "link": "https://stackoverflow.com/users/1823936/rezoan"
                },
                "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": 1610905694,
                "post_id": 65763809,
                "comment_id": 116274434,
                "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": 1610906091,
                "post_id": 65763809,
                "comment_id": 116274569,
                "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": 1610906143,
                "post_id": 65763809,
                "comment_id": 116274580,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 9629731,
                    "reputation": 51350,
                    "user_id": 10248678,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d8f818402f22d485b135a3b685ef908e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "oguz ismail",
                    "link": "https://stackoverflow.com/users/10248678/oguz-ismail"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1610906243,
                "post_id": 65763809,
                "comment_id": 116274620,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2043236,
                    "reputation": 1797,
                    "user_id": 1823936,
                    "user_type": "registered",
                    "accept_rate": 53,
                    "profile_image": "https://i.sstatic.net/cJxCF.jpg?s=256",
                    "display_name": "Rezoan",
                    "link": "https://stackoverflow.com/users/1823936/rezoan"
                },
                "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": 1,
                "creation_date": 1610906321,
                "post_id": 65763809,
                "comment_id": 116274651,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 13548354,
                    "reputation": 31702,
                    "user_id": 9773937,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/gUlzf.jpg?s=256",
                    "display_name": "Charles Xu",
                    "link": "https://stackoverflow.com/users/9773937/charles-xu"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1611128508,
                "post_id": 65763809,
                "comment_id": 116347372,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1610937737,
                "creation_date": 1610937737,
                "answer_id": 65768157,
                "question_id": 65763809,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The suitable bash script example here:\r\n\r\n    for id in $(az account management-group list --query [].id -o tsv)\r\n    do\r\n    \techo &quot;Management Group ID: $id&quot;\r\n    \taz policy assignment list --scope $id\r\n    done",
                "title": "How to use bash variable in Azure CLI"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1610937737,
        "creation_date": 1610904741,
        "last_edit_date": 1610905916,
        "question_id": 65763809,
        "body_markdown": "I am trying to use a bash variable (**ID in the below script**) in azure CLI command. but seems its not working and throwing below error:\r\n\r\n&gt; usage error `--scope`: must be a fully qualified ARM ID.\r\n\r\nThe error is happening on line `az policy assignment list --scope $ID`\r\n\r\nI have verified by echoing the **ID variable** and its outputting correctly which is:\r\n\r\n&gt; &quot;/providers/Microsoft.Management/managementGroups/test-management-group&quot;\r\n\r\n**What i am doing wrong here?**\r\n\r\nFull script is here:\r\n\r\n    MGS=$(az account management-group list)\r\n    for (( i = 0; i &lt; ${#MGS[@]}; i++ )) \r\n    do \r\n        ID=$(echo $MGS | jq .[$i].id)\r\n        echo $ID\r\n        az policy assignment list --scope $ID\r\n    done",
        "link": "https://stackoverflow.com/questions/65763809/how-to-use-bash-variable-in-azure-cli",
        "title": "How to use bash variable in Azure CLI"
    },
    {
        "tags": [
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 245734,
                    "reputation": 337890,
                    "user_id": 519413,
                    "user_type": "registered",
                    "accept_rate": 97,
                    "profile_image": "https://www.gravatar.com/avatar/7839089cd91dc5cc5eb1e0cdbf3312ed?s=256&d=identicon&r=PG",
                    "display_name": "Rory McCrossan",
                    "link": "https://stackoverflow.com/users/519413/rory-mccrossan"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1610983221,
                "post_id": 65777236,
                "comment_id": 116298249,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 7653729,
                    "reputation": 113,
                    "user_id": 6322010,
                    "user_type": "registered",
                    "profile_image": "https://lh4.googleusercontent.com/-6iEkJ7Xw_Ec/AAAAAAAAAAI/AAAAAAAAQJA/pikebUlj1W8/s256-rj/photo.jpg",
                    "display_name": "Abhijit Das",
                    "link": "https://stackoverflow.com/users/6322010/abhijit-das"
                },
                "reply_to_user": {
                    "account_id": 245734,
                    "reputation": 337890,
                    "user_id": 519413,
                    "user_type": "registered",
                    "accept_rate": 97,
                    "profile_image": "https://www.gravatar.com/avatar/7839089cd91dc5cc5eb1e0cdbf3312ed?s=256&d=identicon&r=PG",
                    "display_name": "Rory McCrossan",
                    "link": "https://stackoverflow.com/users/519413/rory-mccrossan"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1610983777,
                "post_id": 65777236,
                "comment_id": 116298537,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 7653729,
                    "reputation": 113,
                    "user_id": 6322010,
                    "user_type": "registered",
                    "profile_image": "https://lh4.googleusercontent.com/-6iEkJ7Xw_Ec/AAAAAAAAAAI/AAAAAAAAQJA/pikebUlj1W8/s256-rj/photo.jpg",
                    "display_name": "Abhijit Das",
                    "link": "https://stackoverflow.com/users/6322010/abhijit-das"
                },
                "reply_to_user": {
                    "account_id": 245734,
                    "reputation": 337890,
                    "user_id": 519413,
                    "user_type": "registered",
                    "accept_rate": 97,
                    "profile_image": "https://www.gravatar.com/avatar/7839089cd91dc5cc5eb1e0cdbf3312ed?s=256&d=identicon&r=PG",
                    "display_name": "Rory McCrossan",
                    "link": "https://stackoverflow.com/users/519413/rory-mccrossan"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1610985097,
                "post_id": 65777236,
                "comment_id": 116299196,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1611001977,
                "creation_date": 1611001977,
                "answer_id": 65781672,
                "question_id": 65777236,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "After fixing some minor problems with the full JSON shown in the Q, the invocation:\r\n\r\n```\r\njq &#39;.[3][].srcip&#39; input.json\r\n```\r\nyields:\r\n```\r\n&quot;1.1.1.1&quot;\r\n&quot;3.3.3.3&quot;\r\n```\r\n## Notes\r\n\r\n1. `.[3][].scrip` is just a shortened form of: `.[3] | .[] | .srcip`\r\n\r\n2. In your initial query, `[.[]]` effectively does nothing because the input is an array.  \r\n",
                "title": "Unable to retrieve key:values, getting error --&gt; jq: error (at &lt;stdin&gt;:0): Cannot index number with string"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": -1,
        "last_activity_date": 1611001977,
        "creation_date": 1610983052,
        "last_edit_date": 1611001397,
        "question_id": 65777236,
        "body_markdown": "Unable to extract key:value pairs, tried indexing the block.\r\n\r\n```\r\n&lt;nd.com.citrix.netscaler.json&quot; -X GET https://abcd.com/nitro/v1/config/lbpersistentsessions?args=vserver:puppet-vip.ta10.sd | jq &#39;[.[] ] | .[3] | [.srcip]&#39;\r\n```\r\n\r\nGetting the following error :\r\n\r\n`\r\njq: error (at &lt;stdin&gt;:0): Cannot index array with string &quot;srcip&quot;\r\n`\r\n\r\nI need to extract the key:values as srcip and destip (see below)\r\n\r\n```\r\n&lt;ion/vnd.com.citrix.netscaler.json&quot; -X GET https://abcd.com/nitro/v1/config/lbpersistentsessions?args=vserver:somevip | jq &#39;[.[] ] | .[3]&#39; | more\r\n[\r\n  {\r\n    &quot;vserver&quot;: &quot;somevip&quot;,\r\n    &quot;type&quot;: &quot;1&quot;,\r\n    &quot;typestring&quot;: &quot;SOURCEIP&quot;,\r\n    &quot;srcip&quot;: “1.1.1.1&quot;,\r\n    &quot;srcipv6&quot;: &quot;::/0&quot;,\r\n    &quot;destip&quot;: &quot;2.2.2.2&quot;,\r\n    &quot;destipv6&quot;: &quot;::/0&quot;,\r\n    &quot;flags&quot;: false,\r\n    &quot;destport&quot;: 0,\r\n    &quot;vservername&quot;: “somevip”,\r\n    &quot;timeout&quot;: &quot;0&quot;,\r\n    &quot;referencecount&quot;: &quot;0&quot;,\r\n    &quot;persistenceparam&quot;: &quot;1.1.1.1&quot;\r\n  },\r\n```\r\n\r\nI had to use [.3] to index as the original output is : \r\n\r\n```\r\n&lt;-Type:application/vnd.com.citrix.netscaler.json&quot; -X GET https://abcd.com/nitro/v1/config/lbpersistentsessions?args=vserver:somevip | jq &#39;[.[] ]&#39; | more\r\n[\r\n  0,\r\n  &quot;Done&quot;,\r\n  &quot;NONE&quot;,\r\n  [\r\n    {\r\n      &quot;vserver&quot;: &quot;somevip&quot;,\r\n      &quot;type&quot;: &quot;1&quot;,\r\n      &quot;typestring&quot;: &quot;SOURCEIP&quot;,\r\n      &quot;srcip&quot;: “1.1.1.1”,\r\n      &quot;srcipv6&quot;: &quot;::/0&quot;,\r\n      &quot;destip&quot;: &quot;2.2.2.2&quot;,\r\n      &quot;destipv6&quot;: &quot;::/0&quot;,\r\n      &quot;flags&quot;: false,\r\n      &quot;destport&quot;: 0,\r\n      &quot;vservername&quot;: &quot;somevip&quot;,\r\n      &quot;timeout&quot;: &quot;0&quot;,\r\n      &quot;referencecount&quot;: &quot;0&quot;,\r\n      &quot;persistenceparam&quot;: &quot;1.1.1.1&quot;\r\n    },\r\n    {\r\n      &quot;vserver&quot;: &quot;somevip&quot;,\r\n      &quot;type&quot;: &quot;1&quot;,\r\n      &quot;typestring&quot;: &quot;SOURCEIP&quot;,\r\n      &quot;srcip&quot;: &quot;3.3.3.3”,\r\n      &quot;srcipv6&quot;: &quot;::/0&quot;,\r\n      &quot;destip&quot;: &quot;4.4.4.4”,\r\n      &quot;destipv6&quot;: &quot;::/0&quot;,\r\n      &quot;flags&quot;: false,\r\n      &quot;destport&quot;: 0,\r\n      &quot;vservername&quot;: &quot;somevip&quot;,\r\n      &quot;timeout&quot;: &quot;0&quot;,\r\n      &quot;referencecount&quot;: &quot;0&quot;,\r\n      &quot;persistenceparam&quot;: &quot;1.1.1.1&quot;\r\n    },\r\n```\r\n\r\nAlso, tried this way and get the error :\r\n\r\n\r\n```\r\n&lt;GET https://abcd.com/nitro/v1/config/lbpersistentsessions?args=vserver:somevip | jq -r &#39;.[] | select(.vserver == &quot;somevip&quot;) | .srcip&#39;\r\n```\r\n`jq: error (at &lt;stdin&gt;:0): Cannot index number with string &quot;vserver&quot;`\r\n",
        "link": "https://stackoverflow.com/questions/65777236/unable-to-retrieve-keyvalues-getting-error-jq-error-at-stdin0-canno",
        "title": "Unable to retrieve key:values, getting error --&gt; jq: error (at &lt;stdin&gt;:0): Cannot index number with string"
    },
    {
        "tags": [
            "json",
            "select",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1611013236,
                "post_id": 65783281,
                "comment_id": 116309363,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1611012755,
                "creation_date": 1611012755,
                "answer_id": 65783524,
                "question_id": 65783281,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Well, just use `select` like this:\r\n\r\n    cat data.json | jq -r &#39;.companies[] | select(.identity) | .domains[]&#39; &gt; yourfile.txt\r\n\r\nTry it out https://jqplay.org/s/NKD3-BkXLj",
                "title": "Using JQ to grep boolean and array at the same time"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1611059284,
        "creation_date": 1611011087,
        "last_edit_date": 1611059284,
        "question_id": 65783281,
        "body_markdown": "I&#39;m pretty new with Jq and have some trouble starting.\r\n\r\nI am making a new bash script that gets a .json file from URL and it needs to grep multiple values but save only domains to a new file as output.\r\n\r\nIn this example, I would need to grep all companies with identity==true, but save only the domains from the array that matches identity=true to a new file.\r\n\r\nI have tried almost everything but to no luck. \r\n\r\n\r\nExample JSON:\r\n\r\n```    \r\n{\r\n\t&quot;companies&quot;: [\r\n\t\t{\r\n\t\t\t&quot;name&quot;: &quot;CompanyOne&quot;,\r\n\t\t\t&quot;url&quot;: &quot;https://companyone.com&quot;,\r\n\t\t\t&quot;identity&quot;: false,\r\n\t\t\t&quot;domains&quot;: [\r\n\t\t\t\t&quot;companyone.com&quot;\r\n\t\t\t]\r\n\t\t},\r\n\t\t{\r\n\t\t\t&quot;name&quot;: &quot;CompanyTwo&quot;,\r\n\t\t\t&quot;url&quot;: &quot;https://companytwotwo.com&quot;,\r\n\t\t\t&quot;identity&quot;: true,\r\n\t\t\t&quot;domains&quot;: [\r\n\t\t\t\t&quot;companytwo.com&quot;,\r\n\t\t\t\t&quot;companytwotwo.net&quot;\r\n\t\t\t]\r\n\t\t}\r\n    ]\r\n}\r\n```\r\n\r\nDesired output:\r\n\r\n    companytwo.com\r\n    companytwotwo.net",
        "link": "https://stackoverflow.com/questions/65783281/using-jq-to-grep-boolean-and-array-at-the-same-time",
        "title": "Using JQ to grep boolean and array at the same time"
    },
    {
        "tags": [
            "arrays",
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1611125057,
                "last_edit_date": 1611125057,
                "creation_date": 1611107444,
                "answer_id": 65802016,
                "question_id": 65800468,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Flattening can be done via the idiomatic expression **del(A) + A[]** here, and what&#39;s left is construction of the surrounding structure, which is trivial.\r\n``` none\r\n.data |= [{values: map(del(.value) + .value[])}]\r\n```\r\n&lt;sup&gt;[Online demo](https://jqplay.org/s/TAihF8Vqd-)&lt;/sup&gt;",
                "title": "Flatten/merge JSON into single array of objects with JQ"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1611146632,
        "creation_date": 1611095456,
        "last_edit_date": 1611146632,
        "question_id": 65800468,
        "body_markdown": "I am trying to merge a nested array of objects within a parent json object into a single array of objects with `jq`. Basically I want to merge each `value` array of objects into a single `values` array underneath the `data` array.\r\n\r\n**Example Input:**\r\n\r\n```\r\n{\r\n  &quot;data&quot;: [\r\n    {\r\n      &quot;id&quot;: 1,\r\n      &quot;error&quot;: &quot;error1&quot;,\r\n      &quot;key&quot;: &quot;key1&quot;,\r\n      &quot;value&quot;: [\r\n        {\r\n          &quot;class_name&quot;: &quot;namespace_read&quot;,\r\n          &quot;in_max&quot;: 148,\r\n          &quot;in_min&quot;: 112,\r\n          &quot;in_rate&quot;: 359750.71875\r\n        },\r\n        {\r\n          &quot;class_name&quot;: &quot;namespace_write&quot;,\r\n          &quot;in_max&quot;: 184,\r\n          &quot;in_min&quot;: 152,\r\n          &quot;in_rate&quot;: 656.1185913085938\r\n        },\r\n        {\r\n          &quot;class_name&quot;: &quot;namespace_test&quot;,\r\n          &quot;in_max&quot;: 152,\r\n          &quot;in_min&quot;: 152,\r\n          &quot;in_rate&quot;: 29.93098068237305\r\n        }\r\n      ]\r\n    },\r\n    {\r\n      &quot;id&quot;: 2,\r\n      &quot;error&quot;: &quot;error2&quot;,\r\n      &quot;key&quot;: &quot;key2&quot;,\r\n      &quot;value&quot;: [\r\n        {\r\n          &quot;class_name&quot;: &quot;namespace_read&quot;,\r\n          &quot;in_max&quot;: 156,\r\n          &quot;in_min&quot;: 112,\r\n          &quot;in_rate&quot;: 459885.03125\r\n        },\r\n        {\r\n          &quot;class_name&quot;: &quot;namespace_write&quot;,\r\n          &quot;in_max&quot;: 176,\r\n          &quot;in_min&quot;: 152,\r\n          &quot;in_rate&quot;: 8970.888671875\r\n        },\r\n        {\r\n          &quot;class_name&quot;: &quot;namespace_test&quot;,\r\n          &quot;in_max&quot;: 152,\r\n          &quot;in_min&quot;: 152,\r\n          &quot;in_rate&quot;: 262.3605346679688\r\n        }\r\n      ]\r\n    }\r\n  ]\r\n}\r\n```\r\n\r\n**Desired Output:**\r\n```\r\n{\r\n  &quot;data&quot;: [\r\n    {\r\n      &quot;values&quot;: [\r\n        {\r\n          &quot;id&quot;: 1,\r\n          &quot;error&quot;: &quot;error1&quot;,\r\n          &quot;key&quot;: &quot;key1&quot;,\r\n          &quot;class_name&quot;: &quot;namespace_read&quot;,\r\n          &quot;in_max&quot;: 148,\r\n          &quot;in_min&quot;: 112,\r\n          &quot;in_rate&quot;: 359750.71875\r\n        },\r\n        {\r\n          &quot;id&quot;: 1,\r\n          &quot;error&quot;: &quot;error1&quot;,\r\n          &quot;key&quot;: &quot;key1&quot;,\r\n          &quot;class_name&quot;: &quot;namespace_write&quot;,\r\n          &quot;in_max&quot;: 184,\r\n          &quot;in_min&quot;: 152,\r\n          &quot;in_rate&quot;: 656.1185913085938\r\n        },\r\n        {\r\n          &quot;id&quot;: 1,\r\n          &quot;error&quot;: &quot;error1&quot;,\r\n          &quot;key&quot;: &quot;key1&quot;,\r\n          &quot;class_name&quot;: &quot;namespace_test&quot;,\r\n          &quot;in_max&quot;: 152,\r\n          &quot;in_min&quot;: 152,\r\n          &quot;in_rate&quot;: 29.93098068237305\r\n        },\r\n        {\r\n          &quot;id&quot;: 2,\r\n          &quot;error&quot;: &quot;error2&quot;,\r\n          &quot;key&quot;: &quot;key2&quot;,\r\n          &quot;class_name&quot;: &quot;namespace_read&quot;,\r\n          &quot;in_max&quot;: 156,\r\n          &quot;in_min&quot;: 112,\r\n          &quot;in_rate&quot;: 459885.03125\r\n        },\r\n        {\r\n          &quot;id&quot;: 2,\r\n          &quot;error&quot;: &quot;error2&quot;,\r\n          &quot;key&quot;: &quot;key2&quot;,\r\n          &quot;class_name&quot;: &quot;namespace_write&quot;,\r\n          &quot;in_max&quot;: 176,\r\n          &quot;in_min&quot;: 152,\r\n          &quot;in_rate&quot;: 8970.888671875\r\n        },\r\n        {\r\n          &quot;id&quot;: 2,\r\n          &quot;error&quot;: &quot;error2&quot;,\r\n          &quot;key&quot;: &quot;key2&quot;,\r\n          &quot;class_name&quot;: &quot;namespace_test&quot;,\r\n          &quot;in_max&quot;: 152,\r\n          &quot;in_min&quot;: 152,\r\n          &quot;in_rate&quot;: 262.3605346679688\r\n        }\r\n      ]\r\n    }\r\n  ]\r\n}\r\n```\r\n\r\nI was trying something like below with jq, but am trying to find a more scalable way to craft the output:\r\n\r\n```\r\n{ &quot;id&quot;: .data[].id, &quot;error&quot;: .data[].error, &quot;key&quot;: .data[].key, &quot;className&quot;: .data[].value[].class_name, &quot;inMax&quot;: .data[].value[].in_max }\r\n```\r\n\r\n",
        "link": "https://stackoverflow.com/questions/65800468/flatten-merge-json-into-single-array-of-objects-with-jq",
        "title": "Flatten/merge JSON into single array of objects with JQ"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 9629731,
                    "reputation": 51350,
                    "user_id": 10248678,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d8f818402f22d485b135a3b685ef908e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "oguz ismail",
                    "link": "https://stackoverflow.com/users/10248678/oguz-ismail"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1611154156,
                "post_id": 65811824,
                "comment_id": 116359863,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 17882377,
                    "reputation": 17,
                    "user_id": 14408107,
                    "user_type": "registered",
                    "profile_image": "https://lh3.googleusercontent.com/a-/AOh14GiR6vE1UhW68dm90P4sh26BQ-ijlSscYys4nIfS=k-s256",
                    "display_name": "Suhas",
                    "link": "https://stackoverflow.com/users/14408107/suhas"
                },
                "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": 1,
                "creation_date": 1611155033,
                "post_id": 65811824,
                "comment_id": 116360389,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 5351266,
                    "reputation": 73064,
                    "user_id": 4265352,
                    "user_type": "registered",
                    "profile_image": "https://lh4.googleusercontent.com/-lzAUc5pYb24/AAAAAAAAAAI/AAAAAAAAAGQ/q3h7bZUnqrs/s256-rj/photo.jpg",
                    "display_name": "axiac",
                    "link": "https://stackoverflow.com/users/4265352/axiac"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1611155188,
                "post_id": 65811824,
                "comment_id": 116360483,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 17882377,
                    "reputation": 17,
                    "user_id": 14408107,
                    "user_type": "registered",
                    "profile_image": "https://lh3.googleusercontent.com/a-/AOh14GiR6vE1UhW68dm90P4sh26BQ-ijlSscYys4nIfS=k-s256",
                    "display_name": "Suhas",
                    "link": "https://stackoverflow.com/users/14408107/suhas"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1611155552,
                "post_id": 65811824,
                "comment_id": 116360696,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1611157736,
                "last_edit_date": 1611157736,
                "creation_date": 1611155609,
                "answer_id": 65812292,
                "question_id": 65811824,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "    $ jq -r &#39;.data[0] | [.id, (.MoreInfo.localInfo | .expirationTime, .isExpirationDateCalculated)] | @tsv&#39; tmp.json\r\n    3a7d3f23-edd2-4e14-8e5b-473ccb2d225e\t2021-02-19T18:30:00.000Z\tfalse\r\n\r\nSome explanations:\r\n\r\n * `.data[0]` selects the object containing `id` from the input.\r\n * `[.id, ...]` creates a new array from the incoming object, consisting of\r\n   * the value associated with `id`\r\n   * the values associated with two of the keys in the object associated with the path `MoreInfo.localInfo`\r\n * The final part takes the previous 3-element array and feeds it to `@tsv`, which outputs a tab-separated string.\r\n * `-r` outputs a raw string, rather than a JSON string (complete with quotation marks).\r\n\r\nA simpler, but more repetitive, filter might be\r\n\r\n    [.data[0].id,\r\n     .data[0].MoreInfo.localInfo.expirationTime,\r\n     .data[0].MoreInfo.localInfo.isExpirationDateCalculated] | @tsv",
                "title": "Extracting key pair values inside from a JSON with JQ"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1611157736,
        "creation_date": 1611153925,
        "last_edit_date": 1611155010,
        "question_id": 65811824,
        "body_markdown": "I have a part JSON output which looks something like this\r\n\r\n    {\r\n    \t&quot;data&quot;: [{\r\n    \t\t&quot;id&quot;: &quot;3a7d3f23-edd2-4e14-8e5b-473ccb2d225e&quot;,\r\n    \t\t&quot;MoreInfo&quot;: {\r\n    \t\t\t&quot;Info1&quot;: [],\r\n    \t\t\t&quot;Info2&quot;: [],\r\n    \t\t\t&quot;localInfo&quot;: {\r\n    \t\t\t\t&quot;id&quot;: &quot;6fa2edf0-d034-458d-857e-e86ed14e850f&quot;,\r\n    \t\t\t\t&quot;isExpirationDateCalculated&quot;: false,\r\n    \t\t\t\t&quot;expirationTime&quot;: &quot;2021-02-19T18:30:00.000Z&quot;\r\n    \t\t\t},\r\n    \t\t\t&quot;replicationInfos&quot;: []\r\n    \t\t},\r\n    \t\t&quot;vmName&quot;: &quot;AD&quot;\r\n    \r\n    \t}]\r\n    }\r\n\r\nI am trying to have this formatted like:\r\n\r\n&gt; id expirationTime isExpirationDateCalculated\r\n\r\nSomething that will look like: \r\n\r\n    3a7d3f23-edd2-4e14-8e5b-473ccb2d225e         2021-02-19T18:30:00.000Z    true\r\n\r\nAny suggestions please? ",
        "link": "https://stackoverflow.com/questions/65811824/extracting-key-pair-values-inside-from-a-json-with-jq",
        "title": "Extracting key pair values inside from a JSON with JQ"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1611160774,
                "last_edit_date": 1611160774,
                "creation_date": 1611159717,
                "answer_id": 65813453,
                "question_id": 65813245,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You don&#39;t need to invoke JQ twice there. The second object can be fetched using the [`input`](https://stedolan.github.io/jq/manual/#input) keyword.\r\n```\r\n.Objects += input.Objects\r\n```\r\n&lt;sup&gt;[Online demo](https://jqplay.org/s/IoHYN7cDpO)&lt;/sup&gt;",
                "title": "Using JQ to merge two JSON snippets from one file"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1611166071,
                "last_edit_date": 1611166071,
                "creation_date": 1611159968,
                "answer_id": 65813530,
                "question_id": 65813245,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can use `reduce`:\r\n\r\n```jq\r\njq -s &#39;reduce .[] as $item ({ Quiet: false }; .Objects += $item.Objects)&#39;\r\n```\r\n\r\nSee it [in action](https://jqplay.org/s/jBSmueiAdd).\r\n\r\nAs @oguz-ismail suggested in a comment, the `-s` (slurp) flag can be removed by using `inputs` to get the rest of the entries after the first one:\r\n\r\n```jq\r\njq &#39;reduce inputs as $item (.; .Objects += $item.Objects)&#39;\r\n```\r\n\r\nSee it [in action](https://jqplay.org/s/rpitQakQP0).\r\n\r\nBoth versions work with any number of entries in the input (the second version requires at least one).\r\n\r\n",
                "title": "Using JQ to merge two JSON snippets from one file"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 2,
        "last_activity_date": 1611166071,
        "creation_date": 1611158932,
        "last_edit_date": 1611165619,
        "question_id": 65813245,
        "body_markdown": "I&#39;ve got output from a script that outputs two structurally identical JSON snippets into one file:\r\n```\r\n{\r\n    &quot;Objects&quot;: [\r\n        {\r\n            &quot;Key&quot;: &quot;somevalue&quot;,\r\n            &quot;VersionId&quot;: &quot;someversion&quot;\r\n        }\r\n    ],\r\n    &quot;Quiet&quot;: false\r\n}\r\n{\r\n    &quot;Objects&quot;: [\r\n        {\r\n            &quot;Key&quot;: &quot;someothervalue&quot;,\r\n            &quot;VersionId&quot;: &quot;someotherversion&quot;\r\n        }\r\n    ],\r\n    &quot;Quiet&quot;: false\r\n}\r\n```\r\nI would like to pass this output through JQ to have one Objects[] list, concatenating all of the objects within the two lists, and outputting the same overall structure.  I can accomplish it with piping between two separate JQ commands:\r\n```\r\njq &#39;.Objects[]&#39; inputfile | jq -s &#39;{&quot;Objects&quot;:., &quot;Quiet&quot;:false}&#39; -\r\n```\r\n\r\nBut I&#39;m wondering if there is a more elegant way to do so using only one invocation of JQ.\r\n\r\nI&#39;m currently using JQ version 1.5 but can update if needed.",
        "link": "https://stackoverflow.com/questions/65813245/using-jq-to-merge-two-json-snippets-from-one-file",
        "title": "Using JQ to merge two JSON snippets from one file"
    },
    {
        "tags": [
            "shell",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1611167537,
                "post_id": 65815461,
                "comment_id": 116366791,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 6196394,
                    "reputation": 86601,
                    "user_id": 5291015,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/4tAvO.jpg?s=256",
                    "display_name": "Inian",
                    "link": "https://stackoverflow.com/users/5291015/inian"
                },
                "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": 1611167725,
                "post_id": 65815461,
                "comment_id": 116366882,
                "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": 6196394,
                    "reputation": 86601,
                    "user_id": 5291015,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/4tAvO.jpg?s=256",
                    "display_name": "Inian",
                    "link": "https://stackoverflow.com/users/5291015/inian"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1611167873,
                "post_id": 65815461,
                "comment_id": 116366956,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1143565,
                    "reputation": 535973,
                    "user_id": 1126841,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/fa05233b2357f8d11c22ef4cfc7bb85c?s=256&d=identicon&r=PG",
                    "display_name": "chepner",
                    "link": "https://stackoverflow.com/users/1126841/chepner"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1611168016,
                "post_id": 65815461,
                "comment_id": 116367024,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 3498061,
                    "reputation": 2624,
                    "user_id": 6782615,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/R6GFq.png?s=256",
                    "display_name": "ilmoi",
                    "link": "https://stackoverflow.com/users/6782615/ilmoi"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1611168933,
                "post_id": 65815461,
                "comment_id": 116367376,
                "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": 1611171713,
                "post_id": 65815461,
                "comment_id": 116368492,
                "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": 1611171817,
                "post_id": 65815461,
                "comment_id": 116368541,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "is_answered": false,
        "answer_count": 0,
        "score": 0,
        "last_activity_date": 1611171842,
        "creation_date": 1611167252,
        "question_id": 65815461,
        "body_markdown": "This seems like a super simple task but I somehow can&#39;t figure it out / find an answer online.\r\n\r\nI have some piped output in the form of `{&quot;key&quot;: &quot;value&quot;}` and I need to insert it into an existing json file along the lines of:\r\n```\r\n{\r\n &quot;existing_key&quot;:&quot;value&quot;\r\n}\r\n```\r\nto get:\r\n```\r\n{\r\n &quot;existing_key&quot;:&quot;value&quot;,\r\n &quot;key&quot;: &quot;value&quot;\r\n}\r\n```\r\n\r\nHow do I do this using jq?",
        "link": "https://stackoverflow.com/questions/65815461/jq-take-piped-output-and-insert-into-json-file",
        "title": "jq: take piped output and insert into json file"
    },
    {
        "tags": [
            "json",
            "nested",
            "jq",
            "updates"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1611210202,
                "last_edit_date": 1611210202,
                "creation_date": 1611209939,
                "answer_id": 65822084,
                "question_id": 65821660,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "That the fields are not at the same level doesn&#39;t really matter here.\r\n```\r\n.models[] |= (.tests[].&quot;dbt_utils.equal_rowcount&quot;.compare_model = &quot;(\\(.name))&quot;)\r\n```\r\n&lt;sup&gt;[Online demo](https://jqplay.org/s/-HcdQGxFrl)&lt;/sup&gt;",
                "title": "Update deeply nested field with value from higher-level object in JQ"
            },
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1611210835,
                "last_edit_date": 1611210835,
                "creation_date": 1611210188,
                "answer_id": 65822125,
                "question_id": 65821660,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The key to a simple solution is to use `|=`, e.g.\r\n\r\n```\r\n.models |= \r\n  map(.name as $name\r\n      | (.tests[].&quot;dbt_utils.equal_rowcount&quot;.compare_model =\r\n         $name))\r\n```\r\n\r\nTo wrap the replacement value in parentheses, just add them:\r\n```\r\n.models |= \r\n  map(&quot;(\\(.name))&quot; as $name\r\n      | (.tests[].&quot;dbt_utils.equal_rowcount&quot;.compare_model =\r\n         $name))\r\n```\r\n\r\nIf you want the replacement to be conditional on the existing value being `null`, you could perhaps (depending on the exact requirements) use `//=`.\r\n\r\n## Using `//=` and `walk`\r\n\r\nHere&#39;s another take on the problem:\r\n\r\n```\r\n.models\r\n  |= map(&quot;(\\(.name))&quot; as $name\r\n         | walk(if type==&quot;object&quot; and has(&quot;compare_model&quot;) \r\n                then .compare_model //= $name\r\n                else . end))\r\n```",
                "title": "Update deeply nested field with value from higher-level object in JQ"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1611210835,
        "creation_date": 1611207023,
        "last_edit_date": 1611210530,
        "question_id": 65821660,
        "body_markdown": "Given the following input JSON:\r\n\r\n```json\r\n{\r\n  &quot;version&quot;: 2,\r\n  &quot;models&quot;: [\r\n    {\r\n      &quot;name&quot;: &quot;first_table&quot;,\r\n      &quot;tests&quot;: [\r\n        {\r\n          &quot;dbt_utils.equal_rowcount&quot;: {\r\n            &quot;compare_model&quot;: null\r\n          }\r\n        }\r\n      ]\r\n    },\r\n    {\r\n      &quot;name&quot;: &quot;second_table&quot;,\r\n      &quot;tests&quot;: [\r\n        {\r\n          &quot;dbt_utils.equal_rowcount&quot;: {\r\n            &quot;compare_model&quot;: null\r\n          }\r\n        }\r\n      ]\r\n    }\r\n  ]\r\n}\r\n\r\n```\r\n\r\n**How would I, using `jq`, replace the `null` (i.e., the value of `&quot;compare_model&quot;`) with the value from the `&quot;name&quot;` key?** Note that the key-value pairs in question here are not at the same level in the hierarchy: the former is nested in an object in an array, and it is this array that is at the same level as the latter.\r\n\r\nFor example, the output file should read:\r\n\r\n```json\r\n{\r\n  &quot;version&quot;: 2,\r\n  &quot;models&quot;: [\r\n    {\r\n      &quot;name&quot;: &quot;first_table&quot;,\r\n      &quot;tests&quot;: [\r\n        {\r\n          &quot;dbt_utils.equal_rowcount&quot;: {\r\n            &quot;compare_model&quot;: &quot;first_table&quot;\r\n          }\r\n        }\r\n      ]\r\n    },\r\n    {\r\n      &quot;name&quot;: &quot;second_table&quot;,\r\n      &quot;tests&quot;: [\r\n        {\r\n          &quot;dbt_utils.equal_rowcount&quot;: {\r\n            &quot;compare_model&quot;: &quot;second_table&quot;\r\n          }\r\n        }\r\n      ]\r\n    }\r\n  ]\r\n}\r\n\r\n```\r\n\r\nFWIW, this is an intermediate step in some YAML (via `yq`, the Python wrapper variety of `jq` as opposed to the `go` variant) wrangling I&#39;m doing on [DBT config files][1].\r\n\r\n(Bonus points if you can wrap the replacement text with parentheses and/or prefix it without breaking out of `jq`. :D If not, no worries -- this step I can do with another program.)\r\n\r\nNeedless to say, but your help is very much appreciated!\r\n\r\n---\r\n\r\n\r\n  [1]: https://docs.getdbt.com/reference/model-properties",
        "link": "https://stackoverflow.com/questions/65821660/update-deeply-nested-field-with-value-from-higher-level-object-in-jq",
        "title": "Update deeply nested field with value from higher-level object in JQ"
    },
    {
        "tags": [
            "amazon-web-services",
            "jq",
            "aws-cli",
            "unicode-escapes",
            "ansi-colors"
        ],
        "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": 1611221509,
                "post_id": 65824304,
                "comment_id": 116382476,
                "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": 1611222499,
                "post_id": 65824304,
                "comment_id": 116382967,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1269357,
                    "reputation": 9375,
                    "user_id": 1226020,
                    "user_type": "registered",
                    "accept_rate": 41,
                    "profile_image": "https://www.gravatar.com/avatar/6af606149e832996a335d459cdafb88e?s=256&d=identicon&r=PG",
                    "display_name": "JHH",
                    "link": "https://stackoverflow.com/users/1226020/jhh"
                },
                "reply_to_user": {
                    "account_id": 6196394,
                    "reputation": 86601,
                    "user_id": 5291015,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/4tAvO.jpg?s=256",
                    "display_name": "Inian",
                    "link": "https://stackoverflow.com/users/5291015/inian"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1611223722,
                "post_id": 65824304,
                "comment_id": 116383546,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1269357,
                    "reputation": 9375,
                    "user_id": 1226020,
                    "user_type": "registered",
                    "accept_rate": 41,
                    "profile_image": "https://www.gravatar.com/avatar/6af606149e832996a335d459cdafb88e?s=256&d=identicon&r=PG",
                    "display_name": "JHH",
                    "link": "https://stackoverflow.com/users/1226020/jhh"
                },
                "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": 1,
                "creation_date": 1611224478,
                "post_id": 65824304,
                "comment_id": 116383870,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1611231909,
                "creation_date": 1611231909,
                "answer_id": 65827391,
                "question_id": 65824304,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The `aws` CLI is feeding its output to `less` because a) you&#39;ve allocated a pseudo-tty with the `-it` flags, b) as far as the process is concerned, it&#39;s outputting directly to the tty and not to a pipe, and c) you haven&#39;t [told it do anything else instead][1]. The correct fix is to remove `-it` - [it&#39;s only there for when you need to provide interactive input][2], and if you&#39;re piping the output to jq then you don&#39;t need or want interactive input. However, if you&#39;re trying to set up an alias or function to behave seamlessly in place of `aws`, you need to decide whether or not to pass `-it` based on whether you want interactive input. You could try this:\r\n\r\n```\r\nfunction daws() {\r\n    local usetty\r\n    if [ -t 1 ]\r\n    then\r\n        usetty=-it\r\n    else\r\n        usetty=\r\n    fi\r\n    docker run --rm $usetty -v ~/.aws:/root/.aws -e AWS_PROFILE -e AWS_REGION amazon/aws-cli &quot;$@&quot;\r\n}\r\n```\r\n\r\nAnd in one line:\r\n```\r\nfunction daws() { local usetty; if [ -t 1 ]; then usetty=-it; else usetty=; fi; docker run --rm $usetty -v ~/.aws:/root/.aws -e AWS_PROFILE -e AWS_REGION amazon/aws-cli &quot;$@&quot;; }\r\n```\r\n\r\nAlternatively you can pass `--no-cli-pager` or set the environment variable `AWS_PAGER` to `cat`, but I tried both and while they didn&#39;t result in any errors, there was still some odd messy output where newlines weren&#39;t applying a carriage-return for part of the output.\r\n\r\n[1]: https://docs.aws.amazon.com/cli/latest/userguide/cli-usage-pagination.html\r\n[2]: https://docs.aws.amazon.com/cli/latest/userguide/install-cliv2-docker.html#cliv2-docker-install",
                "title": "AWS CLI returns JSON with control codes making JQ fail"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1611231909,
        "creation_date": 1611220578,
        "last_edit_date": 1611223706,
        "question_id": 65824304,
        "body_markdown": "I&#39;ve used `jq` many times to parse, pick values etc from JSON returned by AWS CLI, e.g. for `ec2 describe-instances` etc.\r\n\r\nNow I&#39;m using the [dockerized version of AWS CLI v2][1] to get a list of CloudWatch log groups:\r\n\r\n```\r\n$ alias aws=&#39;docker run --rm -it -v ~/.aws:/root/.aws -e AWS_PROFILE -e AWS_REGION amazon/aws-cli&#39;\r\n$ aws logs describe-log-groups\r\n\r\n{\r\n    &quot;logGroups&quot;: [\r\n        {\r\n            ...\r\n        }\r\n    ]\r\n}\r\n```\r\n\r\nThis looks like proper JSON; however when piping this to `jq`, I get:\r\n\r\n`parse error: Invalid numeric literal at line 1, column 2`\r\n\r\nIf looking at the JSON returned from `aws` in a binary editor, or using `jq`:s `inputs` feature, I see that it contains a lot of control codes:\r\n\r\n```\r\n[\r\n  &quot;\\u001b[?1h\\u001b=\\r{\\u001b[m\\r&quot;,\r\n  &quot;    \\&quot;logGroups\\&quot;: [\\u001b[m\\r&quot;,\r\n  &quot;        {\\u001b[m\\r&quot;,\r\n  &quot;            \\&quot;logGroupName\\&quot;: \\&quot;/aws/lambda/...\r\n...\r\n```\r\n\r\nIt seems to me that it&#39;s the fact that I&#39;m using AWS CLI through docker that causes this, because when using the old fashioned AWS CLI v1 installed using `pip` it does not happen - but it could also be v2 vs v1 that is the key difference rather than using docker as the environment I guess (I never tried installing v2 natively).\r\n\r\nThese control codes, e.g. `\\u001b[m`, look like ANSI codes to control formatting such as bold, colors etc. But AFAIK the AWS CLI does not use colored/ANSI output. Why are they included in the returned JSON? Is there a simple tool to strip them away so that I can continue using the dockerized AWS CLI v2 and pipe the output to `jq`? I found other answers using complex `sed` patterns and I thought to myself that there must be a simpler way to do this?\r\n\r\n\r\n**Edit**: here&#39;s a minimal example that shows the control codes using `xxd`. I deliberately listed log groups with a mismatching filter to get an empty array:\r\n\r\n```\r\n$ aws logs describe-log-groups --log-group-name-prefix FOO &gt; foo.txt\r\n$ xxd foo.txt\r\n00000000: 1b5b 3f31 681b 3d0d 7b1b 5b6d 0d0a 2020  .[?1h.=.{.[m..  \r\n00000010: 2020 226c 6f67 4772 6f75 7073 223a 205b    &quot;logGroups&quot;: [\r\n00000020: 5d1b 5b6d 0d0a 7d1b 5b6d 0d0a 0d1b 5b4b  ].[m..}.[m....[K\r\n00000030: 1b5b 3f31 6c1b 3e                        .[?1l.&gt;\r\n$ cat foo.txt | jq\r\nparse error: Invalid numeric literal at line 1, column 2\r\n                                                        $\r\n```\r\n\r\nSame thing displayed with `xxd` when using non-dockerized AWS CLI v1:\r\n\r\n```\r\n00000000: 7b0a 2020 2020 226c 6f67 4772 6f75 7073  {.    &quot;logGroups\r\n00000010: 223a 205b 5d0a 7d0a                      &quot;: [].}.\r\n```\r\n\r\n  [1]: https://docs.aws.amazon.com/cli/latest/userguide/install-cliv2-docker.html",
        "link": "https://stackoverflow.com/questions/65824304/aws-cli-returns-json-with-control-codes-making-jq-fail",
        "title": "AWS CLI returns JSON with control codes making JQ fail"
    },
    {
        "tags": [
            "json",
            "shell",
            "path",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1611235735,
                "creation_date": 1611235735,
                "answer_id": 65828471,
                "question_id": 65827548,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "jq seems picky about paths in input arguments.\r\n\r\nOne solution could be to provide the path as a json array, and then use `getpath` to convert that to a path:\r\n\r\n```\r\nfield=&#39;[&quot;level1&quot;, &quot;level2&quot;, &quot;level3&quot;]&#39;\r\njq -r --argjson f &quot;$field&quot; &#39;getpath($f)&#39; &lt;&lt;&lt; ${DATA}\r\n```\r\n\r\nOr for your specific question:\r\n```\r\n\r\nfield=&#39;[&quot;level1&quot;, &quot;level2&quot;, &quot;level3&quot;]&#39;\r\n\r\njq -r --argjson f &quot;${field}&quot; &#39;getpath($f) | to_entries | .[] | &quot;\\&quot;&quot; + .key + &quot;\\&quot;=\\&quot;&quot; + .value + &quot;\\&quot;&quot;&#39; &lt;&lt;&lt; ${DATA}\r\n```",
                "title": "Accessing nested values in JQ using path passed through command line"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1611239555,
                "last_edit_date": 1611239555,
                "creation_date": 1611238607,
                "answer_id": 65829331,
                "question_id": 65827548,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "In this case `.[$f]` means &quot;return the value associated with the key named `level1.level2.level3`&quot;. See:\r\n```\r\n$ jq --arg f &#39;level1.level2.level3&#39; &#39;.[$f]&#39; &lt;&lt;&lt; &#39;{ &quot;level1.level2.level3&quot;: &quot;foo&quot; }&#39;\r\n&quot;foo&quot;\r\n```\r\n\r\nUnless any of the path components contain a dot, splitting `$f` by dots and using the result as argument to `getpath` should work.\r\n``` none\r\ngetpath($f / &quot;.&quot;)\r\n```",
                "title": "Accessing nested values in JQ using path passed through command line"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1611580188,
        "creation_date": 1611232455,
        "last_edit_date": 1611580188,
        "question_id": 65827548,
        "body_markdown": "How or if is it possible to extract data from JSON structure specifying path as an argument to the command. I got this simple snippet taken from some larger script just for simplicity and have problems working it out:\r\n\r\n    #!/bin/bash\r\n    \r\n    DATA=&#39;{\r\n            &quot;level1&quot;: {\r\n                    &quot;level2&quot;: {\r\n                            &quot;level3&quot;: {\r\n                                    &quot;foo&quot;: &quot;bar&quot;,\r\n                                    &quot;bar&quot;: &quot;baz&quot;,\r\n                                    &quot;baz&quot;: &quot;bar&quot;\r\n                            }\r\n                    }\r\n            }\r\n    \r\n    }&#39;\r\n    \r\n    field=&quot;level1.level2.level3&quot;\r\n    \r\n    # does not work\r\n    jq -r --arg f ${field} &#39;.[$f] | to_entries | .[] | &quot;\\&quot;&quot; + .key + &quot;\\&quot;=\\&quot;&quot; + .value + &quot;\\&quot;&quot;&#39; &lt;&lt;&lt; ${DATA}\r\n    \r\n    # works\r\n    jq -r --arg f ${field} &#39;.level1.level2.level3 | to_entries | .[] | &quot;\\&quot;&quot; + .key + &quot;\\&quot;=\\&quot;&quot; + .value + &quot;\\&quot;&quot;&#39; &lt;&lt;&lt; ${DATA}\r\n\r\n    # also works                              \r\n    field2=&quot;level3&quot;\r\n    \r\n    jq -r --arg f ${field2} &#39;.level1.level2 | .[$f] | to_entries | .[] | &quot;\\&quot;&quot; + .key + &quot;\\&quot;=\\&quot;&quot; + .value + &quot;\\&quot;&quot;&#39; &lt;&lt;&lt; ${DATA}\r\n\r\n\r\nGives the following output:\r\n\r\n    user@astra:~/test$ ./jqtest \r\n    jq: error (at &lt;stdin&gt;:12): null (null) has no keys\r\n    &quot;foo&quot;=&quot;bar&quot;\r\n    &quot;bar&quot;=&quot;baz&quot;\r\n    &quot;baz&quot;=&quot;bar&quot;\r\n    &quot;foo&quot;=&quot;bar&quot;\r\n    &quot;bar&quot;=&quot;baz&quot;\r\n    &quot;baz&quot;=&quot;bar&quot;\r\n\r\nWhat am I doing wrong?",
        "link": "https://stackoverflow.com/questions/65827548/accessing-nested-values-in-jq-using-path-passed-through-command-line",
        "title": "Accessing nested values in JQ using path passed through command line"
    },
    {
        "tags": [
            "json",
            "format",
            "jq",
            "jsonlines"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 6196394,
                    "reputation": 86601,
                    "user_id": 5291015,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/4tAvO.jpg?s=256",
                    "display_name": "Inian",
                    "link": "https://stackoverflow.com/users/5291015/inian"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1611244757,
                "post_id": 65830936,
                "comment_id": 116394135,
                "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": 1611245670,
                "post_id": 65830936,
                "comment_id": 116394635,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 9629731,
                    "reputation": 51350,
                    "user_id": 10248678,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d8f818402f22d485b135a3b685ef908e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "oguz ismail",
                    "link": "https://stackoverflow.com/users/10248678/oguz-ismail"
                },
                "reply_to_user": {
                    "account_id": 6196394,
                    "reputation": 86601,
                    "user_id": 5291015,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/4tAvO.jpg?s=256",
                    "display_name": "Inian",
                    "link": "https://stackoverflow.com/users/5291015/inian"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1611245760,
                "post_id": 65830936,
                "comment_id": 116394679,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1611264768,
                "creation_date": 1611264768,
                "answer_id": 65836045,
                "question_id": 65830936,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Assuming the input is fixed and that each object has a &quot;technico&quot; field, you can run the following:\r\n```\r\njq -r -c &#39;\r\n  select(.contact_type | contains(&quot;tecnico&quot;))\r\n  | {FirstName: .first_name},{LastName: .last_name},{Email: .email}, &quot;&quot;\r\n&#39;\r\n```\r\n\r\nThe -r option suppresses the quotation marks around the top-level string, and the trailing `, &quot;&quot;` has the effect of adding a new-line after each object.\r\n\r\nIf you only want the additional blank lines between the objects, then you might find it easier to use a complementary tool such as `sed` or `awk`.  However, here is a jq-only solution that assumes jq has been called with the -n option in addition to -r -c:\r\n\r\n```\r\ndef nl(stream):\r\n  foreach stream as $s (-1; .+1; if . &gt; 0 then &quot;&quot; else empty end, $s);\r\n\r\nnl(inputs | select(.contact_type | contains(&quot;tecnico&quot;))\r\n| if type == &quot;string&quot;\r\n  then . \r\n  else {FirstName: .first_name},{LastName: .last_name},{Email: .email} \r\n  end\r\n```",
                "title": "JQ separate output"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1611499149,
        "creation_date": 1611244122,
        "last_edit_date": 1611499149,
        "question_id": 65830936,
        "body_markdown": "i have a json formatted in this way : \r\n\r\n    {\r\n      &quot;first_name&quot;: &quot;Mario&quot;,\r\n      &quot;last_name&quot;: &quot;Bros&quot;,\r\n      &quot;email&quot;: &quot;mario.bros@mario.com&quot;,\r\n    \r\n    }\r\n    {\r\n      &quot;first_name&quot;: &quot;Luigi&quot;,\r\n      &quot;last_name&quot;: &quot;Bros&quot;,\r\n      &quot;email&quot;: &quot;luigi.bros@mario.com&quot;,\r\n    \r\n    }\r\n\r\nI have this output with \r\n\r\n    jq --compact-output &#39;select(.contact_type | contains(&quot;tecnico&quot;)) | {FirstName: .first_name},{LastName: .last_name},{Email: .email}&#39;\r\n\r\n    {&quot;FirstName&quot;:&quot;Mario&quot;}\r\n    {&quot;LastName&quot;:&quot;Bros&quot;}\r\n    {&quot;Email&quot;:&quot;mario.bros@mario.com&quot;}\r\n    {&quot;FirstName&quot;:&quot;Luigi&quot;}\r\n    {&quot;LastName&quot;:&quot;Bros&quot;}\r\n    {&quot;Email&quot;:&quot;luigi.bros@mario.com&quot;}\r\n\r\nI want split with space Mario from Luigi.",
        "link": "https://stackoverflow.com/questions/65830936/jq-separate-output",
        "title": "JQ separate output"
    },
    {
        "tags": [
            "json",
            "bash",
            "variables",
            "scripting",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 2663445,
                    "reputation": 592,
                    "user_id": 2302569,
                    "user_type": "registered",
                    "accept_rate": 75,
                    "profile_image": "https://i.sstatic.net/TQIbx.png?s=256",
                    "display_name": "JayJay",
                    "link": "https://stackoverflow.com/users/2302569/jayjay"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1611255839,
                "post_id": 65831486,
                "comment_id": 116399477,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1611246337,
                "creation_date": 1611246337,
                "answer_id": 65831606,
                "question_id": 65831486,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Found the answer. You can do it by the following code.\r\n\r\n    jq -r &#39;keys[] as $k | &quot;\\($k) \\(.[$k].value)&quot;&#39; tmp.json",
                "title": "Extracting values from JSON using bash"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1611246337,
        "creation_date": 1611245929,
        "question_id": 65831486,
        "body_markdown": "    {\r\n      &quot;test1&quot;: {\r\n        &quot;type&quot;: &quot;string&quot;,\r\n        &quot;value&quot;: &quot;foo&quot;\r\n      },\r\n      &quot;test2&quot;: {\r\n        &quot;type&quot;: &quot;string&quot;,\r\n        &quot;value&quot;: &quot;bar&quot;\r\n      }\r\n    }\r\n\r\nIn a json like above I need to get extract the following details. Assuming that I have to extract the key and the value both.\r\n\r\ntest1=foo\r\n\r\ntest2=bar\r\n\r\nIs there anyway this is possible through bash?",
        "link": "https://stackoverflow.com/questions/65831486/extracting-values-from-json-using-bash",
        "title": "Extracting values from JSON using bash"
    },
    {
        "tags": [
            "json",
            "csv",
            "key",
            "export-to-csv",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1611249141,
                "last_edit_date": 1611249141,
                "creation_date": 1611247707,
                "answer_id": 65831999,
                "question_id": 65831692,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Join elements of each tag by commas, put resulting strings into an array with the lab ID as the first element, and pipe it to the `@tsv` filter like so:\r\n``` none\r\nkeys_unsorted[] as $id | [$id, (.[$id].tags[] | join(&quot;,&quot;))] | @tsv\r\n```\r\n&lt;sup&gt;[Online demo](https://jqplay.org/s/mdJ642Qmtf)&lt;/sup&gt;",
                "title": "Nested JSON with variable keys to TSV using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1611495876,
        "creation_date": 1611246650,
        "last_edit_date": 1611495876,
        "question_id": 65831692,
        "body_markdown": "I have the following nested JSON file `labs.json` with variable keywords (`lab001`, `lab002`, etc.) which I would like to convert into a TSV using `jq`:\r\n\r\n```\r\n{\r\n  &quot;lab001&quot;: {\r\n    &quot;tags&quot;: {\r\n      &quot;T1&quot;: [],\r\n      &quot;T2&quot;: [&quot;k26&quot;,&quot;e23&quot;],\r\n      &quot;T3&quot;: [&quot;s92&quot;]\r\n    },\r\n    &quot;code&quot;: &quot;8231&quot;\r\n  },\r\n  &quot;lab002&quot;: {\r\n    &quot;tags&quot;: {\r\n      &quot;T1&quot;: [&quot;t32&quot;,&quot;y55&quot;],\r\n      &quot;T2&quot;: [&quot;q78&quot;],\r\n      &quot;T3&quot;: [&quot;b24&quot;]\r\n    },\r\n    &quot;code&quot;: &quot;9112&quot;\r\n  }\r\n}\r\n```\r\nThe resulting table should look like:\r\n\r\n| ID | T1 | T2 | T3 |\r\n| ----- | -- | -- | -- |\r\n| lab001 | | k26,e23 | s92 |\r\n| lab002 | t32,y55 | q78 | b24 |\r\n\r\nCurrently I am using a rather pedestrian approach by pasting two calls of `jq` and doing some cleanup with `tr`:\r\n\r\n```\r\npaste &lt;(jq -r &#39;keys_unsorted | @csv&#39; labs.json | tr &#39;,&#39; &#39;\\n&#39;) &lt;(jq -r &#39;.[].tags | map(tostring) | @tsv&#39; labs.json) | tr -d &#39;[]&quot;&#39;\r\n```\r\n\r\nIs there any more elegant way to get this done purely with `jq`?",
        "link": "https://stackoverflow.com/questions/65831692/nested-json-with-variable-keys-to-tsv-using-jq",
        "title": "Nested JSON with variable keys to TSV using jq"
    },
    {
        "tags": [
            "json",
            "jq",
            "key-value"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1611252478,
                "creation_date": 1611252478,
                "answer_id": 65833308,
                "question_id": 65832707,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "With `--raw-input`, you&#39;re looking for something like this:\r\n\r\n```\r\n  [., inputs]                                                              # A\r\n| map(split(&quot;: &quot;)                                                          # B\r\n  | {(.[0]): (.[1] | split(&quot;, &quot;) | if length &gt; 1 then . else .[0] end )})  # C\r\n| reduce .[] as $x ({}; . + $x)                                            # D\r\n\r\n```\r\n\r\nWhere:\r\n\r\n- A: Combines first and last lines into a single array e.g. `[&quot;foo: bar&quot;, …]`\r\n- B: Split each line e.g. `[[&quot;foo&quot;, &quot;bar&quot;], …]`\r\n- C: Convert each subset into an object where first element is the key and second element is the value. The value is split by `&quot;, &quot;` but if there&#39;s only one element after the split take it out.\r\n- D: Merge each object into one with `+` e.g. `{&quot;foo&quot;: &quot;bar&quot;} + {&quot;color&quot;: &quot;blue&quot;}` =&gt; `{&quot;foo&quot;: &quot;bar&quot;, &quot;color&quot;: &quot;blue&quot;, …}`",
                "title": "Using JQ to convert plain text block to JSON"
            },
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1611253389,
                "last_edit_date": 1611253389,
                "creation_date": 1611252525,
                "answer_id": 65833323,
                "question_id": 65832707,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Always split the value. If resulting array has multiple elements, then assign it; otherwise assign the original string.\r\n``` none\r\nreduce (inputs / &quot;: &quot;) as [$k, $v] (.;\r\n  .[$k] = ($v / &quot;, &quot; | if has(1) then . else $v end)\r\n)\r\n```\r\n&lt;sup&gt;[Online demo](https://jqplay.org/s/mvuvF8BpiN)&lt;/sup&gt;\r\n\r\nOr, check whether the value contains a separator first and then split, if that makes more sense.\r\n``` none\r\n          ($v | if index(&quot;, &quot;) then split(&quot;, &quot;) else . end)\r\n```\r\n&lt;sup&gt;[Online demo](https://jqplay.org/s/xQ9jb_B7n-)&lt;/sup&gt;\r\n\r\nNote that you need to invoke JQ with **-R** and **-n** on the command line for this to work.",
                "title": "Using JQ to convert plain text block to JSON"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1611579519,
        "creation_date": 1611250248,
        "last_edit_date": 1611579519,
        "question_id": 65832707,
        "body_markdown": "I have a plain text file in format like this:\r\n```\r\nfoo: bar\r\ncolor: blue\r\nnames: joe, john, mary, bob, sue\r\n```\r\n\r\nI need to output the contents of this file as a JSON format:\r\n```\r\n{\r\n  &quot;foo&quot;: &quot;bar&quot;,\r\n  &quot;color&quot;: &quot;blue&quot;,\r\n  &quot;names&quot;: [&quot;joe&quot;, &quot;john&quot;, &quot;mary&quot;, &quot;bob&quot;, &quot;sue&quot;]\r\n}\r\n```\r\n\r\nI have tried using: `jq -R -n &#39;[inputs|split(&quot;:&quot;)|[{(.0):.[1] | add&#39; testfile` (let&#39;s say the name of the file is testfile) but I can only get this result:\r\n```\r\n{\r\n  &quot;foo&quot;: &quot;bar&quot;,\r\n  &quot;color&quot;: &quot;blue&quot;,\r\n  &quot;names&quot;: &quot;joe, john, mary, bob, sue&quot;\r\n}\r\n```\r\n\r\nWhat do I need to do in order to get the desired output? I&#39;ve tried piping `split(&quot;,&quot;)` after `[1]` but it makes every value pair into an array, which I don&#39;t want. \r\n",
        "link": "https://stackoverflow.com/questions/65832707/using-jq-to-convert-plain-text-block-to-json",
        "title": "Using JQ to convert plain text block to JSON"
    },
    {
        "tags": [
            "arrays",
            "json",
            "export-to-csv",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1611305211,
                "last_edit_date": 1611305211,
                "creation_date": 1611255304,
                "answer_id": 65834009,
                "question_id": 65833864,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Use `+` to concatenate strings:\r\n```\r\njq -r &#39;.[]\r\n       | [.login,.name,(\r\n           if .groups == null\r\n           then &quot;grp:-&quot;\r\n           else (\r\n               del(.groups[] | select(.name==&quot;All Users&quot;))\r\n               | [&quot;grp:&quot; + .groups[].name]\r\n#                 ~~~~~~~~\r\n               | join(&quot;|&quot;)\r\n           )\r\n           end\r\n      )]\r\n      | @tsv&#39; \r\n```\r\nYou can even avoid specifying &quot;grp:&quot; twice, but you need to return an array from the *then* branch, too:\r\n```\r\njq -r &#39;.[]\r\n       | [.login, .name, (\r\n           (\r\n               if .groups == null\r\n               then [&quot;-&quot;]\r\n               else (\r\n                   del(.groups[] | select(.name==&quot;All Users&quot;))\r\n                   | [.groups[].name]\r\n               )\r\n               end\r\n           )\r\n           | map(&quot;grp:&quot; + .)\r\n           | join(&quot;|&quot;)\r\n       )]\r\n       | @tsv&#39;\r\n```\r\n*Update*:\r\nGetting inspiration from *peak* I guess this produces the output you wanted:\r\n```\r\njq -r &#39;.[]\r\n        | .groups //= []\r\n        | del(.groups[] | select(.name==&quot;All Users&quot;))\r\n        | .groups[0] //= {name: &quot;-&quot;}\r\n        | [.login, .name, ( [&quot;grp:&quot; + (.groups[].name)] | join(&quot;|&quot;) ) ]\r\n        | @tsv&#39;\r\n```",
                "title": "jq - add prefix to values on array"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1611325707,
                "last_edit_date": 1611325707,
                "creation_date": 1611304005,
                "answer_id": 65841633,
                "question_id": 65833864,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s a slightly shorter and perhaps tidier variant of the solution already given. It has the advantage of handling the edge case mentioned in a comment elsewhere on this page.\r\n\r\n```\r\n  .[]\r\n  | .groups //= [{name: &quot;-&quot;}]\r\n  | [.login,\r\n     .name,\r\n     (del(.groups[] | select(.name==&quot;All Users&quot;))\r\n     | [&quot;grp:&quot; + (.groups[].name)] | join(&quot;|&quot;)) \r\n    ]\r\n  | @tsv\r\n```\r\n\r\n### Simpler still\r\n \r\n```\r\n  .groups //= [{name: &quot;-&quot;}]\r\n  | .groups |= map(select( .name != &quot;All Users&quot;) )\r\n  | [.login, .name,\r\n     (.groups | map(&quot;grp:&quot; + .name) | join(&quot;|&quot;)) ]\r\n  | @tsv```",
                "title": "jq - add prefix to values on array"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 2,
        "last_activity_date": 1683749891,
        "creation_date": 1611254653,
        "last_edit_date": 1683749891,
        "question_id": 65833864,
        "body_markdown": "input json:\r\n\r\n    [\r\n    {\r\n      &quot;login&quot;: &quot;u1&quot;,\r\n      &quot;name&quot;: &quot;u1&quot;,\r\n      &quot;role&quot;: &quot;User&quot;,\r\n      &quot;groups&quot;: [\r\n        {\r\n          &quot;id&quot;: &quot;1234&quot;,\r\n          &quot;name&quot;: &quot;G1&quot;\r\n        },\r\n        {\r\n          &quot;id&quot;: &quot;1235&quot;,\r\n          &quot;name&quot;: &quot;G2&quot;\r\n        }\r\n      ],\r\n      &quot;created&quot;: &quot;2020-05-11 11:06&quot;\r\n    },\r\n    {\r\n      &quot;login&quot;: &quot;u2&quot;,\r\n      &quot;name&quot;: &quot;u2&quot;,\r\n      &quot;role&quot;: &quot;User&quot;,\r\n      &quot;groups&quot;: null,\r\n      &quot;created&quot;: &quot;2020-05-11 11:06&quot;\r\n    }\r\n    ]\r\n\r\n \r\n\r\nI use following filter to get users and groups they are member of:\r\n```\r\n$ jq -r &#39;\r\n  .[]\r\n  | [.login,\r\n     .name,\r\n     ( if .groups == null \r\n       then &quot;grp:-&quot; \r\n       else (del(.groups[]\r\n             | select(.name==&quot;All Users&quot;))\r\n            | [.groups[].name] | join(&quot;|&quot;)) \r\n       end )]\r\n  | @tsv&#39; json\r\n```\r\n```\r\nu1      u1      G1|G2\r\nu2      u2      grp:-\r\n```\r\nHow to add `grp:` prefix for each found group?\r\n\r\nExpected output would be:\r\n\r\n    u1      u1      grp:G1|grp:G2\r\n    u2      u2      grp:-\r\n\r\n",
        "link": "https://stackoverflow.com/questions/65833864/jq-add-prefix-to-values-on-array",
        "title": "jq - add prefix to values on array"
    },
    {
        "tags": [
            "jq",
            "har"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 545260,
                    "reputation": 7615,
                    "user_id": 914967,
                    "user_type": "registered",
                    "accept_rate": 75,
                    "profile_image": "https://i.sstatic.net/sR6j4.png?s=256",
                    "display_name": "shawnzhu",
                    "link": "https://stackoverflow.com/users/914967/shawnzhu"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1611354901,
                "post_id": 65853586,
                "comment_id": 116434468,
                "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": 1611356748,
                "post_id": 65853586,
                "comment_id": 116434960,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 438929,
                    "reputation": 2692,
                    "user_id": 827519,
                    "user_type": "registered",
                    "accept_rate": 57,
                    "profile_image": "https://www.gravatar.com/avatar/43dfb8ba76634e125e17aceafd92d254?s=256&d=identicon&r=PG",
                    "display_name": "wsdookadr",
                    "link": "https://stackoverflow.com/users/827519/wsdookadr"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1611523714,
                "post_id": 65853586,
                "comment_id": 116473380,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 438929,
                    "reputation": 2692,
                    "user_id": 827519,
                    "user_type": "registered",
                    "accept_rate": 57,
                    "profile_image": "https://www.gravatar.com/avatar/43dfb8ba76634e125e17aceafd92d254?s=256&d=identicon&r=PG",
                    "display_name": "wsdookadr",
                    "link": "https://stackoverflow.com/users/827519/wsdookadr"
                },
                "edited": false,
                "score": 4,
                "creation_date": 1611524108,
                "post_id": 65853586,
                "comment_id": 116473457,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 545260,
                    "reputation": 7615,
                    "user_id": 914967,
                    "user_type": "registered",
                    "accept_rate": 75,
                    "profile_image": "https://i.sstatic.net/sR6j4.png?s=256",
                    "display_name": "shawnzhu",
                    "link": "https://stackoverflow.com/users/914967/shawnzhu"
                },
                "reply_to_user": {
                    "account_id": 438929,
                    "reputation": 2692,
                    "user_id": 827519,
                    "user_type": "registered",
                    "accept_rate": 57,
                    "profile_image": "https://www.gravatar.com/avatar/43dfb8ba76634e125e17aceafd92d254?s=256&d=identicon&r=PG",
                    "display_name": "wsdookadr",
                    "link": "https://stackoverflow.com/users/827519/wsdookadr"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1611758179,
                "post_id": 65853586,
                "comment_id": 116553750,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 3642295,
                    "reputation": 5067,
                    "user_id": 3036129,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/glLJ3.jpg?s=256",
                    "display_name": "jackdbd",
                    "link": "https://stackoverflow.com/users/3036129/jackdbd"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1620386103,
                "post_id": 65853586,
                "comment_id": 119191767,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1621308082,
                "creation_date": 1621308082,
                "answer_id": 67579526,
                "question_id": 65853586,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "To indiscriminately delete all request.cookies:\r\n\r\n    jq &#39;del(.. | .request?.cookies?)&#39; www.ibm.com.har\r\n\r\nAs an example, given this JSON file:\r\n\r\n    $ jq -M . /tmp/hartest.json\r\n    {\r\n      &quot;one&quot;: {\r\n        &quot;foo&quot;: {\r\n          &quot;bar&quot;: true,\r\n          &quot;baz&quot;: 23\r\n        }\r\n      },\r\n      &quot;two&quot;: {\r\n        &quot;foo&quot;: {\r\n          &quot;bar&quot;: &quot;Hello&quot;,\r\n          &quot;baz&quot;: &quot;World&quot;\r\n        }\r\n      },\r\n      &quot;three&quot;: {\r\n        &quot;fu&quot;: {\r\n          &quot;bar&quot;: &quot;gone&quot;,\r\n          &quot;baz&quot;: &quot;forgotten&quot;\r\n        }\r\n      }\r\n    }\r\n\r\nI can get rid of all &#39;bar&#39; keys with this command:\r\n\r\n    jq -M &#39;del( .. | .bar?)&#39; /tmp/hartest.json\r\n\r\nRunning the before and after through `diff`:\r\n\r\n    $ diff &lt;(jq -M . /tmp/hartest.json) &lt;(jq -M &#39;del( .. | .bar?)&#39; /tmp/hartest.json )\r\n    4d3\r\n    &lt;       &quot;bar&quot;: true,\r\n    10d8\r\n    &lt;       &quot;bar&quot;: &quot;Hello&quot;,\r\n    16d13\r\n    &lt;       &quot;bar&quot;: &quot;gone&quot;,\r\n\r\nIf I just wanted to get rid of &#39;.foo.bar&#39; only, I would use this:\r\n\r\n    jq -M &#39;del( .. | .foo?.bar?)&#39; /tmp/hartest.json\r\n\r\nwhich, again, running through `diff` gives us:\r\n\r\n    $ diff &lt;(jq -M . /tmp/hartest.json) &lt;(jq -M &#39;del( .. | .foo?.bar?)&#39; /tmp/hartest.json )\r\n    4d3\r\n    &lt;       &quot;bar&quot;: true,\r\n    10d8\r\n    &lt;       &quot;bar&quot;: &quot;Hello&quot;,\r\n\r\n",
                "title": "How to remove Cookie value from HAR file before sharing it with another person"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 3,
        "last_activity_date": 1621308082,
        "creation_date": 1611354578,
        "question_id": 65853586,
        "body_markdown": "It&#39;s common to diagnose web app with HAR file especially when seeking technical support from another person. However, HAR file contains sensitive info like request cookies. For example, if following [this guide](https://www.ibm.com/support/pages/how-do-you-generate-har-file-troubleshoot-issues-ibm-cloud-console), it could share cookie values to technical support if HAR file is not cleaned up.\r\n\r\nSo I prefer deleting request cookies before sharing the HAR file.\r\n\r\nIs there any simple command to do it?",
        "link": "https://stackoverflow.com/questions/65853586/how-to-remove-cookie-value-from-har-file-before-sharing-it-with-another-person",
        "title": "How to remove Cookie value from HAR file before sharing it with another person"
    },
    {
        "tags": [
            "shell",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 10015983,
                    "reputation": 144648,
                    "user_id": 9072753,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/EPmGy.jpg?s=256",
                    "display_name": "KamilCuk",
                    "link": "https://stackoverflow.com/users/9072753/kamilcuk"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1611361780,
                "post_id": 65854485,
                "comment_id": 116436063,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 7878420,
                    "reputation": 1659,
                    "user_id": 5953419,
                    "user_type": "registered",
                    "accept_rate": 50,
                    "profile_image": "https://www.gravatar.com/avatar/86b9ba666bb6a068574b1ed7ccb17326?s=256&d=identicon&r=PG",
                    "display_name": "Ashley",
                    "link": "https://stackoverflow.com/users/5953419/ashley"
                },
                "reply_to_user": {
                    "account_id": 10015983,
                    "reputation": 144648,
                    "user_id": 9072753,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/EPmGy.jpg?s=256",
                    "display_name": "KamilCuk",
                    "link": "https://stackoverflow.com/users/9072753/kamilcuk"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1611362838,
                "post_id": 65854485,
                "comment_id": 116436248,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "is_answered": false,
        "answer_count": 0,
        "score": 0,
        "last_activity_date": 1611366193,
        "creation_date": 1611361256,
        "last_edit_date": 1611366193,
        "question_id": 65854485,
        "body_markdown": "I have a JSON file where items is an array and it has `name` three times in it.\r\n\r\nHow do I iterate the loop using shell script so that using a single script, it outputs the value of `name` for all the names in the array?\r\n\r\nIn my case, I should get the value of `name` three times.\r\n\r\nHere is what I am doing right now:\r\n\r\n\r\n    curl ***** | jq &#39;.items[0].name&#39;\r\n    curl ***** | jq &#39;.items[1].name&#39;\r\n    curl ***** | jq &#39;.items[2].name&#39;\r\n\r\nHow can I create a script that automatically fetches however many times `name` appears in the `items` array and then prints them one by one? Is it possible using some `for` or `while` loop?",
        "link": "https://stackoverflow.com/questions/65854485/how-to-get-the-output-using-jq-for-a-json-array-for-each-value",
        "title": "How to get the output using jq for a json array for each value"
    },
    {
        "tags": [
            "json",
            "date",
            "sorting",
            "format",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1611430231,
                "last_edit_date": 1611430231,
                "creation_date": 1611418320,
                "answer_id": 65861423,
                "question_id": 65860494,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "&gt; I want to sort by date\r\n\r\nSo, thanks to ISO 8601, the filter would be just that:\r\n\r\n    sort_by(.lastConfigChangeAt)\r\n\r\n(That’s the entire jq program.)",
                "title": "jq order by date Error - jq: error (at &lt;stdin&gt;:17): Cannot iterate over string (&quot;2020-12-11...)"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1611430231,
        "creation_date": 1611413018,
        "question_id": 65860494,
        "body_markdown": "Have some records in a json that I want to sort by date, but when trying it gives me the following error\r\n\r\n*dates.json*\r\n```\r\n[  \r\n  {\r\n    &quot;lastScalingAt&quot;: &quot;2020-12-11T17:29:35.888Z&quot;,\r\n    &quot;lastConfigChangeAt&quot;: &quot;2020-12-11T17:29:35.888Z&quot;\r\n  },\r\n  {\r\n    &quot;lastScalingAt&quot;: &quot;2020-12-11T17:29:38.655Z&quot;,\r\n    &quot;lastConfigChangeAt&quot;: &quot;2020-12-11T17:29:38.655Z&quot;\r\n  },\r\n  {\r\n    &quot;lastScalingAt&quot;: &quot;2020-12-11T17:29:37.233Z&quot;,\r\n    &quot;lastConfigChangeAt&quot;: &quot;2020-12-11T17:29:37.233Z&quot;\r\n  },\r\n  {\r\n    &quot;lastScalingAt&quot;: &quot;2020-12-08T20:42:09.990Z&quot;,\r\n    &quot;lastConfigChangeAt&quot;: &quot;2020-03-30T16:23:59.682Z&quot;\r\n  }\r\n]  \r\n```\r\nI have tried with this:\r\n```\r\njq &#39;.[] | .lastConfigChangeAt | sort_by(.lastConfigChangeAt)&#39; dates.json\r\n```\r\n**ERROR:** \r\njq: error (at &lt;stdin&gt;:17): Cannot iterate over string (&quot;2020-12-11...)\r\n\r\nI&#39;ve tried different ways but can&#39;t find what could be wrong\r\n",
        "link": "https://stackoverflow.com/questions/65860494/jq-order-by-date-error-jq-error-at-stdin17-cannot-iterate-over-string",
        "title": "jq order by date Error - jq: error (at &lt;stdin&gt;:17): Cannot iterate over string (&quot;2020-12-11...)"
    },
    {
        "tags": [
            "json",
            "string",
            "concatenation",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1611607234,
                "last_edit_date": 1611607234,
                "creation_date": 1611565337,
                "answer_id": 65881683,
                "question_id": 65877650,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "One way to join two strings is with `+`, e.g. instead of\r\n\r\n    name: .something1\r\n\r\nyou would write\r\n\r\n    name: (&quot;NewName.&quot; + .something1)\r\n\r\nTaking your query as a starting point, the next step would be to wrap everything in an object with `Newlist` as the key:\r\n```\r\n{ Newlist:\r\n    .list\r\n    | map({name: (&quot;NewName.&quot; + .something1),\r\n           HaveItem:\r\n             (if .status.totalItems != 0 \r\n              then &quot;Yes&quot; \r\n              else &quot;No&quot; end),\r\n   \t       Data: \r\n             (if .status.totalItems != 0\r\n              then .status.Items\r\n              else &quot;NULL&quot; end)\r\n\t} ) }\r\n```\r\n\r\nYou should be able to tweak this to produce the final result you want.\t\r\n",
                "title": "Add new list, string and restructure to existing JSON array with jq"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1611607234,
        "creation_date": 1611536130,
        "last_edit_date": 1611565377,
        "question_id": 65877650,
        "body_markdown": "I have this input.json\r\n```\r\n{\r\n   &quot;list&quot;: [\r\n      {\r\n         &quot;something1&quot;: &quot;aaaa&quot;,\r\n         &quot;status&quot;: {\r\n            &quot;totalItems&quot;: 2,\r\n            &quot;Items&quot;: [\r\n               {\r\n                  &quot;city&quot;: &quot;santa&quot;,\r\n                  &quot;state&quot;: &quot;VA&quot;,\r\n                  &quot;adress&quot;: &quot;1 avenue&quot;\r\n               },\r\n               {\r\n                  &quot;city&quot;: &quot;manhatan&quot;,\r\n                  &quot;state&quot;: &quot;NY&quot;,\r\n                  &quot;adress&quot;: &quot;1 drive&quot;\r\n               }\r\n            ]\r\n         }\r\n      },\r\n      {\r\n         &quot;something1&quot;: &quot;bbbb&quot;,\r\n         &quot;status&quot;: {\r\n            &quot;totalItems&quot;: 0\r\n         }\r\n      }\r\n   ]\r\n}\r\n```\r\nI would like to add list and append some text between the value and have output like this: \r\n```\r\n{\r\n   &quot;Newlist&quot;: [\r\n      {\r\n         &quot;name&quot;: &quot;NewName.aaaa&quot;,\r\n         &quot;HaveItem&quot;: &quot;Yes&quot;,\r\n         &quot;Data&quot;: [\r\n            &quot;santa is a city of VA with address 1 avenue&quot;,\r\n            &quot;manhatan is a city of NY with address 1 drive&quot;\r\n         ]\r\n      },\r\n      {\r\n         &quot;name&quot;: &quot;NewName.bbbb&quot;,\r\n         &quot;HaveItem&quot;: &quot;No&quot;\r\n      }\r\n   ]\r\n}\r\n```\r\nI have tried using jq &#39;.list | map({name: .something1, HaveItem: (if .status.totalItems != 0  then &quot;Yes&quot; else &quot;No&quot; end), Data: (if .status.totalItems != 0 then .status.Items else &quot;NULL&quot; end) })&#39; but i dont know how to add string between value.",
        "link": "https://stackoverflow.com/questions/65877650/add-new-list-string-and-restructure-to-existing-json-array-with-jq",
        "title": "Add new list, string and restructure to existing JSON array with jq"
    },
    {
        "tags": [
            "json",
            "nested",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 3004753,
                    "reputation": 1757,
                    "user_id": 2549487,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/dfcc724ce832c29b776b1c3413e101e9?s=256&d=identicon&r=PG",
                    "display_name": "webofmars",
                    "link": "https://stackoverflow.com/users/2549487/webofmars"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1611572377,
                "post_id": 65883327,
                "comment_id": 116485946,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1611572347,
                "creation_date": 1611572347,
                "answer_id": 65883403,
                "question_id": 65883327,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You&#39;re looking for [`map_values`](https://stedolan.github.io/jq/manual/#map(x),map_values(x)). It works just like `map`, but doesn&#39;t convert an object input to an array.\r\n```\r\nmap_values(.value)\r\n```\r\n&lt;sup&gt;[Online demo](https://jqplay.org/s/oE-Gw5OxxD)&lt;/sup&gt;",
                "title": "How to keep one level of object and extract one of its sub-key only?"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1611584128,
                "last_edit_date": 1611584128,
                "creation_date": 1611583366,
                "answer_id": 65886268,
                "question_id": 65883327,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "[oguz&#39;s answer][1] is crisp and to the point, but if you want to do with `*_entries` functions, you could getaway with \r\n\r\n```none\r\nwith_entries(.value = .value.value)\r\n```\r\n\r\n&lt;sup&gt;[jqplay - snippet][2]&lt;/sup&gt;\r\n\r\n\r\n  [1]: https://stackoverflow.com/a/65883403/5291015\r\n  [2]: https://jqplay.org/s/WL9PW5SGtB",
                "title": "How to keep one level of object and extract one of its sub-key only?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1611584128,
        "creation_date": 1611572056,
        "last_edit_date": 1611582653,
        "question_id": 65883327,
        "body_markdown": "I&#39;m playing a bit with terraform state json output and want to transform it a bit.\r\n\r\nGiven that input issued from terraform:\r\n\r\n```JSON\r\n{\r\n  &quot;cost&quot;: {\r\n    &quot;sensitive&quot;: false,\r\n    &quot;value&quot;: &quot;123&quot;\r\n  },\r\n  &quot;test_id&quot;: {\r\n    &quot;sensitive&quot;: false,\r\n    &quot;value&quot;: &quot;6610758455459338306&quot;\r\n  }\r\n}\r\n```\r\n\r\nHow do i convert it to something usefull for my application like bellow:\r\n\r\n```JSON\r\n{\r\n  &quot;cost&quot;: &quot;123&quot;,\r\n  &quot;test_id&quot;: &quot;6610758455459338306&quot;\r\n}\r\n```\r\n\r\nI tried to play with `from_entries`, `with_entries` but i&#39;m a complete noob at it",
        "link": "https://stackoverflow.com/questions/65883327/how-to-keep-one-level-of-object-and-extract-one-of-its-sub-key-only",
        "title": "How to keep one level of object and extract one of its sub-key only?"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1611591044,
                "last_edit_date": 1611591044,
                "creation_date": 1611589911,
                "answer_id": 65888059,
                "question_id": 65886484,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The easiest way to achieve this would be to keep `itemVariationsMap` in a variable, and retrieve item prices from there; not the other way around.\r\n``` none\r\n.itmVarModel\r\n| .itemVariationsMap as $m\r\n| .menuItemMap[]\r\n| { itemname: .displayName, itemprice: $m[&quot;\\(.matchingVariationIds[0])&quot;].price }\r\n```\r\n&lt;sup&gt;[Online demo](https://jqplay.org/s/2PFrnZOvJW)&lt;/sup&gt;",
                "title": "Using a JSON key as a lookup in JQ"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1611591145,
        "creation_date": 1611584189,
        "last_edit_date": 1611591145,
        "question_id": 65886484,
        "body_markdown": "I have some JSON that looks like this:\r\n```\r\n{\r\n    &quot;itmVarModel&quot;: {\r\n        &quot;menuItemMap&quot;: {\r\n            &quot;0&quot;: {\r\n                &quot;matchingVariationIds&quot;: [1234],\r\n                &quot;displayName&quot;: &quot;4 GB&quot;\r\n            },\r\n            &quot;1&quot;: {\r\n                &quot;matchingVariationIds&quot;: [5678],\r\n                &quot;displayName&quot;: &quot;16 GB&quot;\r\n            }\r\n        },\r\n        &quot;itemVariationsMap&quot;: {\r\n            &quot;5678&quot;: {\r\n                &quot;price&quot;: &quot;GBP 62.99&quot;,\r\n                &quot;variationId&quot;: 5678\r\n            },\r\n            &quot;1234&quot;: {\r\n                &quot;price&quot;: &quot;GBP 15.00&quot;,\r\n                &quot;variationId&quot;: 1234\r\n            }\r\n\t\t}\r\n    }\r\n}\r\n```\r\nI need to extract the name and price so that it looks like this:\r\n```\r\n{\r\n  &quot;itemname&quot;: &quot;16 GB&quot;,\r\n  &quot;itemprice&quot;: &quot;GBP 62.99&quot;\r\n}\r\n{\r\n  &quot;itemname&quot;: &quot;4 GB&quot;,\r\n  &quot;itemprice&quot;: &quot;GBP 15.00&quot;\r\n}\r\n```\r\nI&#39;ve just come across JQ which looks perfect for the job but the nearest I have got is:\r\n```\r\n[.itmVarModel.menuItemMap[].matchingVariationIds[]] as $names | {itemname: .itmVarModel.menuItemMap[].displayName, itemprice: .itmVarModel.itemVariationsMap.&quot;$names&quot;.price}\r\n```\r\nI am struggling with the syntax and don&#39;t really know what I am doing tbh.",
        "link": "https://stackoverflow.com/questions/65886484/using-a-json-key-as-a-lookup-in-jq",
        "title": "Using a JSON key as a lookup in JQ"
    },
    {
        "tags": [
            "json",
            "header",
            "export-to-csv",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1611647509,
                "creation_date": 1611647509,
                "answer_id": 65897572,
                "question_id": 65897260,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If you don&#39;t mind the header row being treated like any other CSV row, a jq-only solution would be to add an array of the desired header names to your filter like so:\r\n\r\n    [&quot;Effect&quot;, &quot;ID&quot;, &quot;Description&quot;, &quot;Expiration Date&quot;],\r\n    (.cveRules[] | [.effect, .id, .description, .expiration.date])\r\n    | @csv\r\n\r\nIf you want more control of the header row, then prepend your filter with the desired header row as a single string.",
                "title": "Column Name in the CSV file after converting from JSON using JQ"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1611671977,
        "creation_date": 1611645715,
        "last_edit_date": 1611671977,
        "question_id": 65897260,
        "body_markdown": "I am having problems on adding a column on my csv.\r\n```\r\n$ jq -r &#39;.cveRules[] | [.effect, .id, .description, .expiration.date] | @csv&#39; vulexemptioncmndt.json\r\n&quot;ignore&quot;,&quot;CVE-2020-8116&quot;,&quot;Package dot-prop 4.2.0, status: fixed in 5.1.1, 4.2.1&quot;,&quot;2021-02-27T23:00:00Z&quot;\r\n&quot;ignore&quot;,&quot;CVE-2020-8252&quot;,&quot;Package node 10.21.0, status: fixed in 14.9.0, 12.18.4, 10.22.1&quot;,&quot;2021-02-27T23:00:00Z&quot;\r\n&quot;ignore&quot;,&quot;CVE-2020-8265&quot;,&quot;Package node 10.21.0, status: fixed in 10.23.1&quot;,&quot;2021-02-27T23:00:00Z&quot;\r\n```\r\n\r\nWhat commands should I add so I can have a result of \r\n```\r\n&quot;Effect&quot;, &quot;ID&quot;, &quot;Description&quot;, &quot;Expiration Date&quot;\r\n&quot;ignore&quot;,&quot;CVE-2020-8116&quot;,&quot;Package dot-prop 4.2.0, status: fixed in 5.1.1, 4.2.1&quot;,&quot;2021-02-27T23:00:00Z&quot;\r\n&quot;ignore&quot;,&quot;CVE-2020-8252&quot;,&quot;Package node 10.21.0, status: fixed in 14.9.0, 12.18.4, 10.22.1&quot;,&quot;2021-02-27T23:00:00Z&quot;\r\n&quot;ignore&quot;,&quot;CVE-2020-8265&quot;,&quot;Package node 10.21.0, status: fixed in 10.23.1&quot;,&quot;2021-02-27T23:00:00Z&quot;\r\n```",
        "link": "https://stackoverflow.com/questions/65897260/column-name-in-the-csv-file-after-converting-from-json-using-jq",
        "title": "Column Name in the CSV file after converting from JSON using JQ"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1611815480,
                "last_edit_date": 1611815480,
                "creation_date": 1611723597,
                "answer_id": 65913104,
                "question_id": 65910229,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You don&#39;t need `*_entries` functions here.\r\n```\r\nmap_values(arrays | length)\r\n```\r\n&lt;sup&gt;[Online demo](https://jqplay.org/s/iy9uoj4tjF)&lt;/sup&gt;",
                "title": "Find length of each array field within a JSON object using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1611815480,
        "creation_date": 1611700252,
        "last_edit_date": 1611744341,
        "question_id": 65910229,
        "body_markdown": "I have a process that generates a JSON object containing some &quot;header&quot; values as scalars and a number of payload values as arrays:\r\n```json\r\n{\r\n  &quot;header 1&quot;: 42,\r\n  &quot;header 2&quot;: &quot;2020-01-27&quot;,\r\n  &quot;payload 1&quot;: [\r\n    {\r\n      &quot;foo&quot;: 1\r\n    },\r\n    {\r\n      &quot;foo&quot;: 2\r\n    }\r\n  ],\r\n  &quot;another payload&quot;: [\r\n    10,\r\n    9,\r\n    8,\r\n    7\r\n  ]\r\n}\r\n```\r\nI have been able to isolate the names of the array fields with the following command:\r\n```sh\r\n$ jq &#39;[to_entries | .[] | select(.value | type == &quot;array&quot;)] | from_entries | keys_unsorted&#39; results.json\r\n[\r\n  &quot;payload 1&quot;,\r\n  &quot;another payload&quot;\r\n]\r\n```\r\nBut I don&#39;t know how to use this to get the lengths of the arrays.  The output I&#39;m looking for would be something like:\r\n```json\r\n{\r\n  &quot;payload 1&quot;: 2,\r\n  &quot;another payload&quot;: 4\r\n}\r\n````\r\nOr anything that lists the keys of fields that are arrays and the length of the arrays.\r\n\r\nWhat is a `jq` command to list the lengths of all array fields in the top-level object?",
        "link": "https://stackoverflow.com/questions/65910229/find-length-of-each-array-field-within-a-json-object-using-jq",
        "title": "Find length of each array field within a JSON object using jq"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1611717113,
                "creation_date": 1611717113,
                "answer_id": 65912410,
                "question_id": 65912048,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Assuming the JSON samples have been corrected, and that the following program is in the file &quot;target.jq&quot;, the invocation:\r\n\r\n    jq --argfile lookup lookup.json -f target.jq target.json\r\n\r\nproduces the expected result.\r\n\r\n## target.jq\r\n```\r\n.top_level |= map(\r\n  $lookup[.name] as $value\r\n  | .tests |= map(\r\n      if has(&quot;test_2&quot;)\r\n      then .test_2.param_2 = $value\r\n      else . end) )\r\n```\r\n\r\n## Caveat\r\nSince `--argfile` is officially deprecated, you might wish to choose an alternative method of passing in the contents of lookup.json, but `--argfile` is supported by all extant versions of jq as of this writing.",
                "title": "jq: Conditional insert using &quot;lookup&quot; &amp; &quot;target&quot; JSON objects"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1611878009,
                "last_edit_date": 1611878009,
                "creation_date": 1611877702,
                "answer_id": 65946883,
                "question_id": 65912048,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The **_jq_** answer is already given, but the ask itself is so fascinating - it requires a cross-lookup from a source file into the file being inserted, so I could not help providing also an alternative solution using **`jtc`** utility:\r\n```\r\n&lt;target.json jtc -w&#39;&lt;name&gt;l:&lt;N&gt;v[-1][tests][-1:][0]&#39; \\\r\n                 -i file.json -i&#39;&lt;N&gt;t:&#39; -T&#39;{&quot;param_2&quot;:{{}}}&#39;\r\n```\r\n\r\nA brief overlook of the used options:\r\n - `-w&#39;&lt;name&gt;l:&lt;N&gt;v[-1][tests][-1:][0]&#39;` - selects _points of insertions_ in the source (`target.json`) by finding and memorizing into namespace `N` keys to be looked up in the inserted file, then rolling back 1 level up in the JSON tree, selecting `tests` label, then the last entry in it and finally addressing a 1st element of the last one\r\n - `-i file.json` make an insertion from the file\r\n - `-i&#39;&lt;N&gt;t:&#39;` - this _walk_ over `file.json` finds recursively a tag (label) preserved in the namespace `N` from the respective walk `-w` (if not this insert option with _the walk argument_, then the whole file would get inserted into the insertion points `-w..`)\r\n - `-T&#39;{&quot;param_2&quot;:{{}}}&#39;` - finally, a template operation is applied onto the insertion result transforming found entry (in `file.json`) into the one with the right label\r\n\r\nPS. I&#39;m the developer of the `jtc` - multithreading JSON processing utility for unix.  \r\nPPS. the disclaimer is required by SO.",
                "title": "jq: Conditional insert using &quot;lookup&quot; &amp; &quot;target&quot; JSON objects"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1611878009,
        "creation_date": 1611714128,
        "last_edit_date": 1611722318,
        "question_id": 65912048,
        "body_markdown": "I&#39;m trying to improve a bash script I wrote using `jq` (Python version), but can&#39;t quite get the conditional nature of the task at hand to work. \r\n\r\n**The task**: insert array from one JSON object (&quot;lookup&quot;) into another (&quot;target&quot;) *only* if the key of the &quot;lookup&quot; matches a particular &quot;higher-level&quot; value in the &quot;target&quot;. Assume that the two JSON objects are in `lookup.json` and `target.json`, respectively.\r\n\r\nA minimal example to make this clearer:\r\n\r\n&quot;Lookup&quot; JSON:\r\n\r\n```json\r\n{\r\n   &quot;table_one&quot;: [\r\n      &quot;a_col_1&quot;,\r\n      &quot;a_col_2&quot;\r\n   ],\r\n   &quot;table_two&quot;: [\r\n      &quot;b_col_1&quot;,\r\n      &quot;b_col_2&quot;,\r\n      &quot;b_col_3&quot;\r\n   ]\r\n}\r\n```\r\n\r\n&quot;Target&quot; JSON:\r\n\r\n```json\r\n{\r\n  &quot;top_level&quot;: [\r\n    {\r\n      &quot;name&quot;: &quot;table_one&quot;,\r\n      &quot;tests&quot;: [\r\n        {\r\n          &quot;test_1&quot;: {\r\n            &quot;param_1&quot;: &quot;some_param&quot;\r\n          }\r\n        },\r\n        {\r\n          &quot;test_2&quot;: {\r\n            &quot;param_1&quot;: &quot;another_param&quot;\r\n          }\r\n        }]\r\n    },\r\n    {\r\n      &quot;name&quot;: &quot;table_two&quot;,\r\n      &quot;tests&quot;: [\r\n        {\r\n          &quot;test_1&quot;: {\r\n            &quot;param_1&quot;: &quot;some_param&quot;\r\n          }\r\n        },\r\n        {\r\n          &quot;test_2&quot;: {\r\n            &quot;param_1&quot;: &quot;another_param&quot;\r\n          }\r\n        }\r\n      ]\r\n    }\r\n  ]\r\n}\r\n```\r\n\r\nI want the output to be:\r\n\r\n```json\r\n{\r\n\t&quot;top_level&quot;: [{\r\n\t\t\t\t&quot;name&quot;: &quot;table_one&quot;,\r\n\t\t\t\t&quot;tests&quot;: [{\r\n\t\t\t\t\t\t&quot;test_1&quot;: {\r\n\t\t\t\t\t\t\t&quot;param_1&quot;: &quot;some_param&quot;\r\n\t\t\t\t\t\t}\r\n\t\t\t\t\t},\r\n\t\t\t\t\t{\r\n\t\t\t\t\t\t&quot;test_2&quot;: {\r\n\t\t\t\t\t\t\t&quot;param_1&quot;: &quot;another_param&quot;,\r\n\t\t\t\t\t\t\t&quot;param_2&quot;: [\r\n\t\t\t\t\t\t\t\t&quot;a_col_1&quot;,\r\n\t\t\t\t\t\t\t\t&quot;a_col_2&quot;\r\n\t\t\t\t\t\t\t]\r\n\t\t\t\t\t\t}\r\n\t\t\t\t\t},\r\n\t\t\t\t\t{\r\n\t\t\t\t\t\t&quot;name&quot;: &quot;table_two&quot;,\r\n\t\t\t\t\t\t&quot;tests&quot;: [{\r\n\t\t\t\t\t\t\t\t&quot;test_1&quot;: {\r\n\t\t\t\t\t\t\t\t\t&quot;param_1&quot;: &quot;some_param&quot;\r\n\t\t\t\t\t\t\t\t}\r\n\t\t\t\t\t\t\t},\r\n\t\t\t\t\t\t\t{\r\n\t\t\t\t\t\t\t\t&quot;test_2&quot;: {\r\n\t\t\t\t\t\t\t\t\t&quot;param_1&quot;: &quot;another_param&quot;,\r\n\t\t\t\t\t\t\t\t\t&quot;param_2&quot;: [\r\n\t\t\t\t\t\t\t\t\t\t&quot;b_col_1&quot;,\r\n\t\t\t\t\t\t\t\t\t\t&quot;b_col_2&quot;,\r\n\t\t\t\t\t\t\t\t\t\t&quot;b_col_3&quot;\r\n\t\t\t\t\t\t\t\t\t]\r\n\t\t\t\t\t\t\t\t}\r\n\t\t\t\t\t\t\t}\r\n\t\t\t\t\t\t]\r\n\t\t\t\t\t}\r\n\t\t\t\t]\r\n\t\t\t}\r\n        ]\r\n    }\r\n```\r\n\r\nHopefully, that makes sense. Early attempts slurped both JSON blobs and assigned them to two variables. I&#39;m trying to select for a match on [roughly] `($lookup | keys[]) == $target.top_level.name`, but I can&#39;t quite get this match or the subsequent the array insert working.\r\n\r\nAny advice is well-received!",
        "link": "https://stackoverflow.com/questions/65912048/jq-conditional-insert-using-lookup-target-json-objects",
        "title": "jq: Conditional insert using &quot;lookup&quot; &amp; &quot;target&quot; JSON objects"
    },
    {
        "tags": [
            "json",
            "linux",
            "parsing",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 14709065,
                    "reputation": 9923,
                    "user_id": 10622916,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/0022d8bc5b72b83b2ff1a2a54b571f03?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Bodo",
                    "link": "https://stackoverflow.com/users/10622916/bodo"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1611769359,
                "post_id": 65924386,
                "comment_id": 116559361,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 5902225,
                    "reputation": 16454,
                    "user_id": 4645334,
                    "user_type": "registered",
                    "accept_rate": 87,
                    "profile_image": "https://lh6.googleusercontent.com/-hoIJVId9WIY/AAAAAAAAAAI/AAAAAAAAGQw/r7Es0WqE4rs/s256-rj/photo.jpg",
                    "display_name": "Thomas Sablik",
                    "link": "https://stackoverflow.com/users/4645334/thomas-sablik"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1611770246,
                "post_id": 65924386,
                "comment_id": 116559770,
                "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": 1611773584,
                "post_id": 65924386,
                "comment_id": 116561273,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1611773424,
                "creation_date": 1611773424,
                "answer_id": 65925532,
                "question_id": 65924386,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "With your sample, the following invocation produces the output shown below in accordance with what I take to be the requirements, though the output does slightly differ from what is shown in the question:\r\n\r\n    jq -r -f program.jq myfile.json\r\n\r\nwhere program.jq contains:\r\n```\r\n.SystemInventory[][]\r\n| {BIOSReleaseDate, VersionString, CPUFamily, DeviceDescription, IPv4Address, NICSpeed}\r\n| to_entries[]\r\n| select(.value != null)\r\n| &quot;\\&quot;\\(.key)\\&quot;: \\&quot;\\(.value)\\&quot;&quot;\r\n```\r\n### Output\r\n\r\n```\r\n&quot;BIOSReleaseDate&quot;: &quot;11/12/2020&quot;\r\n&quot;VersionString&quot;: &quot;2.10.0&quot;\r\n&quot;CPUFamily&quot;: &quot;Intel(R) Xeon(TM)&quot;\r\n&quot;DeviceDescription&quot;: &quot;CPU 1&quot;\r\n&quot;CPUFamily&quot;: &quot;Intel(R) Xeon(TM)&quot;\r\n&quot;DeviceDescription&quot;: &quot;CPU 2&quot;\r\n&quot;IPv4Address&quot;: &quot;6.6.16.16&quot;\r\n&quot;NICSpeed&quot;: &quot;100&quot;\r\n```",
                "title": "Parsing json file with nested objects"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1611821988,
                "creation_date": 1611821988,
                "answer_id": 65933362,
                "question_id": 65924386,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "`jq &#39;.SystemInventory.BIOS[0].BIOSReleaseDate&#39;` seems to be fine but I will get just one row, and how to combine with other one e.g. `jq &#39;.SystemInventory.iDRACNIC[0].IPv4Address&#39;` so I would get two lines as output?? \r\nthanks",
                "title": "Parsing json file with nested objects"
            }
        ],
        "is_answered": false,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1611821988,
        "creation_date": 1611768945,
        "last_edit_date": 1611818537,
        "question_id": 65924386,
        "body_markdown": "I&#39;d like to ask you for a help.\r\n\r\nI&#39;m fighting with the &quot;jq&quot; parser but running out of ideas. I would need to extract only the needed lines from the given json file.\r\n\r\nHere is my file:\r\n\r\n    {\r\n      &quot;SystemInventory&quot;: {\r\n        &quot;BIOS&quot;: [\r\n          {\r\n            &quot;BIOSReleaseDate&quot;: &quot;11/12/2020&quot;,\r\n            &quot;FQDD&quot;: &quot;BIOS.Setup.1-1&quot;,\r\n            &quot;SMBIOSPresent&quot;: &quot;True&quot;,\r\n            &quot;VersionString&quot;: &quot;2.10.0&quot;\r\n          }\r\n        ],\r\n        &quot;CPU&quot;: [\r\n          {\r\n            &quot;CPUFamily&quot;: &quot;Intel(R) Xeon(TM)&quot;,\r\n            &quot;Characteristics&quot;: &quot;64-bit capable&quot;,\r\n            &quot;CurrentClockSpeed&quot;: &quot;2.2 GHz&quot;,\r\n            &quot;DeviceDescription&quot;: &quot;CPU 1&quot;\r\n          },\r\n          {\r\n            &quot;CPUFamily&quot;: &quot;Intel(R) Xeon(TM)&quot;,\r\n            &quot;Characteristics&quot;: &quot;64-bit capable&quot;,\r\n            &quot;CurrentClockSpeed&quot;: &quot;2.2 GHz&quot;,\r\n            &quot;DeviceDescription&quot;: &quot;CPU 2&quot;\r\n          }\r\n        ],\r\n        &quot;iDRACNIC&quot;: [\r\n          {\r\n            &quot;IPv4Address&quot;: &quot;6.6.16.16&quot;,\r\n            &quot;NICDuplex&quot;: &quot;Full&quot;,\r\n            &quot;NICEnabled&quot;: &quot;Enabled&quot;,\r\n            &quot;NICSpeed&quot;: &quot;100&quot;,\r\n            &quot;PermanentMACAddress&quot;: &quot;5c:d8:8f:1e:51:ce&quot;\r\n          }\r\n        ]\r\n      }\r\n    }\r\n    \r\n I would need only some lines let&#39;s say, I would expect the output like this:\r\n\r\n    &quot;BIOSReleaseDate&quot;: &quot;11/12/2020&quot;\r\n    &quot;VersionString&quot;: &quot;2.10.0&quot;\r\n    &quot;CPUFamily&quot;: &quot;Intel(R) Xeon(TM)&quot;\r\n    &quot;DeviceDescription&quot;: &quot;CPU 1&quot;\r\n    &quot;DeviceDescription&quot;: &quot;CPU 2&quot;\r\n    &quot;IPv4Address&quot;: &quot;6.6.16.16&quot;\r\n    &quot;NICSpeed&quot;: &quot;100&quot;\r\n\r\nI tried it with &quot;jq&quot; parser but when it comes to nested objects I&#39;m out of ideas.\r\nIs there a way how can I achieve this via jq?\r\n\r\nI would appreciate any kind of help..\r\n\r\nMany thanks in advance\r\n\r\n\r\nThe following approach how to parse the specific rows, based on your inputs, seems to be more convenient for me:\r\n\r\n    cat data.json | jq &#39;.SystemInventory.BIOS[0] | {BIOS: .VersionString}&#39;\r\n    {\r\n      &quot;BIOS&quot;: &quot;2.10.0&quot;\r\n    }\r\n\r\nand\r\n\r\n    cat data.json | jq &#39;.SystemInventory.iDRACNIC[0] | {IP: .IPv4Address}&#39;\r\n    {\r\n      &quot;IP&quot;: &quot;6.6.16.16&quot;\r\n    }\r\n\r\nIs there a way how to achieve that in one command?\r\nThanks in advance!",
        "link": "https://stackoverflow.com/questions/65924386/parsing-json-file-with-nested-objects",
        "title": "Parsing json file with nested objects"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 9238831,
                    "reputation": 43615,
                    "user_id": 6862601,
                    "user_type": "registered",
                    "accept_rate": 88,
                    "profile_image": "https://i.sstatic.net/gw49Zw5I.jpg?s=256",
                    "display_name": "codeforester",
                    "link": "https://stackoverflow.com/users/6862601/codeforester"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1611828262,
                "post_id": 65933153,
                "comment_id": 116577658,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 5,
                "is_accepted": true,
                "score": 5,
                "last_activity_date": 1623700911,
                "last_edit_date": 1623700911,
                "creation_date": 1611825993,
                "answer_id": 65934319,
                "question_id": 65933153,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Built-in commands are [immune](https://stackoverflow.com/q/47443380/6862601) to that limitation, and `printf` is one of them. In conjunction with `xargs`, it would help a lot to achieve this.\r\n```\r\nprintf &#39;%s\\0&#39; *.json | xargs -0 cat -- | jq -s .\r\n```",
                "title": "&quot;Argument list too long&quot; while slurping JSON files"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 3,
        "last_activity_date": 1666843015,
        "creation_date": 1611821096,
        "last_edit_date": 1666843015,
        "question_id": 65933153,
        "body_markdown": "I have thousands of JSON files, and I want to merge them into a single one. I&#39;m using the command below to do this.\r\n```\r\njq -s . -- *.json &gt; result.json\r\n```\r\nBut I am getting argument list too long error, probably because of the number of files I&#39;m trying to merge. Is there any workaround for this issue?",
        "link": "https://stackoverflow.com/questions/65933153/argument-list-too-long-while-slurping-json-files",
        "title": "&quot;Argument list too long&quot; while slurping JSON files"
    },
    {
        "tags": [
            "json",
            "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": 4,
                "creation_date": 1611835092,
                "post_id": 65936470,
                "comment_id": 116580757,
                "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": 1611860247,
                "post_id": 65936470,
                "comment_id": 116593440,
                "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": 1611860382,
                "post_id": 65936470,
                "comment_id": 116593498,
                "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": 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": 1611867396,
                "post_id": 65936470,
                "comment_id": 116596228,
                "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"
                },
                "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": 1611867699,
                "post_id": 65936470,
                "comment_id": 116596353,
                "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"
                },
                "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": 1611867916,
                "post_id": 65936470,
                "comment_id": 116596431,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1611914299,
                "last_edit_date": 1611914299,
                "creation_date": 1611860141,
                "answer_id": 65943509,
                "question_id": 65936470,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If you add a line with &#39;[&#39; at the beginning and another with &#39;]&#39; at the end, then:\r\n\r\n    hjson -j  input.txt\r\n\r\nyields:\r\n\r\n```\r\n[\r\n  &quot;Successes: 0&quot;,\r\n  &quot;Failures: 1&quot;,\r\n  {\r\n    &quot;name&quot;: &quot;&quot;,\r\n    &quot;success&quot;: false,\r\n    &quot;error&quot;: &quot;&quot;,\r\n    &quot;data&quot;: {\r\n      &quot;video&quot;: &quot;&quot;\r\n    }\r\n  }\r\n]\r\n```\r\nSince this is valid JSON, you can pipe it to jq to extract whichever pieces you want.\r\n\r\n\r\nAn interesting lossless possibility is to recognize key-value pairs:\r\n\r\n    jq &#39;map(if type == &quot;string&quot; and index(&quot;:&quot;) \r\n            then [splits(&quot;: *&quot;)]\r\n                 | {(.[0]): .[1] | (tonumber? // .)}\r\n            else . end)&#39;\r\n\r\nWith your sample, this would produce:\r\n\r\n```\r\n[\r\n  {\r\n    &quot;Successes&quot;: 0\r\n  },\r\n  {\r\n    &quot;Failures&quot;: 1\r\n  },\r\n  {\r\n    &quot;name&quot;: &quot;&quot;,\r\n    &quot;success&quot;: false,\r\n    &quot;error&quot;: &quot;&quot;,\r\n    &quot;data&quot;: {\r\n      &quot;video&quot;: &quot;&quot;\r\n    }\r\n  }\r\n]\r\n```\r\n\r\n### Caveat\r\nThe above assumes that if a top-level item is a string with more than one colon, then it is acceptable to discard the string contents after the second colon. \r\n",
                "title": "Extract the valid portions of a mostly JSON file"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1611861300,
                "creation_date": 1611861300,
                "answer_id": 65943804,
                "question_id": 65936470,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If you just want to check, if the json is valid, you could do something like this:\r\n\r\n    jq &lt; foo.json &gt; /dev/null 2&gt;&amp;1\r\n    echo $?\r\n\r\nIf the json in `foo.json` is not valid, `$?` will contain something unequal `0`.\r\nIf `$? == 0` -- then the json was valid. \r\n\r\nBTW: It&#39;s not just because of the `Success` and `Failures` keys (which are outside of the json object) that your json is invalid -- also all the keys and string-values have to be quoted (with double quotes).\r\nSo e.g. a valid version would be:\r\n\r\n    {\r\n      &quot;Successes&quot;: 0,\r\n      &quot;Failures&quot;: 1,\r\n      &quot;name&quot;: &quot;&quot;,\r\n      &quot;success&quot;: false,\r\n      &quot;data&quot;: {\r\n        &quot;video&quot;: &quot;&quot;\r\n      }\r\n    }\r\n\r\n \r\n",
                "title": "Extract the valid portions of a mostly JSON file"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1611868695,
                "creation_date": 1611868695,
                "answer_id": 65945375,
                "question_id": 65936470,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "To emit all but the first two lines of a file, you can use the following:\r\n\r\n```sh\r\n( read; read; cat ) &lt;foo.json\r\n```\r\n\r\nThis will produce\r\n\r\n```js\r\n{\r\n  name: &#39;&#39;,\r\n  success: false,\r\n  error: &#39;&#39;,\r\n  data: {\r\n    video: &#39;&#39;\r\n  }\r\n}\r\n```\r\n\r\nBut contrary to your claims, this is not valid JSON, and `jq` isn&#39;t able to work with that either. If that&#39;s your ultimate goal, use `hjson` to massage that JS into JSON as @peak [demonstrated](https://stackoverflow.com/a/65943509/589924).",
                "title": "Extract the valid portions of a mostly JSON file"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1611873270,
                "last_edit_date": 1611873270,
                "creation_date": 1611872939,
                "answer_id": 65946138,
                "question_id": 65936470,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "To add another guess, while this is not valid JSON, at least some YAML parsers can handle it, which may be available to the next step in the chain you may be consuming input into and even easier than piping through `jq`\r\n\r\nFor example [`pyyaml`][2] for Python (common 3rd-party [LibYAML][1]-based parser) can handle this directly\r\n\r\n```python\r\n&gt;&gt;&gt; s = &quot;&quot;&quot;{\r\n...   name: &#39;&#39;,\r\n...   success: false,\r\n...   error: &#39;&#39;,\r\n...   data: {\r\n...     video: &#39;&#39;\r\n...   }\r\n... }&quot;&quot;&quot;\r\n&gt;&gt;&gt; yaml.safe_load(s)  # returns a Python dictionary\r\n{&#39;name&#39;: &#39;&#39;, &#39;success&#39;: False, &#39;error&#39;: &#39;&#39;, &#39;data&#39;: {&#39;video&#39;: &#39;&#39;}}\r\n```\r\n\r\nI present this rather-gross solution for the 1-liner buffs\r\n\r\n```shell\r\npython3 -c &quot;import sys,json,yaml; print(json.dumps(yaml.safe_load(&#39;&#39;.join([x for x in sys.stdin][2:]))))&quot;\r\n```\r\n\r\n&gt; `imports` libs  \r\nread each line from `stdin`  \r\nslice from the first two `[2:]`  \r\nreconnect &#39;em with `.join`  \r\nparse as yaml to a dictionary  \r\nstringify dict to json\r\n\r\nComplete example (useless use of cat to demonstrate consuming from pipe)\r\n\r\n```shell\r\ncat &lt;&lt; EOF | python3 -c &quot;import sys,json,yaml; print(json.dumps(yaml.safe_load(&#39;&#39;.join([x for x in sys.stdin][2:]))))&quot; | jq\r\nSuccesses: 0\r\nFailures: 1\r\n{\r\n  name: &#39;&#39;,\r\n  success: false,\r\n  error: &#39;&#39;,\r\n  data: {\r\n    video: &#39;&#39;\r\n  }\r\n}\r\nEOF\r\n```\r\n```\r\n{\r\n  &quot;name&quot;: &quot;&quot;,\r\n  &quot;success&quot;: false,\r\n  &quot;error&quot;: &quot;&quot;,\r\n  &quot;data&quot;: {\r\n    &quot;video&quot;: &quot;&quot;\r\n  }\r\n}\r\n```\r\n\r\n[1]: https://github.com/yaml/libyaml\r\n[2]: https://pyyaml.org/wiki/PyYAMLDocumentation",
                "title": "Extract the valid portions of a mostly JSON file"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1611935557,
                "creation_date": 1611935557,
                "answer_id": 65957658,
                "question_id": 65936470,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The following is a response to the task described in the title:\r\n\r\n&gt; Extract the valid portions of a mostly JSON file\r\n\r\nGiven a file in which each JSON entity of interest has a type other than &quot;string&quot; and is on a single line, there is a jq solution that will extract them:\r\n\r\n    jq -nR &#39;inputs | fromjson? | select(type!=&quot;string&quot;)&#39; input.txt\r\n\r\nThe following variant may also be of interest:\r\n\r\n    jq -nR &#39;inputs | fromjson?&#39; input.txt\r\n\r\n",
                "title": "Extract the valid portions of a mostly JSON file"
            }
        ],
        "is_answered": true,
        "answer_count": 5,
        "score": 2,
        "last_activity_date": 1611935557,
        "creation_date": 1611834275,
        "last_edit_date": 1611935057,
        "question_id": 65936470,
        "body_markdown": "I&#39;m using `jq` to parse this file:\r\n\r\n```\r\nSuccesses: 0\r\nFailures: 1\r\n{\r\n  name: &#39;&#39;,\r\n  success: false,\r\n  error: &#39;&#39;,\r\n  data: {\r\n    video: &#39;&#39;\r\n  }\r\n}\r\n```\r\n\r\nAnd obviously running `jq &lt; foo.json` yields: \r\n\r\n```lang-none\r\nparse error: Invalid numeric literal at line 1, column 10\r\n```\r\n\r\nBecause it can&#39;t parse\r\n\r\n```lang-none\r\nSuccesses: 0\r\nFailures: 1\r\n```\r\n\r\nIs there way using Bash or `jq` itself to extract the remaining portion which is valid JSON?\r\n\r\n```json\r\n{\r\n  name: &#39;&#39;,\r\n  success: false,\r\n  error: &#39;&#39;,\r\n  data: {\r\n    video: &#39;&#39;\r\n  }\r\n}\r\n```",
        "link": "https://stackoverflow.com/questions/65936470/extract-the-valid-portions-of-a-mostly-json-file",
        "title": "Extract the valid portions of a mostly JSON file"
    },
    {
        "tags": [
            "json",
            "date",
            "filter",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1611866611,
                "last_edit_date": 1611866611,
                "creation_date": 1611864398,
                "answer_id": 65944462,
                "question_id": 65938964,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "All you need is this:\r\n\r\n```jq\r\n( now | gmtime | strftime(&quot;%Y-%m&quot;) ) as $this_month\r\n| .[]\r\n| select( .created_at | startswith($this_month) )\r\n```\r\n\r\n[jq play](https://jqplay.org/s/uQ9fcixoAA)\r\n\r\nThe rest of this answer addresses the OP&#39;s code.\r\n\r\n---\r\n\r\n**Problem #0**\r\n\r\nNot really a problem, but a lot of necessary work is being done. `gmtime` already returns an array of the date-time components, so \r\n\r\n```jq\r\nnow | gmtime | strftime(&quot;%Y-%m-%dT%H:%M:%S.%Z&quot;) | strptime(&quot;%FT%T.%Z&quot;)[0:6]\r\n```\r\n\r\naka\r\n\r\n```jq\r\nnow | gmtime | strftime(&quot;%FT%T.%Z&quot;) | strptime(&quot;%FT%T.%Z&quot;)[0:6]\r\n```\r\n\r\n\r\nsimplifies to\r\n\r\n```jq\r\nnow | gmtime[0:6]\r\n```\r\n\r\nAlso, the slice is uneeded.\r\n\r\n```jq\r\nnow | gmtime\r\n```\r\n\r\nCaveat: In this new version, the seconds component is fractional (e.g. 23.489198923110962) instead of integral (e.g. 23), but that&#39;s not a problem for us.\r\n\r\n---\r\n\r\n**Problem #1**\r\n\r\n`.id.[].created_at` makes no sense.\r\n\r\n```jq\r\n.id | $f[0] == ( .[].created_at | strptime(&quot;%FT%T.%Z&quot;)[0] ) and\r\n      $f[1] == ( .[].created_at | strptime(&quot;%FT%T.%Z&quot;)[1] )\r\n```\r\n\r\nshould be\r\n\r\n```jq\r\n$f[0] == ( .created_at | strptime(&quot;%FT%T.%Z&quot;)[0] ) and\r\n$f[1] == ( .created_at | strptime(&quot;%FT%T.%Z&quot;)[1] )\r\n```\r\n\r\nThis is the same as the following: (Just my preference)\r\n\r\n```jq\r\n( .created_at | strptime(&quot;%FT%T.%Z&quot;)[0] ) == $f[0] and\r\n( .created_at | strptime(&quot;%FT%T.%Z&quot;)[1] ) == $f[1]\r\n```\r\n\r\nWe can factor out `.created_at`.\r\n\r\n```jq\r\n.created_at | strptime(&quot;%FT%T.%Z&quot;)[0] == $f[0] and\r\n              strptime(&quot;%FT%T.%Z&quot;)[1] == $f[1]\r\n```\r\n\r\nWe can factor out the call to `strptime` as well.\r\n\r\n\r\n```jq\r\n.created_at | strptime(&quot;%FT%T.%Z&quot;) | .[0] == $f[0] and .[1] == $f[1]\r\n```\r\n\r\nThis nets us this:\r\n\r\n```jq\r\n( now | gmtime ) as $f \r\n| map(select( .created_at | strptime(&quot;%FT%T.%Z&quot;) | .[0] == $f[0] and .[1] == $f[1] ))\r\n```\r\n\r\n[jq play](https://jqplay.org/s/LmNE2KnxQz)\r\n\r\n---\r\n\r\n**Problem #2**\r\n\r\nWe need to flatten the array.\r\n\r\n```jq\r\n... | map(select(...))\r\n```\r\nshould be\r\n\r\n```jq\r\n... | map(select(...)) | .[]\r\n```\r\n\r\nOf course, we could flatten first, allowing us to eliminate to use of `map`.\r\n\r\n```jq\r\n... | .[] | select(...)\r\n```\r\n\r\nThis nets us this:\r\n\r\n```jq\r\n( now | gmtime ) as $f \r\n| .[]\r\n| select(\r\n   .created_at\r\n   | strptime(&quot;%FT%T.%Z&quot;)\r\n   | .[0] == $f[0] and .[1] == $f[1]\r\n)\r\n```\r\n\r\n[jq play](https://jqplay.org/s/iB-bNfRTkG)\r\n",
                "title": "I need to Select an id when a date matches a query"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1611866611,
        "creation_date": 1611843586,
        "last_edit_date": 1611864187,
        "question_id": 65938964,
        "body_markdown": "**My json.file**\r\n\r\n```json\r\n[  \r\n  {\r\n    &quot;id&quot;: 0000001,\r\n    &quot;created_at&quot;: &quot;2021-01-28T17:29:35.888Z&quot;\r\n  },\r\n  {\r\n    &quot;id&quot;: 0000002,\r\n    &quot;created_at&quot;: &quot;2020-12-11T17:29:38.655Z&quot;\r\n  },\r\n  {\r\n    &quot;id&quot;: 0000003,\r\n    &quot;created_at&quot;: &quot;2020-12-11T17:29:37.233Z&quot;\r\n  },\r\n  {\r\n    &quot;id&quot;: 0000004,\r\n    &quot;created_at&quot;: &quot;2020-03-30T16:23:59.682Z&quot;\r\n  }\r\n]  \r\n```\r\n\r\n**My Query**\r\n\r\nFirst: I get the date of the day\r\n\r\n```jq\r\n( now | gmtime | strftime(&quot;%Y-%m-%dT%H:%M:%S.%Z&quot;) \r\n```\r\n\r\nThen: I transform it to an array\r\n\r\n```jq\r\n| strptime(&quot;%FT%T.%Z&quot;) [0:6] ) as $f \r\n```\r\n\r\nThen: I want it to show only the id that matches my condition\r\n\r\n```jq\r\n| map(select(\r\n    .id | $f[0] == (.[].created_at | strptime(&quot;%FT%T.%Z&quot;)[0]) and\r\n          $f[1] == (.[].created_at | strptime(&quot;%FT%T.%Z&quot;)[1])\r\n))\r\n```\r\n\r\nWhat happens is that it shows me all the records if it finds the condition correct. But I need only the id of the one that matches. What would be my mistake?\r\n\r\nThe result I get:\r\n\r\n```json\r\n[\r\n  {\r\n    &quot;id&quot;: 1,\r\n    &quot;created_at&quot;: &quot;2021-01-28T17:29:35.888Z&quot;\r\n  },\r\n  {\r\n    &quot;id&quot;: 2,\r\n    &quot;created_at&quot;: &quot;2020-12-11T17:29:38.655Z&quot;\r\n  },\r\n  {\r\n    &quot;id&quot;: 3,\r\n    &quot;created_at&quot;: &quot;2020-12-11T17:29:37.233Z&quot;\r\n  },\r\n  {\r\n    &quot;id&quot;: 4,\r\n    &quot;created_at&quot;: &quot;2020-03-30T16:23:59.682Z&quot;\r\n  }\r\n]\r\n```\r\n\r\nThe result I expect:\r\n\r\n```json\r\n{\r\n    &quot;id&quot;: 1,\r\n    &quot;created_at&quot;: &quot;2021-01-28T17:29:35.888Z&quot;\r\n  },\r\n```",
        "link": "https://stackoverflow.com/questions/65938964/i-need-to-select-an-id-when-a-date-matches-a-query",
        "title": "I need to Select an id when a date matches a query"
    },
    {
        "tags": [
            "json",
            "path",
            "null",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1611887224,
                "creation_date": 1611887224,
                "answer_id": 65947960,
                "question_id": 65947125,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "This issue is covered in the [jq FAQ][1], wherein the following def for a more inclusive version of `paths` is given:\r\n```\r\ndef allpaths:\r\n  def conditional_recurse(f):  def r: ., (select(.!=null) | f | r); r;\r\n  path(conditional_recurse(.[]?)) | select(length &gt; 0);\r\n```\r\n\r\nThe corresponding version of `paths/1` would be:\r\n\r\n```\r\ndef allpaths(filter):\r\n  allpaths as $p | getpath($p) as $v | select($v | filter) | $p;\r\n```\r\n\r\n\r\n  [1]: https://github.com/stedolan/jq/wiki/FAQ",
                "title": "JQ - Fetch all the paths in json including &quot;null&quot; values"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1612105944,
        "creation_date": 1611879607,
        "last_edit_date": 1612105944,
        "question_id": 65947125,
        "body_markdown": "I have a json file in which I wish to retrieve all the paths of all the keys. \r\nI have been using JQ, however, it does not show the paths which have null as their values. What am I missing here? \r\n\r\nJson : \r\n```\r\n{\r\n    &quot;Root&quot;: [\r\n        {\r\n            &quot;id1&quot;: &quot;val&quot;,\r\n            &quot;id2&quot;: &quot;val&quot;,\r\n            &quot;id3&quot;: null,\r\n            &quot;id4&quot;: 1,\r\n            &quot;id5&quot;: null,\r\n            &quot;id6&quot;: &quot;val&quot;,\r\n            &quot;id7&quot;: {\r\n                &quot;id8&quot;: &quot;val&quot;,\r\n                &quot;id9&quot;: &quot;val&quot;,\r\n                &quot;id10&quot;: null,\r\n                &quot;id11&quot;: &quot;val&quot;\r\n            }\r\n        }\r\n    ]\r\n}\r\n```\r\n\r\n```\r\njq -r &#39;paths(scalars)  as $p  | [ ( [ $p[] | tostring ]  | join(&quot;.&quot;) ), ( getpath($p) | tojson )] | join(&quot;: &quot;)&#39; test_data.json\r\n```\r\n\r\nOutput is as shown as \r\n```\r\n{\r\n    &quot;Root&quot;: [\r\n        {\r\n            &quot;id1&quot;: &quot;val&quot;,\r\n            &quot;id2&quot;: &quot;val&quot;,\r\n            &quot;id3&quot;: null,\r\n            &quot;id4&quot;: 1,\r\n            &quot;id5&quot;: null,\r\n            &quot;id6&quot;: &quot;val&quot;,\r\n            &quot;id7&quot;: {\r\n                &quot;id8&quot;: &quot;val&quot;,\r\n                &quot;id9&quot;: &quot;val&quot;,\r\n                &quot;id10&quot;: null,\r\n                &quot;id11&quot;: &quot;val&quot;\r\n            }\r\n        }\r\n    ]\r\n}\r\n```\r\n\r\nI wish to see path of the all nodes including those which have null as their value.",
        "link": "https://stackoverflow.com/questions/65947125/jq-fetch-all-the-paths-in-json-including-null-values",
        "title": "JQ - Fetch all the paths in json including &quot;null&quot; values"
    },
    {
        "tags": [
            "json",
            "grep",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1611906684,
                "creation_date": 1611906684,
                "answer_id": 65950599,
                "question_id": 65950072,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "With your input,\r\n```\r\njq &#39;.[].name&#39; f1.json\r\n```\r\nyields\r\n```\r\n&quot;actual_build&quot;\r\n&quot;CIS_TEPL_QA_Deploy&quot;\r\n&quot;cktest&quot;\r\n&quot;Create_New_DB_Structure&quot;\r\n```",
                "title": "How to get name value in the below json file"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1611933682,
        "creation_date": 1611903495,
        "last_edit_date": 1611933682,
        "question_id": 65950072,
        "body_markdown": "```\r\n[\r\n  {\r\n    &quot;_class&quot;: &quot;hudson.model.FreeStyleProject&quot;,\r\n    &quot;name&quot;: &quot;actual_build&quot;,\r\n    &quot;url&quot;: &quot;http://tepl.tallycloudinfra.com:8080/job/actual_build/&quot;,\r\n    &quot;color&quot;: &quot;blue&quot;,\r\n    &quot;fullname&quot;: &quot;actual_build&quot;\r\n  },\r\n  {\r\n    &quot;_class&quot;: &quot;hudson.model.FreeStyleProject&quot;,\r\n    &quot;name&quot;: &quot;CIS_TEPL_QA_Deploy&quot;,\r\n    &quot;url&quot;: &quot;http://tepl.tallycloudinfra.com:8080/job/CIS_TEPL_QA_Deploy/&quot;,\r\n    &quot;color&quot;: &quot;blue&quot;,\r\n    &quot;fullname&quot;: &quot;CIS_TEPL_QA_Deploy&quot;\r\n  },\r\n  {\r\n    &quot;_class&quot;: &quot;hudson.model.FreeStyleProject&quot;,\r\n    &quot;name&quot;: &quot;cktest&quot;,\r\n    &quot;url&quot;: &quot;http://tepl.tallycloudinfra.com:8080/job/cktest/&quot;,\r\n    &quot;color&quot;: &quot;red&quot;,\r\n    &quot;fullname&quot;: &quot;cktest&quot;\r\n  },\r\n  {\r\n    &quot;_class&quot;: &quot;hudson.model.FreeStyleProject&quot;,\r\n    &quot;name&quot;: &quot;Create_New_DB_Structure&quot;,\r\n    &quot;url&quot;: &quot;http://tepl.tallycloudinfra.com:8080/job/Create_New_DB_Structure/&quot;,\r\n    &quot;color&quot;: &quot;blue&quot;,\r\n    &quot;fullname&quot;: &quot;Create_New_DB_Structure&quot;\r\n  }\r\n]\r\n\r\n```\r\nI tried below jq command i&#39;m getting this error.\r\n\r\nError:\r\n```\r\njq -r &#39;._class[].name&#39; f1.json\r\njq: error (at f1.json:30): Cannot index array with string &quot;_class&quot;\r\n\r\njq -r &#39;._class.name&#39; f1.json\r\njq: error (at f1.json:30): Cannot index array with string &quot;_class&quot;\r\n```",
        "link": "https://stackoverflow.com/questions/65950072/how-to-get-name-value-in-the-below-json-file",
        "title": "How to get name value in the below json file"
    },
    {
        "tags": [
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1611956362,
                "post_id": 65960107,
                "comment_id": 116626022,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 20582315,
                    "reputation": 39,
                    "user_id": 15108100,
                    "user_type": "registered",
                    "profile_image": "https://lh6.googleusercontent.com/-wEhPR5HIr4U/AAAAAAAAAAI/AAAAAAAAAAA/AMZuuclFenabj3i85lZOLL5f7u7FQlUecQ/s96-c/s256-rj/photo.jpg",
                    "display_name": "Tom Donnly",
                    "link": "https://stackoverflow.com/users/15108100/tom-donnly"
                },
                "reply_to_user": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1612138145,
                "post_id": 65960107,
                "comment_id": 116665864,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1611961735,
                "creation_date": 1611961735,
                "answer_id": 65962918,
                "question_id": 65960107,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You might like to consider:\r\n\r\n    jq &#39;.. | strings | select(contains(&quot;tdon&quot;))&#39;\r\n",
                "title": "Problem with jq doing a select and contains"
            },
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1612139523,
                "creation_date": 1612139523,
                "answer_id": 65985718,
                "question_id": 65960107,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "With the sample JSON shown in a comment, the following filter would produce the result shown:\r\n\r\n```\r\n.results[] | .series[][] | flatten[] | select(contains(&quot;tdon&quot;)?)\r\n```\r\n\r\n## Output with -r option\r\n```\r\ntdonn\r\n```",
                "title": "Problem with jq doing a select and contains"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1612139523,
        "creation_date": 1611945974,
        "last_edit_date": 1611947189,
        "question_id": 65960107,
        "body_markdown": "I have limited experience with jq and am having an issue doing a a select contains for a string in a boolean.  This is my json and am looking to get back just tdonn.\r\n\r\n```json\r\n[\r\n  &quot;user&quot;,\r\n  &quot;admin&quot;\r\n]\r\n[\r\n  [\r\n    &quot;tdonn&quot;,\r\n    true\r\n  ]\r\n]\r\n```\r\nHere is what im trying. I have tried many different ways too.\r\n\r\n    jq -e -r &#39;.results[] | .series[] | select(.values[] | contains(&quot;tdon&quot;))[]&#39;",
        "link": "https://stackoverflow.com/questions/65960107/problem-with-jq-doing-a-select-and-contains",
        "title": "Problem with jq doing a select and contains"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 911727,
                    "reputation": 928,
                    "user_id": 945407,
                    "user_type": "registered",
                    "accept_rate": 5,
                    "profile_image": "https://www.gravatar.com/avatar/7599b25221cf81f7ec06b4280f8c21d0?s=256&d=identicon&r=PG",
                    "display_name": "tres.14159",
                    "link": "https://stackoverflow.com/users/945407/tres-14159"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1612053086,
                "post_id": 65974585,
                "comment_id": 116647168,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 911727,
                    "reputation": 928,
                    "user_id": 945407,
                    "user_type": "registered",
                    "accept_rate": 5,
                    "profile_image": "https://www.gravatar.com/avatar/7599b25221cf81f7ec06b4280f8c21d0?s=256&d=identicon&r=PG",
                    "display_name": "tres.14159",
                    "link": "https://stackoverflow.com/users/945407/tres-14159"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1612054067,
                "post_id": 65974585,
                "comment_id": 116647345,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1612062814,
                "last_edit_date": 1612062814,
                "creation_date": 1612056228,
                "answer_id": 65974888,
                "question_id": 65974585,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I found:\r\n\r\n```\r\n$ cat c.json | jq &#39;\r\n  group_by(.genre)\r\n  | map({&quot;genre&quot;: .[0].genre, \r\n         &quot;film&quot;: map(. | del(.genre))})\r\n  | [ .[] | {(.genre): .film}]\r\n  | add&#39;\r\n{\r\n  &quot;comedy&quot;: [\r\n    {\r\n      &quot;title&quot;: &quot;Modern Times &quot;,\r\n      &quot;year&quot;: 1936,\r\n      &quot;country&quot;: &quot;USA&quot;\r\n    },\r\n    {\r\n      &quot;title&quot;: &quot;The Gold Rush&quot;,\r\n      &quot;year&quot;: 1925,\r\n      &quot;country&quot;: &quot;USA&quot;\r\n    }\r\n  ],\r\n  &quot;drama&quot;: [\r\n    {\r\n      &quot;title&quot;: &quot;The Kid&quot;,\r\n      &quot;year&quot;: 1921,\r\n      &quot;country&quot;: &quot;USA&quot;\r\n    }\r\n  ],\r\n  &quot;political satire&quot;: [\r\n    {\r\n      &quot;title&quot;: &quot;The Great Dictator&quot;,\r\n      &quot;year&quot;: 1940,\r\n      &quot;country&quot;: &quot;USA&quot;\r\n    }\r\n  ]\r\n}\r\n```\r\n\r\nMaybe it is not the best, because I think there are a lot of steps...but it runs.",
                "title": "Reshape a array to object with jq"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1612063488,
                "last_edit_date": 1612063488,
                "creation_date": 1612062319,
                "answer_id": 65975375,
                "question_id": 65974585,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "It can be done in three lines:\r\n```\r\n[group_by(.genre)[]\r\n | {(.[0].genre): map_values(del(.genre))}] \r\n| add \r\n```\r\n\r\n## `aggregate_by/3`\r\n\r\nThe relevant generic abstraction here is:\r\n```\r\ndef aggregate_by(s; f; g):\r\n  reduce s as $x  (null; .[$x|f] += [$x|g]);\r\n```\r\n\r\nThis allows the solution to be written directly as:\r\n```\r\naggregate_by(.[]; .genre; del(.genre))\r\n```\r\n\r\n\r\n",
                "title": "Reshape a array to object with jq"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1612064703,
                "last_edit_date": 1612064703,
                "creation_date": 1612063492,
                "answer_id": 65975462,
                "question_id": 65974585,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can use a modified version of Jeff Mercado&#39;s answer on the page [you linked to][1].\r\n\r\n    jq &#39;reduce .[] as $i ({}; .[$i.genre] += [$i])&#39;\r\n\r\nThat groups the objects as you want but leaves the genre key-value pair. You can delete them like so.\r\n\r\n    jq &#39;reduce .[] as $i ({}; .[$i.genre] += [$i|del(.genre)])&#39;\r\n\r\nReally, this is just a concrete version of peak&#39;s &quot;generic abstraction&quot;.\r\n\r\n  [1]: https://stackoverflow.com/a/42428521",
                "title": "Reshape a array to object with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 1,
        "last_activity_date": 1612064703,
        "creation_date": 1612052702,
        "question_id": 65974585,
        "body_markdown": "I am learning advance concepts of jq. And I made a tiny json with array with some films of Charles Chaplin...well this array in json:\r\n\r\n```json\r\n[\r\n    {\r\n        &quot;title&quot;: &quot;The Great Dictator&quot;,\r\n        &quot;year&quot;: 1940,\r\n        &quot;country&quot;: &quot;USA&quot;,\r\n        &quot;genre&quot;: &quot;political satire&quot;\r\n    },\r\n    {\r\n        &quot;title&quot;: &quot;Modern Times &quot;,\r\n        &quot;year&quot;: 1936,\r\n        &quot;country&quot;: &quot;USA&quot;,\r\n        &quot;genre&quot;: &quot;comedy&quot;\r\n    },\r\n    {\r\n        &quot;title&quot;: &quot;The Gold Rush&quot;,\r\n        &quot;year&quot;: 1925,\r\n        &quot;country&quot;: &quot;USA&quot;,\r\n        &quot;genre&quot;: &quot;comedy&quot;\r\n    },\r\n    {\r\n        &quot;title&quot;: &quot;The Kid&quot;,\r\n        &quot;year&quot;: 1921,\r\n        &quot;country&quot;: &quot;USA&quot;,\r\n        &quot;genre&quot;: &quot;drama&quot;\r\n    }\r\n]\r\n```\r\n\r\nAnd I want to convert or reshape into a object with the genres as the keys and the list of the films as array (comedy is only has two element in the array):\r\n\r\n```json\r\n{\r\n    &quot;comedy&quot;: [\r\n        {\r\n            &quot;title&quot;: &quot;Modern Times &quot;,\r\n            &quot;year&quot;: 1936,\r\n            &quot;country&quot;: &quot;USA&quot;\r\n        },\r\n        {\r\n            &quot;title&quot;: &quot;The Gold Rush&quot;,\r\n            &quot;year&quot;: 1925,\r\n            &quot;country&quot;: &quot;USA&quot;\r\n        }\r\n    ],\r\n    &quot;political satire&quot;:  [\r\n        {\r\n            &quot;title&quot;: &quot;The Great Dictator&quot;,\r\n            &quot;year&quot;: 1940,\r\n            &quot;country&quot;: &quot;USA&quot;\r\n        }\r\n    ],\r\n    &quot;drama&quot;: [\r\n        {\r\n            &quot;title&quot;: &quot;The Kid&quot;,\r\n            &quot;year&quot;: 1921,\r\n            &quot;country&quot;: &quot;USA&quot;\r\n        }\r\n    ]\r\n}\r\n```\r\n\r\nBut I can&#39;t do it. I trying the first step to create a object with genre and foo string as var, but it fails: `cat c.json | jq &#39;{.[] | (.genre): &quot;foo&quot; ]}&#39;`",
        "link": "https://stackoverflow.com/questions/65974585/reshape-a-array-to-object-with-jq",
        "title": "Reshape a array to object with jq"
    },
    {
        "tags": [
            "json",
            "path",
            "jq",
            "hierarchical-data"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1612095543,
                "last_edit_date": 1612095543,
                "creation_date": 1612093663,
                "answer_id": 65978745,
                "question_id": 65978589,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Convert namespaces to paths and you can build the desired output using `getpath`/`setpath` built-ins.\r\n```\r\nreduce .[] as {$namespace, $exports} ({};\r\n  ($namespace | ltrimstr(&quot;/&quot;) | split(&quot;/&quot;)) as $path\r\n  | setpath($path; getpath($path) + $exports)\r\n)\r\n```\r\n&lt;sup&gt;[Online demo](https://jqplay.org/s/YRaDkxkl3N)&lt;/sup&gt;",
                "title": "Nest and merge JSON based on namespaces"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 3,
        "last_activity_date": 1612133764,
        "creation_date": 1612092615,
        "last_edit_date": 1612133764,
        "question_id": 65978589,
        "body_markdown": "I&#39;ve got the following JSON document:&lt;br&gt;\r\n*(sorted by namespace; any namespace can appear multiple times)*\r\n\r\n```json\r\n[ {&quot;namespace&quot;: &quot;/&quot;       , &quot;exports&quot;: {&quot;a&quot;: 10, &quot;b&quot;: 11}}\r\n, {&quot;namespace&quot;: &quot;/&quot;       , &quot;exports&quot;: {&quot;c&quot;: 12, &quot;d&quot;: 13}}\r\n, {&quot;namespace&quot;: &quot;/bar&quot;    , &quot;exports&quot;: {&quot;e&quot;: 14, &quot;f&quot;: 15}}\r\n, {&quot;namespace&quot;: &quot;/bar/baz&quot;, &quot;exports&quot;: {&quot;g&quot;: 16, &quot;h&quot;: 17}}\r\n]\r\n```\r\n\r\nthat I need to convert into this JSON document:&lt;br&gt;\r\n*(the risk of key collisions can be ignored)*\r\n\r\n```json\r\n{ &quot;a&quot;: 10\r\n, &quot;b&quot;: 11\r\n, &quot;c&quot;: 12\r\n, &quot;d&quot;: 13\r\n, &quot;bar&quot;: { &quot;e&quot;: 14\r\n         , &quot;f&quot;: 15\r\n         , &quot;baz&quot;: { &quot;g&quot;: 16\r\n                  , &quot;h&quot;: 17}}}\r\n```\r\n\r\nNote that whilst nesting namespaces we only keep their basename e.g.,\r\n\r\n```lang-none\r\n/\r\n/bar\r\n/bar/baz\r\n/bar/baz/bat\r\n```\r\n\r\nbecomes:\r\n\r\n```json\r\n{&quot;bar&quot;: {&quot;baz&quot;: {&quot;bat&quot;: {}}}}\r\n```\r\n\r\nMembers must be nested under their corresponding namespace object with the only expection of members of the root `&quot;/&quot;` namespace which become top-level properties.\r\n\r\nI&#39;ve scratched my head a few times over this problem as I&#39;d like to get this done in one pass (ideally) but I&#39;m open to any other suggestions.\r\n\r\n",
        "link": "https://stackoverflow.com/questions/65978589/nest-and-merge-json-based-on-namespaces",
        "title": "Nest and merge JSON based on namespaces"
    },
    {
        "tags": [
            "arrays",
            "json",
            "null",
            "filtering",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1612162942,
                "post_id": 65986890,
                "comment_id": 116670460,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 20597747,
                    "reputation": 3,
                    "user_id": 15119679,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/af80f830498852e66049c574f61ce318?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "nobody",
                    "link": "https://stackoverflow.com/users/15119679/nobody"
                },
                "reply_to_user": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1614040798,
                "post_id": 65986890,
                "comment_id": 117258017,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1612163994,
                "creation_date": 1612163994,
                "answer_id": 65988572,
                "question_id": 65986890,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Perhaps you are looking for a variant of your solution along the lines of:\r\n```\r\n.array[]\r\n| {name: .firstname, job: .position, location: .sites[]? .officename}\r\n  +  ({phone: .contact[].number}? // null)\r\n```\r\n(The point being that adding null to a JSON object yields the same object.)\r\n\r\nThis variant of course comes with the same caveats as the original. In particular, the use of all but the first array iterators might be problematic.",
                "title": "not sure about the most efficient way to filter a set of json arrays with jq when some keys are only present in a few arrays - //?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1614040720,
        "creation_date": 1612150785,
        "last_edit_date": 1614040720,
        "question_id": 65986890,
        "body_markdown": "just started using jq to try and consolidate a few keys that are in a much larger json file piped from curl.\r\n\r\n - the following command outputs the desired information from all 10 records as expected:\r\n\r\n`curl http://localhost/test.json | jq -r &#39;.array[] | {name: .firstname, job: .position, location: .sites[]? .officename}&#39;`\r\n\r\n - 2 of the records have an additional key, which is absent from the others. adding that key to the command results in keys being returned only for those two records. removing the `?` from `.contact[]?` errors out with `jq: error: Cannot iterate over null`:\r\n\r\n`curl http://localhost/test.json | jq -r &#39;.array[] | {name: .firstname, job: .position, location: .sites[]? .officename, phone: .contact[]? .number}&#39;`\r\n\r\n - currently working around this by using the // operator as shown below. is there a more efficient or recommended way of using jq in this manner?\r\n\r\n`curl http://localhost/test.json | jq -r &#39;.array[] | {name: .firstname, job: .position, location: .sites[]? .officename, phone: .contact[]? .number} // {name: .firstname, job: .position, location: .sites[]? .officename}&#39;`\r\n\r\nthanks\r\n\r\n---edit: adding a short example of test.json below for reproducibility:\r\n\r\n    {\r\n       &quot;id&quot;: 1,\r\n       &quot;array&quot;: [{\r\n             &quot;firstname&quot;: &quot;Nobody&quot;,\r\n             &quot;lastname&quot;: &quot;Nothing&quot;,\r\n             &quot;sites&quot;: [{\r\n                &quot;officename&quot;: &quot;Site1&quot;,\r\n                &quot;city&quot;: &quot;City&quot;\r\n             }],\r\n             &quot;position&quot;: &quot;Test1&quot;\r\n          },\r\n          {\r\n             &quot;firstname&quot;: &quot;Anybody&quot;,\r\n             &quot;lastname&quot;: &quot;Anything&quot;,\r\n             &quot;sites&quot;: [{\r\n                &quot;officename&quot;: &quot;Site2&quot;,\r\n                &quot;city&quot;: &quot;City2&quot;\r\n             }],\r\n             &quot;position&quot;: &quot;Test2&quot;,\r\n             &quot;contact&quot;: [{\r\n                &quot;number&quot;: &quot;123-456-7890&quot;,\r\n                &quot;email&quot;: &quot;test@test.com&quot;\r\n             }]\r\n          }\r\n       ]\r\n    }",
        "link": "https://stackoverflow.com/questions/65986890/not-sure-about-the-most-efficient-way-to-filter-a-set-of-json-arrays-with-jq-whe",
        "title": "not sure about the most efficient way to filter a set of json arrays with jq when some keys are only present in a few arrays - //?"
    },
    {
        "tags": [
            "json",
            "bash",
            "shell",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 3656861,
                    "reputation": 612,
                    "user_id": 3047626,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/21jLo.jpg?s=256",
                    "display_name": "mnikolic",
                    "link": "https://stackoverflow.com/users/3047626/mnikolic"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1612164830,
                "post_id": 65988631,
                "comment_id": 116671021,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 14797711,
                    "reputation": 65,
                    "user_id": 10686923,
                    "user_type": "registered",
                    "profile_image": "https://lh5.googleusercontent.com/-GfD8MlybAnE/AAAAAAAAAAI/AAAAAAAAAAA/AGDgw-hio0xZl6sPAvQ4WcTSt9R14tKB9Q/mo/s256-rj/photo.jpg",
                    "display_name": "karan",
                    "link": "https://stackoverflow.com/users/10686923/karan"
                },
                "reply_to_user": {
                    "account_id": 3656861,
                    "reputation": 612,
                    "user_id": 3047626,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/21jLo.jpg?s=256",
                    "display_name": "mnikolic",
                    "link": "https://stackoverflow.com/users/3047626/mnikolic"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1612165010,
                "post_id": 65988631,
                "comment_id": 116671087,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 7734896,
                    "reputation": 648,
                    "user_id": 5856778,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/TD8uD.jpg?s=256",
                    "display_name": "al3x2ndru",
                    "link": "https://stackoverflow.com/users/5856778/al3x2ndru"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1612166049,
                "post_id": 65988631,
                "comment_id": 116671364,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1612167005,
                "last_edit_date": 1612167005,
                "creation_date": 1612166474,
                "answer_id": 65989031,
                "question_id": 65988631,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "1. The initial `.` in the first invocation of jq is unnecessary.\r\n\r\n2.  This variant should work, though it is definitely not recommended:\r\n```\r\ncat mytest.json| jq -r &#39;keys[]&#39; | while IFS= read -r key ;  do        \r\necho $key \r\nvalue=$(jq --arg key &quot;$key&quot; -r &#39;.[$key]&#39; mytest.json);   \r\necho $value\r\ndone\r\n```\r\n\r\n3. You could obtain the same result with just one invocation of jq without any looping; or if you want to loop in bash, consider\r\n\r\n```\r\nwhile read -r key ; do\r\n   read -r value\r\n   echo &quot;$key&quot;\r\n   echo &quot;$value&quot; \r\ndone &lt; &lt;(jq -r &#39;keys[] as $k | ($k, .[$k])&#39; mytest.json)\r\n```\r\n4. You might wish to consider using `keys_unsorted` instead of `keys`.\r\n\r\n5. The snippets in (3) and especially (2) above are somewhat brittle but can easily be robustified, though the details might depend on your requirements.",
                "title": "jq command returns null output while trying to get value based of a key of a JSON file"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1612167005,
        "creation_date": 1612164284,
        "last_edit_date": 1612164947,
        "question_id": 65988631,
        "body_markdown": "jq command returns null output while trying to get  value based on a key of a JSON file, Below is my json file:\r\n```\r\n{\r\n &quot;name&quot;:&quot;John&quot;, \r\n  &quot;age&quot;:31, \r\n &quot;city&quot;:&quot;New York&quot;\r\n}\r\n```\r\nbash command I&#39;m using to get the value:\r\n```\r\ncat mytest.json| jq -r &#39;.| keys[]&#39; | while IFS= read  key ;  do        \r\necho $key;   \r\nvalue=$(jq  -r &#39;.&quot;&#39;$key&#39;&quot;&#39; mytest.json);   \r\necho $value;\r\ndone\r\n```\r\nI&#39;m I missing something here",
        "link": "https://stackoverflow.com/questions/65988631/jq-command-returns-null-output-while-trying-to-get-value-based-of-a-key-of-a-jso",
        "title": "jq command returns null output while trying to get value based of a key of a JSON file"
    },
    {
        "tags": [
            "json",
            "select",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1612195956,
                "creation_date": 1612195956,
                "answer_id": 65996129,
                "question_id": 65995981,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "So that would be to do below. Select the whole object matching the condition and get the value of `.id`\r\n\r\n``` bash\r\njq &#39;.restrictions[] | select(.database.value | contains(&quot;conto&quot;)).id&#39;\r\n```",
                "title": "Retrieve value based on contents of another value"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1615265268,
        "creation_date": 1612195364,
        "last_edit_date": 1615265268,
        "question_id": 65995981,
        "body_markdown": "I have this json that i am trying to get the just the id out of based on a contains from another value.  I am able to jq the contains part but when I add on | .id i cannot get a result\r\n\r\n```json\r\n{\r\n  &quot;restrictions&quot;: [\r\n    {\r\n      &quot;id&quot;: 1,\r\n      &quot;database&quot;: {\r\n        &quot;match&quot;: &quot;exact&quot;,\r\n        &quot;value&quot;: &quot;db_contoso&quot;\r\n      },\r\n      &quot;measurement&quot;: {},\r\n      &quot;permissions&quot;: [\r\n        &quot;write&quot;\r\n      ]\r\n    },\r\n    {\r\n      &quot;id&quot;: 2,\r\n      &quot;database&quot;: {\r\n        &quot;match&quot;: &quot;exact&quot;,\r\n        &quot;value&quot;: &quot;db2_contoso&quot;\r\n      },\r\n      &quot;measurement&quot;: {},\r\n      &quot;permissions&quot;: [\r\n        &quot;write&quot;\r\n      ]\r\n    }\r\n  ]\r\n}\r\n```\r\n\r\nWhen id run \r\n\r\n```bash\r\njq -r &#39;.restrictions[] | .database.value | select(contains(&quot;conto&quot;)?) \r\n```\r\n\r\nI get the values of `db_contoso` and `db2_contoso`.  but I am trying to pull just the `id` based on that.  When I add `| .id` to the end of that command I get nothing.\r\n",
        "link": "https://stackoverflow.com/questions/65995981/retrieve-value-based-on-contents-of-another-value",
        "title": "Retrieve value based on contents of another value"
    },
    {
        "tags": [
            "arrays",
            "json",
            "bash",
            "azure",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 19895284,
                    "reputation": 1,
                    "user_id": 14576501,
                    "user_type": "registered",
                    "profile_image": "https://lh3.googleusercontent.com/a-/AOh14GhYos_jxOu1EVcLbwuGSHqIuhx5Avc6-OIGWiT7mw=k-s256",
                    "display_name": "Petr Kotula",
                    "link": "https://stackoverflow.com/users/14576501/petr-kotula"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1612216613,
                "post_id": 65999976,
                "comment_id": 116692996,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 19895284,
                    "reputation": 1,
                    "user_id": 14576501,
                    "user_type": "registered",
                    "profile_image": "https://lh3.googleusercontent.com/a-/AOh14GhYos_jxOu1EVcLbwuGSHqIuhx5Avc6-OIGWiT7mw=k-s256",
                    "display_name": "Petr Kotula",
                    "link": "https://stackoverflow.com/users/14576501/petr-kotula"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1612216652,
                "post_id": 65999976,
                "comment_id": 116693015,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1612216529,
                "last_edit_date": 1612216529,
                "creation_date": 1612215706,
                "answer_id": 66000557,
                "question_id": 65999976,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "&gt; I need to use these objectId&#39;s \r\n\r\nGiven the array of strings as shown, the following jq filter produces the ids as shown below:\r\n```\r\n.[] | capture(&quot;.*group:(?&lt;g&gt;[^:]*):&quot;).g\r\n```\r\n\r\nOf course there are other ways to extract the objectIds, e.g. you could presumably simply split on &quot;:&quot;:\r\n```\r\n.[] | split(&quot;:&quot;)[2]\r\n```\r\n### Output\r\n```\r\n&quot;0d275816-7a1d-4847-884d-b5c67f473973&quot;\r\n&quot;106004df-6d49-450e-a180-e5bfa1fef9b3&quot;\r\n&quot;200a2bc4-feeb-4ab5-a4c1-3cc3752fe50e&quot;\r\n&quot;956041d5-49af-4409-a2b4-67c1cf2bc433&quot;\r\n\r\n```",
                "title": "How to parse multidimensional JSON object colon separated into array. need to separe object id. in Bash (az cli, azure)"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1612216529,
        "creation_date": 1612212800,
        "question_id": 65999976,
        "body_markdown": "Example after using jq and jmespath: \r\n\r\ni&#39;m interested in objectId in the middle of the string...\r\ni tried to use sed, regex, but there must be some smart solution....\r\n\r\ncmd 1:\r\n```\r\naz dls fs access show --account &quot;$account&quot; --path &quot;$rootpath/$x&quot; --output table --query &quot;entries[? contains(@,&#39;default:group&#39;)] | [1:6] &quot; &gt; ./output/&quot;$x&quot;_table.json\r\n```\r\n----------------\r\noutput (1 json object):\r\n```\r\n[\r\n  &quot;default:group:0d275816-7a1d-4847-884d-b5c67f473973:-wx&quot;,\r\n  &quot;default:group:106004df-6d49-450e-a180-e5bfa1fef9b3:r-x&quot;,\r\n  &quot;default:group:200a2bc4-feeb-4ab5-a4c1-3cc3752fe50e:r-x&quot;,\r\n  &quot;default:group:956041d5-49af-4409-a2b4-67c1cf2bc433:-wx&quot;\r\n]\r\n```\r\nin the next step I need to use these objectId&#39;s (956041d5-49af-4409-a2b4-67c1cf2bc433) as a input for another command, in the for loop...so, i need to save them into array or file...\r\n\r\nin the pipe I can remove first part of the string: \r\n```\r\nsed s/&quot;default:group:&quot;//\r\n```\r\nShould i use default:group: as a some key in jq??? but how? isnt it better to use another pipe with sed with reg ex to delete &quot;:-wx&quot; from the string?? \r\n\r\n---------------------------------------------\r\n---------------------------------------------\r\ncmd 2\r\n```\r\naz dls fs access show --account &quot;$account&quot; --path &quot;$rootpath/$x&quot; &gt; ./output/&quot;$x&quot;.json\r\n```\r\noutput example (Json without any filter):\r\n```\r\n{\r\n  &quot;entries&quot;: [\r\n    &quot;user::rwx&quot;,\r\n    &quot;user:9cad54de-ec93-4c11-aa3a-b84ce4c91920:rwx&quot;,\r\n    &quot;user:d494419c-01f7-4cf7-a5a4-142647853aac:rwx&quot;,\r\n    &quot;group::rwx&quot;,\r\n    &quot;group:0d275816-7a1d-4847-884d-b5c67f473973:-wx&quot;,\r\n    &quot;group:106004df-6d49-450e-a180-e5bfa1fef9b3:r-x&quot;,\r\n    &quot;group:5e36e3d9-1579-41fb-b621-3b5baec1e1f2:r-x&quot;,\r\n    &quot;group:83f994b9-167f-4886-a10a-63d145befd86:r-x&quot;,\r\n    &quot;group:a2adc59f-c1d4-4c48-8676-9d241aa8138c:-wx&quot;,\r\n    &quot;group:e4cded2e-6991-4259-bf4c-b93773b28a57:-wx&quot;,\r\n    &quot;mask::rwx&quot;,\r\n    &quot;other::---&quot;,\r\n    &quot;default:user::rwx&quot;,\r\n    &quot;default:user:9cad54de-ec93-4c11-aa3a-b84ce4c91920:rwx&quot;,\r\n    &quot;default:user:d494419c-01f7-4cf7-a5a4-142647853aac:rwx&quot;,\r\n    &quot;default:group::rwx&quot;,\r\n    &quot;default:group:0d275816-7a1d-4847-884d-b5c67f473973:-wx&quot;,\r\n    &quot;default:group:106004df-6d49-450e-a180-e5bfa1fef9b3:r-x&quot;,\r\n    &quot;default:group:5e36e3d9-1579-41fb-b621-3b5baec1e1f2:r-x&quot;,\r\n    &quot;default:group:83f994b9-167f-4886-a10a-63d145befd86:r-x&quot;,\r\n    &quot;default:group:a2adc59f-c1d4-4c48-8676-9d241aa8138c:-wx&quot;,\r\n    &quot;default:group:e4cded2e-6991-4259-bf4c-b93773b28a57:-wx&quot;,\r\n    &quot;default:mask::rwx&quot;,\r\n    &quot;default:other::---&quot;\r\n  ],\r\n  &quot;group&quot;: &quot;1e682179-6809-4f88-8313-a399302b1b1a&quot;,\r\n  &quot;owner&quot;: &quot;d494419c-01f7-4cf7-a5a4-142647853aac&quot;,\r\n  &quot;permission&quot;: &quot;770&quot;,\r\n  &quot;stickyBit&quot;: false\r\n}\r\n```\r\n",
        "link": "https://stackoverflow.com/questions/65999976/how-to-parse-multidimensional-json-object-colon-separated-into-array-need-to-se",
        "title": "How to parse multidimensional JSON object colon separated into array. need to separe object id. in Bash (az cli, azure)"
    },
    {
        "tags": [
            "bash",
            "git",
            "curl",
            "installation",
            "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": 1612218845,
                "post_id": 66000844,
                "comment_id": 116693657,
                "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": 1612218870,
                "post_id": 66000844,
                "comment_id": 116693662,
                "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": 1612218923,
                "post_id": 66000844,
                "comment_id": 116693679,
                "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": 1612218952,
                "post_id": 66000844,
                "comment_id": 116693690,
                "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": 1612218975,
                "post_id": 66000844,
                "comment_id": 116693696,
                "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": 1612219189,
                "post_id": 66000844,
                "comment_id": 116693754,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 20605813,
                    "reputation": 11,
                    "user_id": 15126098,
                    "user_type": "registered",
                    "profile_image": "https://lh3.googleusercontent.com/-gNWXbH5N3m8/AAAAAAAAAAI/AAAAAAAAAAA/AMZuuckgLAzMN9unEW0uc2TxcLFVT6rlyw/s96-c/s256-rj/photo.jpg",
                    "display_name": "user15126098",
                    "link": "https://stackoverflow.com/users/15126098/user15126098"
                },
                "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": 1612219825,
                "post_id": 66000844,
                "comment_id": 116693924,
                "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": 1612220558,
                "post_id": 66000844,
                "comment_id": 116694115,
                "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": 1612220595,
                "post_id": 66000844,
                "comment_id": 116694126,
                "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": 1612220694,
                "post_id": 66000844,
                "comment_id": 116694156,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1670592977,
                "creation_date": 1670592977,
                "answer_id": 74743880,
                "question_id": 66000844,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "```\r\njq=/usr/local/Cellar/jqz\r\ncurl -L -o $jq https://github.com/stedolan/jq/releases/latest/download/jq-osx-amd64\r\n```\r\n\r\nIt looks like you are storing the binary with the name `jqz`. No surprise that it cannot be executed as `jq`; you would have to invoke it as `jqz`.\r\n\r\nI don&#39;t know if `/usr/local/Cellar` is part of your PATH?\r\n\r\nThe canonical way would be:\r\n\r\n```\r\njq=&#39;/usr/local/bin/jq&#39;\r\ncurl -L -o &quot;$jq&quot; https://github.com/stedolan/jq/releases/latest/download/jq-osx-amd64\r\n```\r\n\r\nyou could also store it in the `bin` directory of your home folder: `jq=&quot;$HOME/bin&quot; which should be added automatically to your PATH on most installations (might require a logout &amp; login).",
                "title": "Installing/running JQ on git bash"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1670592977,
        "creation_date": 1612217325,
        "question_id": 66000844,
        "body_markdown": "I&#39;m trying to implement a git hook that edits some JSON every time I push. \r\nI have JQ installed on my Mac using homebrew &quot;brew install jq&quot;, but when the git hook runs my .sh I get the error \r\n\r\n    jq: command not found\r\nMy latest attempts have been to use curl to download the jq library, point to it, and run jq that way: \r\n\r\n    jq=/usr/local/Cellar/jqz\r\n\tcurl -L -o $jq https://github.com/stedolan/jq/releases/latest/download/jq-osx-amd64\r\nUnfortunately, this is also returning the same &#39;command not found&#39; error.  \r\nSidenote: jq=/usr/bin/jq gives me a permission error when I try to write to it",
        "link": "https://stackoverflow.com/questions/66000844/installing-running-jq-on-git-bash",
        "title": "Installing/running JQ on git bash"
    },
    {
        "tags": [
            "json",
            "csv",
            "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": 1612246685,
                "post_id": 66004162,
                "comment_id": 116699584,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1638430764,
                "creation_date": 1638430764,
                "answer_id": 70195661,
                "question_id": 66004162,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "At the end of the line &quot;hostname&quot;: &quot;computer1.domain.com&quot;, the comma is an error.\r\nIf you correct this, the solution could be:\r\n[Proposal][1]\r\n\r\n\r\n  [1]: https://jqplay.org/s/bOkLsBlfNn\r\n\r\nAt the you have 2 additional columns one with the keys an other with the values in your csv file.",
                "title": "How to pull keys and values in jq csv when you don&#39;t know the key name"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1638430764,
        "creation_date": 1612244192,
        "last_edit_date": 1612246611,
        "question_id": 66004162,
        "body_markdown": "I have a semi working jq filter that pulls out `.key, .value.sitename` and shows it in a one line csv format. I&#39;d like to add any `tag_*` keys and values (if found) at the end of the csv line.\r\n\r\n```\r\n[.key , .value.hostname, .value.attributes.sitename  ] | @csv\r\n```\r\n\r\nI need help with the `.value.attributes.tag*` keys since they might be completely missing or different `tag_` names. They all start with `tag_` but could be anything. I&#39;d like to pair the found tag name and value together if possible and append it on the csv line with the host.\r\n\r\n```\r\n{\r\n  &quot;key&quot;: &quot;computer1.domain.com&quot;,\r\n  &quot;value&quot;: {\r\n    &quot;attributes&quot;: {\r\n      &quot;TESTID&quot;: &quot;23423423&quot;,\r\n      &quot;sitename&quot;: &quot;siteidname&quot;,\r\n      &quot;tag_robo_equip&quot;: &quot;boopbeep&quot;,\r\n      &quot;tag_modern&quot;: &quot;cybertruck&quot;\r\n    },\r\n    &quot;hostname&quot;: &quot;computer1.domain.com&quot;,\r\n  }\r\n}\r\n```",
        "link": "https://stackoverflow.com/questions/66004162/how-to-pull-keys-and-values-in-jq-csv-when-you-dont-know-the-key-name",
        "title": "How to pull keys and values in jq csv when you don&#39;t know the key name"
    },
    {
        "tags": [
            "json",
            "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": 0,
                "creation_date": 1612265319,
                "post_id": 66008619,
                "comment_id": 116706946,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 424282,
                    "reputation": 5266,
                    "user_id": 804184,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/53510ab1eae1780bbe41692e6286afd0?s=256&d=identicon&r=PG",
                    "display_name": "Alejandro",
                    "link": "https://stackoverflow.com/users/804184/alejandro"
                },
                "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": 1,
                "creation_date": 1612266082,
                "post_id": 66008619,
                "comment_id": 116707294,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1612267102,
                "last_edit_date": 1612267102,
                "creation_date": 1612266296,
                "answer_id": 66009074,
                "question_id": 66008619,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You shouldn&#39;t [parse the output of `ls`](https://mywiki.wooledge.org/ParsingLs). Pass `folder1/file1.pdf`, `folder1/file2.pdf`, etc. to JQ as positional arguments instead, and parse them in there.\r\n```\r\njq -n &#39;reduce ($ARGS.positional[] / &quot;/&quot;) as [$k, $v] (.; .[$k] += [&quot;prefix-\\($v)&quot;])&#39; --args */*\r\n```",
                "title": "Using JQ to create a JSON file from a list of files"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1612349932,
        "creation_date": 1612264577,
        "last_edit_date": 1612349932,
        "question_id": 66008619,
        "body_markdown": "I want to create a JSON file from a list of files like:\r\n```\r\n$ ls -r *\r\nfolder1/\r\n   file1.pdf\r\n   file2.pdf\r\n   file3.pdf\r\nfolder2/\r\n\r\n   file4.pdf\r\n   file5.pdf\r\n   file6.pdf\r\n```\r\nI want a json file that looks like this:\r\n```\r\n{\r\n  &#39;folder1&#39; : [ &#39;file1.pdf&#39;, &#39;file2.pdf&#39;, &#39;file3.pdf&#39; ],\r\n  &#39;folder2&#39; : [ &#39;file4.pdf&#39;, &#39;file5.pdf&#39;, &#39;file6.pdf&#39; ]\r\n}\r\n```\r\n\r\nFor now I am able to create the list of files with `jq` but not sure how to name them. This is what I am doing now:\r\n```\r\n$ ls folder | jq -R -s &#39;split(&quot;\\n&quot;) -[&quot;&quot;]&#39;\r\n[ \r\n   &quot;file1.pdf&quot;,\r\n   &quot;file2.pdf&quot;,\r\n   &quot;file3.pdf&quot;\r\n]\r\n```\r\n\r\nThanks a lot for the help!\r\n\r\nPS. Additionally, I need to include a prefix in the name of files. I can try to do it with `sed` but if maybe there is an easier way to do it here, that would be even better.",
        "link": "https://stackoverflow.com/questions/66008619/using-jq-to-create-a-json-file-from-a-list-of-files",
        "title": "Using JQ to create a JSON file from a list of files"
    },
    {
        "tags": [
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 1852014,
                    "reputation": 24882,
                    "user_id": 1678362,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/8ba023d18099cde022b9e4394d5714c0?s=256&d=identicon&r=PG",
                    "display_name": "Aaron",
                    "link": "https://stackoverflow.com/users/1678362/aaron"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1612280070,
                "post_id": 66012491,
                "comment_id": 116714135,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 20582315,
                    "reputation": 39,
                    "user_id": 15108100,
                    "user_type": "registered",
                    "profile_image": "https://lh6.googleusercontent.com/-wEhPR5HIr4U/AAAAAAAAAAI/AAAAAAAAAAA/AMZuuclFenabj3i85lZOLL5f7u7FQlUecQ/s96-c/s256-rj/photo.jpg",
                    "display_name": "Tom Donnly",
                    "link": "https://stackoverflow.com/users/15108100/tom-donnly"
                },
                "reply_to_user": {
                    "account_id": 1852014,
                    "reputation": 24882,
                    "user_id": 1678362,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/8ba023d18099cde022b9e4394d5714c0?s=256&d=identicon&r=PG",
                    "display_name": "Aaron",
                    "link": "https://stackoverflow.com/users/1678362/aaron"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1612281269,
                "post_id": 66012491,
                "comment_id": 116714777,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1852014,
                    "reputation": 24882,
                    "user_id": 1678362,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/8ba023d18099cde022b9e4394d5714c0?s=256&d=identicon&r=PG",
                    "display_name": "Aaron",
                    "link": "https://stackoverflow.com/users/1678362/aaron"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1612281397,
                "post_id": 66012491,
                "comment_id": 116714848,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1852014,
                    "reputation": 24882,
                    "user_id": 1678362,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/8ba023d18099cde022b9e4394d5714c0?s=256&d=identicon&r=PG",
                    "display_name": "Aaron",
                    "link": "https://stackoverflow.com/users/1678362/aaron"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1612281635,
                "post_id": 66012491,
                "comment_id": 116714975,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1662111161,
                "creation_date": 1662111161,
                "answer_id": 73580526,
                "question_id": 66012491,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You are almost there. First, extract only the `name` of each role, then select those names which contain &quot;contoso&quot;:\r\n\r\n```\r\n.roles[].name | select(contains(&quot;contoso&quot;))\r\n```\r\n\r\n* `roles[].name` generates a list of all names\r\n* `select(contains(&quot;contoso&quot;))` only selects those names which contain &quot;contoso&quot;",
                "title": "JQ contains output"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1662111161,
        "creation_date": 1612278980,
        "last_edit_date": 1662111065,
        "question_id": 66012491,
        "body_markdown": "I am trying to retrieve the values containg contoso.  So my output in this case should just readdata_contoso and writedata_contoso but I am having issues.  I am trying `jq -e -r &quot;.roles[] | select(.name | contains(&quot;cont&quot;))&quot;`\r\n\r\n```\r\n{\r\n  &quot;roles&quot;: [\r\n    {\r\n      &quot;name&quot;: &quot;readdata_contoso&quot;,\r\n      &quot;permissions&quot;: {\r\n        &quot;&quot;: [\r\n          &quot;ReadData&quot;\r\n        ]\r\n      }\r\n    },\r\n    {\r\n      &quot;name&quot;: &quot;writedata_contoso&quot;,\r\n      &quot;permissions&quot;: {\r\n        &quot;&quot;: [\r\n          &quot;WriteData&quot;\r\n        ]\r\n      }\r\n    }\r\n  ]\r\n}\r\n```",
        "link": "https://stackoverflow.com/questions/66012491/jq-contains-output",
        "title": "JQ contains output"
    },
    {
        "tags": [
            "json",
            "command-line",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1612297580,
                "last_edit_date": 1612297580,
                "creation_date": 1612281013,
                "answer_id": 66013046,
                "question_id": 66013045,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Use `strptime` to convert date string to date object and then `strftime` to format the date:\r\n\r\n```shell\r\n$ echo &#39;{&quot;createdDate&quot;: &quot;2005-09-28T16:34:40Z&quot;}&#39; |\r\n    jq &#39;\r\n       { createdYear: .createdDate\r\n           | strptime(&quot;%Y-%m-%dT%H:%M:%SZ&quot;)\r\n           | strftime(&quot;%Y&quot;) }&#39;\r\n{\r\n  &quot;createdYear&quot;: &quot;2005&quot;\r\n}\r\n```",
                "title": "How to to extract the year from JSON date using jq"
            },
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1612297679,
                "creation_date": 1612297679,
                "answer_id": 66017141,
                "question_id": 66013045,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Why not just:\r\n\r\n    {createdYear: .createdDate[0:4]}",
                "title": "How to to extract the year from JSON date using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": -2,
        "last_activity_date": 1612297679,
        "creation_date": 1612281013,
        "question_id": 66013045,
        "body_markdown": "I have a bunch of JSON with dates in ISO format. How can I print only the year component of the date?\r\n\r\n```shell\r\n$ echo &#39;{&quot;createdDate&quot;: &quot;2005-09-28T16:34:40Z&quot;}&#39; | jq &#39;{ createdYear: ??? }&#39;\r\n{\r\n  &quot;createdYear&quot;: &quot;2005&quot;\r\n}\r\n```",
        "link": "https://stackoverflow.com/questions/66013045/how-to-to-extract-the-year-from-json-date-using-jq",
        "title": "How to to extract the year from JSON date using jq"
    },
    {
        "tags": [
            "bash",
            "grep",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1612304511,
                "creation_date": 1612304511,
                "answer_id": 66018472,
                "question_id": 66014705,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Without seeing an informative sample of the JSON it&#39;s not clear what the best solution would be, but the following meets the functional requirements as I understand them, without requiring any further post-processing:\r\n```\r\njq -r &#39;\r\n  def count(stream): reduce stream as $s (0; .+1);\r\n  if count(.[][] | select(.State == &quot;InService&quot;)) &gt; 1 then &quot;yes&quot; else empty end\r\n&#39;\r\n```",
                "title": "Trying to verify jq command output equal string or string has more than one occurrence (AWS ELB instances state query)"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -1,
        "last_activity_date": 1612344109,
        "creation_date": 1612287058,
        "last_edit_date": 1612344109,
        "question_id": 66014705,
        "body_markdown": "I&#39;m trying to check that all instances attached to an AWS ELB are in a state of **&quot;InService&quot;**,\r\nFor that, I created an AWS CLI command to check the status of the instances.\r\nproblem is that the JSON output returns the status of both instances.\r\nSo it is not that trivial to examine the output as I wish.\r\n\r\nWhen I run the command:\r\n\r\n    aws elb describe-instance-health --load-balancer-name ELB-NAME | jq -r &#39;.[] | .[] | .State&#39;\r\nThe output is:\r\n\r\n    InService\r\n    InService\r\n\r\nThe complete JSON is:\r\n\r\n    {\r\n        &quot;InstanceStates&quot;: [\r\n            {\r\n                &quot;InstanceId&quot;: &quot;i-0cc1e6d50ccbXXXXX&quot;,\r\n                &quot;State&quot;: &quot;InService&quot;,\r\n                &quot;ReasonCode&quot;: &quot;N/A&quot;,\r\n                &quot;Description&quot;: &quot;N/A&quot;\r\n            },\r\n            {\r\n                &quot;InstanceId&quot;: &quot;i-0fc21ddf457eXXXXX&quot;,\r\n                &quot;State&quot;: &quot;InService&quot;,\r\n                &quot;ReasonCode&quot;: &quot;N/A&quot;,\r\n                &quot;Description&quot;: &quot;N/A&quot;\r\n            }\r\n        ]\r\n    }\r\n\r\n\r\nWhat I&#39;ve done so far is creating that one liner shell command:\r\n\r\n    export STR=$&#39;InService\\nInService&#39;\r\n    if aws elb describe-instance-health --load-balancer-name ELB-NAME | jq -r &#39;.[] | .[] | .State&#39; | grep -q &quot;$STR&quot;; then echo &#39;yes&#39;; fi\r\n\r\nBut I get **&quot;yes&quot;** as long as there is &quot;InService&quot; at the first command output\r\n\r\nIs there a way I can get **TRUE/YES** only if I get twice &quot;InService&quot; as an output?\r\nor any other way to determine that this is indeed what I got in return?\r\n",
        "link": "https://stackoverflow.com/questions/66014705/trying-to-verify-jq-command-output-equal-string-or-string-has-more-than-one-occu",
        "title": "Trying to verify jq command output equal string or string has more than one occurrence (AWS ELB instances state query)"
    },
    {
        "tags": [
            "bash",
            "shell",
            "path",
            "jq",
            "recursive-datastructures"
        ],
        "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": 1612290336,
                "post_id": 66014841,
                "comment_id": 116718996,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1612363964,
                "last_edit_date": 1612363964,
                "creation_date": 1612303906,
                "answer_id": 66018372,
                "question_id": 66014841,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The following implements a solution to the problem as I understand it:\r\n\r\n```\r\n# $prefix is an array interpreted as the prefix\r\ndef details($prefix):\r\n  def out:\r\n    select(has(&quot;name&quot;) and has(&quot;type&quot;)) | [.name, .type, &quot;/&quot; + ($prefix|join(&quot;/&quot;))];\r\n\r\n  out,\r\n    if (.nested | (. and length&gt;0))\r\n    then .name as $n | .nested[] | details($prefix + [$n]) \r\n    else empty\r\n    end;\r\n  \r\n.structure[]\r\n| details([])\r\n| @csv\r\n```\r\n\r\nGiven your sample input, the output would be:\r\n\r\n```\r\n&quot;rootgroup1&quot;,&quot;group&quot;,&quot;/&quot;\r\n&quot;nestedproject1&quot;,&quot;project&quot;,&quot;/rootgroup1&quot;\r\n&quot;nestedgroup1&quot;,&quot;group&quot;,&quot;/rootgroup1&quot;\r\n&quot;nestednestedproject2&quot;,&quot;project&quot;,&quot;/rootgroup1/nestedgroup1&quot;\r\n&quot;rootproject1&quot;,&quot;project&quot;,&quot;/&quot;\r\n&quot;rootgroup2&quot;,&quot;group&quot;,&quot;/&quot;\r\n```\r\n\r\nThis differs in some respects from the sample output, but hopefully you can take it from here.\r\n",
                "title": "jq: recursion -&gt; nested arrays"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1625601174,
        "creation_date": 1612287521,
        "last_edit_date": 1625601174,
        "question_id": 66014841,
        "body_markdown": "How can I parse this json structure with jq? It should loop over leafs (projects and groups) recursively. \r\n\r\nMy use case is: create project and groups in VCS with CLI. Group can have multiple projects, group can be empty, projects must have parent group created in advance.\r\n\r\nSimilar analogy would be:\r\n- group = folder\r\n- project = file\r\n- path = absolute path in format `/root-groups/nested-groups-level-1/nested-groups-level-2/nested-groups-level-N`\r\n\r\nThanks\r\n\r\n```\r\n{\r\n   &quot;structure&quot;:[\r\n      {\r\n         &quot;name&quot;:&quot;rootgroup1&quot;,\r\n         &quot;type&quot;:&quot;group&quot;,\r\n         &quot;nested&quot;:[\r\n            {\r\n               &quot;name&quot;:&quot;nestedproject1&quot;,\r\n               &quot;type&quot;:&quot;project&quot;\r\n            },\r\n            {\r\n               &quot;name&quot;:&quot;nestedgroup1&quot;,\r\n               &quot;type&quot;:&quot;group&quot;,\r\n               &quot;nested&quot;:[\r\n                  {\r\n                     &quot;name&quot;:&quot;nestednestedproject2&quot;,\r\n                     &quot;type&quot;:&quot;project&quot;\r\n                  }\r\n               ]\r\n            }\r\n         ]\r\n      },\r\n      {\r\n         &quot;name&quot;:&quot;rootproject1&quot;,\r\n         &quot;type&quot;:&quot;project&quot;\r\n      },\r\n      {\r\n         &quot;name&quot;:&quot;rootgroup2&quot;,\r\n         &quot;type&quot;:&quot;group&quot;,\r\n         &quot;nested&quot;: []\r\n      }\r\n   ]\r\n}\r\n```\r\n\r\nExpected output:\r\n\r\n\r\n```\r\n&quot;rootgroup1&quot;,&quot;group&quot;,&quot;&quot;\r\n&quot;nestedproject1&quot;,&quot;project&quot;,&quot;rootgroup1&quot;\r\n&quot;nestedgroup1&quot;,&quot;group&quot;,&quot;rootgroup1&quot;\r\n&quot;nestednestedproject2&quot;,&quot;group&quot;,&quot;rootgroup1/nestedgroup1&quot;\r\n&quot;rootproject1&quot;,&quot;project&quot;,&quot;&quot;\r\n&quot;rootgroup2&quot;,&quot;group&quot;,&quot;&quot;\r\n```\r\n\r\nTry:\r\n```\r\njq -r &#39;.structure[] | .. | &quot;\\(.name?) \\(.type?)&quot;&#39;\r\n```\r\n\r\nStill not sure, how create a parent path.",
        "link": "https://stackoverflow.com/questions/66014841/jq-recursion-nested-arrays",
        "title": "jq: recursion -&gt; nested arrays"
    },
    {
        "tags": [
            "json",
            "iteration",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 6196394,
                    "reputation": 86601,
                    "user_id": 5291015,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/4tAvO.jpg?s=256",
                    "display_name": "Inian",
                    "link": "https://stackoverflow.com/users/5291015/inian"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1612343035,
                "post_id": 66023723,
                "comment_id": 116734018,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 11854868,
                    "reputation": 821,
                    "user_id": 8675116,
                    "user_type": "registered",
                    "accept_rate": 72,
                    "profile_image": "https://lh6.googleusercontent.com/-ht09ft9gZLI/AAAAAAAAAAI/AAAAAAAAK4U/o46tohOPvc0/s256-rj/photo.jpg",
                    "display_name": "Beefcake",
                    "link": "https://stackoverflow.com/users/8675116/beefcake"
                },
                "reply_to_user": {
                    "account_id": 6196394,
                    "reputation": 86601,
                    "user_id": 5291015,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/4tAvO.jpg?s=256",
                    "display_name": "Inian",
                    "link": "https://stackoverflow.com/users/5291015/inian"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1612343413,
                "post_id": 66023723,
                "comment_id": 116734177,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1612345909,
                "last_edit_date": 1612345909,
                "creation_date": 1612345361,
                "answer_id": 66024840,
                "question_id": 66023723,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Start with the root path and traverse down and use `to_entries` to get past the varying key names and use the `.value` field only\r\n\r\n```bash\r\njq &#39;.vnet_spoke_object.subnets | to_entries[].value | { name, cidr }&#39;\r\n```\r\n\r\nor collect it as an array of objects\r\n\r\n```bash\r\njq &#39;.vnet_spoke_object.subnets | to_entries | map(.value | { name, cidr })&#39;\r\n```\r\n\r\n&lt;sup&gt;[jqplay - Demo][1]&lt;/sup&gt;\r\n\r\n\r\n  [1]: https://jqplay.org/s/O7g4t-PO5s",
                "title": "Iterate over objects and print select values"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1615265234,
        "creation_date": 1612340831,
        "last_edit_date": 1615265234,
        "question_id": 66023723,
        "body_markdown": "**Question:** I would like to know how I can iterate over an object to print out the name of each subnet and its cidr range in the subnets object.\r\n\r\nI know how I can print out the vnet name and cidr range:\r\n\r\n`jq &#39;.[] | select(.vnet) | {name: .vnet.name, cidr: .vnet.address_space[0]}&#39;`\r\n\r\nI have looked online and found that you can convert the object to an array, but I am unsure how I can look through that array to print out the values:\r\n`jq &#39;.[] | to_entries | map_values(.value)&#39;`\r\n\r\nEssentially the **desired OUTPUT** should look something like this:\r\n```\r\n{\r\n    &quot;name&quot;: &quot;asdf1&quot;,\r\n    &quot;cidr&quot;: &quot;10.....&quot;\r\n},\r\n{\r\n    &quot;name&quot;: &quot;asdf2&quot;,\r\n    &quot;cidr&quot;: &quot;10.....&quot;\r\n}\r\n//...and so forth\r\n```\r\n\r\n**Sample INPUT:**\r\n```\r\n{\r\n    &quot;route_tables&quot;: {\r\n        &quot;asdf&quot;: {\r\n            &quot;disable_bgp_route_propagation&quot;: true,\r\n            &quot;name&quot;: &quot;az_afw&quot;,\r\n            &quot;resource_group_name&quot;: &quot;vnet-spoke&quot;,\r\n            &quot;route_entries&quot;: {\r\n                &quot;re1&quot;: {\r\n                    &quot;name&quot;: &quot;rt-rfc-10-8&quot;,\r\n                    &quot;next_hop_in_ip_address&quot;: &quot;10.0.0.0&quot;,\r\n                    &quot;next_hop_type&quot;: &quot;VirtualAppliance&quot;,\r\n                    &quot;prefix&quot;: &quot;10.0.0.0/8&quot;\r\n                },\r\n                &quot;re2&quot;: {\r\n                    &quot;name&quot;: &quot;rt-rfc-172-12&quot;,\r\n                    &quot;next_hop_in_ip_address&quot;: &quot;10.0.0.0&quot;,\r\n                    &quot;next_hop_type&quot;: &quot;VirtualAppliance&quot;,\r\n                    &quot;prefix&quot;: &quot;172.16.0.0/12&quot;\r\n                }\r\n            }\r\n        }\r\n    },\r\n    &quot;vnet_peering_settings&quot;: {\r\n        &quot;peer1&quot;: {\r\n            &quot;peer_to_source&quot;: {\r\n                &quot;allow_forwarded_traffic&quot;: true,\r\n                &quot;allow_gateway_transit&quot;: false,\r\n                &quot;allow_virtual_network_access&quot;: true,\r\n                &quot;use_remote_gateways&quot;: true\r\n            },\r\n            &quot;source_to_peer&quot;: {\r\n                &quot;allow_forwarded_traffic&quot;: true,\r\n                &quot;allow_gateway_transit&quot;: true,\r\n                &quot;allow_virtual_network_access&quot;: true,\r\n                &quot;use_remote_gateways&quot;: false\r\n            }\r\n        }\r\n    },\r\n    &quot;vnet_spoke_object&quot;: {\r\n        &quot;specialsubnets&quot;: {},\r\n        &quot;subnets&quot;: {\r\n            &quot;objectAsdf1&quot;: {\r\n                &quot;cidr&quot;: &quot;10.0.0.1/24&quot;,\r\n                &quot;enforce_private_link_endpoint_network_policies&quot;: false,\r\n                &quot;enforce_private_link_service_network_policies&quot;: false,\r\n                &quot;name&quot;: &quot;asdf1&quot;,\r\n                &quot;nsg_creation&quot;: true,\r\n                &quot;nsg_inbound&quot;: [],\r\n                &quot;nsg_outbound&quot;: [],\r\n                &quot;route&quot;: null,\r\n                &quot;service_endpoints&quot;: []\r\n            },\r\n            &quot;objectAsdf2&quot;: {\r\n                &quot;cidr&quot;: &quot;10.0.0.1/24&quot;,\r\n                &quot;enforce_private_link_endpoint_network_policies&quot;: false,\r\n                &quot;enforce_private_link_service_network_policies&quot;: false,\r\n                &quot;name&quot;: &quot;asdf2&quot;,\r\n                &quot;nsg_creation&quot;: true,\r\n                &quot;nsg_inbound&quot;: [],\r\n                &quot;nsg_outbound&quot;: [],\r\n                &quot;route&quot;: &quot;asdf&quot;,\r\n                &quot;service_endpoints&quot;: [\r\n                    &quot;Microsoft.EventHub&quot;\r\n                ]\r\n            },\r\n            &quot;objectAsdf3&quot;: {\r\n                &quot;cidr&quot;: &quot;10.0.0.1/24&quot;,\r\n                &quot;enforce_private_link_endpoint_network_policies&quot;: false,\r\n                &quot;enforce_private_link_service_network_policies&quot;: false,\r\n                &quot;name&quot;: &quot;asdf3&quot;,\r\n                &quot;nsg_creation&quot;: true,\r\n                &quot;nsg_inbound&quot;: [],\r\n                &quot;nsg_outbound&quot;: [],\r\n                &quot;route&quot;: &quot;asdf&quot;,\r\n                &quot;service_endpoints&quot;: []\r\n            },\r\n            &quot;objectAsdf4&quot;: {\r\n                &quot;cidr&quot;: &quot;10.0.0.1/24&quot;,\r\n                &quot;enforce_private_link_endpoint_network_policies&quot;: false,\r\n                &quot;enforce_private_link_service_network_policies&quot;: false,\r\n                &quot;name&quot;: &quot;asdf4&quot;,\r\n                &quot;nsg_creation&quot;: true,\r\n                &quot;nsg_inbound&quot;: [],\r\n                &quot;nsg_outbound&quot;: [],\r\n                &quot;route&quot;: &quot;asdf&quot;,\r\n                &quot;service_endpoints&quot;: []\r\n            }\r\n        },\r\n        &quot;vnet&quot;: {\r\n            &quot;address_space&quot;: [\r\n                &quot;10.0.0.0/16&quot;\r\n            ],\r\n            &quot;ddos_id&quot;: &quot;placeholder&quot;,\r\n            &quot;dns&quot;: [\r\n                &quot;10.0.0.1&quot;,\r\n                &quot;10.0.0.1&quot;\r\n            ],\r\n            &quot;enable_ddos_std&quot;: false,\r\n            &quot;name&quot;: &quot;asdf&quot;\r\n        }\r\n    }\r\n}\r\n```",
        "link": "https://stackoverflow.com/questions/66023723/iterate-over-objects-and-print-select-values",
        "title": "Iterate over objects and print select values"
    },
    {
        "tags": [
            "json",
            "linux",
            "bash",
            "shell",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1612381817,
                "creation_date": 1612381817,
                "answer_id": 66034677,
                "question_id": 66024299,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The key to a simple solution here is using `paths`, `getpath`, and `setpath`, e.g. like so:\r\n\r\n### Invocation\r\n\r\n    jq -f program.jq --argfile b b.json a.json\r\n\r\n### program.jq\r\n```\r\nreduce ($b | paths(scalars)) as $p (.;\r\n  ($b|getpath($p)) as $v\r\n  | if $v != null then setpath($p; $v) else . end)\r\n```\r\n",
                "title": "How to merge two JSON files using jq or any tool?"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1612422406,
                "creation_date": 1612422406,
                "answer_id": 66040821,
                "question_id": 66024299,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "[Merging JSON files recursively in the command-line](https://e.printstacktrace.blog/merging-json-files-recursively-in-the-command-line/)\r\n\r\ndeepmerge.jq:  \r\n```\r\ndef deepmerge(a;b):                                                                                                                                                  \r\n    reduce b[] as $item (a; \r\n        reduce ($item | keys_unsorted[]) as $key (.; \r\n            $item[$key] as $val | ($val | type) as $type | .[$key] = if ($type == &quot;object&quot;) then\r\n            deepmerge({}; [if .[$key] == null then {} else .[$key] end, $val])\r\n            elif ($type == &quot;null&quot;) then\r\n            .[$key]\r\n            else\r\n            $val\r\n            end)\r\n        );   \r\n    deepmerge({}; .)\r\n```\r\n\r\n```\r\njq -f deepmerge.jq -s aa.json bb.json\r\n```\r\n\r\nit works",
                "title": "How to merge two JSON files using jq or any tool?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1612422406,
        "creation_date": 1612343153,
        "last_edit_date": 1612421066,
        "question_id": 66024299,
        "body_markdown": "I&#39;ve got 2 json files and want to merge them into one file.\r\nHere the content of files:\r\n\r\na.json:  \r\n\r\n```\r\n{\r\n\t&quot;config&quot;:\r\n\t{\r\n\t\t&quot;config1&quot;:\r\n\t\t{\r\n\t\t\t&quot;config11&quot;:\r\n\t\t\t{\r\n\t\t\t\t&quot;apple&quot;:&quot;apple&quot;,\r\n\t\t\t\t&quot;orange&quot;:&quot;orange&quot;,\r\n\t\t\t\t&quot;lemon&quot;:[\r\n\t\t\t\t\t&quot;lemon1&quot;,\r\n\t\t\t\t\t&quot;lemon2&quot;,\r\n\t\t\t\t\t&quot;lemon3&quot;\r\n\t\t\t\t],\r\n\t\t\t\t&quot;pear&quot;:&quot;pear&quot;\r\n\t\t\t}\r\n\t\t},\r\n\t\t&quot;config2&quot;:\r\n\t\t{\r\n\t\t\t&quot;config21&quot;:&quot;hello&quot;,\r\n\t\t\t&quot;config22&quot;:&quot;goodbye&quot;\r\n\t\t}\r\n\t}\r\n}\r\n```\r\n\r\nb.json:  \r\n\r\n```\r\n{\r\n\t&quot;config&quot;:\r\n\t{\r\n\t\t&quot;config1&quot;:\r\n\t\t{\r\n\t\t\t&quot;config11&quot;:\r\n\t\t\t{\r\n\t\t\t\t&quot;apple&quot;:null,\r\n\t\t\t\t&quot;orange&quot;:null,\r\n\t\t\t\t&quot;lemon&quot;:[\r\n\t\t\t\t\t&quot;lemon4&quot;,\r\n\t\t\t\t\t&quot;lemon5&quot;,\r\n\t\t\t\t\t&quot;lemon6&quot;\r\n\t\t\t\t],\r\n\t\t\t\t&quot;pear&quot;:null\r\n\t\t\t}\r\n\t\t},\r\n\t\t&quot;config2&quot;:\r\n\t\t{\r\n\t\t\t&quot;config21&quot;:&quot;hey&quot;,\r\n\t\t\t&quot;config22&quot;:null\r\n\t\t}\r\n\t}\r\n}\r\n```\r\n\r\nI want to merge the not-null part of b.json into a.json  \r\n\r\nExpected result:  \r\n\r\n```\r\n{\r\n\t&quot;config&quot;:\r\n\t{\r\n\t\t&quot;config1&quot;:\r\n\t\t{\r\n\t\t\t&quot;config11&quot;:\r\n\t\t\t{\r\n\t\t\t\t&quot;apple&quot;:&quot;apple&quot;,\r\n\t\t\t\t&quot;orange&quot;:&quot;orange&quot;,\r\n\t\t\t\t&quot;lemon&quot;:[\r\n\t\t\t\t\t&quot;lemon4&quot;,\r\n\t\t\t\t\t&quot;lemon5&quot;,\r\n\t\t\t\t\t&quot;lemon6&quot;\r\n\t\t\t\t],\r\n\t\t\t\t&quot;pear&quot;:&quot;pear&quot;\r\n\t\t\t}\r\n\t\t},\r\n\t\t&quot;config2&quot;:\r\n\t\t{\r\n\t\t\t&quot;config21&quot;:&quot;hey&quot;,\r\n\t\t\t&quot;config22&quot;:&quot;goodbye&quot;\r\n\t\t}\r\n\t}\r\n}\r\n```\r\n\r\nI try this command:  \r\n\r\n```\r\njq -s &#39;.[0] + .[1]&#39; a.json b.json\r\n```\r\n\r\nbut the output is not i want  \r\n\r\ni read https://stedolan.github.io/jq/manual ,but i still don&#39;t know how to do\r\n\r\n \r\nAny helps？Thank you.\r\n\r\n\r\n**append**:  \r\n\r\naa.json\r\n```\r\n{\r\n  &quot;config&quot;: {\r\n    &quot;config_again&quot;: {\r\n      &quot;country&quot;: {\r\n        &quot;countrylist&quot;: [\r\n          &quot;CANADA&quot;,\r\n          &quot;MEXICO&quot;,\r\n          &quot;USA&quot;\r\n        ]\r\n      },\r\n      &quot;language&quot;: {\r\n        &quot;languageorderlist&quot;: [\r\n          &quot;en_US&quot;,\r\n          &quot;hu_HU&quot;,\r\n          &quot;in_ID&quot;,\r\n          &quot;it_IT&quot;,\r\n          &quot;iw_IL&quot;,\r\n          &quot;zh_CN&quot;\r\n        ]\r\n      },\r\n      &quot;video&quot;: {\r\n        &quot;mp4&quot;: &quot;1&quot;,\r\n        &quot;mkv&quot;: &quot;1&quot;\r\n      },\r\n      &quot;Audio&quot;: {\r\n        &quot;audio_audio&quot;: &quot;0x111111&quot;\r\n      }\r\n    }\r\n  }\r\n}\r\n\r\n```\r\n\r\nbb.json:  \r\n```\r\n{\r\n  &quot;config&quot;: {\r\n    &quot;config_again&quot;: {\r\n      &quot;country&quot;: {\r\n        &quot;countrylist&quot;: [\r\n          &quot;USA&quot;\r\n        ]\r\n      },\r\n      &quot;language&quot;: {\r\n        &quot;languageorderlist&quot;: [\r\n          &quot;en_US&quot;,\r\n          &quot;de_DE&quot;\r\n        ]\r\n      },\r\n      &quot;video&quot;: {\r\n        &quot;mp4&quot;: null,\r\n        &quot;mkv&quot;: null\r\n      },\r\n      &quot;Audio&quot;: {\r\n        &quot;audio_audio&quot;: &quot;0x666666&quot;\r\n      }\r\n    }\r\n  }\r\n}\r\n```",
        "link": "https://stackoverflow.com/questions/66024299/how-to-merge-two-json-files-using-jq-or-any-tool",
        "title": "How to merge two JSON files using jq or any tool?"
    },
    {
        "tags": [
            "json",
            "csv",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 2123582,
                    "reputation": 55,
                    "user_id": 1886319,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/3261430344af31088afd38dda0651767?s=256&d=identicon&r=PG",
                    "display_name": "Waqar Ahmed",
                    "link": "https://stackoverflow.com/users/1886319/waqar-ahmed"
                },
                "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": 1,
                "creation_date": 1612351133,
                "post_id": 66025003,
                "comment_id": 116737702,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1612346384,
                "creation_date": 1612346384,
                "answer_id": 66025164,
                "question_id": 66025003,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can store root object in a variable, and then expand the Employees arrays:\r\n\r\n```\r\n$ jq -r &#39;. as $root | .Employees[]|[$root.Country, $root.State, .Name, .address] | @csv&#39;\r\n&quot;USA&quot;,&quot;TX&quot;,&quot;Name1&quot;,&quot;SomeAdress1&quot;\r\n&quot;USA&quot;,&quot;FL&quot;,&quot;Name2&quot;,&quot;SomeAdress2&quot;\r\n&quot;USA&quot;,&quot;FL&quot;,&quot;Name3&quot;,&quot;SomeAdress3&quot;\r\n&quot;USA&quot;,&quot;CA&quot;,&quot;Name4&quot;,&quot;SomeAdress4&quot;\r\n```",
                "title": "Generate a separate CSV record for each array element"
            },
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1612346534,
                "creation_date": 1612346534,
                "answer_id": 66025204,
                "question_id": 66025003,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You need to generate a separate array for each employee.\r\n``` none\r\n[.Country, .State] + (.Employees[] | [.Name, .address]) | @csv\r\n```\r\n&lt;sup&gt;[Online demo](https://jqplay.org/s/JZVwgNVWgp)&lt;/sup&gt;",
                "title": "Generate a separate CSV record for each array element"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1612398302,
                "creation_date": 1612398302,
                "answer_id": 66037708,
                "question_id": 66025003,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The other answers are good, but I want to talk about why your attempt doesn&#39;t work, as well as why it seems like it should.\r\n\r\nYou are wondering why this:\r\n\r\n```\r\njq -r &#39;.|[.Country,.State,(.Employees[]|.Name,.address)] | @csv&#39;\r\n```\r\n\r\nproduces this:\r\n\r\n```\r\n&quot;USA&quot;,&quot;TX&quot;,&quot;Name1&quot;,&quot;SomeAdress1&quot;\r\n&quot;USA&quot;,&quot;FL&quot;,&quot;Name2&quot;,&quot;SomeAdress2&quot;,&quot;Name3&quot;,&quot;SomeAdress3&quot;\r\n&quot;USA&quot;,&quot;CA&quot;,&quot;Name4&quot;,&quot;SomeAdress4&quot;\r\n```\r\n\r\nperhaps because this:\r\n\r\n```\r\njq &#39;{Country:.Country,State:.State,Name:(.Employees[]|.Name)}&#39;\r\n```\r\n\r\nproduces this:\r\n\r\n```\r\n{\r\n  &quot;Country&quot;: &quot;USA&quot;,\r\n  &quot;State&quot;: &quot;TX&quot;,\r\n  &quot;Name&quot;: &quot;Name1&quot;\r\n}\r\n{\r\n  &quot;Country&quot;: &quot;USA&quot;,\r\n  &quot;State&quot;: &quot;FL&quot;,\r\n  &quot;Name&quot;: &quot;Name2&quot;\r\n}\r\n{\r\n  &quot;Country&quot;: &quot;USA&quot;,\r\n  &quot;State&quot;: &quot;FL&quot;,\r\n  &quot;Name&quot;: &quot;Name3&quot;\r\n}\r\n{\r\n  &quot;Country&quot;: &quot;USA&quot;,\r\n  &quot;State&quot;: &quot;CA&quot;,\r\n  &quot;Name&quot;: &quot;Name4&quot;\r\n}\r\n```\r\n\r\nIt turns out the difference is in what exactly `[...]` and `{...}` do in a `jq` filter. In  the array constructor `[...]`, the entire contents of the square brackets, commas and all, is a single filter, which is fully evaluated and all the results combined into one array. Each comma inside is simply the sequencing operator, which means generate all the values from the filter on its left, then all the values from the filter on its right. In contrast, the commas in the `{...}` object constructor _are_ part of the syntax and just separate the fields of the object. If any of the field expressions yield multiple values then multiple whole objects are produced. If _multiple_ field expressions yield multiple value then you get a whole object for every _combination_ of yielded values.\r\n\r\nWhen you do this:\r\n\r\n```\r\njq -r &#39;.|[.Country,.State,(.Employees[]|.Name,.address)] | @csv&#39;\r\n                  ^      ^                   ^\r\n                  1      2                   3\r\n```\r\n\r\nthe problem is that the commas labelled &quot;1&quot;, &quot;2&quot; and &quot;3&quot; are all doing the same thing, evaluating all the values for the filter on the left, then all the values for the filter on the right. Then the array constructor catches all of them and produces a single array. The array constructor will never create more than one array for one input.\r\n\r\nSo with that in mind, you need to make sure that where you&#39;re expanding out `.Employees[]` _isn&#39;t inside_ your array constructor. Here&#39;s another option to add to the answers you already have:\r\n\r\n```\r\njq -r &#39;.Employee=.Employees[]|[.Country,.State,.Employee.Name,.Employee.address]|@csv&#39;\r\n```\r\n[demo](https://jqplay.org/s/oNKKIqLtNk)\r\n\r\nor indeed:\r\n\r\n```\r\njq -r &#39;.Employees[] as $e|[.Country,.State,$e.Name,$e.address]|@csv&#39;\r\n```\r\n[demo](https://jqplay.org/s/JP-5c8tk_-)\r\n\r\n",
                "title": "Generate a separate CSV record for each array element"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 0,
        "last_activity_date": 1612398302,
        "creation_date": 1612345878,
        "last_edit_date": 1612351296,
        "question_id": 66025003,
        "body_markdown": "I have a JSON:\r\n```\r\n{\r\n  &quot;Country&quot;: &quot;USA&quot;,\r\n  &quot;State&quot;: &quot;TX&quot;,\r\n  &quot;Employees&quot;: [\r\n    {\r\n      &quot;Name&quot;: &quot;Name1&quot;,\r\n      &quot;address&quot;: &quot;SomeAdress1&quot;\r\n    }\r\n  ]\r\n}\r\n{\r\n  &quot;Country&quot;: &quot;USA&quot;,\r\n  &quot;State&quot;: &quot;FL&quot;,\r\n  &quot;Employees&quot;: [\r\n    {\r\n      &quot;Name&quot;: &quot;Name2&quot;,\r\n      &quot;address&quot;: &quot;SomeAdress2&quot;\r\n    },\r\n    {\r\n      &quot;Name&quot;: &quot;Name3&quot;,\r\n      &quot;address&quot;: &quot;SomeAdress3&quot;\r\n    }\r\n  ]\r\n}\r\n{\r\n  &quot;Country&quot;: &quot;USA&quot;,\r\n  &quot;State&quot;: &quot;CA&quot;,\r\n  &quot;Employees&quot;: [\r\n    {\r\n      &quot;Name&quot;: &quot;Name4&quot;,\r\n      &quot;address&quot;: &quot;SomeAdress4&quot;\r\n    }\r\n  ]\r\n}\r\n```\r\nI want to use jq to get the following result in csv format:\r\n\r\nCountry, State, Name, Address\r\n```\r\nUSA, TX, Name1, SomeAdress1\r\nUSA, FL, Name2, SomeAdress2\r\nUSA, FL, Name3, SomeAdress3\r\nUSA, CA, Name4, SomeAdress4\r\n```\r\nI have got the following jq:\r\n```\r\njq -r &#39;.|[.Country,.State,(.Employees[]|.Name,.address)] | @csv&#39;\r\n```\r\nAnd I get the following with 2nd line having more columns than required. I want these extra columns in a separate row:\r\n```\r\n&quot;USA&quot;,&quot;TX&quot;,&quot;Name1&quot;,&quot;SomeAdress1&quot;\r\n&quot;USA&quot;,&quot;FL&quot;,&quot;Name2&quot;,&quot;SomeAdress2&quot;,&quot;Name3&quot;,&quot;SomeAdress3&quot;\r\n&quot;USA&quot;,&quot;CA&quot;,&quot;Name4&quot;,&quot;SomeAdress4&quot;\r\n```\r\nAnd I want the following result:\r\n```\r\n&quot;USA&quot;,&quot;TX&quot;,&quot;Name1&quot;,&quot;SomeAdress1&quot;\r\n&quot;USA&quot;,&quot;FL&quot;,&quot;Name2&quot;,&quot;SomeAdress2&quot;\r\n&quot;USA&quot;,&quot;FL&quot;,&quot;Name3&quot;,&quot;SomeAdress3&quot;\r\n&quot;USA&quot;,&quot;CA&quot;,&quot;Name4&quot;,&quot;SomeAdress4&quot;\r\n```",
        "link": "https://stackoverflow.com/questions/66025003/generate-a-separate-csv-record-for-each-array-element",
        "title": "Generate a separate CSV record for each array element"
    },
    {
        "tags": [
            "arrays",
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 1143565,
                    "reputation": 535973,
                    "user_id": 1126841,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/fa05233b2357f8d11c22ef4cfc7bb85c?s=256&d=identicon&r=PG",
                    "display_name": "chepner",
                    "link": "https://stackoverflow.com/users/1126841/chepner"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1612367094,
                "post_id": 66030825,
                "comment_id": 116745845,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 15836379,
                    "reputation": 13,
                    "user_id": 11436563,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f0ca059d7c9c5512a247f71e73240c20?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Stephen7337",
                    "link": "https://stackoverflow.com/users/11436563/stephen7337"
                },
                "reply_to_user": {
                    "account_id": 1143565,
                    "reputation": 535973,
                    "user_id": 1126841,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/fa05233b2357f8d11c22ef4cfc7bb85c?s=256&d=identicon&r=PG",
                    "display_name": "chepner",
                    "link": "https://stackoverflow.com/users/1126841/chepner"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1612369773,
                "post_id": 66030825,
                "comment_id": 116747225,
                "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": 1612370043,
                "post_id": 66030825,
                "comment_id": 116747369,
                "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": 1612370118,
                "post_id": 66030825,
                "comment_id": 116747411,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 15836379,
                    "reputation": 13,
                    "user_id": 11436563,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f0ca059d7c9c5512a247f71e73240c20?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Stephen7337",
                    "link": "https://stackoverflow.com/users/11436563/stephen7337"
                },
                "reply_to_user": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1612448442,
                "post_id": 66030825,
                "comment_id": 116774290,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1612531260,
                "last_edit_date": 1612531260,
                "creation_date": 1612466879,
                "answer_id": 66052515,
                "question_id": 66030825,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Use --argjson instead of --arg in the outer invocation.  So, breaking things up for clarity, you would have:\r\n\r\n```\r\noutput=$(aws iam get-policy-version --policy-arn arn:aws:iam::123456789012:policy/MyPolicy --version-id v2 | jq -r --arg arg2 &quot;MyPolicy&quot; &#39;.entity + {&quot;PolicyName&quot;: $arg2}&#39; )\r\n\r\njq -rn --argjson arg1 &quot;$output&quot; &#39;. + [$arg1]&#39;\r\n```\r\n\r\nWith the JSON shown in the comment, this would produce:\r\n```\r\n[\r\n  {\r\n    &quot;PolicyName&quot;: &quot;MyPolicy&quot;\r\n  }\r\n]\r\n```\r\n\r\nI would also suggest that you try to avoid calling jq twice, e.g. along the lines of:\r\n```\r\naws ... | \r\n  jq --arg arg2 MyPolicy &#39;[.entity + {&quot;PolicyName&quot;: $arg2}]&#39;\r\n```\r\n\r\n",
                "title": "jq: syntax error, unexpected &#39;:&#39; using jq for input?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1612531260,
        "creation_date": 1612366888,
        "last_edit_date": 1612525493,
        "question_id": 66030825,
        "body_markdown": "I am trying to build an array using jq:  https://jqplay.org/s/MSk-uUDrRU\r\n\r\nWhen I attempt this in the wild, using a jq command like:\r\n```\r\necho &quot;[]&quot; | jq -r --arg arg1 $(aws iam get-policy-version --policy-arn arn:aws:iam::123456789012:policy/MyPolicy --version-id v2 | jq -r --arg arg2 &quot;MyPolicy&quot; &#39;.entity + {&quot;PolicyName&quot;: $arg2}&#39;) &#39;.[.|length] |= . + $arg1&#39;\r\n```\r\nI get an error message like:\r\n```\r\njq: error: syntax error, unexpected &#39;:&#39;, expecting $end (Unix shell quoting issues?) at &lt;top-level&gt;, line 1:\r\n&quot;CreateDate&quot;:            \r\njq: 1 compile error\r\n```\r\nThis code that is in $arg1 prints out to a file okay.\r\n```\r\naws &lt;long calling argument&gt; | jq -r --arg arg2 &quot;MyPolicy&quot; &#39;.entity + {&quot;PolicyName&quot;: $arg2}&#39;\r\n```\r\n\r\nThe AWS command is https://docs.aws.amazon.com/cli/latest/reference/iam/get-policy-version.html\r\n\r\nPlease note, this is all wrapped in a loop to build an array of the policy versions in which I&#39;m interested.  The `&quot;[]&quot;` is initially defined in variable outside of the loop.",
        "link": "https://stackoverflow.com/questions/66030825/jq-syntax-error-unexpected-using-jq-for-input",
        "title": "jq: syntax error, unexpected &#39;:&#39; using jq for input?"
    },
    {
        "tags": [
            "arrays",
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 9629731,
                    "reputation": 51350,
                    "user_id": 10248678,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d8f818402f22d485b135a3b685ef908e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "oguz ismail",
                    "link": "https://stackoverflow.com/users/10248678/oguz-ismail"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1612372807,
                "post_id": 66031869,
                "comment_id": 116748781,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 20622243,
                    "reputation": 1,
                    "user_id": 15138984,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/192e41509d85f67dd7972259eb37c6f9?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Thomas",
                    "link": "https://stackoverflow.com/users/15138984/thomas"
                },
                "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": 1612378481,
                "post_id": 66031869,
                "comment_id": 116751268,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 39208,
                    "reputation": 267964,
                    "user_id": 112968,
                    "user_type": "registered",
                    "accept_rate": 68,
                    "profile_image": "https://i.sstatic.net/zHTaT.png?s=256",
                    "display_name": "knittl",
                    "link": "https://stackoverflow.com/users/112968/knittl"
                },
                "reply_to_user": {
                    "account_id": 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": 1662331050,
                "post_id": 66031869,
                "comment_id": 129975425,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1662403506,
                "creation_date": 1662403506,
                "answer_id": 73613583,
                "question_id": 66031869,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The following works for your given input:\r\n\r\n```\r\n. as { id: $processid, &quot;last-modified&quot;: { &quot;$date&quot;: $lastupdate } }\r\n| { a:&quot;Application&quot;, o:&quot;Operation&quot; } as $types\r\n| {\r\n    entries: [\r\n        {\r\n            parent: {\r\n                $processid, \r\n                published: .Published.&quot;$date&quot;, \r\n                modified: $lastupdate,\r\n                access_authentication: .access.authentication, \r\n                access_complexity: .access.complexity, \r\n                access_vector: .access.vector\r\n            },\r\n            children: .available_product\r\n                | map(\r\n                    split(&quot;:&quot;) as [$prefix, $name, $typeid, $name, $score]\r\n                    | $types[$typeid] as $type\r\n                    | { $processid, $type, $name, $score, $lastupdate }\r\n                )\r\n                | to_entries\r\n                | map({childid: (.key+1)} + .value)\r\n        }\r\n    ]\r\n}\r\n```\r\n\r\nGenerating the output:\r\n\r\n```\r\n{\r\n  &quot;entries&quot;: [\r\n    {\r\n      &quot;parent&quot;: {\r\n        &quot;processid&quot;: &quot;FOO11100&quot;,\r\n        &quot;published&quot;: &quot;2020-04-02T15:15:00Z&quot;,\r\n        &quot;modified&quot;: &quot;2020-12-24T16:15:00Z&quot;,\r\n        &quot;access_authentication&quot;: &quot;SINGLE&quot;,\r\n        &quot;access_complexity&quot;: &quot;LOW&quot;,\r\n        &quot;access_vector&quot;: &quot;NETWORK&quot;\r\n      },\r\n      &quot;children&quot;: [\r\n        {\r\n          &quot;childid&quot;: 1,\r\n          &quot;processid&quot;: &quot;FOO11100&quot;,\r\n          &quot;type&quot;: &quot;Application&quot;,\r\n          &quot;name&quot;: &quot;roxy&quot;,\r\n          &quot;score&quot;: &quot;1.8&quot;,\r\n          &quot;lastupdate&quot;: &quot;2020-12-24T16:15:00Z&quot;\r\n        },\r\n        {\r\n          &quot;childid&quot;: 2,\r\n          &quot;processid&quot;: &quot;FOO11100&quot;,\r\n          &quot;type&quot;: &quot;Application&quot;,\r\n          &quot;name&quot;: &quot;roxy&quot;,\r\n          &quot;score&quot;: &quot;1.9&quot;,\r\n          &quot;lastupdate&quot;: &quot;2020-12-24T16:15:00Z&quot;\r\n        },\r\n        {\r\n          &quot;childid&quot;: 3,\r\n          &quot;processid&quot;: &quot;FOO11100&quot;,\r\n          &quot;type&quot;: &quot;Operation&quot;,\r\n          &quot;name&quot;: &quot;ianu&quot;,\r\n          &quot;score&quot;: &quot;10.0&quot;,\r\n          &quot;lastupdate&quot;: &quot;2020-12-24T16:15:00Z&quot;\r\n        }\r\n      ]\r\n    }\r\n  ]\r\n}\r\n```\r\n\r\nAn alternative version which generates the same output could be:\r\n\r\n```\r\n.id as $processid\r\n| .&quot;last-modified&quot;.&quot;$date&quot; as $lastupdate\r\n| {\r\n    entries: [\r\n        {\r\n            parent: {\r\n                $processid, \r\n                published: .Published.&quot;$date&quot;, \r\n                modified: $lastupdate,\r\n                access_authentication: .access.authentication, \r\n                access_complexity: .access.complexity, \r\n                access_vector: .access.vector\r\n            },\r\n            children: .available_product\r\n                | to_entries\r\n                | map(\r\n                    .value |= split(&quot;:&quot;)\r\n                    | {\r\n                        $processid,\r\n                        childid: (.key+1),\r\n                        type: { a:&quot;Application&quot;, o:&quot;Operation&quot; }[.value[2]],\r\n                        name: .value[3],\r\n                        score: .value[4],\r\n                        $lastupdate\r\n                    }\r\n                )\r\n        }\r\n    ]\r\n}\r\n```",
                "title": "JQ: Convert Array to Array, access upper elements and position"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1662403506,
        "creation_date": 1612370470,
        "last_edit_date": 1612370820,
        "question_id": 66031869,
        "body_markdown": "I got the following source:\r\n```\r\n{\r\n\t&quot;id&quot;: &quot;FOO11100&quot;,\r\n\t&quot;Published&quot;: {\r\n\t\t&quot;$date&quot;: &quot;2020-04-02T15:15:00Z&quot;\r\n\t},\r\n\t&quot;Modified&quot;: {\r\n\t\t&quot;$date&quot;: &quot;2020-12-24T16:15:00Z&quot;\r\n\t},\r\n\t&quot;last-modified&quot;: {\r\n\t\t&quot;$date&quot;: &quot;2020-12-24T16:15:00Z&quot;\r\n\t},\r\n\t&quot;access&quot;: {\r\n\t\t&quot;authentication&quot;: &quot;SINGLE&quot;,\r\n\t\t&quot;complexity&quot;: &quot;LOW&quot;,\r\n\t\t&quot;vector&quot;: &quot;NETWORK&quot;\r\n\t},\r\n\t&quot;available_product&quot;: [\r\n\t\t&quot;custom:foo:a:roxy:1.8&quot;,\r\n\t\t&quot;custom:foo:a:roxy:1.9&quot;,\r\n\t\t&quot;custom:foo:o:ianu:10.0&quot;\r\n\t]\r\n}\r\n```\r\n\r\nI want to get something like that:\r\n```\r\n{\r\n  &quot;entries&quot;: [\r\n  {\r\n    &quot;parent&quot;: {\r\n      &quot;processid&quot;: &quot;FOO11100&quot;,\r\n      &quot;published&quot;: &quot;2020-04-02T15:15:00Z&quot;,\r\n      &quot;modified&quot;: &quot;2020-12-24T16:15:00Z&quot;,\r\n      &quot;access_authentication&quot;: &quot;SINGLE&quot;,\r\n      &quot;access_complexity&quot;: &quot;LOW&quot;,\r\n      &quot;access_vector&quot;: &quot;NETWORK&quot;\r\n    },\r\n    &quot;childs&quot;: [\r\n        {\r\n          &quot;processid&quot;: &quot;FOO11100&quot;,\r\n          &quot;childid&quot;: 1,\r\n          &quot;type&quot;: &quot;Application&quot;,\r\n          &quot;name&quot;: &quot;roxy&quot;,\r\n          &quot;score&quot;: &quot;1.8&quot;,\r\n          &quot;lastupdate&quot;: &quot;2020-12-24T16:15:00Z&quot;\r\n        },\r\n        {\r\n          &quot;processid&quot;: &quot;FOO11100&quot;,\r\n          &quot;childid&quot;: 2,\r\n          &quot;type&quot;: &quot;Application&quot;,\r\n          &quot;name&quot;: &quot;roxy&quot;,\r\n          &quot;score&quot;: &quot;1.9&quot;,\r\n          &quot;lastupdate&quot;: &quot;2020-12-24T16:15:00Z&quot;\r\n        },\r\n        {\r\n          &quot;processid&quot;: &quot;FOO11100&quot;,\r\n          &quot;childid&quot;: 3,\r\n          &quot;type&quot;: &quot;Operation&quot;,\r\n          &quot;name&quot;: &quot;ianu&quot;,\r\n          &quot;score&quot;: &quot;10.0&quot;,\r\n          &quot;lastupdate&quot;: &quot;2020-12-24T16:15:00Z&quot;\r\n        }\r\n      ]\r\n    }\r\n  ]\r\n}\r\n```\r\n\r\nThe upper part is no problem, but in the lower part I want to iterate over the elements within .available_product and access:\r\n- id and last-modified outside of the array for processid and lastupdate within the new object\r\n- the position of the element within the array for childid\r\n- the tokenized text part 3 to translate it (a=Application, o=Operation)\r\n\r\nCurrently i have that:\r\n```\r\n{entries: \r\n [\r\n  { parent: \r\n   {\r\n    processid: .id, \r\n    published: .Published.&quot;$date&quot;, \r\n    modified: .&quot;last-modified&quot;.&quot;$date&quot;, \r\n    access_authentication: .access.authentication, \r\n    access_complexity: .access.complexity, \r\n    access_vector: .access.vector\r\n   }, \r\n   childs: .available_product\r\n  }\r\n ]\r\n}\r\n```\r\n\r\nbut I dont have any luck with the array processing.\r\n\r\nany help appreciated",
        "link": "https://stackoverflow.com/questions/66031869/jq-convert-array-to-array-access-upper-elements-and-position",
        "title": "JQ: Convert Array to Array, access upper elements and position"
    },
    {
        "tags": [
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 22779,
                    "reputation": 132266,
                    "user_id": 56541,
                    "user_type": "registered",
                    "accept_rate": 81,
                    "profile_image": "https://i.sstatic.net/Wm7Xg.png?s=256",
                    "display_name": "David Z",
                    "link": "https://stackoverflow.com/users/56541/david-z"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1612389127,
                "post_id": 66036175,
                "comment_id": 116755492,
                "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": 1612397995,
                "post_id": 66036175,
                "comment_id": 116757872,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1612389679,
                "creation_date": 1612389679,
                "answer_id": 66036368,
                "question_id": 66036175,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "This `jq` script should do the trick:\r\n```\r\n{\r\n  id,\r\n  name: (first(.Tags[] | select(.Key == &quot;Name&quot;).Value)? // &quot;(none)&quot;)\r\n}\r\n| &quot;\\(.id) \\(.name)&quot;\r\n```\r\nIt works similar to your pseudocode, but it doesn&#39;t proactively defend against the `.Tags` array being absent or empty. There&#39;s no particular reason to treat that differently than the case where it exists but doesn&#39;t contain a `Name` entry. This program just tries to access `.Value` of the `Name` entry, and if that doesn&#39;t work for any reason at all, it substitutes `&quot;(none)&quot;`.\r\n\r\nYou can use this either by putting it in a file, or directly with\r\n```console\r\n$ jq -r &#39;{id, name: ...} | &quot;\\(.id) \\(.name)&quot;&#39; input.json\r\n```",
                "title": "jq: Find a key in a struct in an array or use default value in jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1612389679,
        "creation_date": 1612388757,
        "question_id": 66036175,
        "body_markdown": "Consider this JSON input:\r\n```\r\n{\r\n  &quot;id&quot;:0,\r\n  &quot;Tags&quot;: [\r\n    {&quot;Key&quot;:&quot;Name&quot;, &quot;Value&quot;:&quot;machine1&quot;},\r\n    {&quot;Key&quot;:&quot;Stage&quot;, &quot;Value&quot;:&quot;UAT&quot;}\r\n  ]\r\n},\r\n{\r\n  &quot;id&quot;:1,\r\n  &quot;Tags&quot;: [\r\n    {&quot;Key&quot;:&quot;Stage&quot;, &quot;Value&quot;:&quot;UAT&quot;}\r\n  ]\r\n},\r\n{\r\n  &quot;id&quot;:2,\r\n  &quot;Tags&quot;: []\r\n},\r\n{\r\n  &quot;id&quot;:3\r\n}\r\n```\r\nI seek a solution that after piping and selects will yield either the value of the `Value` field where a key `Name` is `Name` or `(none)` as a default.  The closest I get is:\r\n```\r\njq -r &#39;if(.Tags == null or .Tags == []) then .Tags=[{&quot;Key&quot;:&quot;Name&quot;,&quot;Value&quot;:&quot;(none)&quot;}] else . end | &quot;\\(.id) \\(.Tags[] | select(.Key == &quot;Name&quot;)|.Value)&quot; &#39;\r\n```\r\nThe solution works for id 0, 2, and 3.   It is when the `Tags` array exists but does *not* contain .Key == &quot;Name&quot; that the select yields null and no value is returned.  If I jiggle around with this a little more I can probably stumble into it but.   Ideally I want to do something like this (jq pseudocode):\r\n```\r\nDefend against null tags, then walk array looking for Name\r\n&#39;\\(.Tags // [{}] | select(.Tags[].Key == &quot;Name&quot;)?.Value // &quot;(none)&quot;)\r\n```\r\nIt might just be that I do need 1 more stage but I want to explore other clever possibilities.",
        "link": "https://stackoverflow.com/questions/66036175/jq-find-a-key-in-a-struct-in-an-array-or-use-default-value-in-jq",
        "title": "jq: Find a key in a struct in an array or use default value in jq"
    },
    {
        "tags": [
            "json",
            "object",
            "nested",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1612452834,
                "last_edit_date": 1612452834,
                "creation_date": 1612426182,
                "answer_id": 66041623,
                "question_id": 66041386,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Convert keys to paths, and put the values in their original places using [`setpath`](https://stedolan.github.io/jq/manual/#setpath(PATHS;VALUE)).\r\n```\r\n. as $in | reduce keys_unsorted[] as $k ({}; setpath($k / &quot;.&quot;; $in[$k]))\r\n```\r\n&lt;sup&gt;[Online demo](https://jqplay.org/s/v4Mat2Wgay)&lt;/sup&gt;",
                "title": "How to unflatten a JSON object?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1612452834,
        "creation_date": 1612425141,
        "last_edit_date": 1612440664,
        "question_id": 66041386,
        "body_markdown": "How to convert the flattened JSON like following\r\n```json\r\n{\r\n  &quot;foo.bar1&quot;: &quot;1&quot;,\r\n  &quot;foo.bar2&quot;: &quot;2&quot;,\r\n  &quot;foo.bar3.doo1&quot;: &quot;3&quot;,\r\n  &quot;foo.bar3.doo2&quot; : &quot;4&quot;\r\n}\r\n```\r\nto be nested like\r\n```json\r\n{\r\n  &quot;foo&quot;: {\r\n    &quot;bar1&quot;: &quot;1&quot;,\r\n    &quot;bar2&quot;: &quot;2&quot;,\r\n    &quot;bar3&quot;: {\r\n      &quot;doo1&quot;: &quot;3&quot;,\r\n      &quot;doo2&quot;: &quot;4&quot;\r\n    }\r\n  }\r\n}\r\n```\r\n? I could find many posts about flattening a nested JSON, but not vice versa.\r\n",
        "link": "https://stackoverflow.com/questions/66041386/how-to-unflatten-a-json-object",
        "title": "How to unflatten a JSON object?"
    },
    {
        "tags": [
            "json",
            "file",
            "merge",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1612442359,
                "creation_date": 1612442359,
                "answer_id": 66045802,
                "question_id": 66043938,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Assuming both files contain valid JSON, you could do worse than:\r\n```\r\njq --argfile extra 2.json &#39;.data.items += $extra&#39; 1.json\r\n```\r\n",
                "title": "jq: add new elements to list from other file"
            },
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1612461831,
                "creation_date": 1612461831,
                "answer_id": 66051307,
                "question_id": 66043938,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "if you&#39;re willing to normalize the detail file:\r\n\r\n    items=$(jq -c &#39; . | { data: { items: . }} &#39; 2.json)\r\n\r\n    jq -s &#39;{ data: { items: map(.data.items[])}}&#39; 1.json &lt;(echo $items)",
                "title": "jq: add new elements to list from other file"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1612461831,
        "creation_date": 1612435104,
        "last_edit_date": 1612442889,
        "question_id": 66043938,
        "body_markdown": "I have two json files. \r\nFile 1: \r\n\r\n    {\r\n\t  &quot;data&quot;: {\r\n\t\t&quot;items&quot;: []\r\n\t  }\r\n    }\r\nFile 2:\r\n\r\n    [\r\n      { \r\n        &quot;name&quot;: &quot;first name&quot;,\r\n        &quot;path&quot;: [{\r\n                &quot;matcher&quot;: &quot;exact&quot;,\r\n        }]\r\n      },\r\n      {\r\n        ...\r\n      }\r\n    ]\r\n\r\nI want to add all items from File 2 to the .data.items list in File 1.\r\nHow can I accomplish this?\r\n\r\nThanks in advance!",
        "link": "https://stackoverflow.com/questions/66043938/jq-add-new-elements-to-list-from-other-file",
        "title": "jq: add new elements to list from other file"
    },
    {
        "tags": [
            "json",
            "field",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1612441901,
                "post_id": 66044249,
                "comment_id": 116771169,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 3556115,
                    "reputation": 602,
                    "user_id": 2969854,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/ab2b5774301d6321cb3adbdddc91736f?s=256&d=identicon&r=PG",
                    "display_name": "Soufiane ELH",
                    "link": "https://stackoverflow.com/users/2969854/soufiane-elh"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1612442344,
                "post_id": 66044249,
                "comment_id": 116771379,
                "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": 1612442820,
                "post_id": 66044249,
                "comment_id": 116771625,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1616055442,
                "creation_date": 1616055442,
                "answer_id": 66687147,
                "question_id": 66044249,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You are filtering multiple times during object construction. You could filter first and then do the construction on the filtered list eg.\r\n\r\n```jq\r\nmap(select(.location==&quot;Stockholm&quot;)) \r\n  | map({newname: .name, contains_w: (.name | startswith(&quot;W&quot;))})\r\n```\r\n\r\nhttps://jqplay.org/s/aXjlgOEDnb",
                "title": "using jq : how can i use the same search in other field without duplicate code?"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1616055442,
        "creation_date": 1612436320,
        "last_edit_date": 1612436654,
        "question_id": 66044249,
        "body_markdown": "I have the following json file for exemple:\r\n```\r\n{\r\n    &quot;FOO&quot;: {\r\n        &quot;name&quot;: &quot;Donald&quot;,\r\n        &quot;location&quot;: &quot;Stockholm&quot;\r\n    },\r\n    &quot;BAR&quot;: {\r\n        &quot;name&quot;: &quot;Walt&quot;,\r\n        &quot;location&quot;: &quot;Stockholm&quot;\r\n    },\r\n    &quot;BAZ&quot;: {\r\n        &quot;name&quot;: &quot;Jack&quot;,\r\n        &quot;location&quot;: &quot;Whereever&quot;\r\n    }\r\n}\r\n```\r\nand i have this jq command : \r\n```\r\ncat json | jq .[] | {newname : select(.location==&quot;Stockholm&quot;) | .name , contains_w : select(.location==&quot;Stockholm&quot;) | .name  | startswith(&quot;W&quot;)} \r\n```\r\nso i get the result : \r\n```\r\n{\r\n  &quot;newname&quot;: &quot;Donald&quot;,\r\n  &quot;contains_w&quot;: false\r\n}\r\n{\r\n  &quot;newname&quot;: &quot;Walt&quot;,\r\n  &quot;contains_w&quot;: true\r\n}\r\n```\r\n\r\nmy question is : is there any way to `DRY` my command ? &lt;br&gt;\r\ni mean how can i get the same result without **duplicate** the part : \r\n```\r\nselect(.location==&quot;Stockholm&quot;) | .name \r\n```\r\nhow can i reuse the result of **newname** feild ?\r\n\r\ni have a really big file to work with so i don&#39;t want to waste time and resources.",
        "link": "https://stackoverflow.com/questions/66044249/using-jq-how-can-i-use-the-same-search-in-other-field-without-duplicate-code",
        "title": "using jq : how can i use the same search in other field without duplicate code?"
    },
    {
        "tags": [
            "json",
            "jq",
            "nested-lists",
            "jsonpath"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1612449723,
                "creation_date": 1612449723,
                "answer_id": 66047864,
                "question_id": 66047747,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "With JQ it&#39;d be easier than that.\r\n``` none\r\n{\r\n  name:   map(.name),\r\n  id:     map(.id),\r\n  states: map(.locations | map(.state))\r\n}\r\n```\r\n&lt;sup&gt;[Online demo](https://jqplay.org/s/acWzuH6TRu)&lt;/sup&gt;",
                "title": "How to read nested array elements from JSON?"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1615639456,
                "creation_date": 1615639456,
                "answer_id": 66613644,
                "question_id": 66047747,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "In JSLT you can implement it like this:\r\n\r\n    {\r\n      &quot;name&quot; : [for (.) .name],\r\n      &quot;id&quot;: [for (.) .id],\r\n      &quot;states&quot;: flatten([for (.) [for (.locations) .state]])\r\n    } \r\n\r\nThe `states` key is a bit awkward to implement, as you see. I have thought of making it possible to let path expressions traverse arrays, and if we add that to the language it could be implemented like this:\r\n\r\n    {\r\n      &quot;name&quot; : .[].name,\r\n      &quot;id&quot;: .[].id,\r\n      &quot;states&quot;: .[].locations.[].state\r\n    } ",
                "title": "How to read nested array elements from JSON?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1615639456,
        "creation_date": 1612449294,
        "last_edit_date": 1612531511,
        "question_id": 66047747,
        "body_markdown": "I need to parse a JSON with nested array elements and extract the values.\r\n\r\nI am not sure how to use the nested array to set the value of an attribute in output JSON.\r\n\r\nThis is the input:\r\n\r\n      [{\r\n    \t\t&quot;name&quot;: &quot;book1&quot;,\r\n    \t\t&quot;id&quot;: 18789,\r\n    \t\t&quot;locations&quot;: [{\r\n    \t\t\t&quot;state&quot;: &quot;mystate&quot;,\r\n    \t\t\t&quot;phone&quot;: 8877887700\r\n    \t\t}, {\r\n    \t\t\t&quot;state&quot;: &quot;mystate1&quot;,\r\n    \t\t\t&quot;phone&quot;: 8877887701\r\n    \t\t}]\r\n    \t},\r\n    \t{\r\n    \t\t&quot;name&quot;: &quot;book2&quot;,\r\n    \t\t&quot;id&quot;: 18781,\r\n    \t\t&quot;locations&quot;: [{\r\n    \t\t\t&quot;state&quot;: &quot;mystate3&quot;,\r\n    \t\t\t&quot;phone&quot;: 8877887711\r\n    \t\t}, {\r\n    \t\t\t&quot;state&quot;: &quot;mystate4&quot;,\r\n    \t\t\t&quot;phone&quot;: 8877887702\r\n    \t\t}]\r\n    \t}]\r\n\r\nAnd this is the expected output:\r\n\r\n    {\r\n    \t&quot;name&quot;: [&quot;book1&quot;, &quot;book2&quot;],\r\n    \t&quot;id&quot;: [&quot;18789&quot;, &quot;18781&quot;],\r\n    \t&quot;states&quot;: [\r\n    \t\t[&quot;mystate&quot;, &quot;mystate&quot;],\r\n    \t\t[&quot;mystate3&quot;, &quot;mystate4&quot;]\r\n    \t]\r\n    }\r\n\r\nI am trying to use the following JSLT expression:\r\n\r\n    {\r\n      &quot;name&quot; : [for (.)\r\n                   let s = string(.name)\r\n                   $s],\r\n    &quot;id&quot;: [for (.)\r\n                   let s = string(.id)\r\n                   $s],\r\n    &quot;states&quot;: [for (.)\r\n                   let s = string(.locations)\r\n                   $s]\r\n    }  \r\n\r\nBut I am not sure how to set the `states` in this case so that I have the value of state in the output.\r\n\r\nA solution using JQ or JSONPath may also help.",
        "link": "https://stackoverflow.com/questions/66047747/how-to-read-nested-array-elements-from-json",
        "title": "How to read nested array elements from JSON?"
    },
    {
        "tags": [
            "json",
            "shell",
            "export-to-csv",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1612480255,
                "post_id": 66050102,
                "comment_id": 116787871,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2797264,
                    "reputation": 1,
                    "user_id": 2406253,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/1e46183a6ae0241e7a17a027f232f16a?s=256&d=identicon&r=PG",
                    "display_name": "user2406253",
                    "link": "https://stackoverflow.com/users/2406253/user2406253"
                },
                "reply_to_user": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1612498693,
                "post_id": 66050102,
                "comment_id": 116791516,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2797264,
                    "reputation": 1,
                    "user_id": 2406253,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/1e46183a6ae0241e7a17a027f232f16a?s=256&d=identicon&r=PG",
                    "display_name": "user2406253",
                    "link": "https://stackoverflow.com/users/2406253/user2406253"
                },
                "reply_to_user": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1612499266,
                "post_id": 66050102,
                "comment_id": 116791618,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": -1,
                "last_activity_date": 1612467662,
                "creation_date": 1612467662,
                "answer_id": 66052708,
                "question_id": 66050102,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "One way to do it would be to use the [update operator][1] `|=` to delete the unwanted key-value pair.\r\n\r\n    jq -r &#39;.prefixes[] |= del(.network_border_group)\r\n           | (.prefixes[0] | keys_unsorted),\r\n             (.prefixes[] | to_entries | map(.value))\r\n           | @tsv&#39;\r\n\r\n\r\n  [1]: https://stedolan.github.io/jq/manual/v1.6/#Assignment",
                "title": "Convert json to csv with only selected keys"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1612507865,
                "last_edit_date": 1612507865,
                "creation_date": 1612470923,
                "answer_id": 66053431,
                "question_id": 66050102,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Say you had a list of fields in `$fields`. Then all you&#39;d need is this:\r\n\r\n```jq\r\n.prefixes |                 // The array of records from which we will build our rows.\r\n(\r\n   $fields,                 // The header row\r\n   (                        // The data rows\r\n      .[] |                 //   For each input,\r\n      [ .[ $fields[] ] ]    //   create an array of the selected values\r\n   )\r\n) |\r\n@tsv\r\n```\r\n\r\nThis will serve as the basis of all the following solutions. What will differ is how we build `$fields`.\r\n\r\n---\r\n\r\nAllow list:\r\n\r\n```jq\r\n[ &quot;ip_prefix&quot;, &quot;region&quot;, &quot;service&quot; ] as $fields |\r\n.prefixes |\r\n( $fields, ( .[] | [ .[ $fields[] ] ] ) ) | @tsv\r\n```\r\n\r\nExample use:\r\n\r\n```sh\r\njq -r --argjson fields &#39;[ &quot;ip_prefix&quot;, &quot;region&quot;, &quot;service&quot; ]&#39; &#39;\r\n   [ &quot;ip_prefix&quot;, &quot;region&quot;, &quot;service&quot; ] as $fields |\r\n   .prefixes |\r\n   ( $fields, ( .[] | [ .[ $fields[] ] ] ) ) | @tsv\r\n&#39; data.json\r\n```\r\n\r\n---\r\n\r\nBlocked item:\r\n\r\n```jq\r\n.prefixes |\r\n( .[0] | keys_unsorted | map(select( . != &quot;network_border_group&quot; )) ) as $fields |\r\n.prefixes |\r\n( $fields, ( .[] | [ .[ $fields[] ] ] ) ) | @tsv\r\n```\r\n\r\n---\r\n\r\nBlock list:\r\n\r\n```jq\r\n[ &quot;network_border_group&quot; ] as $blocked |\r\n.prefixes |\r\n( .[0] | keys_unsorted - $blocked ) as $fields |\r\n( $fields, ( .[] | [ .[ $fields[] ] ] ) ) | @tsv\r\n```\r\n\r\nExample use:\r\n\r\n```sh\r\njq -r --argjson blocked &#39;[ &quot;network_border_group&quot; ]&#39; &#39;\r\n   .prefixes |\r\n   ( .[0] | keys_unsorted - $blocked ) as $fields |\r\n   ( $fields, ( .[] | [ .[ $fields[] ] ] ) ) | @tsv\r\n&#39; data.json\r\n```",
                "title": "Convert json to csv with only selected keys"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1612481847,
                "last_edit_date": 1612481847,
                "creation_date": 1612479878,
                "answer_id": 66055186,
                "question_id": 66050102,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The following variations assume a &quot;whitelist&quot; approach is appropriate:\r\n\r\n### Without a header row\r\n```\r\n.prefixes[] | [.ip_prefix,.region,.service] | @csv\r\n```\r\n\r\nOr, specifying the whitelist as an argument:\r\n\r\n    jq -r --argjson whitelist &#39;[&quot;ip_prefix&quot;,&quot;region&quot;,&quot;service&quot;]&#39; &#39;\r\n      .prefixes[] | [ .[$whitelist[]] ] | @csv&#39;\r\n\r\n\r\n### With a header row:\r\n```\r\n[&quot;ip_prefix&quot;,&quot;region&quot;,&quot;service&quot;] as $whitelist\r\n| $whitelist,\r\n  (.prefixes[] | [getpath($whitelist[]|[.])])\r\n| @csv\r\n```\r\n\r\nEtc.\r\n\r\nNote that none of the above require any special ordering of keys in the objects in the source.",
                "title": "Convert json to csv with only selected keys"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 0,
        "last_activity_date": 1612617861,
        "creation_date": 1612457359,
        "last_edit_date": 1612617861,
        "question_id": 66050102,
        "body_markdown": "I have a json script with the following content.\r\n```\r\n{\r\n  &quot;syncToken&quot;: &quot;1612442658&quot;,\r\n  &quot;createDate&quot;: &quot;2021-02-04-12-44-18&quot;,\r\n  &quot;prefixes&quot;: [\r\n    {\r\n      &quot;ip_prefix&quot;: &quot;3.5.140.0/22&quot;,\r\n      &quot;region&quot;: &quot;ap-northeast-2&quot;,\r\n      &quot;service&quot;: &quot;AMAZON&quot;,\r\n      &quot;network_border_group&quot;: &quot;ap-northeast-2&quot;\r\n    },\r\n    {\r\n      &quot;ip_prefix&quot;: &quot;35.180.0.0/16&quot;,\r\n      &quot;region&quot;: &quot;eu-west-3&quot;,\r\n      &quot;service&quot;: &quot;AMAZON&quot;,\r\n      &quot;network_border_group&quot;: &quot;eu-west-3&quot;\r\n    },\r\n    {\r\n      &quot;ip_prefix&quot;: &quot;52.93.178.234/32&quot;,\r\n      &quot;region&quot;: &quot;us-west-1&quot;,\r\n      &quot;service&quot;: &quot;AMAZON&quot;,\r\n      &quot;network_border_group&quot;: &quot;us-west-1&quot;\r\n    }\r\n  ]\r\n}\r\n`````\r\nMy requirement is to convert this json to csv in the below format.\r\n`````\r\nip_prefix         region           service    \r\n3.5.140.0/22      ap-northeast-2   AMAZON     \r\n35.180.0.0/16     eu-west-3        AMAZON     \r\n52.93.178.234/32  us-west-1        AMAZON   \r\n``````\r\n\r\nUsed jq to convert the data using the below command\r\n````\r\njq -r &#39;(.prefixes[0] | keys_unsorted), (.prefixes[] | to_entries | map(.value))|@tsv&#39; ip-ranges.json \r\n```````\r\nBut its exporting all the keys. Need help in exporting few keys out of many keys.\r\n\r\n",
        "link": "https://stackoverflow.com/questions/66050102/convert-json-to-csv-with-only-selected-keys",
        "title": "Convert json to csv with only selected keys"
    },
    {
        "tags": [
            "json",
            "output",
            "jq",
            "data-objects"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1612484856,
                "post_id": 66055077,
                "comment_id": 116788968,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": -1,
                "last_activity_date": 1612479301,
                "creation_date": 1612479301,
                "answer_id": 66055078,
                "question_id": 66055077,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "To satisfy the search we will use the following:\r\n- `select()`: pick the key that we will be selecting to search explicitly\r\n- `ascii_downcase`: this modifier is helpful for these type of searches where you do not know if the key has a a certain value. This will remove case sensitivity *i.e. `Tom vs tOm vs toM etc`*\r\n- `contains()`: help search for multiple values\r\n\r\n`jq &#39;select( keys[]| ascii_downcase |contains( &quot;pw&quot;,&quot;password&quot;))&#39;`\r\n\r\n\r\n\r\n\r\n**`BONUS:`**\r\n\r\n*However another search might be if you want to search the values based on a specific key in more structured sanitized data where the key name is explicitly the same you would be able to search the values by do this -&gt;*\r\n\r\n`jq &#39;select( .Password| ascii_downcase |contains( &quot;pw&quot;,&quot;password&quot;))&#39;`",
                "title": "JSON How to search keys name value and print the objects that contains a string or set of strings with case insensitivity?"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1612494032,
                "last_edit_date": 1612494032,
                "creation_date": 1612485290,
                "answer_id": 66055936,
                "question_id": 66055077,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "To sanitize a stream of objects efficiently:\r\n\r\n```\r\nwith_entries( if .key | ascii_downcase | IN(&quot;password&quot;, &quot;pw&quot;, &quot;pa$$word&quot;)\r\n              then .key=&quot;Password&quot; \r\n              else . end) \r\n```\r\n\r\nTo select efficiently, without sanitizing the results:\r\n\r\n```\r\nselect( any(keys_unsorted[] | ascii_downcase;\r\n            IN(&quot;password&quot;, &quot;pw&quot;, &quot;pa$$word&quot;) ) )\r\n```",
                "title": "JSON How to search keys name value and print the objects that contains a string or set of strings with case insensitivity?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1612494032,
        "creation_date": 1612479301,
        "question_id": 66055077,
        "body_markdown": "Goal:\r\n- Search the keys actual name value for a string or set of strings \r\n- search using case insensitive values\r\n- return the object(s) containing the values\r\n\r\nUn-sanitized test data:\r\n\r\n    {\r\n        &quot;PassworD&quot;: &quot;dashnd8&quot;,\r\n        &quot;Name&quot;: &quot;Katy&quot;\r\n    }\r\n    {\r\n        &quot;PasSWOrd&quot;: &quot;DJNAS98das98&quot;,\r\n        &quot;Name&quot;: &quot;Paulo&quot;\r\n    }\r\n    {\r\n        &quot;Pa$$word&quot;: &quot;H(AD*Sn&quot;,\r\n        &quot;Name&quot;: &quot;Crissy&quot;\r\n        \r\n    }\r\n    {\r\n        &quot;PW&quot;: &quot;nA(*DS&quot;,\r\n        &quot;Name&quot;: &quot;Jamel&quot;\r\n        \r\n    }\r\n    {\r\n        &quot;pW&quot;: &quot;0d9asm0i&quot;,\r\n        &quot;Name&quot;: &quot;Denny&quot;\r\n    }\r\n\r\n\r\nsanitized test data:\r\n\r\n    {\r\n        &quot;Password&quot;: &quot;PW&quot;,\r\n        &quot;Name&quot;: &quot;Katy&quot;\r\n    }\r\n    {\r\n        &quot;Password&quot;: &quot;pW&quot;,\r\n        &quot;Name&quot;: &quot;Paulo&quot;\r\n    }\r\n    {\r\n        &quot;Password&quot;: &quot;pw&quot;,\r\n        &quot;Name&quot;: &quot;Crissy&quot;\r\n        \r\n    }\r\n    {\r\n        &quot;Password&quot;: &quot;passWorD&quot;,\r\n        &quot;Name&quot;: &quot;Jamel&quot;\r\n        \r\n    }\r\n    {\r\n        &quot;Password&quot;: &quot;PAssword&quot;,\r\n        &quot;Name&quot;: &quot;Denny&quot;\r\n    }\r\n\r\n\r\nNote: if the json object has a different Hierarchy please add the necessary steps to access your data",
        "link": "https://stackoverflow.com/questions/66055077/json-how-to-search-keys-name-value-and-print-the-objects-that-contains-a-string",
        "title": "JSON How to search keys name value and print the objects that contains a string or set of strings with case insensitivity?"
    },
    {
        "tags": [
            "json",
            "jq",
            "jsonlines"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1612562339,
                "creation_date": 1612562339,
                "answer_id": 66071160,
                "question_id": 66070280,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s one possibility:\r\n\r\n    jq -c &#39;keys_unsorted[] as $k | {($k): .[$k]}&#39;\r\n\r\n### Recursive unbundling\r\n\r\nIt might be worthwhile encapsulating this functionality in a recursive function:\r\n\r\n    def unbundle:\r\n      if type == &quot;object&quot; \r\n      then keys_unsorted[] as $k\r\n      | {($k): .[$k] | unbundle}\r\n      else . end;\r\n\r\nWith your example, `unbundle` would produce:\r\n```\r\n{&quot;dog&quot;:{&quot;breed_1&quot;:12}}\r\n{&quot;dog&quot;:{&quot;breed_2&quot;:20}}\r\n{&quot;cat&quot;:{&quot;breed_1&quot;:6}}\r\n{&quot;cat&quot;:{&quot;breed_2&quot;:8}}\r\n```\r\n\r\n    ",
                "title": "Convert JSON dictionary to JSON lines using jQ"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1612562411,
        "creation_date": 1612557516,
        "last_edit_date": 1612562411,
        "question_id": 66070280,
        "body_markdown": "I have a Json file named `some_file.json`:\r\n```\r\n{\r\n  &quot;dog&quot;: {\r\n           &quot;breed_1&quot;: 12,\r\n           &quot;breed_2&quot;: 20,\r\n         },\r\n  &quot;cat&quot;: {\r\n           &quot;breed_1&quot;: 6,\r\n           &quot;breed_2&quot;: 8,\r\n         },\r\n}\r\n```\r\n\r\nI want to convert it to the below json lines file:\r\n\r\n```\r\n{&quot;dog&quot;:{&quot;breed_1&quot;:12,&quot;breed_2&quot;:20}}\r\n{&quot;cat&quot;:{&quot;breed_1&quot;:6,&quot;breed_2&quot;:8}}\r\n```\r\n\r\nNotice, how every key value in the original JSON is now on a single line. \r\n\r\nI can write some code for this in any programming language. But I was wondering how I can use jQ to convert the JSON to a JSON lines file. \r\n\r\nI tried, `cat some_file.json | jq &#39;.[]&#39; -c &gt; lines_file.jsonl` and it returned\r\n\r\n```\r\n{&quot;breed_1&quot;: 12, &quot;breed_2&quot;: 20}\r\n{&quot;breed_1&quot;: 6, &quot;breed_2&quot;: 8}\r\n```\r\n\r\nThe `dog` and `cat` key vanish. \r\n",
        "link": "https://stackoverflow.com/questions/66070280/convert-json-dictionary-to-json-lines-using-jq",
        "title": "Convert JSON dictionary to JSON lines using jQ"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1612586546,
                "creation_date": 1612586546,
                "answer_id": 66073639,
                "question_id": 66071313,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "One iteration is what’s needed here:\r\n```\r\n.[] | (.name, .author.email)\r\n```",
                "title": "jq: Alternate between arguments seperated by the comma operator"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -1,
        "last_activity_date": 1612586546,
        "creation_date": 1612563206,
        "question_id": 66071313,
        "body_markdown": "I have a `json` that&#39;s structured like:\r\n\r\n```json\r\n[\r\n  {\r\n    &quot;id&quot;: &quot;1&quot;,\r\n    &quot;name&quot;: &quot;Hello&quot;,\r\n    &quot;active&quot;: true,  \r\n    &quot;author&quot;: {\r\n      &quot;firstName&quot;: &quot;Jane&quot;,\r\n      &quot;lastName&quot;: &quot;Smith&quot;,    \r\n      &quot;email&quot;: &quot;hello@example.com&quot;,\r\n    }\r\n  },\r\n  {\r\n    &quot;id&quot;: &quot;2&quot;,\r\n    &quot;name&quot;: &quot;World&quot;,\r\n    &quot;active&quot;: true,  \r\n    &quot;author&quot;: {\r\n      &quot;firstName&quot;: &quot;John&quot;,\r\n      &quot;lastName&quot;: &quot;Doe&quot;,    \r\n      &quot;email&quot;: &quot;world@example.com&quot;,\r\n    }\r\n  }\r\n]\r\n```\r\n\r\nWith `jq &#39;.[].name, .[].author.email&#39; foo.json`\r\n\r\nI get the list of all names, and the list of all emails. However, they do not display in an alternating format, with one name following each email\r\n\r\nI thought maybe it should output the parent array, and then pipe that into a new object like this:\r\n\r\n`jq &#39;.[] | {name: .[].name, email: .[].author.email}&#39; foo.json`\r\n\r\nHowever, that seems like it is a syntactically wrong approach.\r\n\r\nWhat&#39;s the correct notation/syntax for this?",
        "link": "https://stackoverflow.com/questions/66071313/jq-alternate-between-arguments-seperated-by-the-comma-operator",
        "title": "jq: Alternate between arguments seperated by the comma operator"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1612573247,
                "last_edit_date": 1612573247,
                "creation_date": 1612570680,
                "answer_id": 66072325,
                "question_id": 66071801,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Using [`to_entries`](https://stedolan.github.io/jq/manual/#to_entries,from_entries,with_entries) makes the problem much more difficult than it needs to be.\r\n\r\nThe problem can instead be solved in just one simple operation.\r\n\r\nSince you want to update the value of each key, it makes sense to use [`map_values`](https://stedolan.github.io/jq/manual/#map(x),map_values(x)), which is meant for this purpose:\r\n\r\n    jq &#39;map_values(.value)&#39; file.json\r\n\r\nOutput:\r\n\r\n    {\r\n      &quot;foo&quot;: &quot;hello&quot;,\r\n      &quot;bar&quot;: &quot;goodbye&quot;\r\n    }\r\n\r\nSee the documentation for `map_values` [here](https://stedolan.github.io/jq/manual/#map(x),map_values(x)).",
                "title": "jq reduce (or map?) to transform to object containing {&quot;key1&quot;:&quot;value1&quot;,&quot;key2&quot;:&quot;value2&quot; }"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1612588164,
        "creation_date": 1612566428,
        "last_edit_date": 1612588164,
        "question_id": 66071801,
        "body_markdown": "I have a json file in the following format:\r\n\r\n```\r\n{\r\n    &quot;foo&quot;: {\r\n        &quot;type&quot;: &quot;string&quot;,\r\n        &quot;value&quot;: &quot;hello&quot;\r\n    },\r\n    &quot;bar&quot;: {\r\n        &quot;type&quot;: &quot;string&quot;,\r\n        &quot;value&quot;: &quot;goodbye&quot;\r\n    }\r\n}\r\n```\r\n\r\nI want to transform it to:\r\n```\r\n{\r\n&quot;foo&quot;: &quot;hello&quot;,\r\n&quot;bar&quot;: &quot;goodbye&quot;\r\n}\r\n```\r\n\r\nBest I have got to:\r\n```\r\ncat file.json | jq &#39;to_entries[] | reduce . as $item ({}; reduce . as $value ({}; $item.key + &quot;:&quot; + $item.value.value))&#39;\r\n\r\n```\r\nwhich gives:\r\n```\r\n&quot;foo:hello&quot;\r\n&quot;bar:goodbye&quot;\r\n```\r\n\r\nclose, but still a long way to go.\r\n\r\nAll assistance appreciated. Thanks.",
        "link": "https://stackoverflow.com/questions/66071801/jq-reduce-or-map-to-transform-to-object-containing-key1value1-key2v",
        "title": "jq reduce (or map?) to transform to object containing {&quot;key1&quot;:&quot;value1&quot;,&quot;key2&quot;:&quot;value2&quot; }"
    },
    {
        "tags": [
            "jq",
            "macos-catalina"
        ],
        "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": 1612651351,
                "post_id": 66073927,
                "comment_id": 116834772,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 18464930,
                    "reputation": 207,
                    "user_id": 13451415,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/bc6f44d5e3a2e0b5f7e2488f3628b9fb?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "user13451415",
                    "link": "https://stackoverflow.com/users/13451415/user13451415"
                },
                "reply_to_user": {
                    "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": 1612695144,
                "post_id": 66073927,
                "comment_id": 116841909,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1612709120,
                "creation_date": 1612709120,
                "answer_id": 66089189,
                "question_id": 66073927,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Posted this issue in jq github repo and got [prompted][1] for issue with ~/.jq file. Indeed my ~/.jq file had the said syntax error. Fixing my ~/.jq file fixed the issue.\r\n\r\n\r\n  [1]: https://github.com/stedolan/jq/issues/2264#issuecomment-774684289",
                "title": "jq: error: syntax error, Unexpected $end (Unix shell quoting issues?) at &lt;builtin&gt;, line 29: )"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 4,
        "last_activity_date": 1612709120,
        "creation_date": 1612590002,
        "last_edit_date": 1612607145,
        "question_id": 66073927,
        "body_markdown": "Started seeing this issue with jq suddenly out of the blue for my system where its failing for simplest of use-cases:\r\n\r\n```\r\n$ echo &#39;{&quot;foo&quot;: 0}&#39; | jq .\r\njq: error: syntax error, unexpected $end (Unix shell quoting issues?) at &lt;builtin&gt;, line 29:\r\n  )\r\njq: 1 compile error\r\n```\r\n\r\nHere&#39;s a description of my environment:\r\n\r\nOS and Version: MacOS Catalina 10.15.7, 64-bit\r\njq versions: 1.6, 1.5, 1.4\r\n\r\nI tried installing jq with brew (`brew install jq`) as well as using binaries directly provided [here](https://stedolan.github.io/jq/download/) for OSX 64-bit and getting same error. It works strangely however with jq-1.3 but thats a pretty old version missing some important filters like `gsub`.",
        "link": "https://stackoverflow.com/questions/66073927/jq-error-syntax-error-unexpected-end-unix-shell-quoting-issues-at-builti",
        "title": "jq: error: syntax error, Unexpected $end (Unix shell quoting issues?) at &lt;builtin&gt;, line 29: )"
    },
    {
        "tags": [
            "json",
            "csv",
            "export-to-csv",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1616788127,
                "last_edit_date": 1616788127,
                "creation_date": 1612793709,
                "answer_id": 66103341,
                "question_id": 66100850,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "To achieve the desired result, you can simply invoke jq once using thie following jq program:\r\n\r\n```\r\n.grocery[]\r\n| [.type] + ( .items[] | [.name, .quantity])\r\n| join (&quot;,&quot;)\r\n```\r\n\r\nSee it in action at [jqplay.org][1]\r\n\r\n[![jqplay.org][2]][1]\r\n\r\n\r\n  [1]: https://jqplay.org/s/R1BBWHkKvO\r\n  [2]: https://i.sstatic.net/IioA3.png",
                "title": "Not able to get the desired output using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1616788127,
        "creation_date": 1612784094,
        "last_edit_date": 1616708374,
        "question_id": 66100850,
        "body_markdown": "I have a json file like below: shopping-items.json\r\n```\r\n{\r\n  &quot;grocery&quot; : [\r\n    {\r\n      &quot;type&quot;: &quot;fruits&quot;,\r\n      &quot;items&quot; : [\r\n        { &quot;name&quot;: &quot;mango&quot;, &quot;quantity&quot;: &quot;1kg&quot; },\r\n        { &quot;name&quot;: &quot;kiwi&quot;, &quot;quantity&quot;: &quot;2pc&quot; },\r\n        { &quot;name&quot;: &quot;apple&quot;, &quot;quantity&quot;: &quot;2kg&quot; },\r\n        { &quot;name&quot;: &quot;banana&quot;, &quot;quantity&quot;: &quot;6pc&quot; }\r\n      ]\r\n    },\r\n    {\r\n      &quot;type&quot;: &quot;vegetables&quot;,\r\n      &quot;items&quot; : [\r\n        { &quot;name&quot;: &quot;potato&quot;, &quot;quantity&quot;: &quot;3kg&quot; },\r\n        { &quot;name&quot;: &quot;onion&quot;, &quot;quantity&quot;: &quot;2kg&quot; },\r\n        { &quot;name&quot;: &quot;tomato&quot;, &quot;quantity&quot;: &quot;2kg&quot; }\r\n      ]\r\n    },\r\n    {\r\n      &quot;type&quot;: &quot;dryfruits&quot;,\r\n      &quot;items&quot; : [\r\n        { &quot;name&quot;: &quot;almonds&quot;, &quot;quantity&quot;: &quot;2kg&quot; },\r\n        { &quot;name&quot;: &quot;cachewnut&quot;, &quot;quantity&quot;: &quot;1kg&quot; },\r\n        { &quot;name&quot;: &quot;walnut&quot;, &quot;quantity&quot;: &quot;1.5kg&quot; }\r\n      ]\r\n    },\r\n    {\r\n      &quot;type&quot;: &quot;pulses&quot;,\r\n      &quot;items&quot; : [\r\n        { &quot;name&quot;: &quot;Blackgram&quot;, &quot;quantity&quot;: &quot;1kg&quot; },\r\n        { &quot;name&quot;: &quot;chickpeas&quot;, &quot;quantity&quot;: &quot;2kg&quot; },\r\n        { &quot;name&quot;: &quot;lentils&quot;, &quot;quantity&quot;: &quot;1.5kg&quot; }\r\n      ]\r\n    }\r\n  ]\r\n}\r\n```\r\nI have tried several jq queries on this set:-\r\n```\r\n$ cat shopping-items.json | jq -r &#39;.grocery[] | .items[] | [.name, .quantity]  | join (&quot;,&quot;)&#39;\r\nmango,1kg\r\nkiwi,2pc\r\napple,2kg\r\nbanana,6pc\r\npotato,3kg\r\nonion,2kg\r\ntomato,2kg\r\nalmonds,2kg\r\ncachewnut,1kg\r\nwalnut,1.5kg\r\nBlackgram,1kg\r\nchickpeas,2kg\r\nlentils,1.5kg\r\n```\r\n```\r\n$ cat shopping-items.json | jq -r &#39;.grocery[] | [.type, .items[].name, .items[].quantity] | join (&quot;,&quot;)&#39;\r\nfruits,mango,kiwi,apple,banana,1kg,2pc,2kg,6pc\r\nvegetables,potato,onion,tomato,3kg,2kg,2kg\r\ndryfruits,almonds,cachewnut,walnut,2kg,1kg,1.5kg\r\npulses,Blackgram,chickpeas,lentils,1kg,2kg,1.5kg\r\n```\r\n\r\nBut desired result is as below:-\r\n```\r\nfruits,mango,1kg\r\nfruits,kiwi,2pc\r\nfruits,apple,2kg\r\nfruits,banana,6pc\r\nvegetables,potato,3kg\r\nvegetables,onion,2kg\r\nvegetables,tomato,2kg\r\ndryfruits,almonds,2kg\r\ndryfruits,cachewnut,1kg\r\ndryfruits,walnut,1.5kg\r\npulses,Blackgram,1kg\r\npulses,chickpeas,2kg\r\npulses,lentils,1.5kg\r\n```\r\nThere is a way, but I feel it&#39;s not efficient. Looking for an efficient way for this result.\r\n``` shell\r\nfilename=shopping-items.json\r\ncount=`cat ${filename} | jq -c &#39;.grocery[] | keys&#39; | wc -l`\r\ncounter=0\r\nwhile [ $counter -lt $count ]\r\ndo\r\n  var_type=`cat ${filename} | jq -r .grocery[$counter].type`\r\n  jq --arg var_type $var_type --argjson c $counter --raw-output &#39;.grocery[$c].items[] | [$var_type, .name, .quantity] | join(&quot;,&quot;)&#39; ${filename}\r\n  counter=`expr $counter + 1`\r\ndone\r\n```",
        "link": "https://stackoverflow.com/questions/66100850/not-able-to-get-the-desired-output-using-jq",
        "title": "Not able to get the desired output using jq"
    },
    {
        "tags": [
            "json",
            "nested",
            "eval",
            "jq",
            "fromjson"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 6196394,
                    "reputation": 86601,
                    "user_id": 5291015,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/4tAvO.jpg?s=256",
                    "display_name": "Inian",
                    "link": "https://stackoverflow.com/users/5291015/inian"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1612788145,
                "post_id": 66101660,
                "comment_id": 116867414,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 6902314,
                    "reputation": 321,
                    "user_id": 5301531,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/363b2cd7bd986242f382dc42a6061987?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "M. Christopher",
                    "link": "https://stackoverflow.com/users/5301531/m-christopher"
                },
                "reply_to_user": {
                    "account_id": 6196394,
                    "reputation": 86601,
                    "user_id": 5291015,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/4tAvO.jpg?s=256",
                    "display_name": "Inian",
                    "link": "https://stackoverflow.com/users/5291015/inian"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1612788423,
                "post_id": 66101660,
                "comment_id": 116867549,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 6196394,
                    "reputation": 86601,
                    "user_id": 5291015,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/4tAvO.jpg?s=256",
                    "display_name": "Inian",
                    "link": "https://stackoverflow.com/users/5291015/inian"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1612788528,
                "post_id": 66101660,
                "comment_id": 116867610,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 9629731,
                    "reputation": 51350,
                    "user_id": 10248678,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d8f818402f22d485b135a3b685ef908e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "oguz ismail",
                    "link": "https://stackoverflow.com/users/10248678/oguz-ismail"
                },
                "reply_to_user": {
                    "account_id": 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": 1612788957,
                "post_id": 66101660,
                "comment_id": 116867832,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 6196394,
                    "reputation": 86601,
                    "user_id": 5291015,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/4tAvO.jpg?s=256",
                    "display_name": "Inian",
                    "link": "https://stackoverflow.com/users/5291015/inian"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1612789116,
                "post_id": 66101660,
                "comment_id": 116867908,
                "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": 1612789304,
                "post_id": 66101660,
                "comment_id": 116868004,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 6902314,
                    "reputation": 321,
                    "user_id": 5301531,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/363b2cd7bd986242f382dc42a6061987?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "M. Christopher",
                    "link": "https://stackoverflow.com/users/5301531/m-christopher"
                },
                "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": 1612789905,
                "post_id": 66101660,
                "comment_id": 116868256,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1612794604,
                "creation_date": 1612794604,
                "answer_id": 66103559,
                "question_id": 66101660,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "For a generic solution, you might wish to consider `walk/1`, and for efficiency, avoid calling `fromjson` redundantly:\r\n\r\n    walk(if type == &quot;string&quot;\r\n         then . as $x | try fromjson catch $x\r\n         else . end)",
                "title": "Use jq to interpret nested JSON in JSON"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1612796176,
                "creation_date": 1612796176,
                "answer_id": 66103972,
                "question_id": 66101660,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If you want to go off the “deep end” and try evaluating fromjson recursively:\r\n```\r\ndef deep:\r\n  walk(if type == &quot;string&quot;          \r\n           then . as $x \r\n           | try (fromjson | deep)\r\n             catch $x     \r\n           else . end);\r\ndeep\r\n```",
                "title": "Use jq to interpret nested JSON in JSON"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 2,
        "last_activity_date": 1613398214,
        "creation_date": 1612787351,
        "last_edit_date": 1612796397,
        "question_id": 66101660,
        "body_markdown": "I&#39;m looking to use jq to automatically resolve any field which contains json as json, example:\r\n\r\n**Input**\r\n\r\n    {\r\n      &quot;guaranteedPrizes&quot;: &quot;[]&quot;,\r\n    }\r\n\r\n**Output**\r\n\r\n    {\r\n      &quot;guaranteedPrizes&quot;: [],\r\n    }\r\n",
        "link": "https://stackoverflow.com/questions/66101660/use-jq-to-interpret-nested-json-in-json",
        "title": "Use jq to interpret nested JSON in JSON"
    },
    {
        "tags": [
            "json",
            "jq",
            "nested-loops",
            "lookup"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1612808265,
                "last_edit_date": 1612808265,
                "creation_date": 1612800844,
                "answer_id": 66105268,
                "question_id": 66104360,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can use `gsub` with a named capture group for expanding all the macros in a single run without hardcoding their names. And, `with_entries` doesn&#39;t help at all in this case; use `map_values` instead.\r\n```\r\nmap(. as $lookup | map_values(gsub(&quot;\\\\{(?&lt;found_key&gt;.*?)\\\\}&quot;; $lookup[.found_key])))\r\n```\r\n&lt;sup&gt;[Online demo](https://jqplay.org/s/sVpCZo5MfZ)&lt;/sup&gt;",
                "title": "Expand references to sibling values in a JSON using JQ"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1615687314,
        "creation_date": 1612797540,
        "last_edit_date": 1615687314,
        "question_id": 66104360,
        "body_markdown": "I have a JSON document holding configurations with macros.  I need to expand macros that reference other elements.  For simplicity, consider this input document.\r\n```\r\n[\r\n  {\r\n    &quot;first&quot;: &quot;Tim&quot;,\r\n    &quot;Full&quot;: &quot;{first} {last}&quot;,\r\n    &quot;last&quot;: &quot;Smith&quot;\r\n  },\r\n  {\r\n    &quot;first&quot;: &quot;Jane&quot;,\r\n    &quot;Full&quot;: &quot;{first} {last}&quot;,\r\n    &quot;last&quot;: &quot;Doe&quot;\r\n  }\r\n]\r\n```\r\nPerformance is not paramount here so I don&#39;t mind blindly checking for every element occurring in every other element.\r\n\r\nI worked out the following logic as a proof of concept.  But can&#39;t figure out how to add a nested loop on `$lookup` to update the other `with_entries` value.\r\n```\r\njq  &#39;\r\n  .[]\r\n| . as $lookup\r\n| with_entries(\r\n    .value=(\r\n      .value\r\n      | sub(&quot;{first}&quot;; $lookup.first)\r\n    )\r\n  )\r\n&#39;\r\n```\r\nJQ processes streams of values/documents and it feels like I now need to work with two streams.  Which I hoped to accomplish by using `$lookup` for the back reference. Now I am stuck.\r\n\r\n**SOLUTION**\r\n*oguz ismail provided a great solution for the original question (Please give them a +1) that uses map_values().  It is very clear and I wanted to include it here for reference.  You will note that it uses a named group `(?&lt;found_key&gt;.*?)` in the regular expression (see oniguruma&#39;s [named group][1])*\r\n```\r\nmap(. as $lookup | map_values(gsub(&quot;\\\\{(?&lt;found_key&gt;.*?)\\\\}&quot;; $lookup[.found_key])))\r\n```\r\n\r\n*I asked how to process when there are non-string elements in the structure.  Here is an example that includes an array of colors:*\r\n```\r\n[\r\n  {\r\n    &quot;first&quot;: &quot;Tim&quot;,\r\n    &quot;Full&quot;: &quot;{first} {last}&quot;,\r\n    &quot;last&quot;: &quot;Smith&quot;,\r\n    &quot;colors&quot;: [&quot;red&quot;, &quot;blue&quot;]\r\n  }\r\n]\r\n```\r\n\r\n*oguz ismail provided a solution for this structure as well that only attempts to modify elements that are strings:*\r\n\r\n```\r\nmap(\r\n  . as $lookup\r\n  | (.[] | strings)\r\n  |= gsub(&quot;\\\\{(?&lt;found_key&gt;.*?)\\\\}&quot;; $lookup[.found_key])\r\n)\r\n```\r\n\r\n\r\n  [1]: https://github.com/kkos/oniguruma/blob/master/doc/RE",
        "link": "https://stackoverflow.com/questions/66104360/expand-references-to-sibling-values-in-a-json-using-jq",
        "title": "Expand references to sibling values in a JSON using JQ"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 1852014,
                    "reputation": 24882,
                    "user_id": 1678362,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/8ba023d18099cde022b9e4394d5714c0?s=256&d=identicon&r=PG",
                    "display_name": "Aaron",
                    "link": "https://stackoverflow.com/users/1678362/aaron"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1612864590,
                "post_id": 66116539,
                "comment_id": 116893261,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1852014,
                    "reputation": 24882,
                    "user_id": 1678362,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/8ba023d18099cde022b9e4394d5714c0?s=256&d=identicon&r=PG",
                    "display_name": "Aaron",
                    "link": "https://stackoverflow.com/users/1678362/aaron"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1612866616,
                "post_id": 66116539,
                "comment_id": 116894150,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1612872882,
                "creation_date": 1612872882,
                "answer_id": 66118794,
                "question_id": 66116539,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "This might be a problem with call_api itself - since it&#39;s not defined what that is. Some programs (e.g. curl, more) behave slightly differently depending on where their output goes. Typically the big distinction is between tty and not-a-tty but you may find differences between pipe and regular file. There should be no inherent difference in jq&#39;s behavior.\r\n\r\n```\r\nrichard@sophia:~/cc/dpbuilder (bug/T-10571) $ jq -r &#39;.[]&#39; &lt; fred.json \r\nHello\r\nWorld\r\nrichard@sophia:~/cc/dpbuilder (bug/T-10571) $ jq -r &#39;.[]&#39; fred.json \r\nHello\r\nWorld\r\nrichard@sophia:~/cc/dpbuilder (bug/T-10571) $ cat fred.json | jq -r &#39;.[]&#39;\r\nHello\r\nWorld\r\nrichard@sophia:~/cc/dpbuilder (bug/T-10571) $ \r\n```\r\n\r\nAlso check how large the output is - you may be running into limits in terms of piped output. In particular, is it greater than 64k?",
                "title": "jq with pipe error. Without pipe not error"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1612872882,
        "creation_date": 1612864216,
        "last_edit_date": 1612866844,
        "question_id": 66116539,
        "body_markdown": "I&#39;m trying to call an api and in the same line parse its output with `jq`. \r\nIf I do all in one line it gives me an error:\r\n\r\n    bash-4.2$ call_api -s &quot;job=work_1*&amp;status=Executing&quot;  | $PATH_API/jq &#39;.statuses[].name // empty&#39; --raw-output\r\n    parse error: Unfinished string at EOF at line 2301, column 61\r\n\r\nBut if I redirect the api&#39;s output to a file and then apply `jq` to that file it doesn&#39;t raise any error:\r\n\r\n    bash-4.2$ call_api -s &quot;job=work_1*&amp;status=Executing&quot;  &gt; /tmp/kk\r\n    bash-4.2$  $PATH_API/jq &#39;.statuses[].name // empty&#39; --raw-output /tmp/kk\r\n    work_1_002103ALLGDC\r\n    work_1_000049EVEFIN\r\n    work_1_002038ALF003\r\n\r\nDo you know why? Is it possible to fix it to can achieve it in one line?",
        "link": "https://stackoverflow.com/questions/66116539/jq-with-pipe-error-without-pipe-not-error",
        "title": "jq with pipe error. Without pipe not error"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1613140539,
                "last_edit_date": 1613140539,
                "creation_date": 1612876634,
                "answer_id": 66119780,
                "question_id": 66119475,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "One way to pass a value to [tag:jq] on the command-line is to use the `--arg` option. Here, I created the variable `$name` containing `my_comp_2`:\r\n\r\n\r\n    $ jq -r --arg name my_comp_2 &#39;\r\n      .[]\r\n      | select(.name == $name)\r\n      | .desiredVersions[].name\r\n    &#39; file.json\r\n    1.0\r\n\r\n`-r` outputs the &quot;raw&quot; value, without the enclosing double quotes.",
                "title": "Newbie question about &#39;jq&#39; tool for json - how do I create a query for this?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1613140539,
        "creation_date": 1612875492,
        "last_edit_date": 1612875722,
        "question_id": 66119475,
        "body_markdown": "Please help a JSON / jq newbie. I have a JSON-file that looks something like this:\r\n\r\n    [\r\n       {\r\n    \t\t&quot;name&quot;: &quot;my_comp_1&quot;,\r\n    \t\t&quot;desiredVersions&quot;: []\r\n    \t},\r\n    \t{\r\n    \t\t&quot;name&quot;: &quot;my_comp_2&quot;,\r\n    \t\t&quot;desiredVersions&quot;: [{\r\n    \t\t\t&quot;name&quot;: &quot;1.0&quot;,\r\n    \t\t\t&quot;component&quot;: {\r\n    \t\t\t\t&quot;name&quot;: &quot;my_comp_2&quot;\r\n    \t\t\t}\r\n    \t\t}]\r\n    \t},\r\n    \t{\r\n    \t\t&quot;name&quot;: &quot;my_comp_3&quot;,\r\n    \t\t&quot;desiredVersions&quot;: [{\r\n    \t\t\t&quot;name&quot;: &quot;1.1&quot;,\r\n    \t\t\t&quot;component&quot;: {\r\n    \t\t\t\t&quot;name&quot;: &quot;my_comp_3&quot;\r\n    \t\t\t}\r\n    \t\t}]\r\n    \t}\r\n    ]\r\n\r\nI need to create queries like: \r\nWhat is the version for &#39;my_comp_2&#39;\r\nwhich in the example should give me &#39;1.0&#39;    \r\nI have figured out how to take variables from commandline, but not the jq-query itself. Please help.",
        "link": "https://stackoverflow.com/questions/66119475/newbie-question-about-jq-tool-for-json-how-do-i-create-a-query-for-this",
        "title": "Newbie question about &#39;jq&#39; tool for json - how do I create a query for this?"
    },
    {
        "tags": [
            "json",
            "linux",
            "csv",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 10648681,
                    "reputation": 13005,
                    "user_id": 7840440,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/8YBUl.png?s=256",
                    "display_name": "Raman Sailopal",
                    "link": "https://stackoverflow.com/users/7840440/raman-sailopal"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1612879027,
                "post_id": 66120306,
                "comment_id": 116899450,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 18814198,
                    "reputation": 13,
                    "user_id": 13721734,
                    "user_type": "registered",
                    "profile_image": "https://lh5.googleusercontent.com/-L8ZsbNkea6k/AAAAAAAAAAI/AAAAAAAAAAA/AMZuucmkrvQeLztl_R_Mt2-yNAES3waC3Q/s256-rj/photo.jpg",
                    "display_name": "Gianmarco Plutino",
                    "link": "https://stackoverflow.com/users/13721734/gianmarco-plutino"
                },
                "reply_to_user": {
                    "account_id": 10648681,
                    "reputation": 13005,
                    "user_id": 7840440,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/8YBUl.png?s=256",
                    "display_name": "Raman Sailopal",
                    "link": "https://stackoverflow.com/users/7840440/raman-sailopal"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1612879414,
                "post_id": 66120306,
                "comment_id": 116899611,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1612895687,
                "creation_date": 1612895687,
                "answer_id": 66125019,
                "question_id": 66120306,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The following assumes the input consists of a stream of valid JSON objects along the lines shown in the question.\r\n\r\nIf the relevant values of .id are known beforehand, then generating the header row is trivial, and a  solution implemented with flexibility in mind is as follows:\r\n```\r\ndef oneline:\r\n  .content.resources\r\n  | INDEX(.[]; .id) | map_values(.value);\r\n\r\ndef emit($keys):\r\n  [.[ $keys[] ]];\r\n  \r\n[0,1,5,6] as $keys\r\n| $keys,\r\n  (inputs | oneline | emit($keys))\r\n| join(&quot;,&quot;)\r\n```\r\n\r\nSince this relies on `inputs` to read the input, jq should be invoked with the -r and -n options (e.g. `jq -rn -f program.jq`)\r\n\r\n### Using the first object to determine the relevant .id values\r\n\r\nIf the relevant values of .id are determined by the first JSON object in the stream, the above defs can be reused with the following:\r\n```\r\n\r\n(input | oneline) as $first\r\n| ($first | keys) as $keys\r\n| $keys,\r\n  ($first | emit($keys)),\r\n  (inputs | oneline | emit($keys))\r\n| join(&quot;,&quot;)\r\n```\r\n\r\nThis solution would be used with jq&#39;s -r and -n options.\r\n",
                "title": "Convert JSON file to CSV file using jq"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1612895687,
        "creation_date": 1612878600,
        "last_edit_date": 1612878922,
        "question_id": 66120306,
        "body_markdown": "i have JSON file called myresponse.json.\r\n\r\n\r\n    &quot;status&quot;:&quot;CONTENT&quot;,\r\n    &quot;valid&quot;:true,\r\n    &quot;success&quot;:true,\r\n    &quot;failure&quot;:false,\r\n    &quot;content&quot;:{\r\n      &quot;id&quot;:0,&quot;resources&quot;:[{\r\n    \r\n      &quot;id&quot;:0,&quot;value&quot;:52.51742935180664\r\n      },\r\n     {\r\n      &quot;id&quot;:1,&quot;value&quot;:13.392845153808594\r\n      },\r\n     {\r\n      &quot;id&quot;:5,&quot;value&quot;:&quot;2021-02-09T13:15:15Z&quot;\r\n      },\r\n     {\r\n      &quot;id&quot;:6,&quot;value&quot;:20.754192352294922\r\n      }]}}}\r\n \r\n\r\n    &quot;status&quot;:&quot;CONTENT&quot;,\r\n        &quot;valid&quot;:true,\r\n        &quot;success&quot;:true,\r\n        &quot;failure&quot;:false,\r\n        &quot;content&quot;:{\r\n          &quot;id&quot;:0,&quot;resources&quot;:[{\r\n        \r\n          &quot;id&quot;:0,&quot;value&quot;:52.51742935180664\r\n          },\r\n         {\r\n          &quot;id&quot;:1,&quot;value&quot;:13.392845153808594\r\n          },\r\n         {\r\n          &quot;id&quot;:5,&quot;value&quot;:&quot;2021-02-09T13:15:15Z&quot;\r\n          },\r\n         {\r\n          &quot;id&quot;:6,&quot;value&quot;:20.754192352294922\r\n          }]}}}\r\n\r\nobtained with a curl.\r\n\r\nhow can i use jq to convert json to csv file where &quot;0,1,5,6&quot; must be the columns and the values ​​of &quot;0,1,5,6&quot; must respectively occupy each row of the csv file, like this:\r\n\r\n  \r\n\r\n      0,1,5,6\r\n    \r\n      52.51742935180664, 13.392845153808594, &quot;2021-02-09T13:15:15Z&quot;, 20.754192352294922\r\n      52.51742935180664, 13.392845153808594, &quot;2021-02-09T13:15:15Z&quot;, 20.754192352294922\r\n\r\nThanks for your help!\r\n",
        "link": "https://stackoverflow.com/questions/66120306/convert-json-file-to-csv-file-using-jq",
        "title": "Convert JSON file to CSV file using jq"
    },
    {
        "tags": [
            "json",
            "powershell",
            "file",
            "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": 1612880685,
                "post_id": 66120729,
                "comment_id": 116900197,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 13157914,
                    "reputation": 4893,
                    "user_id": 9504458,
                    "user_type": "registered",
                    "profile_image": "https://lh6.googleusercontent.com/-WwLYxZDTcu8/AAAAAAAAAAI/AAAAAAAAZF4/6lngnHRUX7c/s256-rj/photo.jpg",
                    "display_name": "Erik Mart&#237;n Jord&#225;n",
                    "link": "https://stackoverflow.com/users/9504458/erik-mart%c3%adn-jord%c3%a1n"
                },
                "reply_to_user": {
                    "account_id": 6196394,
                    "reputation": 86601,
                    "user_id": 5291015,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/4tAvO.jpg?s=256",
                    "display_name": "Inian",
                    "link": "https://stackoverflow.com/users/5291015/inian"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1612883864,
                "post_id": 66120729,
                "comment_id": 116901641,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 6196394,
                    "reputation": 86601,
                    "user_id": 5291015,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/4tAvO.jpg?s=256",
                    "display_name": "Inian",
                    "link": "https://stackoverflow.com/users/5291015/inian"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1612883930,
                "post_id": 66120729,
                "comment_id": 116901674,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 13157914,
                    "reputation": 4893,
                    "user_id": 9504458,
                    "user_type": "registered",
                    "profile_image": "https://lh6.googleusercontent.com/-WwLYxZDTcu8/AAAAAAAAAAI/AAAAAAAAZF4/6lngnHRUX7c/s256-rj/photo.jpg",
                    "display_name": "Erik Mart&#237;n Jord&#225;n",
                    "link": "https://stackoverflow.com/users/9504458/erik-mart%c3%adn-jord%c3%a1n"
                },
                "reply_to_user": {
                    "account_id": 6196394,
                    "reputation": 86601,
                    "user_id": 5291015,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/4tAvO.jpg?s=256",
                    "display_name": "Inian",
                    "link": "https://stackoverflow.com/users/5291015/inian"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1612884862,
                "post_id": 66120729,
                "comment_id": 116902083,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1612906521,
                "last_edit_date": 1612906521,
                "creation_date": 1612893585,
                "answer_id": 66124468,
                "question_id": 66120729,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "jq can only write to STDIN and STDOUT, so the simplest approach would be to process one file at a time, e.g. putting your jq program inside a shell loop.  [tag:sponge] is often used when employing this approach.\r\n\r\nHowever, there is an alternative that has the advantage of efficiency.  It requires only one invocation of jq, the output of which would include the filename information (obtained from `input_filename`).  This output would then be the input of an auxiliary process, e.g. `awk`.",
                "title": "Replace value of object property in multiple JSON files"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1612906521,
        "creation_date": 1612880068,
        "last_edit_date": 1612906405,
        "question_id": 66120729,
        "body_markdown": "I&#39;m working with multiple JSON files that are located in the same folder.\r\n\r\nFiles contain objects with the same properties and they are such as:\r\n\r\n```json\r\n{  \r\n    &quot;identifier&quot;: &quot;cameraA&quot;,\r\n    &quot;alias&quot;: &quot;a&quot;,\r\n    &quot;rtsp&quot;: &quot;192.168.1.1&quot;\r\n}\r\n```\r\n\r\nI want to replace a property for all the objects in the JSON files at the same time for a certain condition.\r\n\r\nFor example, let&#39;s say that I want to replace all the rtsp values of the objects with identifier equal to &quot;cameraA&quot;.\r\n\r\nI&#39;ve been trying with something like: \r\n\r\n```terminal\r\n jq &#39;if .identifier == \\&quot;cameraA&quot; then .rtsp=\\&quot;cameraX&quot; else . end&#39; -c *.json\r\n```\r\n\r\nBut it isn&#39;t working.\r\n\r\nIs there a simple way to replace the property of an object among multiple JSON files?\r\n\r\n",
        "link": "https://stackoverflow.com/questions/66120729/replace-value-of-object-property-in-multiple-json-files",
        "title": "Replace value of object property in multiple JSON files"
    },
    {
        "tags": [
            "arrays",
            "json",
            "jq",
            "transformation"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1612895856,
                "creation_date": 1612895856,
                "answer_id": 66125052,
                "question_id": 66124805,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You could use `group_by` and do the transformation after that, i.e. form the key with `.foo` and add all the `.bar`&#39;s\r\n\r\n```none\r\ngroup_by(.foo)[] | { (.[0].foo): [.[].bar] }\r\n```\r\n\r\n&lt;sup&gt;[jqplay - demo][1]&lt;/sup&gt;\r\n\r\n\r\n  [1]: https://jqplay.org/s/N1cAbWMf0B",
                "title": "How to transform list of objects into object of lists using jq?"
            },
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1612905433,
                "last_edit_date": 1612905433,
                "creation_date": 1612895961,
                "answer_id": 66125064,
                "question_id": 66124805,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "A simple and efficient solution would avoid `group_by`, the implementation of which currently entails a sorting operation:\r\n\r\n    reduce .[] as $x ({}; .[$x.foo] += [$x.bar])",
                "title": "How to transform list of objects into object of lists using jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 2,
        "last_activity_date": 1612905578,
        "creation_date": 1612894801,
        "last_edit_date": 1612905578,
        "question_id": 66124805,
        "body_markdown": "Let&#39;s say I have some JSON that looks like:\r\n\r\n```\r\n[\r\n    {&quot;foo&quot;: &quot;apple&quot;, &quot;bar&quot;: 42},\r\n    {&quot;foo&quot;: &quot;pear&quot;, &quot;bar&quot;: 13},\r\n    {&quot;foo&quot;: &quot;apple&quot;, &quot;bar&quot;: 666}\r\n]\r\n```\r\nHow can I transform it into something like:\r\n\r\n```\r\n{\r\n   &quot;apple&quot;: [42, 666],\r\n   &quot;pear&quot;: [13],\r\n}\r\n```\r\ngrouping the `bar`s by the `foo`s?\r\n\r\nSo far, I&#39;ve tried using `jq`&#39;s `group_by(...)` function which gave me:\r\n\r\n```\r\n[\r\n  [{&quot;foo&quot;: &quot;apple&quot;, &quot;bar&quot;: 42}, {&quot;foo&quot;: &quot;apple&quot;, &quot;bar&quot;: 666}],\r\n  [{&quot;foo&quot;: &quot;pear&quot;, &quot;bar&quot;: 13}]\r\n]\r\n```\r\nwhich is a start but not exactly what I&#39;m looking for.\r\n",
        "link": "https://stackoverflow.com/questions/66124805/how-to-transform-list-of-objects-into-object-of-lists-using-jq",
        "title": "How to transform list of objects into object of lists using jq?"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1628308793,
                "creation_date": 1628308793,
                "answer_id": 68689301,
                "question_id": 66415016,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "To iterate over a hash array , you can use `to_entries` and that will transform to a array .\r\n\r\nAfter you can use `select` to filter rows you want to keep .\r\n\r\n     jq -r &#39;to_entries[]| select(  ( .value | type ) == &quot;string&quot; ) | &quot;\\(.key), \\(.value)&quot; &#39; \r\n\r\n\r\n\r\n\r\n",
                "title": "Using jq to get json values"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1649559493,
                "creation_date": 1649559493,
                "answer_id": 71813442,
                "question_id": 66415016,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can use `to_entries`\r\n\r\n```\r\nto_entries[] | select(.key==&quot;food_group&quot; or .key==&quot;glycemic_index&quot;) | &quot;\\(.key), \\(.value)&quot;\r\n```\r\n\r\nDemo\r\n\r\nhttps://jqplay.org/s/Aqvos4w7bo",
                "title": "Using jq to get json values"
            }
        ],
        "is_answered": false,
        "answer_count": 2,
        "score": -1,
        "last_activity_date": 1649559493,
        "creation_date": 1612902814,
        "last_edit_date": 1614556351,
        "question_id": 66415016,
        "body_markdown": "Input json:\r\n\r\n```json\r\n{\r\n&quot;food_group&quot;: &quot;fruit&quot;,\r\n&quot;glycemic_index&quot;: &quot;low&quot;,\r\n\t&quot;fruits&quot;: {\r\n\t\t&quot;fruit_name&quot;: &quot;apple&quot;,\r\n\t\t&quot;size&quot;: &quot;large&quot;,\r\n\t\t&quot;color&quot;: &quot;red&quot;\r\n\t}\r\n}\r\n```\r\n\r\nBelow two jq commands work:\r\n\r\n```\r\n# jq -r &#39;keys_unsorted[] as $key | &quot;\\($key), \\(.[$key])&quot;&#39; food.json\r\nfood_group, fruit\r\nglycemic_index, low\r\nfruits, {&quot;fruit_name&quot;:&quot;apple&quot;,&quot;size&quot;:&quot;large&quot;,&quot;color&quot;:&quot;red&quot;}\r\n\r\n# jq -r &#39;keys_unsorted[0:2] as $key | &quot;\\($key)&quot;&#39; food.json\r\n[&quot;food_group&quot;,&quot;glycemic_index&quot;]\r\n``` \r\n\r\n\r\nHow to get values for the first two keys using jq in the same manner? I tried below \r\n\r\n```\r\n# jq -r &#39;keys_unsorted[0:2] as $key | &quot;\\($key), \\(.[$key])&quot;&#39; food.json\r\njq: error (at food.json:9): Cannot index object with array\r\n```\r\n\r\nExpected output:\r\n\r\n```\r\nfood_group, fruit\r\nglycemic_index, low\r\n```",
        "link": "https://stackoverflow.com/questions/66415016/using-jq-to-get-json-values",
        "title": "Using jq to get json values"
    },
    {
        "tags": [
            "json",
            "bash",
            "csv",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1612960657,
                "last_edit_date": 1612960657,
                "creation_date": 1612931820,
                "answer_id": 66130973,
                "question_id": 66130421,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Use `input_filename` to get the input filename. To skip the first line, use `inputs` without the -n option:\r\n```\r\njq -R &#39;\r\n  inputs\r\n  | [splits(&quot;, *&quot;)] as $row\r\n  | {(input_filename): { ($row[3]): $row[:3] }}\r\n&#39; serverset1.csv\r\n```\r\nThis produces a stream of the &quot;filename&quot; objects, which you can then readily assemble into an array by modifying the script (rather than invoking jq a second time).\r\n\r\nIf the input file has no header, then use the -n command-line option.\r\n\r\n### Caveats\r\n1.  jq can read very simple CSV files but is not well-suited to reading CSV files in general.  If your CSV file cannot easily be read properly by jq, you could use one of the many excellent alternatives for converting a CSV to a TSV file.\r\n\r\n2.  The above program does not attempt to convert numeric or boolean strings to JSON numbers or boolean values; any such conversions can however easily be accomplished using jq by making the appropriate tweaks to the above program.\r\n\r\n",
                "title": "Using jq, convert csv file to json, using csv filename as top level object name"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1613101085,
                "creation_date": 1613101085,
                "answer_id": 66166026,
                "question_id": 66130421,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Given the sample input, the following produces the requested output:\r\n```\r\n# The -n option is omitted in order to skip the header\r\njq -R &#39;\r\n  reduce inputs as $in ({};\r\n   (input_filename | sub(&quot;[.]csv$&quot;;&quot;&quot;)) as $file\r\n   | ($in | [splits(&quot;, *&quot;)]) as $row\r\n   | {location: $row[0], category: $row[1], address: $row[2]} as $obj\r\n   | .[$file][$row[3]] += [$obj])\r\n| [ . ]\r\n&#39; serverset1.csv\r\n```\r\n\r\nAdditional files can be specified on the command line.\r\n\r\nThe above could easily be modified if it is desired to generate the key names based on the header.",
                "title": "Using jq, convert csv file to json, using csv filename as top level object name"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 3,
        "last_activity_date": 1613101085,
        "creation_date": 1612926940,
        "question_id": 66130421,
        "body_markdown": "I need to convert a bunch of csv files to json, using bash and jq v1.6. (I can&#39;t use other scripting languages because of a restriction on what script types are allowed to run on the server). Neither JSON or jq are significant parts of my skillset.\r\n\r\nI need to use the csv filename as the json object name, read the csv to get the fieldnames from the header, and do a bit of re-mapping to move &quot;owner&quot; to a list (array?) name.\r\n\r\nSo, take this:\r\n```\r\nserverset1.csv\r\n\r\nlocation,category,ip,owner\r\nset1rack1,webserver,127.0.0.1,Customer1\r\nset1rack2,appserver,127.0.0.2,Customer1\r\nset1rack1,webserver,127.0.0.3,Customer2\r\nset1rack2,appserver,127.0.0.4,Customer2\r\n\r\n```\r\n\r\nto this\r\n```\r\n[\r\n   {\r\n      &quot;serverset1&quot;:[\r\n         {\r\n            &quot;Customer1&quot;:[\r\n               {\r\n                  &quot;location&quot;:&quot;set1rack1&quot;,\r\n                  &quot;category&quot;:&quot;webserver&quot;,\r\n                  &quot;address&quot;:&quot;127.0.0.1&quot;\r\n               },\r\n               {\r\n                  &quot;location&quot;:&quot;set1rack2&quot;,\r\n                  &quot;category&quot;:&quot;appserver&quot;,\r\n                  &quot;address&quot;:&quot;127.0.0.2&quot;\r\n               }\r\n            ],\r\n            &quot;Customer2&quot;:[\r\n               {\r\n                  &quot;location&quot;:&quot;set1rack1&quot;,\r\n                  &quot;category&quot;:&quot;webserver&quot;,\r\n                  &quot;address&quot;:&quot;127.0.0.3&quot;\r\n               },\r\n               {\r\n                  &quot;location&quot;:&quot;set1rack2&quot;,\r\n                  &quot;category&quot;:&quot;appserver&quot;,\r\n                  &quot;address&quot;:&quot;127.0.0.4&quot;\r\n               }\r\n            ]\r\n         }\r\n      ]\r\n   }\r\n]\r\n```\r\n\r\nI got as far as this:\r\n\r\n```\r\nfilename=&quot;serverset1.csv&quot;; \\\r\ncat &quot;$filename&quot; | jq --slurp --raw-input --raw-output \\\r\n&#39;\r\n  split(&quot;\\n&quot;) | .[1:] | map(split(&quot;,&quot;)) |\r\n    map(\r\n         {\r\n            &quot;location&quot;: .[0],\r\n            &quot;category&quot;: .[1],\r\n            &quot;address&quot;: .[2],\r\n            &quot;owner&quot;: .[3]\r\n         }\r\n    )\r\n&#39; \r\n```\r\n\r\nwhich yields this:\r\n\r\n```\r\n[\r\n  {\r\n    &quot;location&quot;: &quot;set1rack1&quot;,\r\n    &quot;category&quot;: &quot;webserver&quot;,\r\n    &quot;address&quot;: &quot;127.0.0.1&quot;,\r\n    &quot;owner&quot;: &quot;Customer1&quot;\r\n  },\r\n  {\r\n    &quot;location&quot;: &quot;set1rack2&quot;,\r\n    &quot;category&quot;: &quot;appserver&quot;,\r\n    &quot;address&quot;: &quot;127.0.0.2&quot;,\r\n    &quot;owner&quot;: &quot;Customer1&quot;\r\n  },\r\n  {\r\n    &quot;location&quot;: &quot;set1rack1&quot;,\r\n    &quot;category&quot;: &quot;webserver&quot;,\r\n    &quot;address&quot;: &quot;127.0.0.3&quot;,\r\n    &quot;owner&quot;: &quot;Customer2&quot;\r\n  },\r\n  {\r\n    &quot;location&quot;: &quot;set1rack2&quot;,\r\n    &quot;category&quot;: &quot;appserver&quot;,\r\n    &quot;address&quot;: &quot;127.0.0.4&quot;,\r\n    &quot;owner&quot;: &quot;Customer2&quot;\r\n  }\r\n]\r\n```\r\n\r\nbut then I hit a syntax wall. \r\n\r\nAny help is appreciated.\r\n\r\n~Jaimie\r\n",
        "link": "https://stackoverflow.com/questions/66130421/using-jq-convert-csv-file-to-json-using-csv-filename-as-top-level-object-name",
        "title": "Using jq, convert csv file to json, using csv filename as top level object name"
    },
    {
        "tags": [
            "arrays",
            "json",
            "bash",
            "csv",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1612957430,
                "last_edit_date": 1612957430,
                "creation_date": 1612955206,
                "answer_id": 66135692,
                "question_id": 66133046,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "&gt; they serve it in TSV format, which is not very convenient.\r\n\r\nActually, jq and TSV go extremely well together, and certainly using jq to process TSV files does not require using the -s (&quot;slurp&quot;) option, which indeed is usually (but by no means always) best avoided.\r\n\r\nIf your goal were simply to produce a stream of the “tconst” objects, you could process the TSV file on a line-by-line basis; if you wanted to assemble that stream into a single array, then you could use jq with the -c option to produce a stream with one JSON object per line, and then assemble them together using a tool such as `awk` (i.e., simply adding the opening and closing brackets and the delimiting commas).\r\n\r\nIn your case, though, it would probably be simplest to split the TSV file first (e.g. using the unix/linux/mac `split` command -- see below) and then process each file along the lines of your jq program. Since your chunks are quite small (1000 objects each), you could even use jq with the -s option, but it&#39;s just as easy to use `inputs` and the -n command-line option instead:\r\n\r\n    jq -n &#39;[inputs]&#39;\r\n \r\n\r\nOr you could combine these strategies: split into chunks, and process each chunk using jq with the -c option to produce a stream, and assembling each such stream into a JSON array.\r\n\r\n### split\r\nFor splitting a file into chunks, see for example: \r\n\r\nhttps://stackoverflow.com/questions/2016894/how-to-split-a-large-text-file-into-smaller-files-with-equal-number-of-lines/36765351#36765351\r\n\r\nhttps://stackoverflow.com/questions/25249516/split-text-file-into-smaller-multiple-text-file-using-command-line\r\n\r\nand many others.\r\n",
                "title": "Convert TSV file to multiple JSON arrays with jq"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1612959189,
                "creation_date": 1612959189,
                "answer_id": 66136661,
                "question_id": 66133046,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If `python` is your option, how about making use of it because the data structure of python has a high compatibility with `json`. Would you please try:\r\n```\r\n#!/usr/bin/python\r\n\r\nimport json\r\n\r\nary = []                                        # declare an empty array\r\nwith open(&#39;./title.crew.tsv&#39;) as f:\r\n    header = f.readline().rstrip().split(&#39;\\t&#39;)  # read the header line and split\r\n    for line in f:                              # iterate the following lines\r\n        body = line.rstrip().split(&#39;\\t&#39;)\r\n        d = {}                                  # empty dictionary\r\n        for i in range(0, len(header)):\r\n            if &#39;,&#39; in body[i]:                  # if the value contains &quot;,&quot;\r\n                b = body[i].split(&#39;,&#39;)          # then split the value on it\r\n            else:\r\n                b = body[i]\r\n            if b == &#39;\\N&#39;:                       # if the value is &quot;\\N&quot;\r\n                b = []                          # then replace with an empty array\r\n            d[header[i]] = b                    # generate an object\r\n        ary.append(d)                           # append the object to the array\r\nprint(json.dumps(ary, indent=2))\r\n```\r\nOutput:\r\n```\r\n[\r\n  {\r\n    &quot;directors&quot;: &quot;nm0349785&quot;, \r\n    &quot;tconst&quot;: &quot;tt0000238&quot;, \r\n    &quot;writers&quot;: []\r\n  }, \r\n  {\r\n    &quot;directors&quot;: &quot;nm0349785&quot;, \r\n    &quot;tconst&quot;: &quot;tt0000239&quot;, \r\n    &quot;writers&quot;: []\r\n  }, \r\n  {\r\n    &quot;directors&quot;: [], \r\n    &quot;tconst&quot;: &quot;tt0000240&quot;, \r\n    &quot;writers&quot;: []\r\n  }, \r\n&lt;..SNIPPED..&gt;\r\n```\r\nAs `python` is a general programing language, it has a high flexibility to process the input. It is also easy to split the result into multiple json files.",
                "title": "Convert TSV file to multiple JSON arrays with jq"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1612965039,
                "last_edit_date": 1612965039,
                "creation_date": 1612962302,
                "answer_id": 66137477,
                "question_id": 66133046,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Since 1000 is a small number in the present context, here&#39;s a solution that does not use `split`; instead, it boils down to a single two-step pipeline.\r\n\r\nThe first part of the pipeline consists of an invocation of jq with the -c option (for converting the TSV into a stream of JSON arrays, one per chunk); this is described below.  \r\n\r\nThe second part of the pipeline converts this stream of arrays into the desired set of files, one array per file; this part of the pipeline can easily be implemented using `awk` or a similar tool of your choice, and is not discussed further below.\r\n\r\n## program.jq\r\n```\r\n# Assemble the items in the (possibly empty) stream into a \r\n# (possibly empty) stream of arrays of length $n or less.\r\n# $n can be any integer greater than 0;\r\n# emit nothing if `stream` is empty.\r\ndef assemble(stream; $n):\r\n  # box the input to detect eos\r\n  foreach ((stream|[.]), null) as $item ({};\r\n     (.array|length) as $l\r\n     | if $item == null # eos\r\n       then .emit = (0 &lt; $l and $l &lt; $n)\r\n       else if $l == $n\r\n            then .array = $item\r\n            else .array += $item\r\n            end\r\n       | .emit = (.array|length == $n)\r\n       end;\r\n\r\n     if .emit then .array else empty end) ;\r\n\r\n\r\ndef stream:\r\n  inputs\r\n  | split(&quot;\\t&quot;)\r\n  | map_values(if . == &quot;\\\\N&quot; then &quot;&quot; else . end)\r\n  | map(split(&quot;,&quot;))\r\n  | { tconst: .[0][0],\r\n      directors: .[1],\r\n      writers:   .[2] };\r\n      \r\nassemble(stream; 1000)\r\n```\r\n\r\n### Invocation: \r\n\r\nTo skip the header, we omit the -n command-line option that would be used if there were no header:\r\n\r\n    jq -Rc -f program.jq input.tsv\r\n\r\n",
                "title": "Convert TSV file to multiple JSON arrays with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 1,
        "last_activity_date": 1612965039,
        "creation_date": 1612944409,
        "last_edit_date": 1612946654,
        "question_id": 66133046,
        "body_markdown": "I would like to use the [open data IMDb][1], but they serve it in TSV format, which is not very convenient.\r\n\r\nhttps://datasets.imdbws.com/title.crew.tsv.gz\r\n\r\n    tconst\tdirectors\twriters\r\n    tt0000238\tnm0349785\t\\N\r\n    tt0000239\tnm0349785\t\\N\r\n    tt0000240\t\\N\t\\N\r\n    tt0000241\tnm0349785\t\\N\r\n    tt0000242\tnm0617588\tnm0617588\r\n    tt0000243\tnm0349785\t\\N\r\n    tt0000244\tnm0349785\t\\N\r\n    tt0000245\t\\N\t\\N\r\n    tt0000246\tnm0617588\t\\N\r\n    tt0000247\tnm0002504,nm0005690,nm2156608\tnm0000636,nm0002504\r\n    tt0000248\tnm0808310\t\\N\r\n    tt0000249\tnm0808310\t\\N\r\n    tt0000250\tnm0005717\t\\N\r\n    tt0000251\tnm0177862\t\\N\r\n\r\nI want to convert TSV data to JSON. \r\n\r\n    [\r\n      {\r\n        &quot;tconst&quot;: &quot;tt0000247&quot;,\r\n        &quot;directors&quot;: [\r\n          &quot;nm0005690&quot;,\r\n          &quot;nm0002504&quot;,\r\n          &quot;nm2156608&quot;\r\n        ],\r\n        &quot;writers&quot;: [\r\n          &quot;nm0000636&quot;,\r\n          &quot;nm0002504&quot;\r\n        ]\r\n      },\r\n      {\r\n        &quot;tconst&quot;: &quot;tt0000248&quot;,\r\n        &quot;directors&quot;: [\r\n          &quot;nm0808310&quot;\r\n        ],\r\n        &quot;writers&quot;: [\r\n          &quot;\\\\N&quot;\r\n        ]\r\n      }\r\n    ]\r\n\r\nI can do this with the command:\r\n\r\n    jq -rRs &#39;split(&quot;\\n&quot;)[1:-1] |\r\n             map([split(&quot;\\t&quot;)[]|split(&quot;,&quot;)] | {\r\n                     &quot;tconst&quot;:.[0][0],\r\n                     &quot;directors&quot;:.[1],\r\n                     &quot;writers&quot;:.[2]\r\n                 }\r\n        )&#39; ./title.crew.tsv &gt; ./title.crew.json\r\n\r\nHowever, the file turns out to be very large, I get out of memory errors.\r\n\r\n**1.** How can split this TSV file into several JSON files, each with 1000 records? \r\n\r\n```\r\n./title.crew.page1.json\r\n./title.crew.page2.json\r\n./title.crew.page3.json\r\n```\r\n\r\n**2.** How can exclude empty fields? To have an empty array.\r\n\r\n`&quot;writers&quot;: [ &quot;\\\\N&quot; ]` -&gt; `&quot;writers&quot;: [ ]`\r\n\r\n**UPD (The second question was solved.):**\r\n\r\n```\r\njq -rRs &#39;split(&quot;\\n&quot;)[1:-1] |\r\n         map([split(&quot;\\t&quot;)[]|split(&quot;,&quot;)] | \r\n         .[2] |= if .[0] == &quot;\\\\N&quot; then [] else . end | {\r\n                 &quot;tconst&quot;:.[0][0],\r\n                 &quot;directors&quot;:.[1],\r\n                 &quot;writers&quot;:.[2]\r\n             }\r\n    )&#39; ./title.crew.tsv &gt; ./title.crew.json\r\n```\r\n\r\n```\r\n[\r\n  {\r\n    &quot;tconst&quot;: &quot;tt0000247&quot;,\r\n    &quot;directors&quot;: [\r\n      &quot;nm0005690&quot;,\r\n      &quot;nm0002504&quot;,\r\n      &quot;nm2156608&quot;\r\n    ],\r\n    &quot;writers&quot;: [\r\n      &quot;nm0000636&quot;,\r\n      &quot;nm0002504&quot;\r\n    ]\r\n  },\r\n  {\r\n    &quot;tconst&quot;: &quot;tt0000248&quot;,\r\n    &quot;directors&quot;: [\r\n      &quot;nm0808310&quot;\r\n    ],\r\n    &quot;writers&quot;: []\r\n  }\r\n]\r\n```\r\n\r\nThanks for answers.\r\n\r\n\r\n  [1]: https://www.imdb.com/interfaces/",
        "link": "https://stackoverflow.com/questions/66133046/convert-tsv-file-to-multiple-json-arrays-with-jq",
        "title": "Convert TSV file to multiple JSON arrays with jq"
    },
    {
        "tags": [
            "json",
            "duplicates",
            "field",
            "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": 1612955111,
                "post_id": 66135479,
                "comment_id": 116925766,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1612960477,
                "creation_date": 1612960477,
                "answer_id": 66136982,
                "question_id": 66135479,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "## With a variable\r\n```\r\n&lt; myfile.json jq  -c &#39;\r\n  (.data | select(.answers != null) | .answers | map(.answer) | del(.[] | nulls)) as $data\r\n  | { \r\n    domain: .name, \r\n    results: $data,\r\n    includes: $data | map(match(&quot;rearch:(.*?)?[ \\&quot;]&quot;; &quot;ig&quot;).captures[0].string) | unique\r\n    }\r\n&#39;\r\n```\r\n\r\n## Without a variable\r\n```\r\n&lt; myfile.json jq  -c &#39;\r\n  { domain: .name, \r\n    results: (.data | select(.answers != null) | .answers | map(.answer) | del(.[] | nulls)) }\r\n  | .includes = (.results | map(match(&quot;rearch:(.*?)?[ \\&quot;]&quot;; &quot;ig&quot;).captures[0].string) | unique)\r\n&#39;\r\n```\r\n",
                "title": "jq : how can i use the same search in other field without duplicate code?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -1,
        "last_activity_date": 1612960477,
        "creation_date": 1612954313,
        "question_id": 66135479,
        "body_markdown": "i have this jq command :\r\n```\r\ncat myfile | jq  -c &#39;{ \r\n    domain: .name, \r\n    results: .data | select(.answers != null) | .answers | map(.answer) | del(.[] | nulls) , \r\n    includes: .data | select(.answers != null) | .answers | map(.answer) | del(.[] | nulls) | map(match(&quot;rearch:(.*?)?[ \\&quot;]&quot;; &quot;ig&quot;).captures[0].string) | unique\r\n    }&#39;\r\n\r\n```\r\nto get this result :\r\n```\r\n{&quot;domain&quot;:&quot;blabla.com&quot;,&quot;results&quot;:[&quot;dorem rearch:blble.k iyh&quot;],&quot;includes&quot;:[&quot;blble.k&quot;]}\r\n{&quot;domain&quot;:&quot;bla.com&quot;,&quot;results&quot;:[&quot;koa rearch:ble.m&quot;,&quot;kl rearch:be.c lk&quot;],&quot;includes&quot;:[&quot;ble.m&quot;,&quot;be.c&quot;]}\r\n```\r\n\r\nmy **question** is : is there any way to ```DRY``` my command ?&lt;br&gt;\r\ni mean how can i get the *same result* without **duplicate** the part :\r\n\r\n&gt; .data | select(.answers != null) | .answers | map(.answer) | del(.[] |\r\n&gt; nulls)\r\n\r\nhow can i reuse the result of `results` feild ?&lt;br&gt;\r\ni have a really big file to work with so i don&#39;t want to waste time and resources.\r\n\r\n",
        "link": "https://stackoverflow.com/questions/66135479/jq-how-can-i-use-the-same-search-in-other-field-without-duplicate-code",
        "title": "jq : how can i use the same search in other field without duplicate code?"
    },
    {
        "tags": [
            "amazon-web-services",
            "jq",
            "aws-cli"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 58377,
                    "reputation": 271975,
                    "user_id": 174777,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/6PnNW.jpg?s=256",
                    "display_name": "John Rotenstein",
                    "link": "https://stackoverflow.com/users/174777/john-rotenstein"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1612992355,
                "post_id": 66140960,
                "comment_id": 116942552,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1613000587,
                "last_edit_date": 1613000587,
                "creation_date": 1613000128,
                "answer_id": 66146738,
                "question_id": 66140960,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Following is Python 3.8 based AWS Lambda, but you can change a bit to use as python script file to execute on any supported host machine.\r\n\r\n```\r\nimport boto3\r\nimport ast\r\n\r\n\r\nconfig_service = boto3.client(&#39;config&#39;)\r\n\r\n# Refactor to extract out duplicate code as a seperate def\r\ndef lambda_handler(event, context):\r\n    results = get_resource_details()\r\n    for resource in results:\r\n        if &quot;configuration&quot; in resource:\r\n            config=ast.literal_eval(resource)[&quot;configuration&quot;]\r\n            if &quot;ipPermissionsEgress&quot; in config:\r\n                ipPermissionsEgress=config[&quot;ipPermissionsEgress&quot;]\r\n                for data in ipPermissionsEgress:\r\n                    for userIdGroupPair in data[&quot;userIdGroupPairs&quot;]:\r\n                        if userIdGroupPair[&quot;userId&quot;] != &quot;123456789111&quot;:\r\n                            print(userIdGroupPair[&quot;groupId&quot;])\r\n            elif &quot;ipPermissions&quot; in config: \r\n                ipPermissions=config[&quot;ipPermissions&quot;]\r\n                for data in ipPermissions:\r\n                    for userIdGroupPair in data[&quot;userIdGroupPairs&quot;]:\r\n                        if userIdGroupPair[&quot;userId&quot;] != &quot;123456789111&quot;:\r\n                            print(userIdGroupPair[&quot;groupId&quot;])\r\n\r\n\r\ndef get_resource_details():\r\n    query = &quot;SELECT configuration.ipPermissions.userIdGroupPairs.groupId,configuration.ipPermissionsEgress.userIdGroupPairs.groupId,configuration.ipPermissionsEgress.userIdGroupPairs.userId,configuration.ipPermissions.userIdGroupPairs.userId WHERE resourceType = &#39;AWS::EC2::SecurityGroup&#39; AND configuration &lt;&gt; &#39;null&#39;&quot;\r\n    results = config_service.select_resource_config(\r\n        Expression=query,\r\n        Limit=100\r\n    ) # you might need to refacor to add support huge list of records using NextToken\r\n    return results[&quot;Results&quot;]\r\n\r\n```",
                "title": "AWS CLI Query to find Shared Security Groups"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1613000587,
        "creation_date": 1612974739,
        "last_edit_date": 1612992253,
        "question_id": 66140960,
        "body_markdown": "I am trying to write a query to return results of any referenced security group not owned by the current account.\r\n\r\nThis means I am trying to show security groups that are being used as part of a peering connection from another VPC.\r\n\r\nThere are a couple of restrictions.\r\n\r\nShow the entire security group details (security group id, description)\r\nOnly show security groups where IpPermissions.UserIdGroupPairs has a Value and where that value is not equal to the owner of the security group\r\n\r\nI am trying to write this using a single AWS CLI cmd vs a bash script or python script.\r\n\r\nAny thoughts?\r\n\r\nHeres what I have so far.\r\n\r\n```\r\naws ec2 describe-security-groups --query &quot;SecurityGroups[?IpPermissions.UserIdGroupPairs[*].UserId != &#39;`aws sts get-caller-identity --query &#39;Account&#39; --output text`&#39;]&quot;\r\n```\r\n",
        "link": "https://stackoverflow.com/questions/66140960/aws-cli-query-to-find-shared-security-groups",
        "title": "AWS CLI Query to find Shared Security Groups"
    },
    {
        "tags": [
            "json",
            "bash",
            "export-to-csv",
            "jq",
            "gsub"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 4663062,
                    "reputation": 89888,
                    "user_id": 3776858,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/Cagbk.jpg?s=256",
                    "display_name": "Cyrus",
                    "link": "https://stackoverflow.com/users/3776858/cyrus"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1612979896,
                "post_id": 66142393,
                "comment_id": 116937475,
                "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": 1612980137,
                "post_id": 66142393,
                "comment_id": 116937576,
                "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": 1612981988,
                "post_id": 66142393,
                "comment_id": 116938367,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 16592927,
                    "reputation": 161,
                    "user_id": 11990618,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/51ce16c66ff98ed00b2f2c2cf52d9c3d?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Welsige",
                    "link": "https://stackoverflow.com/users/11990618/welsige"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1612982181,
                "post_id": 66142393,
                "comment_id": 116938429,
                "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": 1612982355,
                "post_id": 66142393,
                "comment_id": 116938496,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 16592927,
                    "reputation": 161,
                    "user_id": 11990618,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/51ce16c66ff98ed00b2f2c2cf52d9c3d?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Welsige",
                    "link": "https://stackoverflow.com/users/11990618/welsige"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1612982598,
                "post_id": 66142393,
                "comment_id": 116938603,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 5,
                "is_accepted": true,
                "score": 5,
                "last_activity_date": 1612984881,
                "last_edit_date": 1633608757,
                "creation_date": 1612983080,
                "answer_id": 66143190,
                "question_id": 66142393,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Using the -r option with the `@csv` filter is intended to (and indeed in this case does) produce valid CSV according to the various CSV standards which allow embedded newlines within quoted string values.\r\n\r\nThus the problem you seem to be facing is that the program which you are using to ingest the CSV does not accept embedded newlines within double-quoted fields.\r\n\r\nThe simplest workaround may therefore be to &quot;encode&quot; the newline characters in a way that will be acceptable to both you and the other program. \r\n\r\nFor example, you could encode the newlines as pipe (&quot;|&quot;) symbols using the jq filter:\r\n\r\n    gsub(&quot;\\n&quot;; &quot;|&quot;)\r\n\r\nAssuming &quot;text&quot; is a string-valued field which might contain embedded newlines, you would replace `.text` with\r\n\r\n    (.text | gsub(&quot;\\n&quot;; &quot;|&quot;))\r\n\r\nIf the value of `.text` might be null, then you will have to decide how you want to handle nulls.  (One possibility would be: `.text | tostring | gsub(&quot;\\n&quot;;&quot;|&quot;)`.)\r\n\r\nIf you want the transformation to apply to all of the string fields, then replace `| @csv` by something like:\r\n\r\n    | map(if type == &quot;string&quot; then gsub(&quot;\\n&quot;; &quot;|&quot;) else . end)\r\n    | @csv\r\n\r\n\r\n\r\n\r\n### https://www.rfc-editor.org/rfc/rfc4180\r\n&gt; Fields containing line breaks (CRLF), double quotes, and commas should be enclosed in double-quotes. \r\n\r\n",
                "title": "JQ replace &quot;\\n&quot; from inside an encoded field"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1613133704,
        "creation_date": 1612979746,
        "last_edit_date": 1613133704,
        "question_id": 66142393,
        "body_markdown": "I have by now tried a lot of solutions, but i am afraid my understanding of JQ is laking, I just started trying to use it from 2 days ago.\r\n\r\nI got a pretty nice solution to parse my files from Json to Csv, but for 1 little pitfal.\r\n\r\nThe Json have inside it 1 field that is base64 encoded (.data), which is in itself a encoded Json. Inside this sub-Json, theres a field with text (.text) that have &quot;\\n&quot;, and when converting, well, the row gets corrupted as the &quot;\\n&quot; is translated to actual line breaks in the final file.\r\n\r\nThis is the command I have now:\r\n```\r\njq-linux64 -r &#39;[&quot;ackId&quot;,&quot;data&quot;,&quot;senderPhoneNumber&quot;,&quot;eventType&quot;,&quot;eventId&quot;,&quot;messageId2&quot;,&quot;postbackData&quot;,&quot;text&quot;,&quot;sendTime&quot;,&quot;project_number&quot;,&quot;type&quot;,&quot;event_type&quot;,&quot;product&quot;,&quot;messageId&quot;,&quot;publishTime&quot;], (.receivedMessages[] | [.ackId, .message.data, (.message.data | @base64d | fromjson | .senderPhoneNumber, .eventType, .eventId, .messageId, .postbackData, .text, .sendTime), .message.attributes.project_number, .message.attributes.type, .message.attributes.event_type, .message.attributes.product, .message.messageId,.message.publishTime]) | @csv&#39; &lt;inputfile.txt &gt;outputfile.txt\r\n```\r\n\r\nIn this command I do the decode, use the &quot;fromjson&quot; and then grab the fields i need from inside it.\r\n\r\nThe field &quot;.text&quot; is the one that has the linebreaks I wish removed/replaced.\r\n\r\nI tried sub and gsub, but was unable to create a valid command line or one that yields the desired output.\r\n\r\nAny tips regarding how to replace &quot;\\n&quot; from inside the field &quot;,text&quot; ?\r\n\r\n\r\nSample Input File:\r\n```\r\n{\r\n  &quot;receivedMessages&quot;: [\r\n\t{\r\n      &quot;ackId&quot;: &quot;xxxxxx&quot;,\r\n      &quot;message&quot;: {\r\n        &quot;data&quot;: &quot;eyJzZW5kZXJQaG9uZU51bWJlciI6ICIrOTk5OTk5OTk5OTk5OSIsIm1lc3NhZ2VJZCI6ICIyM2QyM2QyM2QzMmQiLCJzZW5kVGltZSI6ICIyMDIxLTAyLTAyVDIwOjAwOjAwLjAwMDAxIiwidGV4dCI6ICJYWFhYWCBYWFhYWFhYRSwgWFhYWFhYWC8gWHh4eHh4LlxuXG5YeHh4eHh4eHg6XG5cbjEgeHh4eCB4eCB4eHh4ICgyMDAgeHgpXG4yLDUgeHh4eHhcbjEgeHh4eCBcblxuWHh4eHh4IHh4eHh4eCJ9Cg==&quot;,\r\n        &quot;attributes&quot;: {\r\n          &quot;product&quot;: &quot;XXXX&quot;,\r\n          &quot;project_number&quot;: &quot;XXXXXX&quot;,\r\n          &quot;message_type&quot;: &quot;TEXT&quot;,\r\n          &quot;type&quot;: &quot;message&quot;\r\n        },\r\n        &quot;messageId&quot;: &quot;234234234234234234&quot;,\r\n        &quot;publishTime&quot;: &quot;2021-02-02T20:15:22.888Z&quot;\r\n      }\r\n    }\r\n    ]\r\n}\r\n```\r\n\r\nWhen I process this file with the above command, it gives:\r\n```\r\n&quot;ackId&quot;,&quot;data&quot;,&quot;senderPhoneNumber&quot;,&quot;eventType&quot;,&quot;eventId&quot;,&quot;messageId2&quot;,&quot;postbackData&quot;,&quot;text&quot;,&quot;sendTime&quot;,&quot;project_number&quot;,&quot;type&quot;,&quot;event_type&quot;,&quot;product&quot;,&quot;messageId&quot;,&quot;publishTime&quot;\r\n&quot;xxxxxx&quot;,&quot;eyJzZW5kZXJQaG9uZU51bWJlciI6ICIrOTk5OTk5OTk5OTk5OSIsIm1lc3NhZ2VJZCI6ICIyM2QyM2QyM2QzMmQiLCJzZW5kVGltZSI6ICIyMDIxLTAyLTAyVDIwOjAwOjAwLjAwMDAxIiwidGV4dCI6ICJYWFhYWCBYWFhYWFhYRSwgWFhYWFhYWC8gWHh4eHh4LlxuXG5YeHh4eHh4eHg6XG5cbjEgeHh4eCB4eCB4eHh4ICgyMDAgeHgpXG4yLDUgeHh4eHhcbjEgeHh4eCBcblxuWHh4eHh4IHh4eHh4eCJ9Cg==&quot;,&quot;+9999999999999&quot;,,,&quot;23d23d23d32d&quot;,,&quot;XXXXX XXXXXXXE, XXXXXXX/ Xxxxxx.\r\n\r\nXxxxxxxxx:\r\n\r\n1 xxxx xx xxxx (200 xx)\r\n2,5 xxxxx\r\n1 xxxx\r\n\r\nXxxxxx xxxxxx&quot;,&quot;2021-02-02T20:00:00.00001&quot;,&quot;XXXXXX&quot;,&quot;message&quot;,,&quot;XXXX&quot;,&quot;234234234234234234&quot;,&quot;2021-02-02T20:15:22.888Z&quot;\r\n```\r\nThe field &quot;.text&quot; generates line breaks from the encoded &quot;\\n&quot;, that make 1 row become multiple rows, thus corrupting this row for latter processing.\r\n\r\n\r\n---Full Answer code as answered by @peak\r\n```\r\njq-linux64 -r &#39;[&quot;ackId&quot;,&quot;data&quot;,&quot;senderPhoneNumber&quot;,&quot;eventType&quot;,&quot;eventId&quot;,&quot;messageId2&quot;,&quot;postbackData&quot;,&quot;text&quot;,&quot;sendTime&quot;,&quot;project_number&quot;,&quot;type&quot;,&quot;event_type&quot;,&quot;product&quot;,&quot;messageId&quot;,&quot;publishTime&quot;], (.receivedMessages[] | [.ackId, .message.data, (.message.data|@base64d|fromjson|.senderPhoneNumber,.eventType,.eventId,.messageId,.postbackData,(.text | tostring | gsub(&quot;\\n&quot;; &quot;|&quot;)),.sendTime),.message.attributes.project_number,.message.attributes.type,.message.attributes.event_type,.message.attributes.product,.message.messageId,.message.publishTime]) | @csv&#39; &lt;input.json &gt;output.csv\r\n```",
        "link": "https://stackoverflow.com/questions/66142393/jq-replace-n-from-inside-an-encoded-field",
        "title": "JQ replace &quot;\\n&quot; from inside an encoded field"
    },
    {
        "tags": [
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 143796,
                    "reputation": 6134,
                    "user_id": 352403,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/6e8473a08926aca6bea5d246ed15e697?s=256&d=identicon&r=PG",
                    "display_name": "souser",
                    "link": "https://stackoverflow.com/users/352403/souser"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1613147806,
                "post_id": 66175484,
                "comment_id": 116995182,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 19961064,
                    "reputation": 31,
                    "user_id": 14628641,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/1755da566d37b02c83e55ed0eb84d0a0?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "user14628641",
                    "link": "https://stackoverflow.com/users/14628641/user14628641"
                },
                "reply_to_user": {
                    "account_id": 143796,
                    "reputation": 6134,
                    "user_id": 352403,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/6e8473a08926aca6bea5d246ed15e697?s=256&d=identicon&r=PG",
                    "display_name": "souser",
                    "link": "https://stackoverflow.com/users/352403/souser"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1613149960,
                "post_id": 66175484,
                "comment_id": 116996149,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 143796,
                    "reputation": 6134,
                    "user_id": 352403,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/6e8473a08926aca6bea5d246ed15e697?s=256&d=identicon&r=PG",
                    "display_name": "souser",
                    "link": "https://stackoverflow.com/users/352403/souser"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1613150760,
                "post_id": 66175484,
                "comment_id": 116996479,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 19961064,
                    "reputation": 31,
                    "user_id": 14628641,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/1755da566d37b02c83e55ed0eb84d0a0?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "user14628641",
                    "link": "https://stackoverflow.com/users/14628641/user14628641"
                },
                "reply_to_user": {
                    "account_id": 143796,
                    "reputation": 6134,
                    "user_id": 352403,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/6e8473a08926aca6bea5d246ed15e697?s=256&d=identicon&r=PG",
                    "display_name": "souser",
                    "link": "https://stackoverflow.com/users/352403/souser"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1613152407,
                "post_id": 66175484,
                "comment_id": 116997240,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "is_answered": false,
        "answer_count": 0,
        "score": 1,
        "last_activity_date": 1613147275,
        "creation_date": 1613147275,
        "question_id": 66175484,
        "body_markdown": "I have a JSON file with data as below:\r\n\r\n  \r\n  \r\n\r\n    {\r\n        &quot;servers&quot;:{\r\n            &quot;author-name&quot;:{\r\n                &quot;server&quot;: &quot;app-dv-app01&quot;\r\n            },\r\n            &quot;authorname2&quot;:{\r\n                &quot;server&quot;: &quot;app-dv-app02&quot;\r\n            }\r\n           }\r\n        } \r\n\r\nI am trying to access the servername based on the username here from a script with the jq as below:\r\n\r\n    jq .servers.${AUTHOR}.server\r\n\r\n\r\nFor **authorname2** it is working fine and returning server app-dv-app02.\r\nBut for **author-name** it is throwing error as below. In general I checked that if the Authorname in JSON file contains a &quot;-&quot; then this problem arises.\r\n\r\n\r\n    + AUTHOR=author-name\r\n    + cat dev-servers.json\r\n    + jq .servers.author-name.server\r\n    jq: error: name/0 is not defined at &lt;top-level&gt;, line 1:\r\n    .servers.ppataky-unzer.server                 \r\n    jq: 1 compile error\r\n\r\n\r\nCould someone please help here to rectify the correct syntax of jq call.\r\n\r\nThanks a lot.\r\n",
        "link": "https://stackoverflow.com/questions/66175484/jq-error-xyz-0-is-not-defined-at-top-level-line-1",
        "title": "jq: error: xyz/0 is not defined at &lt;top-level&gt;, line 1:"
    },
    {
        "tags": [
            "arrays",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 2637951,
                    "reputation": 4791,
                    "user_id": 3014199,
                    "user_type": "registered",
                    "accept_rate": 79,
                    "profile_image": "https://www.gravatar.com/avatar/72332b0ac6ee78bc829c378c6c747e0e?s=256&d=identicon&r=PG",
                    "display_name": "peer",
                    "link": "https://stackoverflow.com/users/3014199/peer"
                },
                "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": 1613157232,
                "post_id": 66177544,
                "comment_id": 116999218,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1613160177,
                "last_edit_date": 1613160177,
                "creation_date": 1613158451,
                "answer_id": 66178023,
                "question_id": 66177544,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "`add` expects an array, so you could wrap your stream up (`[..|.v?]`), or much better, define a stream-based version of `add`:\r\n\r\n```\r\ndef sigma(s): reduce s as $x (0; .+$x);\r\n\r\nsigma(.. | .v?)\r\n```\r\n\r\n(Since `[]|add` yields `null`, you might like to replace `0` by `null` in the above def.)\r\n\r\n",
                "title": "How to process the results of a recursive descent like an array?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1613160177,
        "creation_date": 1613156185,
        "question_id": 66177544,
        "body_markdown": "I want to filter for all values of a certain key and then apply further computation on an array of them, e.g. sum them up.\r\n\r\n```\r\n{\r\n    &quot;v&quot;: 0,\r\n    &quot;child&quot;: {\r\n        &quot;v&quot;: 2,\r\n        &quot;child&quot;: {\r\n            &quot;v&quot;: 3,\r\n            &quot;child&quot;: {\r\n                &quot;v&quot;: null\r\n            }\r\n        },\r\n    &quot;list&quot;: [{&quot;v&quot;:4}]\r\n    }\r\n}\r\n```\r\n\r\nIntuitively I try  `jq &#39;..|.v? | add&#39;` and expect `9` but get an error:  \r\n\r\n```\r\njq: error (at &lt;stdin&gt;:12): Cannot iterate over number (0)\r\nexit status 5\r\n```\r\n\r\nSo I guess it treats the first element as an array, instead of treating all filtered values as an array.\r\n\r\nWith `jq &#39;..|.v?&#39;` I can print them out:\r\n\r\n```\r\n0\r\n2\r\n3\r\nnull\r\nnull\r\n4\r\n```\r\n\r\nBut they don&#39;t seem to be an array (because &#180;echo &quot;[0,2,3,null,null,4]&quot; | jq &#39;add&#39;&#180; works).\r\n\r\nSo what is the &quot;type&quot; of the result of `jq &#39;..|.v?&#39;` and how can I treat it as an array?",
        "link": "https://stackoverflow.com/questions/66177544/how-to-process-the-results-of-a-recursive-descent-like-an-array",
        "title": "How to process the results of a recursive descent like an array?"
    },
    {
        "tags": [
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 5128181,
                    "reputation": 225,
                    "user_id": 4109416,
                    "user_type": "registered",
                    "accept_rate": 33,
                    "profile_image": "https://lh5.googleusercontent.com/-DQ1f3nAhobY/AAAAAAAAAAI/AAAAAAAAASc/4rDWj4QqgVk/s256-rj/photo.jpg",
                    "display_name": "Kumar Saras",
                    "link": "https://stackoverflow.com/users/4109416/kumar-saras"
                },
                "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": 1,
                "creation_date": 1613157540,
                "post_id": 66177589,
                "comment_id": 116999336,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1613159253,
                "creation_date": 1613159253,
                "answer_id": 66178169,
                "question_id": 66177589,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "In the question, you ask for the generalization of &#39;*&#39; for multiple objects.  Here is a stream-oriented generalization:\r\n\r\n```\r\ndef star(s): reduce s as $x ({}; . * $x);\r\n```\r\n\r\nWith your two files, an invocation along the lines of:\r\n\r\n    jq -n &#39;\r\n      def star(s): reduce s as $x ({}; . * $x);\r\n      star(inputs)\r\n    &#39; file*.json\r\n\r\n\r\nwould produce the output shown below, which however differs from your expected.json, thus suggesting that your requirements might need clarification.\r\n\r\n### Output\r\n```\r\n{\r\n  &quot;parent1&quot;: {\r\n    &quot;child1&quot;: {\r\n      &quot;prop1&quot;: &quot;val1&quot;,\r\n      &quot;prop4&quot;: &quot;val4&quot;\r\n    },\r\n    &quot;child2&quot;: {\r\n      &quot;prop2&quot;: &quot;val2&quot;\r\n    },\r\n    &quot;child3&quot;: {\r\n      &quot;prop3&quot;: &quot;val3&quot;\r\n    }\r\n  }\r\n}\r\n```",
                "title": "How to merge multi json files into one without duplicates using jq?"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": -1,
        "last_activity_date": 1613159253,
        "creation_date": 1613156388,
        "last_edit_date": 1613157362,
        "question_id": 66177589,
        "body_markdown": "I have multiple json files and all have the same parent element. I want to merge all the child elements into one file with one parent element without duplicate keys(take only the last occurrence of a key into the final file).\r\n\r\nExample.\r\n\r\nfile1.json\r\n```\r\n{\r\n    &quot;parent1&quot;: {\r\n        &quot;child1&quot;: {\r\n            &quot;prop1&quot;:&quot;val1&quot;\r\n        },\r\n        &quot;child2&quot;: {\r\n            &quot;prop2&quot;:&quot;val2&quot;\r\n        }\r\n    }\r\n}        \r\n```\r\nfile2.json\r\n```\r\n{\r\n    &quot;parent1&quot;: {\r\n        &quot;child1&quot;: {\r\n            &quot;prop4&quot;:&quot;val4&quot;\r\n        },\r\n        &quot;child3&quot;: {\r\n            &quot;prop3&quot;:&quot;val3&quot;\r\n        }\r\n    }\r\n}\r\n```\r\n\r\nexpected.json\r\n```\r\n{\r\n    &quot;parent1&quot;: {\r\n        &quot;child1&quot;: {\r\n            &quot;prop4&quot;:&quot;val4&quot;\r\n        },\r\n        &quot;child2&quot;: {\r\n            &quot;prop2&quot;:&quot;val2&quot;\r\n        },\r\n        &quot;child3&quot;: {\r\n            &quot;prop3&quot;:&quot;val3&quot;\r\n        }\r\n    }\r\n}\r\n```\r\n\r\nI have taken 2 files just for example, but actually I have multiple files in the directory.\r\nFor 2 files I understand this can be done by\r\n```jq -S -s &#39;.[0] * .[1]&#39; file1.json file2.json```\r\nBut how to do it for multiple files using jq?",
        "link": "https://stackoverflow.com/questions/66177589/how-to-merge-multi-json-files-into-one-without-duplicates-using-jq",
        "title": "How to merge multi json files into one without duplicates using jq?"
    },
    {
        "tags": [
            "json",
            "csv",
            "select",
            "export-to-csv",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1613250517,
                "last_edit_date": 1613250517,
                "creation_date": 1613215282,
                "answer_id": 66184518,
                "question_id": 66182953,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "    jq -r &#39;\r\n      .[] \r\n      | select(.sex | endswith(&quot;female&quot;)) \r\n      | to_entries\r\n      | map(.value) \r\n      | @csv \r\n    &#39; target.json\r\n\r\nto_entries to:\r\n\r\n    [\r\n      {\r\n        &quot;key&quot;: &quot;name&quot;,\r\n        &quot;value&quot;: &quot;Kasia&quot;\r\n      },\r\n      {\r\n        &quot;key&quot;: &quot;age&quot;,\r\n        &quot;value&quot;: &quot;5&quot;\r\n      },\r\n      {\r\n        &quot;key&quot;: &quot;sex&quot;,\r\n        &quot;value&quot;: &quot;female&quot;\r\n      }\r\n    ]\r\n\r\nand map(.value) to:\r\n\r\n    [\r\n      &quot;Kasia&quot;,\r\n      &quot;5&quot;,\r\n      &quot;female&quot;\r\n    ]\r\n\r\n",
                "title": "How can I export to CSV with condition?"
            },
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1613252162,
                "creation_date": 1613252162,
                "answer_id": 66190161,
                "question_id": 66182953,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The following makes no assumptions about the ordering of keys within objects.  It also produces a CSV header line, and ensures the output conforms with the typical CSV requirement that the result be &quot;rectangular&quot;:\r\n```\r\njq -r &#39;\r\n  (.[0]|keys_unsorted) as $keys\r\n  | $keys,\r\n    (.[] \r\n     | select(.sex | endswith(&quot;female&quot;)) \r\n     | [.[ $keys[] ]])\r\n  | @csv \r\n&#39; target.json\r\n```",
                "title": "How can I export to CSV with condition?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1618652793,
        "creation_date": 1613202836,
        "last_edit_date": 1618652793,
        "question_id": 66182953,
        "body_markdown": "    cat target.json | jq &#39;.[] | select(.sex | endswith(&quot;female&quot;)) |@csv&#39;\r\n\r\n\r\nI tried the code above to output csv with the condition, in which only girls are listed. \r\n\r\n&quot;target.json&quot;\r\n\r\n    [ \r\n     { \r\n      &quot;name&quot;: &quot;Mike&quot;, \r\n      &quot;age&quot;: &quot;15&quot;,\r\n      &quot;sex&quot;: &quot;male&quot;\r\n     }, \r\n     { \r\n      &quot;name&quot;: &quot;Dan&quot;, \r\n      &quot;age&quot;: &quot;10&quot;,\r\n      &quot;sex&quot;: &quot;male&quot; \r\n     }, \r\n     { \r\n      &quot;name&quot;: &quot;Kasia&quot;, \r\n      &quot;age&quot;: &quot;5&quot;,\r\n      &quot;sex&quot;: &quot;female&quot; \r\n     }\r\n    ]\r\n\r\n\r\nHowever it fails to create and says this error code.\r\n\r\n    jq: error (at &lt;stdin&gt;:0): object ({&quot;sex&quot;:&quot;...) cannot be csv-formatted, only array\r\n\r\nCan anyone show me how?\r\n\r\n",
        "link": "https://stackoverflow.com/questions/66182953/how-can-i-export-to-csv-with-condition",
        "title": "How can I export to CSV with condition?"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1613276486,
                "post_id": 66192252,
                "comment_id": 117024100,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1526413,
                    "reputation": 13993,
                    "user_id": 1424739,
                    "user_type": "registered",
                    "accept_rate": 17,
                    "profile_image": "https://www.gravatar.com/avatar/19d3c927744b5ad3b94afbf88e1c3844?s=256&d=identicon&r=PG",
                    "display_name": "user1424739",
                    "link": "https://stackoverflow.com/users/1424739/user1424739"
                },
                "reply_to_user": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1613276612,
                "post_id": 66192252,
                "comment_id": 117024116,
                "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": 1613277132,
                "post_id": 66192252,
                "comment_id": 117024167,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1526413,
                    "reputation": 13993,
                    "user_id": 1424739,
                    "user_type": "registered",
                    "accept_rate": 17,
                    "profile_image": "https://www.gravatar.com/avatar/19d3c927744b5ad3b94afbf88e1c3844?s=256&d=identicon&r=PG",
                    "display_name": "user1424739",
                    "link": "https://stackoverflow.com/users/1424739/user1424739"
                },
                "reply_to_user": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1613277423,
                "post_id": 66192252,
                "comment_id": 117024205,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1613441519,
                "creation_date": 1613441519,
                "answer_id": 66217862,
                "question_id": 66192252,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The following illustrates how to convert the array-oriented JSON produced by rb2json0.rb to a more object-oriented JSON, in a way that you can query for `update_info@ident` in a straightforward way.\r\n\r\n```\r\ndef objectify:\r\n  if type == &quot;array&quot;\r\n  then if length&gt;=2 and (.[0]|type) == &quot;string&quot; and (.[1]|type) == &quot;array&quot;\r\n       then  {(.[0]): ( .[1:] | map(objectify)) | objectify }\r\n       elif length&gt;=3 and .[0][0:1] == &quot;@&quot; and (.[1]|type) == &quot;string&quot;\r\n       then  { (.[1] + .[0]): ( .[2:] | map(objectify)) | objectify }\r\n       else map(objectify)\r\n       end\r\n  else . \r\n  end;\r\n```\r\n\r\n### Illustrative query\r\nGiven the snippet shown, the following produces the output shown below:\r\n```\r\nobjectify | .. | objects | .[&quot;update_info@ident&quot;]? // empty\r\n```\r\n\r\n#### Output\r\n```\r\n[[24,10]]\r\n```",
                "title": "How to extract data from JSON converted from ruby script?"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": -3,
        "last_activity_date": 1613441519,
        "creation_date": 1613274261,
        "last_edit_date": 1613278036,
        "question_id": 66192252,
        "body_markdown": "https://stackoverflow.com/questions/66191457/how-to-convert-a-ruby-file-to-json\r\n\r\nI use the above approach (`rb2json0.rb` is in the above link) to convert a ruby script to JSON. But the JSON is not well formatted as it only has arrays but not dictionaries, making it difficult to work with the JSON output.\r\n\r\nI specifically want to extract fields in `update_info`, e.g.,\r\n\r\n- Name\r\n- Description\r\n- License\r\n- References\r\n- Author\r\n\r\nand to extract the fields in `register_options`, e.g.,\r\n\r\n- LHOST\r\n- SOURCE\r\n- FILENAME\r\n- DOCAUTHOR\r\n\r\nNote that the extraction should not assume the field names are fixed to these specific ones, as other field names can be used in other similar files.\r\n\r\nThe output should be a two-column TSV, with the field name as the first column and the field value as the second column. For example,\r\n\r\n```\r\nName&lt;TAB&gt;Microsoft Word UNC Path Injector\r\n...\r\n```\r\n\r\nCould anybody let me know the best `jq` way to achieve this? Thanks.\r\n\r\nword_unc_injector.rb is at \r\nhttps://github.com/rapid7/metasploit-framework/blob/master/modules/auxiliary/docx/word_unc_injector.rb\r\n      \r\n```\r\n$ rb2json0.rb &lt; word_unc_injector.rb | jq . # too long to include all output.\r\n[\r\n  &quot;program&quot;,\r\n  [\r\n    [\r\n      &quot;command&quot;,\r\n      [\r\n        &quot;@ident&quot;,\r\n        &quot;require&quot;,\r\n        [\r\n...\r\n```\r\n\r\nEDIT. The full solution of this problem may be complicated. But the first step might be to extract the part corresponding to `update_info`. Here is the relevant JSON fragment.\r\n\r\n```\r\n...\r\n                        [    \r\n                          &quot;method_add_arg&quot;,\r\n                          [    \r\n                            &quot;fcall&quot;,\r\n                            [    \r\n                              &quot;@ident&quot;,\r\n                              &quot;update_info&quot;,\r\n                              [    \r\n                                24,  \r\n                                10   \r\n                              ]    \r\n                            ]    \r\n                          ],   \r\n                          [    \r\n                            &quot;arg_paren&quot;,\r\n                            [    \r\n                              &quot;args_add_block&quot;,\r\n                              [    \r\n                                [    \r\n                                  &quot;var_ref&quot;,\r\n                                  [    \r\n                                    &quot;@ident&quot;,\r\n                                    &quot;info&quot;,\r\n                                    [    \r\n                                      24,  \r\n                                      22   \r\n                                    ]    \r\n                                  ]    \r\n                                ],   \r\n                                [    \r\n                                  &quot;bare_assoc_hash&quot;,\r\n                                  [    \r\n                                    [    \r\n                                      &quot;assoc_new&quot;,\r\n                                      [    \r\n                                        &quot;string_literal&quot;,\r\n                                        [    \r\n                                          &quot;string_content&quot;,\r\n                                          [    \r\n                                            &quot;@tstring_content&quot;,\r\n                                            &quot;Name&quot;,\r\n...\r\n```\r\n",
        "link": "https://stackoverflow.com/questions/66192252/how-to-extract-data-from-json-converted-from-ruby-script",
        "title": "How to extract data from JSON converted from ruby script?"
    },
    {
        "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": 1,
                "creation_date": 1613319124,
                "post_id": 66197271,
                "comment_id": 117032901,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 8886515,
                    "reputation": 479,
                    "user_id": 6634613,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/a0e462ce811156e58de0acc5af47d228?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Tomasz",
                    "link": "https://stackoverflow.com/users/6634613/tomasz"
                },
                "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": 1613319324,
                "post_id": 66197271,
                "comment_id": 117032949,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1613319752,
                "last_edit_date": 1613319752,
                "creation_date": 1613319529,
                "answer_id": 66197371,
                "question_id": 66197271,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can use [`--argjson`][1] instead off `-arg` to let JQ handle it as a number:\r\n```bash\r\n➜  ID=&quot;123&quot;\r\n➜  cat test.json | jq -r --argjson ID &quot;$ID&quot; &#39;.[] | select(.id==$ID) | .output&#39;\r\njq select doesn&#39;t work :(\r\n➜  \r\n```\r\n\r\n&lt;hr&gt;\r\n\r\nYou could also use [`tostring`][1] to convert the ID to a string so you can keep the existing format;\r\n```none\r\n➜  ID=&quot;123&quot;\r\n➜  cat test.json | jq -r --arg ID &quot;$ID&quot; &#39;.[] | select(.id|tostring==$ID) | .output&#39;\r\njq select doesn&#39;t work :(\r\n➜ \r\n➜  ID=&quot;some-text&quot;\r\n➜  cat test.json | jq -r --arg ID &quot;$ID&quot; &#39;.[] | select(.id|tostring==$ID) | .output&#39;\r\njq select works!\r\n➜ \r\n```\r\n\r\n\r\n  [1]: https://stedolan.github.io/jq/manual/",
                "title": "jq, variables, select and numbers?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1613319752,
        "creation_date": 1613318861,
        "question_id": 66197271,
        "body_markdown": "It seems that jq&#39;s &quot;select&quot;, when used with variables, only works for text strings, but not for numbers.\r\nHow do I use jq so that I can select no matter if the value is a number or not?\r\n\r\n```\r\n$ cat test.json\r\n[\r\n  {\r\n    &quot;id&quot;: &quot;some-text&quot;,\r\n    &quot;output&quot;: &quot;jq select works!&quot;\r\n  },\r\n  {\r\n    &quot;id&quot;: 123,\r\n    &quot;output&quot;: &quot;jq select doesn&#39;t work :(&quot;\r\n  }\r\n]\r\n```\r\n\r\n- Let&#39;s try to select &quot;output&quot; where &quot;id&quot; is &quot;some-text&quot; - it works:\r\n\r\n```\r\n$ ID=&quot;some-text&quot;\r\n$ cat test.json | jq -r --arg ID &quot;$ID&quot; &#39;.[] | select(.id==$ID) | .output&#39;\r\njq select works!\r\n$ \r\n```\r\n\r\n\r\n- Let&#39;s try to select &quot;output&quot; where &quot;id&quot; is &quot;123&quot; - it doesn&#39;t work:\r\n\r\n```\r\n$ ID=&quot;123&quot;\r\n$ cat test.json | jq -r --arg ID &quot;$ID&quot; &#39;.[] | select(.id==$ID) | .output&#39;\r\n$ \r\n```\r\n\r\n- Interestingly, &quot;select&quot; does work if I don&#39;t pass the variable via --arg:\r\n\r\n```\r\n$ cat test.json | jq -r &#39;.[] | select(.id==123) | .output&#39;\r\njq select doesn&#39;t work :(\r\n```\r\n\r\nWhat am I doing wrong?",
        "link": "https://stackoverflow.com/questions/66197271/jq-variables-select-and-numbers",
        "title": "jq, variables, select and numbers?"
    },
    {
        "tags": [
            "json",
            "ansible",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1613333199,
                "creation_date": 1613333199,
                "answer_id": 66199615,
                "question_id": 66197521,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You could check whether the new file is JSON-equal to the original file using jq&#39;s `==` operator.  One way to do this without generating any output on stdout would be to use jq&#39;s built-in `halt_error/1`.  There are many possibilities, but here is a simple stand-alone illustration:\r\n\r\n```\r\necho &#39;{&quot;a&quot;: 0}&#39; | jq --argfile f1 &lt;(echo {}) &#39;\r\n   if . == $f1 then empty else null|halt_error(99) end&#39; \r\n```\r\n\r\nTo avoid calling jq twice, an alternative would be to use jq BOTH to write out the possibly-altered file AND to set the return code as appropriate, along the lines suggested by the above example using `halt_error`.",
                "title": "Detect changes on json file in Ansible: jq uses different indention -&gt; File is always changed"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1613679785,
                "creation_date": 1613679785,
                "answer_id": 66267618,
                "question_id": 66197521,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "With the help of @peak I found a solution:\r\n\r\n    jq --arg platform &quot;MyPlatformName&quot; &#39;if .payload.platformName == $platform then . else .payload.platformName = $platform, (null|halt_error(99)) end&#39; resources/commonProperties.json &gt; /tmp/out.json\r\n\r\nThis would result in returncode 99 if the file was edited\r\n\r\n    # echo $?\r\n    99\r\n\r\nIf we re-run the tool on the modified file, no modification needs to be applied and we got rc = 0\r\n\r\n    # jq --arg platform &quot;MyPlatformName&quot; &#39;if .payload.platformName == $platform then . else .payload.platformName = $platform, (null|halt_error(99)) end&#39; /tmp/out.json &gt; /tmp/out2.json\r\n    # echo $?\r\n    0\r\n\r\n",
                "title": "Detect changes on json file in Ansible: jq uses different indention -&gt; File is always changed"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1613679785,
        "creation_date": 1613320295,
        "question_id": 66197521,
        "body_markdown": "Using Ansible, I want to replace a string in a json file. It seems Ansible has no similar module like [xml](https://docs.ansible.com/ansible/latest/collections/community/general/xml_module.html) for json, I&#39;m using the [`jq` cli tool](https://stedolan.github.io/jq/). Since a restart in the underlying application is required (which takes some time, since it&#39;s an heavy and old java app), I&#39;d like to have a change detection so the restart is only applied when needed.\r\n\r\nThe return code with the `-e` parameter doesn&#39;t change, so my idea was to fetch the hash of the file before `jq` runs and compare it with the hash after that. Fetching the hash could be done with the `stat` module:\r\n\r\n    - set_fact: \r\n        common_properties_file: &quot;{{ resources_dir }}/commonProperties.json&quot;\r\n    \r\n    - name: Get hash of {{ common_properties_file }}\r\n      stat: path={{ common_properties_file }}\r\n      register: coomon_properties_check\r\n    \r\n    - name: Hash before modification\r\n      debug:\r\n        var: coomon_properties_check.stat.checksum\r\n\r\nBut during testing I found out that the hash even changes when just printing the file without any modification. A diff shows that the entire file got modified by different indention:\r\n\r\n    # jq &#39;.&#39; resources/commonProperties.json &gt; resources/commonProperties.json_jq\r\n    # colordiff resources/commonProperties.json resources/commonProperties.json_jq\r\n    2,14c2,10\r\n    &lt;     &quot;name&quot;: &quot;Notification mail customization&quot;,\r\n    &lt;     &quot;type&quot;: &quot;com.ibm.connections.notification.mail&quot;,\r\n    &lt;     &quot;payload&quot;: {\r\n    &lt;         &quot;platformName&quot;: &quot;HCL Connections&quot;,\r\n    &lt;         &quot;photoType&quot;:&quot;url&quot;,\r\n    &lt;         &quot;style&quot;: {\r\n    &lt;             &quot;bodyBackgroundColor&quot;: &quot;#eeeeee&quot;,\r\n    &lt;             &quot;sidebarBackgroundColor&quot;: &quot;#3d6cf0&quot;,\r\n    &lt;             &quot;messageBackgroundColor&quot;: &quot;#ffffff&quot;\r\n    &lt;         },\r\n    &lt;         &quot;activityDateFormat&quot;: &quot;dd MMM&quot;,\r\n    &lt;         &quot;activityMax&quot; : &quot;25&quot;,\r\n    &lt;         &quot;subjectAppNameAppend&quot; : &quot;tail&quot;\r\n    ---\r\n    &gt;   &quot;name&quot;: &quot;Notification mail customization&quot;,\r\n    &gt;   &quot;type&quot;: &quot;com.ibm.connections.notification.mail&quot;,\r\n    &gt;   &quot;payload&quot;: {\r\n    &gt;     &quot;platformName&quot;: &quot;HCL Connections&quot;,\r\n    &gt;     &quot;photoType&quot;: &quot;url&quot;,\r\n    &gt;     &quot;style&quot;: {\r\n    &gt;       &quot;bodyBackgroundColor&quot;: &quot;#eeeeee&quot;,\r\n    &gt;       &quot;sidebarBackgroundColor&quot;: &quot;#3d6cf0&quot;,\r\n    &gt;       &quot;messageBackgroundColor&quot;: &quot;#ffffff&quot;\r\n    16c12,16\r\n    &lt;     &quot;path&quot;: &quot;notify&quot;\r\n    ---\r\n    &gt;     &quot;activityDateFormat&quot;: &quot;dd MMM&quot;,\r\n    &gt;     &quot;activityMax&quot;: &quot;25&quot;,\r\n    &gt;     &quot;subjectAppNameAppend&quot;: &quot;tail&quot;\r\n    &gt;   },\r\n    &gt;   &quot;path&quot;: &quot;notify&quot;\r\n\r\nI also tried `jq --tab` without success. The only way I see is to write a small Ansible module that parse the json to an array, check if the modifications need to be applied and set the changed state so that I can use them to decide if we need a restart. \r\n\r\nIs there a native way without having to write an Ansible module for that purpose?",
        "link": "https://stackoverflow.com/questions/66197521/detect-changes-on-json-file-in-ansible-jq-uses-different-indention-file-is-a",
        "title": "Detect changes on json file in Ansible: jq uses different indention -&gt; File is always changed"
    },
    {
        "tags": [
            "json",
            "jq",
            "kubectl"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 19037951,
                    "reputation": 889,
                    "user_id": 13898676,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f3d4bed9e628611584259560c214fd0e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Alan",
                    "link": "https://stackoverflow.com/users/13898676/alan"
                },
                "reply_to_user": {
                    "account_id": 18535276,
                    "reputation": 2389,
                    "user_id": 13505098,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/iamBe.png?s=256",
                    "display_name": "Seyi Daniel",
                    "link": "https://stackoverflow.com/users/13505098/seyi-daniel"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1613339228,
                "post_id": 66200213,
                "comment_id": 117038728,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1613480332,
                "last_edit_date": 1613480332,
                "creation_date": 1613345109,
                "answer_id": 66201106,
                "question_id": 66200213,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Given the stream of JSON objects shown in the question, the following jq filter will produce the desired output assuming the stream is somehow &quot;slurped&quot;:\r\n \r\n```\r\n. as $in\r\n| reduce range(0;length) as $i ({};.[$i+1|tostring] = $in[$i])\r\n| {Servers: .}\r\n\r\n```\r\n\r\nTo avoid having to call jq twice, you could wrap your filter in square brackets, and pipe that into the above; better yet, you can streamline everything, e.g. along the following lines:\r\n\r\n```\r\n.items\r\n| [to_entries[]\r\n   | {(.key+1|tostring): .value}\r\n   | map_values(\r\n      {Name:.metadata.name,\r\n       Port:.spec.ports[0].port,\r\n       Group: &quot;group name&quot;,\r\n       SSLMode: &quot;prefer&quot;,\r\n       MaintenanceDB: &quot;postgres&quot;}) ]\r\n| {Servers: add}\r\n```\r\n",
                "title": "Format json output with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1613480332,
        "creation_date": 1613337309,
        "question_id": 66200213,
        "body_markdown": "I&#39;m writing a script which will obtain certain info from my Kubernetes cluster.\r\n\r\nThe following command\r\n\r\n&lt;!-- begin snippet: js hide: false console: true babel: false --&gt;\r\n\r\n&lt;!-- language: lang-bash --&gt;\r\n\r\n    kubectl get --context &lt;my-context&gt; svc --selector=&#39;&lt;my-selectors&gt;&#39; -o json |\r\n    jq -r &#39; .items[]| {Name:.metadata.name, Port:.spec.ports[0].port} + {Group: &quot;test&quot;, Group: &quot;group name&quot;, SSLMode: &quot;prefer&quot;, MaintenanceDB: &quot;postgres&quot;} &#39;&gt;file.json\r\n\r\n&lt;!-- end snippet --&gt;\r\n\r\nwill output something like this\r\n\r\n    {\r\n      &quot;Name&quot;: &quot;db-name&quot;,\r\n      &quot;Port&quot;: 3000,\r\n      &quot;Group&quot;: &quot;group name&quot;,\r\n      &quot;SSLMode&quot;: &quot;prefer&quot;,\r\n      &quot;MaintenanceDB&quot;: &quot;postgres&quot;\r\n    }\r\n    {\r\n      &quot;Name&quot;: &quot;db-name&quot;,\r\n      &quot;Port&quot;: 5432,\r\n      &quot;Group&quot;: &quot;group name&quot;,\r\n      &quot;SSLMode&quot;: &quot;prefer&quot;,\r\n      &quot;MaintenanceDB&quot;: &quot;postgres&quot;\r\n    }\r\n\r\n\r\nI&#39;ve been trying to get the above into the following format\r\n\r\n    {\r\n      &quot;Servers&quot;:{\r\n        &quot;1&quot;: {\r\n          &quot;Name&quot;: &quot;db-name&quot;,\r\n          &quot;Port&quot;: 3000,\r\n          &quot;Group&quot;: &quot;Server Group 1&quot;,\r\n          &quot;SSLMode&quot;: &quot;prefer&quot;,\r\n          &quot;MaintenanceDB&quot;: &quot;postgres&quot;\r\n        },\r\n        &quot;2&quot;: {\r\n          &quot;Name&quot;: &quot;db-name&quot;,\r\n          &quot;Port&quot;: 5432,\r\n          &quot;Group&quot;: &quot;Server Group 1&quot;,\r\n          &quot;SSLMode&quot;: &quot;prefer&quot;,\r\n          &quot;MaintenanceDB&quot;: &quot;postgres&quot;\r\n        }\r\n      }\r\n    }\r\n\r\nOnly just discovered jq so the few things I&#39;ve tried have been unsuccessful. Would be grateful for any pointers.\r\n\r\n",
        "link": "https://stackoverflow.com/questions/66200213/format-json-output-with-jq",
        "title": "Format json output with jq"
    },
    {
        "tags": [
            "bash",
            "shell",
            "sh",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 10015983,
                    "reputation": 144648,
                    "user_id": 9072753,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/EPmGy.jpg?s=256",
                    "display_name": "KamilCuk",
                    "link": "https://stackoverflow.com/users/9072753/kamilcuk"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1613379781,
                "post_id": 66205174,
                "comment_id": 117047335,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2417392,
                    "reputation": 1,
                    "user_id": 2111153,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/a61103d57937686e3def627c72be1ad9?s=256&d=identicon&r=PG",
                    "display_name": "Mahendra Sawarkar",
                    "link": "https://stackoverflow.com/users/2111153/mahendra-sawarkar"
                },
                "reply_to_user": {
                    "account_id": 10015983,
                    "reputation": 144648,
                    "user_id": 9072753,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/EPmGy.jpg?s=256",
                    "display_name": "KamilCuk",
                    "link": "https://stackoverflow.com/users/9072753/kamilcuk"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1613646127,
                "post_id": 66205174,
                "comment_id": 117141927,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "is_answered": false,
        "answer_count": 0,
        "score": 0,
        "last_activity_date": 1613379670,
        "creation_date": 1613379670,
        "question_id": 66205174,
        "body_markdown": "I am trying to loop through the JSON having an array nested within. I am trying to achieve this with the help of Shell script and JQ. But I am getting weird output as there is space in one of the values.\r\n\r\nPlease help me with this:\r\n\r\nBelow is the snippet I am using:\r\n\r\n==fruits.json==\r\n\r\n```\r\n{\r\n\t&quot;fruits&quot;: [\r\n\t\t{\r\n\t\t\t&quot;name&quot; : &quot;Orange&quot;,\r\n\t\t\t&quot;colour&quot;: &quot;Orange&quot;\r\n\r\n\t\t},\r\n\t\t{\r\n\t\t\t&quot;name&quot; : &quot;Red Grapes&quot;,\r\n\t\t\t&quot;colour&quot;: &quot;Red&quot;\r\n\r\n\t\t}\r\n\t]\r\n}\r\n```\r\n\r\n==Shell script: fruits.sh==\r\n```\r\n#!/bin/bash\r\n\r\ncall_api() {\r\n    FILE=&quot;/akasia/RestApiTestAutomation/fruits.json&quot;\r\n    jsonFile=$(jq . $FILE)\r\n    #echo &quot;This is array &quot; $(echo $jsonFile | jq -c &#39;.fruits[]&#39; )\r\n    for row in $(echo &quot;${jsonFile}&quot; | jq -c &#39;.fruits[]&#39; );\r\n    do\r\n        echo &quot;The row is &quot; $row\r\n    done\r\n}\r\ncall_api\r\n\r\n```\r\n\r\nI am seeing below output:\r\n```\r\nThe row is  {&quot;name&quot;:&quot;Orange&quot;,&quot;colour&quot;:&quot;Orange&quot;}\r\nThe row is  {&quot;name&quot;:&quot;Red\r\nThe row is  Grapes&quot;,&quot;colour&quot;:&quot;Red&quot;}\r\n```\r\n\r\nThe expected output is:\r\n```\r\nThe row is  {&quot;name&quot;:&quot;Orange&quot;,&quot;colour&quot;:&quot;Orange&quot;}\r\nThe row is  {&quot;name&quot;:&quot;Red Grapes&quot;,&quot;colour&quot;:&quot;Red&quot;}\r\n```\r\n\r\nPlease help me with this. Thanks in advance!\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/66205174/unable-to-loop-through-the-json-internal-array-having-spaces-in-values-using-bas",
        "title": "Unable to loop through the JSON internal Array having spaces in values using Bash script JQ"
    },
    {
        "tags": [
            "json",
            "list",
            "jq",
            "jsonpath",
            "druid"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 309588,
                    "reputation": 1773,
                    "user_id": 622121,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/5eb5b05a7391cfa97fc9016ce95471ee?s=256&d=identicon&r=PG",
                    "display_name": "Kenji Noguchi",
                    "link": "https://stackoverflow.com/users/622121/kenji-noguchi"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1630291908,
                "post_id": 66205415,
                "comment_id": 121907840,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1613421301,
                "creation_date": 1613421301,
                "answer_id": 66215042,
                "question_id": 66205415,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Try a filter like this and no flattening should be required:\r\n\r\n    jq &#39;.[] | {name,lastseen}&#39;\r\n\r\nUsing your input, this results in:\r\n\r\n    {\r\n      &quot;name&quot;: &quot;Temperature Sensor A&quot;,\r\n      &quot;lastseen&quot;: &quot;2021-02-15T05:02Z&quot;\r\n    }\r\n    {\r\n      &quot;name&quot;: &quot;Temperature Sensor B&quot;,\r\n      &quot;lastseen&quot;: &quot;2021-02-15T05:01Z&quot;\r\n    }\r\n    {\r\n      &quot;name&quot;: &quot;Temperature Sensor Backup&quot;,\r\n      &quot;lastseen&quot;: &quot;2021-02-15T05:00Z&quot;\r\n    }\r\n\r\n",
                "title": "Apache Druid – Ingesting multiple objects in flat JSON data returns only single row"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1620243502,
                "creation_date": 1620243502,
                "answer_id": 67407738,
                "question_id": 66205415,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I think it&#39;s possible, but not easy.\r\n\r\nI was in a similar situation, except the multi-record documents were in Kafka, not HTTP. Ultimately, the easiest solution was to change the format of the data going in, and you&#39;ve made it clear that&#39;s not an option for you.\r\n\r\nBatching support does seem to exist:\r\nhttps://github.com/apache/druid/issues/4373\r\n\r\nGian, one of the main committers for Druid said in 2019:\r\nhttps://github.com/apache/druid/issues/4373#issuecomment-489819616\r\n&gt;  However, at present, you do need to implement a custom extension to\r\n&gt; get it (none of the builtin parsers will split out messages into\r\n&gt; multiple rows). I expect we will add that functionality at some point,\r\n&gt; but have not yet.\r\n\r\nIt looks like the solution is to write your own extension. A sample extension can be found here:\r\nhttps://github.com/implydata/druid-example-extension\r\n\r\nI know that&#39;s not a great solution, and it sounds like it might be possible in the future, so I&#39;d keep an eye on releases as they come out.",
                "title": "Apache Druid – Ingesting multiple objects in flat JSON data returns only single row"
            }
        ],
        "is_answered": false,
        "answer_count": 2,
        "score": 2,
        "last_activity_date": 1620243502,
        "creation_date": 1613380781,
        "question_id": 66205415,
        "body_markdown": "**I&#39;m aiming to ingest this JSON data into Apache Druid as multiple rows.** The data (about 10x more rows than this example) is served from a proprietary HTTP server that I have no control over. I cannot change how the data is presented from the HTTP server. The data will be pulled periodically, as there is no notification from the HTTP server.\r\n\r\n    {\r\n      &quot;1&quot;: {\r\n        &quot;lastseen&quot;: &quot;2021-02-15T05:02Z&quot;,\r\n        &quot;name&quot;: &quot;Temperature Sensor A&quot;,\r\n        &quot;state&quot;: {\r\n          &quot;alert&quot;: &quot;none&quot;,\r\n          &quot;level&quot;: 152,\r\n          &quot;on&quot;: true,\r\n          &quot;reachable&quot;: true\r\n        }\r\n      },\r\n      &quot;3&quot;: {\r\n        &quot;lastseen&quot;: &quot;2021-02-15T05:01Z&quot;,\r\n        &quot;name&quot;: &quot;Temperature Sensor B&quot;,\r\n        &quot;state&quot;: {\r\n          &quot;alert&quot;: &quot;none&quot;,\r\n          &quot;level&quot;: 13,\r\n          &quot;on&quot;: false,\r\n          &quot;reachable&quot;: true\r\n        }\r\n      },\r\n      &quot;4&quot;: {\r\n        &quot;lastseen&quot;: &quot;2021-02-15T05:00Z&quot;,\r\n        &quot;name&quot;: &quot;Temperature Sensor Backup&quot;,\r\n        &quot;state&quot;: {\r\n          &quot;alert&quot;: &quot;none&quot;,\r\n          &quot;level&quot;: 76,\r\n          &quot;on&quot;: true,\r\n          &quot;reachable&quot;: true\r\n        }\r\n      }\r\n    }\r\n\r\nNote that object 2 is missing. This number is an internal record ID from the server, and if object 2 is deleted, this ID will disappear from subsequent requests.\r\n\r\nI have created a data source that successfully pulls the data, but it ends up as as single row. As I understand, since the JSON object has no array at the root level, Druid sees these three objects as a single row.\r\n\r\nI suspect that the answer lies somewhere in the [`flattenSpec`][1] area, but I have failed to get this going. The closest I have gotten so far is with the following `flattenSpec`, but this only returns the first row from the JSON data (though the row is represented correctly).\r\n\r\n      &quot;inputFormat&quot;: {\r\n        &quot;type&quot;: &quot;json&quot;,\r\n        &quot;flattenSpec&quot;: {\r\n          &quot;fields&quot;: [\r\n            {\r\n              &quot;type&quot;: &quot;jq&quot;,\r\n              &quot;expr&quot;: &quot;.[].name&quot;,\r\n              &quot;name&quot;: &quot;name&quot;\r\n            },\r\n            {\r\n              &quot;type&quot;: &quot;jq&quot;,\r\n              &quot;expr&quot;: &quot;.[].lastseen&quot;,\r\n              &quot;name&quot;: &quot;lastseen&quot;\r\n            }\r\n          ]\r\n        }\r\n      }\r\n\r\nThe above `flattenSpec` gives me a single row that looks like:\r\n\r\n    lastseen              | name\r\n    2021-02-15T05:02Z     | Temperature Sensor A\r\n\r\n**How can I get Druid to see all the rows?** What is the right flattenSpec (or jq / JSONPath expression)?\r\n\r\nI am not concerned about performance, but I would prefer not to have to spin up more proxy-like services between the HTTP server and Druid.\r\n\r\n  [1]: https://druid.apache.org/docs/0.19.0/ingestion/data-formats.html#flattenspec",
        "link": "https://stackoverflow.com/questions/66205415/apache-druid-ingesting-multiple-objects-in-flat-json-data-returns-only-single",
        "title": "Apache Druid – Ingesting multiple objects in flat JSON data returns only single row"
    },
    {
        "tags": [
            "linux",
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "user_type": "does_not_exist",
                    "display_name": "user2849202"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1613405638,
                "post_id": 66211414,
                "comment_id": 117059088,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "user_type": "does_not_exist",
                    "display_name": "user2849202"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1613405738,
                "post_id": 66211414,
                "comment_id": 117059128,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 8198,
                    "reputation": 182934,
                    "user_id": 14637,
                    "user_type": "registered",
                    "accept_rate": 88,
                    "profile_image": "https://www.gravatar.com/avatar/1904e7096278a10f1dfb3fdc0ceb53cc?s=256&d=identicon&r=PG",
                    "display_name": "Thomas",
                    "link": "https://stackoverflow.com/users/14637/thomas"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1613406066,
                "post_id": 66211414,
                "comment_id": 117059281,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 955045,
                    "reputation": 1650,
                    "user_id": 980515,
                    "user_type": "registered",
                    "accept_rate": 40,
                    "profile_image": "https://www.gravatar.com/avatar/0d3e9bf3a67f85b77a6cf587b07f798f?s=256&d=identicon&r=PG",
                    "display_name": "Fabry",
                    "link": "https://stackoverflow.com/users/980515/fabry"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1613406339,
                "post_id": 66211414,
                "comment_id": 117059417,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 955045,
                    "reputation": 1650,
                    "user_id": 980515,
                    "user_type": "registered",
                    "accept_rate": 40,
                    "profile_image": "https://www.gravatar.com/avatar/0d3e9bf3a67f85b77a6cf587b07f798f?s=256&d=identicon&r=PG",
                    "display_name": "Fabry",
                    "link": "https://stackoverflow.com/users/980515/fabry"
                },
                "reply_to_user": {
                    "account_id": 8198,
                    "reputation": 182934,
                    "user_id": 14637,
                    "user_type": "registered",
                    "accept_rate": 88,
                    "profile_image": "https://www.gravatar.com/avatar/1904e7096278a10f1dfb3fdc0ceb53cc?s=256&d=identicon&r=PG",
                    "display_name": "Thomas",
                    "link": "https://stackoverflow.com/users/14637/thomas"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1613406388,
                "post_id": 66211414,
                "comment_id": 117059446,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 14709065,
                    "reputation": 9923,
                    "user_id": 10622916,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/0022d8bc5b72b83b2ff1a2a54b571f03?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Bodo",
                    "link": "https://stackoverflow.com/users/10622916/bodo"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1613406979,
                "post_id": 66211414,
                "comment_id": 117059729,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 955045,
                    "reputation": 1650,
                    "user_id": 980515,
                    "user_type": "registered",
                    "accept_rate": 40,
                    "profile_image": "https://www.gravatar.com/avatar/0d3e9bf3a67f85b77a6cf587b07f798f?s=256&d=identicon&r=PG",
                    "display_name": "Fabry",
                    "link": "https://stackoverflow.com/users/980515/fabry"
                },
                "reply_to_user": {
                    "account_id": 14709065,
                    "reputation": 9923,
                    "user_id": 10622916,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/0022d8bc5b72b83b2ff1a2a54b571f03?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Bodo",
                    "link": "https://stackoverflow.com/users/10622916/bodo"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1613407560,
                "post_id": 66211414,
                "comment_id": 117060006,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1613407984,
                "creation_date": 1613407984,
                "answer_id": 66212124,
                "question_id": 66211414,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Instead of using `&lt;&lt;&lt; $(...)` use: `&lt; &lt;(...)`",
                "title": "Bash Command grouping on nested while loops"
            },
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1613408018,
                "creation_date": 1613408018,
                "answer_id": 66212133,
                "question_id": 66211414,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "This should work :\r\n\r\n```\r\n#!/usr/bin/env bash\r\n  \r\nmetrics=&#39;{&quot;names&quot;:[&quot;metric1&quot;,&quot;metric12&quot;]}&#39;\r\n\r\ndata=&quot;{\\&quot;metrics\\&quot;:[&quot;\r\n\r\nwhile IFS=$&#39;\\t&#39; read -r name; do\r\n  metric=$(curl &quot;https://localhost/..../${name}&quot;)\r\n  tagName=$(echo &quot;${metric}&quot; | ./jq -r &quot;.availableTags[0].tag&quot;)\r\n\r\n  while IFS=$&#39;\\t&#39; read -r tagValue; do\r\n      metricResult=$(curl &quot;https://localhost/...../${name}?tag=${tagName}:${tagValue}&quot;)\r\n      metricName=&quot;BAL BLA BLA&quot;\r\n      metricValue=$(echo &quot;${metricResult}&quot; | ./jq &quot;.measurements[0].value&quot;)\r\n\r\n      metricJson=&quot;{\\&quot;metric\\&quot;:\\&quot;${metricName}\\&quot;,\\&quot;metricValue\\&quot;:${metricValue}},&quot;\r\n     \r\n      data=&quot;${data}${metricJson}&quot;\r\n  done &lt; &lt;(echo &quot;${metric}&quot; | ./jq -r &quot;.availableTags[0].values[]&quot;)\r\n\r\ndone &lt; &lt;(echo &quot;${metrics}&quot; | ./jq -r &quot;.names[]&quot;)\r\n\r\necho &quot;${data}&quot;\r\n```",
                "title": "Bash Command grouping on nested while loops"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1613408018,
        "creation_date": 1613405270,
        "last_edit_date": 1613407532,
        "question_id": 66211414,
        "body_markdown": "How can I use command grouping in order to modify the global variable &quot;data&quot; of the following script?\r\n\r\n    metrics=&#39;{&quot;names&quot;:[&quot;metric1&quot;,&quot;metric12&quot;]}&#39;\r\n\r\n    data=&quot;{\\&quot;metrics\\&quot;:[&quot;\r\n\r\n    echo &quot;${metrics}&quot; | ./jq -r &quot;.names[]&quot; |\r\n    while IFS=$&#39;\\t&#39; read -r name; do\r\n      metric=$(curl &quot;https://localhost/..../${name}&quot;)\r\n      tagName=$(echo &quot;${metric}&quot; | ./jq -r &quot;.availableTags[0].tag&quot;)\r\n\r\n      echo &quot;${metric}&quot; | ./jq -r &quot;.availableTags[0].values[]&quot;  |\r\n      while IFS=$&#39;\\t&#39; read -r tagValue; do\r\n\t      metricResult=$(curl &quot;https://localhost/...../${name}?tag=${tagName}:${tagValue}&quot;)\r\n\t      metricName=&quot;BAL BLA BLA&quot;\r\n\t      metricValue=$(echo &quot;${metricResult}&quot; | ./jq &quot;.measurements[0].value&quot;)\r\n\r\n\t      metricJson=&quot;{\\&quot;metric\\&quot;:\\&quot;${metricName}\\&quot;,\\&quot;metricValue\\&quot;:${metricValue}},&quot;\r\n\t     \r\n          data=&quot;${data}${metricJson}&quot;\r\n      done\r\n  \r\n    done\r\n\r\n    echo &quot;${data}&quot;\r\n\r\nAs per my understanding each while-loop is executed in a subshell, therefore the global &quot;data&quot; variable will not be modified. \r\nI was thinking to use `command grouping` but so far no luck.\r\n\r\n**EDIT**\r\n\r\nI tried with the following but it is not working:\r\n\r\n    while IFS=$&#39;\\t&#39; read -r name; do\r\n      echo &quot;######## ${name}&quot;\r\n     \r\n      while IFS=&quot; &quot; read -r tagValue; do\r\n        #.....  \r\n      done &lt;&lt;&lt; $(echo &quot;${metric}&quot; | ./jq -r &quot;.availableTags[0].values[]&quot;)\r\n  \r\n    done &lt;&lt;&lt; $(echo &quot;${metrics}&quot; | ./jq -r &quot;.names[]&quot;)\r\n\r\nNow The while-loop is not working, the output of `echo ${name}` is `metric1 metric12`. I tried to use this `IFS=&#39; &#39; read -r ..` or this ` IFS= read -r ..` but still the variable `name` is not containing a single metric but all of them",
        "link": "https://stackoverflow.com/questions/66211414/bash-command-grouping-on-nested-while-loops",
        "title": "Bash Command grouping on nested while loops"
    }
]