[
    {
        "tags": [
            "linux",
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1689537777,
                "post_id": 76700103,
                "comment_id": 135224039,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1689563772,
                "last_edit_date": 1689563772,
                "creation_date": 1689548247,
                "answer_id": 76700733,
                "question_id": 76700103,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "&gt; Is there a way I can pass my custom function to jq select function?\r\n\r\nNo, not if it&#39;s a bash function.  See also @pmf&#39;s comments.\r\n\r\nIn the context of jq (and in many other contexts as well), it&#39;s usually better to think in terms of &quot;passing in data&quot; rather than &quot;passing in functions&quot;.  In the present case, the latter leads to a very simple solution.\r\n\r\nIf bookmark.json contains the stream of JSON as shown, then you could simply use the following invocation of jq to obtain the desired result:\r\n```\r\n&lt; bookmark.json jq -r --arg keyword Networking &#39;\r\n  select(.name | index($keyword))\r\n&#39; \r\n```\r\n\r\nAs pointed out by @pmf, `index` is case-sensitive.  If you want the check to be case-insensitive, then there are various possibilities, depending on your detailed requirements, e.g. with respect to robustness, Unicode case-folding rules, etc.  One possibility to consider would be to use `ascii_upcase`, e.g.:\r\n```\r\n    ($keyword | ascii_upcase) as $k\r\n    | select(.name | ascii_upcase | index($k))\r\n```\r\n",
                "title": "Is there a way I can pass my custom function to jq select function?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1689563772,
        "creation_date": 1689536237,
        "last_edit_date": 1689536481,
        "question_id": 76700103,
        "body_markdown": "I have this code where I want to check if a name attribute in JSON objects contains a particular word.\r\n\r\nIn the fetchLog function, I am using jq to query objects that contain a particular word. The function **checkName** in the jq code to check if the name attribute contains the keyword $1 which is an argument to the function **fetchLog**.\r\n\r\n\r\n```\r\nfunction fetchLog(){\r\n   jq -r &#39;.roots.bookmark_bar.children[]&#39; | \\\r\n   jq &#39;{name,url} | select((checkName .name $1) == true)&#39; bookmark.json\r\n}\r\n\r\nfunction checkName()\r\n{\r\n   if [[ $1 == *&quot;$2&quot;* ]]; then\r\n      echo true\r\n   else\r\n      echo false\r\n   fi\r\n}\r\n\r\n```\r\nbookmark.json contain:\r\n```\r\n{\r\n  &quot;name&quot;: &quot;Networking&quot;,\r\n  &quot;url&quot;: &quot;https://www.youtube.com/watch?v=AhOU2eOpmX0&amp;list=PLIFyRwBY_4bRLmKfP1KnZA6rZbRHtxmXi&amp;index=7&quot;\r\n}\r\n{\r\n  &quot;name&quot;: &quot;algorithm - How are ssl certificates verified? - Stack Overflow&quot;,\r\n  &quot;url&quot;: &quot;https://stackoverflow.com/questions/188266/how-are-ssl-certificates-verified&quot;\r\n}\r\n{\r\n  &quot;name&quot;: &quot;(170) What is SSL &amp; TLS ? What is HTTPS ? What is an SSL VPN? - Practical TLS - YouTube&quot;,\r\n  &quot;url&quot;: &quot;https://www.youtube.com/watch?v=HMoFvRK4HUo&amp;list=PLIFyRwBY_4bTwRX__Zn4-letrtpSj1mzY&quot;\r\n}\r\n```\r\n\r\nWhen I run `fetchLog networking`.\r\n\r\nI keep getting an error:\r\n```\r\n+ jq &#39;{name,url} | select((checkName .name $1) == true)&#39;\r\njq: error: syntax error, unexpected &#39;$&#39; (Unix shell quoting issues?) at &lt;top-level&gt;, line 1:\r\n{name,url} | select((checkName .name $1) == true)                                     \r\njq: 1 compile error\r\n```\r\n\r\nI expected the output of \r\n```\r\nfetchLog networking\r\n``` \r\nto be\r\n```\r\n{\r\n    &quot;name&quot;: &quot;Networking&quot;,\r\n    &quot;url&quot;: &quot;https://www.youtube.com/watch?v=AhOU2eOpmX0&amp;list=PLIFyRwBY_4bRLmKfP1KnZA6rZbRHtxmXi&amp;index=7&quot;\r\n}\r\n```\r\n\r\ninstead of the error:\r\n```\r\n+ jq &#39;{name,url} | select((checkName .name $1) == true)&#39;\r\njq: error: syntax error, unexpected &#39;$&#39; (Unix shell quoting issues?) at &lt;top-level&gt;, line 1:\r\n{name,url} | select((checkName .name $1) == true)                                     \r\njq: 1 compile error\r\n```",
        "link": "https://stackoverflow.com/questions/76700103/is-there-a-way-i-can-pass-my-custom-function-to-jq-select-function",
        "title": "Is there a way I can pass my custom function to jq select function?"
    },
    {
        "tags": [
            "json",
            "github-actions",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 10402418,
                    "reputation": 14920,
                    "user_id": 7670262,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/3zdDY.jpg?s=256",
                    "display_name": "Azeem",
                    "link": "https://stackoverflow.com/users/7670262/azeem"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1689567682,
                "post_id": 76701305,
                "comment_id": 135226321,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 11029926,
                    "reputation": 65,
                    "user_id": 8101554,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/Hnrmw.jpg?s=256",
                    "display_name": "Jesse O",
                    "link": "https://stackoverflow.com/users/8101554/jesse-o"
                },
                "reply_to_user": {
                    "account_id": 10402418,
                    "reputation": 14920,
                    "user_id": 7670262,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/3zdDY.jpg?s=256",
                    "display_name": "Azeem",
                    "link": "https://stackoverflow.com/users/7670262/azeem"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1689568765,
                "post_id": 76701305,
                "comment_id": 135226405,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 10402418,
                    "reputation": 14920,
                    "user_id": 7670262,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/3zdDY.jpg?s=256",
                    "display_name": "Azeem",
                    "link": "https://stackoverflow.com/users/7670262/azeem"
                },
                "edited": false,
                "score": 3,
                "creation_date": 1689568840,
                "post_id": 76701305,
                "comment_id": 135226418,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 10402418,
                    "reputation": 14920,
                    "user_id": 7670262,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/3zdDY.jpg?s=256",
                    "display_name": "Azeem",
                    "link": "https://stackoverflow.com/users/7670262/azeem"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1689569001,
                "post_id": 76701305,
                "comment_id": 135226437,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1699313707,
                "last_edit_date": 1699313707,
                "creation_date": 1697183090,
                "answer_id": 77285919,
                "question_id": 76701305,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The comment from [@Azeem](https://stackoverflow.com/users/7670262/azeem) resolved my issue:\r\n\r\n    RESPONSE=$(aws sqs ... --output json | jq -c)\r\n\r\nAs I believe some readers might overlook the comment, I&#39;ve posted it here.\r\n",
                "title": "How to store json output in a variable and use it in another step in Github actions"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1699313707,
        "creation_date": 1689563937,
        "last_edit_date": 1689568833,
        "question_id": 76701305,
        "body_markdown": "I have a step in github actions that gets a message from sqs queue. The response is an object with a message array. [receive_message_sqs][2] But then I try to get the ReceiptHandle from the object in the array but i keep running into this error. \r\n\r\n\r\nHere is the step that receives the message\r\n````\r\n     - name: Receive Message from SQS Queue\r\n        id: receive_message\r\n        run: |\r\n          RESPONSE=$(aws sqs receive-message --queue-url https://sqs.us-east-1.amazonaws.com/my-queue.fifo \\\r\n          --attribute-names All \\\r\n          --message-attribute-names All --max-number-of-messages 10 --output json)\r\n          echo &quot;::set-output name=receipt_handle::$RESPONSE&quot;\r\n````\r\n\r\nHere is the next step that uses the the Response from the previous step. I want to extract the receipt_handle from the RESPONSE and into a variable and check if it worked. I need the first object in the array\r\n````\r\n      - name: Check ReceiptHandle\r\n        id: check_receipt_handle\r\n        run: |\r\n          RECEIPT_HANDLE=$(echo &quot;${{ steps.receive_message.outputs.receipt_handle }}&quot; | jq -r &#39;.Messages[0].ReceiptHandle&#39;)\r\n          if [ -z &quot;$RECEIPT_HANDLE&quot; ]; then\r\n            echo &quot;ReceiptHandle is empty. Failing the workflow.&quot;\r\n            exit 1\r\n          else\r\n            echo &quot;ReceiptHandle: $RECEIPT_HANDLE&quot;\r\n          fi\r\n          echo &quot;::set-output name=receipt_handle::$RECEIPT_HANDLE&quot;\r\n````\r\n\r\nHere is a screenshot of what the object looks like\r\n[![enter image description here][3]][3]\r\n\r\n\r\n\r\n\r\nThis is the error i am getting back for the check ReceiptHandle step. Looks like something that has to do with json parsing.\r\n[![enter image description here][4]][4]\r\n\r\n\r\nIs there a way to solve this?\r\n\r\n\r\n  [1]: https://i.sstatic.net/WVMyO.png\r\n  [2]: https://awscli.amazonaws.com/v2/documentation/api/latest/reference/sqs/receive-message.html\r\n  [3]: https://i.sstatic.net/6EKbj.jpg\r\n  [4]: https://i.sstatic.net/46ONj.png\r\n\r\n[![enter image description here][1]][1]",
        "link": "https://stackoverflow.com/questions/76701305/how-to-store-json-output-in-a-variable-and-use-it-in-another-step-in-github-acti",
        "title": "How to store json output in a variable and use it in another step in Github actions"
    },
    {
        "tags": [
            "json",
            "unix",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1689597096,
                "last_edit_date": 1689597096,
                "creation_date": 1689595065,
                "answer_id": 76704229,
                "question_id": 76703471,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Assuming you want to compare items of matching positions within their respective streams, you could slurp just one file, and successively read in the other file&#39;s items as a stream using `input` while iterating over the slurped ones using `$file1[]`:\r\n```sh\r\n&lt;File2.json jq --slurpfile file1 File1.json -rn \\\r\n  &#39;$file1[] | select(.transferIN != input.transferIN).IPs[]&#39;\r\n```\r\n```\r\n10.1.1.2/32\r\n10.1.1.4/32\r\n```\r\n",
                "title": "Compare two JSON files and select all entries with a changed attribute"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1689597096,
        "creation_date": 1689588995,
        "question_id": 76703471,
        "body_markdown": "I have two JSON files with peers statistics:\r\n\r\nFile1.json:\r\n```\r\n{\r\n  &quot;transferIN&quot;: 111111,\r\n  &quot;transferOUT&quot;: 111234,\r\n  &quot;IPs&quot;: [\r\n    &quot;10.1.1.1/32&quot;\r\n  ]\r\n}\r\n{\r\n  &quot;transferIN&quot;: 111222,\r\n  &quot;transferOUT&quot;: 222234,\r\n  &quot;IPs&quot;: [\r\n    &quot;10.1.1.2/32&quot;\r\n  ]\r\n}\r\n{\r\n  &quot;transferIN&quot;: 111333,\r\n  &quot;transferOUT&quot;: 333556,\r\n  &quot;IPs&quot;: [\r\n    &quot;10.1.1.3/32&quot;\r\n  ]\r\n}\r\n{\r\n  &quot;transferIN&quot;: 111444,\r\n  &quot;transferOUT&quot;: 444875,\r\n  &quot;IPs&quot;: [\r\n    &quot;10.1.1.4/32&quot;\r\n  ]\r\n}\r\n```\r\n\r\n\r\nFile2.json:\r\n```\r\n{\r\n  &quot;transferIN&quot;: 111111,\r\n  &quot;transferOUT&quot;: 111234,\r\n  &quot;IPs&quot;: [\r\n    &quot;10.1.1.1/32&quot;\r\n  ]\r\n}\r\n{\r\n  &quot;transferIN&quot;: 111345,\r\n  &quot;transferOUT&quot;: 222233,\r\n  &quot;IPs&quot;: [\r\n    &quot;10.1.1.2/32&quot;\r\n  ]\r\n}\r\n{\r\n  &quot;transferIN&quot;: 111333,\r\n  &quot;transferOUT&quot;: 333990,\r\n  &quot;IPs&quot;: [\r\n    &quot;10.1.1.3/32&quot;\r\n  ]\r\n}\r\n{\r\n  &quot;transferIN&quot;: 111446,\r\n  &quot;transferOUT&quot;: 4448456,\r\n  &quot;IPs&quot;: [\r\n    &quot;10.1.1.4/32&quot;\r\n  ]\r\n}\r\n```\r\n\r\nI want to compare them and get a list of IPs only which has a changed &quot;transferIN&quot; key.\r\n\r\nSo output should be like this:\r\n10.1.1.2/32\r\n10.1.1.4/32\r\n\r\nI will use this in the bash script. So I started to look into jq.\r\n\r\n\r\nWhat I did:\r\n\r\n\r\n```\r\njq -n --slurpfile file1 File1.json --slurpfile file2 File2.json &#39;$file2 - $file1&#39; | jq .[] | jq -r .IPs[]\r\n```\r\n\r\nBut this only show peers that have any changed stats (transferOUT can change also)\r\n\r\n10.1.1.2/32\r\n10.1.1.3/32\r\n10.1.1.4/32\r\n\r\nAlso looked to INDEX and map_values but with no result.",
        "link": "https://stackoverflow.com/questions/76703471/compare-two-json-files-and-select-all-entries-with-a-changed-attribute",
        "title": "Compare two JSON files and select all entries with a changed attribute"
    },
    {
        "tags": [
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1689606777,
                "post_id": 76705819,
                "comment_id": 135233805,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 3899033,
                    "reputation": 23527,
                    "user_id": 3227319,
                    "user_type": "registered",
                    "accept_rate": 48,
                    "profile_image": "https://www.gravatar.com/avatar/07963e9a55d88a99656dd16ecebd25f9?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Jordi",
                    "link": "https://stackoverflow.com/users/3227319/jordi"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1689607254,
                "post_id": 76705819,
                "comment_id": 135233927,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "reply_to_user": {
                    "account_id": 6313442,
                    "reputation": 45115,
                    "user_id": 5625547,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/oqCND.jpg?s=256",
                    "display_name": "0stone0",
                    "link": "https://stackoverflow.com/users/5625547/0stone0"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1689607259,
                "post_id": 76705819,
                "comment_id": 135233928,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1689672359,
                "last_edit_date": 1689672359,
                "creation_date": 1689606847,
                "answer_id": 76705868,
                "question_id": 76705819,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "To delete all `headers` and `cookies` from every nested object, use\r\n\r\n```\r\nmap(.[] |= del(.headers?, .cookies?))\r\n```\r\n\r\n##### [Jqplay Demo](https://jqplay.org/s/6BqCMHyrp_3)\r\n\r\n----------\r\n\r\nIf you don&#39;t want to remove them from every object, rather just a few, listing each item in a `del` would be enough:\r\n```\r\nmap(del(.httpRequest.cookies, .httpRequest.headers, .httpResponse.headers, .httpResponse.cookies))\r\n```\r\n##### [JqPlay Demo](https://jqplay.org/s/hW7p1IUNOU_o)\r\n\r\n----------\r\n\r\nIf you would like to keep a few hardcoded keys for each `.httpRequest` and `.httpResponse`, you can [`map()`][1] over them and them update ([`|=`][2]) that key:\r\n```\r\nmap(.httpRequest |= { method } | .httpResponse |= { statusCode })\r\n```\r\n\r\n##### [JqPlay Demo](https://jqplay.org/s/cQ1fx_Xqj-x)\r\n\r\n\r\n----------\r\n\r\n\r\nThen, based on OP&#39;s [comment][3], if you want to specify a few keys inside `.header`, instead of using the short hand, define the key and then use the same update logic to keep a few keys:\r\n```\r\nmap(.httpRequest |= { method } | .httpResponse |= { headers: (.headers | { Expires }), statusCode })\r\n```\r\n\r\n##### [JqPlay Demo](https://jqplay.org/s/fVLf8xm1_UC)\r\n\r\n\r\n----------\r\n\r\nAs asked in OP&#39;s [new comment](https://stackoverflow.com/questions/76705819/jq-remove-fields-form-item-array/76705868?noredirect=1#comment135242625_76705868), on to extend above filter to remove any other top leven keys; We can use the same strategy, create a new object (so we don&#39;t need to `del` everything), but update the required keys with the same logic as above\r\n```\r\nmap({ \r\n    httpRequest: (.httpRequest | { method }),\r\n    httpResponse: (.httpResponse | { headers: (.headers | { Expires }), statusCode }),\r\n})\r\n```\r\n\r\n##### [JqPlay Demo](https://jqplay.org/s/MVGFsPuD6cR)\r\n\r\n  [1]: https://jqlang.github.io/jq/manual/#map(f),map_values(f)\r\n  [2]: https://jqlang.github.io/jq/manual/#Update-assignment:%7C=\r\n  [3]: https://stackoverflow.com/questions/76705819/jq-remove-fields-form-item-array/76705868?noredirect=1#comment135234250_76705868",
                "title": "jq: Remove fields form item array"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1689672359,
        "creation_date": 1689606496,
        "question_id": 76705819,
        "body_markdown": "This is my desired output:\r\n\r\n```lang-yaml\r\n[\r\n  {\r\n    &quot;httpRequest&quot;: {\r\n      &quot;method&quot;: &quot;POST&quot;,\r\n      &quot;path&quot;: &quot;/catalog-data-rest/catalog/search.xml&quot;,\r\n      &quot;body&quot;: {\r\n        &quot;type&quot;: &quot;STRING&quot;,\r\n        &quot;string&quot;: &quot;&lt;request&gt;&lt;oid&gt;2.16.840.1.113883.4.292.10.12&lt;/oid&gt;&lt;startIndex&gt;1&lt;/startIndex&gt;&lt;pageSize&gt;100&lt;/pageSize&gt;&lt;/request&gt;&quot;,\r\n        &quot;contentType&quot;: &quot;text/html; charset=utf-8&quot;\r\n      }\r\n    },\r\n    &quot;httpResponse&quot;: {\r\n      &quot;statusCode&quot;: 200,\r\n      &quot;reasonPhrase&quot;: &quot;OK&quot;,\r\n      &quot;headers&quot;: {\r\n        &quot;Content-Type&quot;: [\r\n          &quot;application/xml&quot;\r\n        ]\r\n      },\r\n      &quot;body&quot;: {\r\n        &quot;type&quot;: &quot;XML&quot;,\r\n        &quot;xml&quot;: &quot;&lt;?xml version= \\&quot;1.0\\&quot; encoding=\\&quot;UTF-8\\&quot; standalone=\\&quot;yes\\&quot;?&gt; &lt;resultSet&gt; &lt;request&gt; &lt;oid&gt;2.16.840.1.113883.4.292.10.12&lt;/oid&gt;...&quot;,\r\n        &quot;contentType&quot;: &quot;application/xml&quot;\r\n      }\r\n    }\r\n  },\r\n  {\r\n    //...\r\n  }\r\n]\r\n```\r\n\r\nThe problem is that my raw source is a bit not clear and I need to clear it up:\r\n\r\n```lang-yaml\r\n[ {\r\n  &quot;httpRequest&quot; : {\r\n    &quot;method&quot; : &quot;POST&quot;,\r\n    &quot;path&quot; : &quot;/catalog-data-rest/catalog/search.xml&quot;,\r\n    &quot;headers&quot; : {\r\n      &quot;content-length&quot; : [ &quot;141&quot; ],\r\n      &quot;content-encoding&quot; : [ &quot;.*&quot; ],\r\n      &quot;User-Agent&quot; : [ &quot;Apache-HttpClient/4.5.13 (Java/11.0.19)&quot; ],\r\n      &quot;Host&quot; : [ &quot;preproduccio.gcatalegs.isisscat.intranet.gencat.cat:8443&quot; ],\r\n      &quot;Cookie&quot; : [ &quot;JSESSIONID=0000DVEWfJHnChmIF3Qm8fS7AOG:19pp48tgo&quot; ],\r\n      &quot;Content-Type&quot; : [ &quot;text/xml;charset=UTF-8&quot; ],\r\n      &quot;Connection&quot; : [ &quot;Keep-Alive&quot; ],\r\n      &quot;Authorization&quot; : [ &quot;Basic VVNVTVBJVFNUOkJ4c2w3MjU5&quot; ],\r\n      &quot;Accept-Encoding&quot; : [ &quot;gzip,deflate&quot; ]\r\n    },\r\n    &quot;cookies&quot; : {\r\n      &quot;JSESSIONID&quot; : &quot;0000DVEWfJHnChmIF3Qm8fS7AOG:19pp48tgo&quot;\r\n    },\r\n    &quot;keepAlive&quot; : true,\r\n    &quot;secure&quot; : true,\r\n    &quot;localAddress&quot; : &quot;127.0.0.1:1080&quot;,\r\n    &quot;remoteAddress&quot; : &quot;127.0.0.1&quot;,\r\n    &quot;body&quot; : {\r\n      &quot;type&quot; : &quot;XML&quot;,\r\n      &quot;xml&quot; : &quot;&lt;request&gt;&lt;tableName&gt;ET 99CCA&lt;/tableName&gt;&lt;owner&gt;&lt;ownerType&gt;REF&lt;/ownerType&gt;&lt;/owner&gt;&lt;startIndex&gt;1&lt;/startIndex&gt;&lt;pageSize&gt;100&lt;/pageSize&gt;&lt;/request&gt;&quot;,\r\n      &quot;rawBytes&quot; : &quot;PHJlcXVlc3Q+PHRhYmxlTmFtZT5FVCA5OUNDQTwvdGFibGVOYW1lPjxvd25lcj48b3duZXJUeXBlPlJFRjwvb3duZXJUeXBlPjwvb3duZXI+PHN0YXJ0SW5kZXg+MTwvc3RhcnRJbmRleD48cGFnZVNpemU+MTAwPC9wYWdlU2l6ZT48L3JlcXVlc3Q+&quot;,\r\n      &quot;contentType&quot; : &quot;text/xml; charset=utf-8&quot;\r\n    }\r\n  },\r\n  &quot;httpResponse&quot; : {\r\n    &quot;statusCode&quot; : 200,\r\n    &quot;reasonPhrase&quot; : &quot;OK&quot;,\r\n    &quot;headers&quot; : {\r\n      &quot;X-XSS-Protection&quot; : [ &quot;1; mode=block&quot; ],\r\n      &quot;X-Powered-By&quot; : [ &quot;Servlet/3.0&quot; ],\r\n      &quot;X-Frame-Options&quot; : [ &quot;DENY&quot; ],\r\n      &quot;X-Content-Type-Options&quot; : [ &quot;nosniff&quot; ],\r\n      &quot;Strict-Transport-Security&quot; : [ &quot;max-age=31536000 ; includeSubDomains&quot; ],\r\n      &quot;Set-Cookie&quot; : [ &quot;JSESSIONID=0000NOyZg7ww-mcbN2YfxKE-957:19pp48tgo; Path=/; Secure; HttpOnly&quot; ],\r\n      &quot;Pragma&quot; : [ &quot;no-cache&quot; ],\r\n      &quot;Expires&quot; : [ &quot;0&quot; ],\r\n      &quot;Date&quot; : [ &quot;Mon, 17 Jul 2023 15:01:13 GMT&quot; ],\r\n      &quot;Content-Type&quot; : [ &quot;application/xml&quot; ],\r\n      &quot;Content-Language&quot; : [ &quot;en-US&quot; ],\r\n      &quot;Cache-Control&quot; : [ &quot;no-cache, no-store, max-age=0, must-revalidate&quot; ]\r\n    },\r\n    &quot;cookies&quot; : {\r\n      &quot;JSESSIONID&quot; : &quot;0000NOyZg7ww-mcbN2YfxKE-957:19pp48tgo&quot;\r\n    },\r\n    &quot;body&quot; : {\r\n      &quot;type&quot; : &quot;XML&quot;,\r\n      &quot;xml&quot; : &quot;&lt;?xml version=\\&quot;1.0\\&quot; encoding=\\&quot;UTF-8\\&quot; standalone=\\&quot;yes\\&quot;?&gt;&lt;resultSet&gt;&lt;request&gt;&lt;tableName&gt;ET 99CCA&lt;/tableName&gt;&lt;owner&gt;&lt;ownerType&gt;RE...&quot;,\r\n      &quot;rawBytes&quot; : &quot;PD94bWwgdmVyc2lvbj0iMS4wIiBlb...&quot;,\r\n      &quot;contentType&quot; : &quot;application/xml&quot;\r\n    }\r\n  },\r\n  &quot;id&quot; : &quot;8755ddd1-835c-40fe-870f-decf16242e4e&quot;,\r\n  &quot;priority&quot; : 0,\r\n  &quot;timeToLive&quot; : {\r\n    &quot;unlimited&quot; : true\r\n  },\r\n  &quot;times&quot; : {\r\n    &quot;remainingTimes&quot; : 1\r\n  }\r\n} ]\r\n```\r\n\r\nHow could I remove `httpRequest.headers` and `httpRequest.cookies` from each item in array?",
        "link": "https://stackoverflow.com/questions/76705819/jq-remove-fields-form-item-array",
        "title": "jq: Remove fields form item array"
    },
    {
        "tags": [
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1689643673,
                "post_id": 76708990,
                "comment_id": 135239560,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 4879,
                    "reputation": 248190,
                    "user_id": 7552,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/b60298053f87465641c1b1192338c8cd?s=256&d=identicon&r=PG",
                    "display_name": "glenn jackman",
                    "link": "https://stackoverflow.com/users/7552/glenn-jackman"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1689644290,
                "post_id": 76708990,
                "comment_id": 135239600,
                "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": 1689644516,
                "post_id": 76708990,
                "comment_id": 135239618,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1720922,
                    "reputation": 4234,
                    "user_id": 1576804,
                    "user_type": "registered",
                    "accept_rate": 53,
                    "profile_image": "https://www.gravatar.com/avatar/1d8c02f1526bc8baeb2fd08b8b82f772?s=256&d=identicon&r=PG",
                    "display_name": "vkaul11",
                    "link": "https://stackoverflow.com/users/1576804/vkaul11"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1689644732,
                "post_id": 76708990,
                "comment_id": 135239636,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 32384,
                    "reputation": 127026,
                    "user_id": 89817,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/df253c3b6533949ea94f31f328f3e769?s=256&d=identicon&r=PG",
                    "display_name": "Gordon Davisson",
                    "link": "https://stackoverflow.com/users/89817/gordon-davisson"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1689646850,
                "post_id": 76708990,
                "comment_id": 135239800,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1689699333,
                "creation_date": 1689699333,
                "answer_id": 76715035,
                "question_id": 76708990,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "This looks complicated and definitely doesn&#39;t require `bash`, the simple `sh` should suffice here.\r\n\r\nWhy store the output of the command in a variable and then print and format + redirect the content of the variable?\r\n\r\n```\r\njq -nc \\\r\n  --arg model &quot;$model_name&quot; \\\r\n  --arg prompt &quot;$name&quot; \\\r\n  &#39;{$model, $prompt}&#39; \\\r\n  &gt;&gt; &quot;$dest_file&quot;\r\n```\r\n\r\nThe option [`-c`](https://jqlang.github.io/jq/manual/v1.6/#Invokingjq) produces _compact output_ which means that everything will be in a single line.",
                "title": "how to print json from bash in single line"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1689699333,
        "creation_date": 1689643377,
        "question_id": 76708990,
        "body_markdown": "I have to derive a json String from a text file but the output happens to go into multiple lines.\r\nMy code \r\n\r\n    #!/usr/bin/bash\r\n    filename=&quot;$1&quot;\r\n    dest_file= output/output.jsonl\r\n    while read -r line; do\r\n        name=&quot;$line&quot;\r\n        echo &quot;Name read from file - $name&quot;\r\n        model_name=&quot;test-model&quot;\r\n        JSON_STRING=$(  jq -n  --arg model &quot;$model_name&quot; --arg prompt &quot;$name&quot; &#39;{model: $model, prompt: $prompt}&#39; )\r\n        printf &quot;%s&quot; &quot;$JSON_STRING&quot; &gt;&gt; &quot;$dest_file&quot;\r\n    done &lt; &quot;$filename&quot;\r\nThe file is a simple test.txt\r\nwith only 1 line \r\n\r\n   \r\n\r\n     primer query\r\n\r\nand the output I get is this  \r\n\r\n    {\r\n      &quot;model&quot;: &quot;test-model&quot;,\r\n      &quot;prompt&quot;: &quot;primer query&quot;\r\n    }\r\n\r\nWhat I want is `{&quot;model&quot;: &quot;test-model&quot;, &quot;prompt&quot;: &quot;primer query&quot;}` in one line\r\nI tried `jq -c` but then it gives empty output\r\n\r\n",
        "link": "https://stackoverflow.com/questions/76708990/how-to-print-json-from-bash-in-single-line",
        "title": "how to print json from bash in single line"
    },
    {
        "tags": [
            "arrays",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 19373190,
                    "reputation": 525,
                    "user_id": 14166067,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/MwI649pB.jpg?s=256",
                    "display_name": "Hasan Raza",
                    "link": "https://stackoverflow.com/users/14166067/hasan-raza"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1689659550,
                "post_id": 76709497,
                "comment_id": 135240875,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 4879,
                    "reputation": 248190,
                    "user_id": 7552,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/b60298053f87465641c1b1192338c8cd?s=256&d=identicon&r=PG",
                    "display_name": "glenn jackman",
                    "link": "https://stackoverflow.com/users/7552/glenn-jackman"
                },
                "reply_to_user": {
                    "account_id": 19373190,
                    "reputation": 525,
                    "user_id": 14166067,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/MwI649pB.jpg?s=256",
                    "display_name": "Hasan Raza",
                    "link": "https://stackoverflow.com/users/14166067/hasan-raza"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1689684677,
                "post_id": 76709497,
                "comment_id": 135246094,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1689689925,
                "post_id": 76709497,
                "comment_id": 135247401,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1689655099,
                "last_edit_date": 1689655099,
                "creation_date": 1689654606,
                "answer_id": 76709543,
                "question_id": 76709497,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s a solution with [`reduce`][1]:\r\n\r\n```sh\r\njq &#39;\r\n    .locals.products | to_entries\r\n    | reduce .[] as $e (\r\n        {}; . + { ($e.key): $e.value | keys }\r\n    )\r\n&#39;\r\n```\r\n\r\nNotice that  both keys in `core-tower2` are identical, which leads to jq dropping the duplicate, resulting in\r\n\r\n```json\r\n{\r\n  &quot;core-tower1&quot;: [\r\n    &quot;core-tower1-product-a&quot;,\r\n    &quot;core-tower1-product-b&quot;\r\n  ],\r\n  &quot;core-tower2&quot;: [\r\n    &quot;core-tower2-product-a&quot;\r\n  ]\r\n}\r\n```\r\n\r\n\r\n  [1]: https://jqlang.github.io/jq/manual/#Reduce",
                "title": "How do I use jq to convert this object to this object?"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1689664936,
                "creation_date": 1689664936,
                "answer_id": 76710357,
                "question_id": 76709497,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If your issue is with the swallowed duplicate keys, then consider using the `--stream` option which provides the input document &quot;in pieces&quot;, so that the parts can be processed before any duplicate keys can collapse. This approach, however, may need more insight into the logical structuring of your document, so let me assume here that you want to generally cut off the first two levels `.[2:]`, build the values array from the level directly above the scalars/leaves (i.e. the second-to-last level, `-2`), and just copy over all levels in between:\r\n```sh\r\njq --stream -n &#39;\r\n  reduce (inputs | select(has(1))[0][2:]) as $p ({};\r\n    setpath($p | .[-2:] |= [last]; $p[-2])\r\n  )\r\n&#39;\r\n```\r\n```json\r\n{\r\n  &quot;core-tower1&quot;: [\r\n    &quot;core-tower1-product-b&quot;,\r\n    &quot;core-tower1-product-b&quot;\r\n  ],\r\n  &quot;core-tower2&quot;: [\r\n    &quot;core-tower2-product-a&quot;,\r\n    &quot;core-tower2-product-a&quot;\r\n  ]\r\n}\r\n```",
                "title": "How do I use jq to convert this object to this object?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1689664936,
        "creation_date": 1689653748,
        "last_edit_date": 1689654722,
        "question_id": 76709497,
        "body_markdown": "I&#39;m trying to convert the object below using jq:\r\n\r\n```json\r\n{\r\n    &quot;locals&quot;: {\r\n      &quot;products&quot;: {\r\n        &quot;core-tower1&quot;: {\r\n          &quot;core-tower1-product-a&quot;: [&quot;dev&quot;],\r\n          &quot;core-tower1-product-b&quot;: [&quot;dev&quot;, &quot;prod&quot;]\r\n        },\r\n        &quot;core-tower2&quot;: {\r\n          &quot;core-tower2-product-a&quot;: [&quot;pol&quot;, &quot;onb&quot;],\r\n          &quot;core-tower2-product-a&quot;: [&quot;dev&quot;, &quot;prod&quot;]\r\n        }\r\n      }\r\n    }\r\n  }\r\n\r\n```\r\n\r\nto this\r\n\r\n     \r\n```json\r\n{\r\n        &quot;core-tower1&quot;: [\r\n          &quot;core-tower1-product-a&quot;,\r\n          &quot;core-tower1-product-b&quot;\r\n        ]\r\n        &quot;core-tower2&quot;: [\r\n          &quot;core-tower2-product-a&quot;,\r\n          &quot;core-tower2-product-a&quot;\r\n        ]\r\n      }\r\n```\r\n\r\nI tried this it as seen below:\r\n\r\n```sh\r\njq {&#39;(.locals.products|keys[])&#39;:&#39;.locals.products|.[]|keys&#39;}\r\n```\r\n\r\nbut I got the result below:\r\n    \r\n```json\r\n {\r\n        &quot;core-tower1&quot;: [\r\n          &quot;core-tower1-product-a&quot;,\r\n          &quot;core-tower1-product-b&quot;\r\n        ]\r\n        &quot;core-tower1&quot;: [\r\n          &quot;core-tower2-product-a&quot;,\r\n          &quot;core-tower2-product-a&quot;\r\n        ]\r\n      }\r\n {\r\n        &quot;core-tower2&quot;: [\r\n          &quot;core-tower1-product-a&quot;,\r\n          &quot;core-tower1-product-b&quot;\r\n        ]\r\n        &quot;core-tower2&quot;: [\r\n          &quot;core-tower2-product-a&quot;,\r\n          &quot;core-tower2-product-a&quot;\r\n        ]\r\n      }\r\n\r\n```\r\n\r\nLet me know if there&#39;s a different way to do this or is jq the best approach here.",
        "link": "https://stackoverflow.com/questions/76709497/how-do-i-use-jq-to-convert-this-object-to-this-object",
        "title": "How do I use jq to convert this object to this object?"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 6313442,
                    "reputation": 45115,
                    "user_id": 5625547,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/oqCND.jpg?s=256",
                    "display_name": "0stone0",
                    "link": "https://stackoverflow.com/users/5625547/0stone0"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1689696220,
                "post_id": 76714308,
                "comment_id": 135249055,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1689696614,
                "post_id": 76714308,
                "comment_id": 135249118,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2196372,
                    "reputation": 11,
                    "user_id": 1941898,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/495d97ab2d0422f625bcbf30e81ecefc?s=256&d=identicon&r=PG",
                    "display_name": "Jim Hastings",
                    "link": "https://stackoverflow.com/users/1941898/jim-hastings"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1689696618,
                "post_id": 76714308,
                "comment_id": 135249120,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2196372,
                    "reputation": 11,
                    "user_id": 1941898,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/495d97ab2d0422f625bcbf30e81ecefc?s=256&d=identicon&r=PG",
                    "display_name": "Jim Hastings",
                    "link": "https://stackoverflow.com/users/1941898/jim-hastings"
                },
                "reply_to_user": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1689696780,
                "post_id": 76714308,
                "comment_id": 135249149,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1689762102,
                "last_edit_date": 1689762102,
                "creation_date": 1689698388,
                "answer_id": 76714923,
                "question_id": 76714308,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You could write your custom merge operation. For instance, iterate over all items, then over each item&#39;s fields, and collect all values in an array under the field&#39;s name under the according `.location` value. Finally, repair the `.location` arrays by replacing them with only their `first` item:\r\n```sh\r\nreduce .[] as $item ({};\r\n  reduce ($item | to_entries[]) as $ent (.;\r\n    .[$item.location][$ent.key] += [$ent.value]\r\n  )\r\n) | map(.location |= first)\r\n```\r\n```json\r\n[\r\n  {\r\n    &quot;location&quot;: &quot;apc1&quot;,\r\n    &quot;type&quot;: [\r\n      &quot;app&quot;,\r\n      &quot;ctl&quot;\r\n    ],\r\n    &quot;fgrp&quot;: [\r\n      &quot;cert-apc-1&quot;\r\n    ],\r\n    &quot;cgrp&quot;: [\r\n      &quot;ctl-apc1&quot;\r\n    ]\r\n  }\r\n]\r\n```\r\n[Demo](https://jqplay.org/s/1KK5CR1DIIQ)\r\n\r\nGoing further, you could concatenate the array values using `join` with a glue string (here `&quot;,&quot;`). Before that, prep the reparation of `.location` to match the type requirements of `join` (which only accepts arrays):\r\n```sh\r\nreduce .[] as $item ({};\r\n  reduce ($item | to_entries[]) as $ent (.;\r\n    .[$item.location][$ent.key] += [$ent.value]\r\n  )\r\n) | map(.location |= [first] | .[] |= join(&quot;,&quot;))\r\n```\r\n```json\r\n[\r\n  {\r\n    &quot;location&quot;: &quot;apc1&quot;,\r\n    &quot;type&quot;: &quot;app,ctl&quot;,\r\n    &quot;fgrp&quot;: &quot;cert-apc-1&quot;,\r\n    &quot;cgrp&quot;: &quot;ctl-apc1&quot;\r\n  }\r\n]\r\n```\r\n[Demo](https://jqplay.org/s/C8VlLnSnkw7)\r\n\r\nFor convenience, you can now wrap this filter into a function definition with its dynamic parts (the index and join expressions) parametrized:\r\n```sh\r\ndef merge(idx_expr; join_expr):\r\n  reduce .[] as $item ({};\r\n    reduce ($item | to_entries[]) as $ent (.;\r\n      .[$item | idx_expr][$ent.key] += [$ent.value]\r\n    )\r\n  ) | map(join_expr);\r\n\r\nmerge(.location; .location |= [first] | .[] |= join(&quot;,&quot;))\r\n```\r\n```json\r\n[\r\n  {\r\n    &quot;location&quot;: &quot;apc1&quot;,\r\n    &quot;type&quot;: &quot;app,ctl&quot;,\r\n    &quot;fgrp&quot;: &quot;cert-apc-1&quot;,\r\n    &quot;cgrp&quot;: &quot;ctl-apc1&quot;\r\n  }\r\n]\r\n```\r\n[Demo](https://jqplay.org/s/aKdPUdftfEC)\r\n\r\nOr give your function a more general-purpose character by excluding the final mapping from it, so it produces an object (not an array) with the indices as keys, thus acting more like an array-valued variant of `group_by` (also making no distinction in processing regarding the indexed field, which after all could be any index expression, not just the value of one common field):\r\n```sh\r\ndef merge_by(f):\r\n  reduce .[] as $item ({};\r\n    reduce ($item | to_entries[]) as $ent (.;\r\n      .[$item|f][$ent.key] += [$ent.value]\r\n    )\r\n  );\r\n\r\nmerge_by(.location)\r\n```\r\n```json\r\n{\r\n  &quot;apc1&quot;: {\r\n    &quot;location&quot;: [\r\n      &quot;apc1&quot;,\r\n      &quot;apc1&quot;\r\n    ],\r\n    &quot;type&quot;: [\r\n      &quot;app&quot;,\r\n      &quot;ctl&quot;\r\n    ],\r\n    &quot;fgrp&quot;: [\r\n      &quot;cert-apc-1&quot;\r\n    ],\r\n    &quot;cgrp&quot;: [\r\n      &quot;ctl-apc1&quot;\r\n    ]\r\n  }\r\n}\r\n```\r\n[Demo](https://jqplay.org/s/hmK_1Xo9HRe)",
                "title": "JQ map and merge"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1689873800,
                "creation_date": 1689873800,
                "answer_id": 76732295,
                "question_id": 76714308,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "&gt; Attempted `group_by(.location) | map(add)` but as noted it basically just keeps the last value.\r\n\r\nFollowing this more functional `group_by`-based approach, you could replace `add` with a custom function that first decomposes its input array (of grouped objects) into a stream of path-value pairs, then flips the first two positions in every path array (from [position, field name] to [field name, position]), and reomposes it again. The result is a single object (the field names moved to first position) with its items containing maps of that field&#39;s values across the group (with `null` (or a shorter array) at positions where the corresponing item did not have that field). Thus, a subsequent `join` would also require the arrays to be reduced to only contain non-null `values`:\r\n\r\n```sh\r\ndef merge: fromstream(tostream | first[:2] |= reverse)\r\n  | .location |= .[:1] | .[] |= (map(values) | join(&quot;,&quot;));\r\n\r\ngroup_by(.location) | map(merge)\r\n```\r\n```json\r\n[\r\n  {\r\n    &quot;location&quot;: &quot;apc1&quot;,\r\n    &quot;type&quot;: &quot;app,ctl&quot;,\r\n    &quot;fgrp&quot;: &quot;cert-apc-1&quot;,\r\n    &quot;cgrp&quot;: &quot;ctl-apc1&quot;\r\n  }\r\n]\r\n```\r\n[Demo](https://jqplay.org/s/AjcJwZqEmOU)\r\n",
                "title": "JQ map and merge"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1689873800,
        "creation_date": 1689693690,
        "last_edit_date": 1689696450,
        "question_id": 76714308,
        "body_markdown": "When I group and add (read merge) objects based on a value I would like to have certain attributes be concatenated together instead of the default &quot;object on the right wins&quot; behavior.\r\n\r\n[demo](https://jqplay.org/s/7wVBGZ3crWs)\r\n\r\nPut another way I would like the addition/merge of these two objects\r\n\r\n```\r\n[\r\n  {\r\n    &quot;location&quot;: &quot;apc1&quot;,\r\n    &quot;type&quot;: &quot;app&quot;,\r\n    &quot;fgrp&quot;: &quot;cert-apc-1&quot;\r\n  },\r\n  {\r\n    &quot;location&quot;: &quot;apc1&quot;,\r\n    &quot;type&quot;: &quot;ctl&quot;,\r\n    &quot;cgrp&quot;: &quot;ctl-apc1&quot;\r\n  }\r\n]\r\n```\r\n\r\nto produce this\r\n\r\n```\r\n[\r\n  {\r\n    &quot;location&quot;: &quot;apc1&quot;,\r\n    &quot;type&quot;: &quot;app,ctl&quot;,\r\n    &quot;fgrp&quot;: &quot;cert-apc-1&quot;,\r\n    &quot;cgrp&quot;: &quot;ctl-apc1&quot;\r\n  }\r\n]\r\n```\r\n\r\nAttempted `group_by(.location) | map(add)` but as noted it basically just keeps the last value.  Also looked at transpose but was unsure it would meet the requirement.  Also, I&#39;m not married to a comma as a delimiter if something else is easier.",
        "link": "https://stackoverflow.com/questions/76714308/jq-map-and-merge",
        "title": "JQ map and merge"
    },
    {
        "tags": [
            "json",
            "rest",
            "curl",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1689766135,
                "last_edit_date": 1689766135,
                "creation_date": 1689765129,
                "answer_id": 76720684,
                "question_id": 76720656,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "```\r\n.result | map(&quot;\\(.fxid)\\n\\(.id)&quot;) | join(&quot;\\n------\\n&quot;)\r\n```\r\n\r\nWill give \r\n```none\r\n03e401a\r\n123\r\n------\r\n03e4099\r\n567\r\n------\r\n867\r\n666\r\n```\r\n\r\nWhen running `jq` with the `--raw-output` option.\r\n\r\n\r\nThe idea is to concat `id` and `fxid` with a newline (`\\n`) and then `join` each item with some horizontal lines wrapped on newlines.\r\n\r\n\r\n----------\r\n\r\nDemo:  \r\n[![ \\[JqPlay Demo\\]][1]](https://jqplay.org/s/kg3PEzd99MS)\r\n\r\n\r\n  [1]: https://i.sstatic.net/U4a22.png",
                "title": "how to use jq to group the parsing json results"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1689766851,
                "creation_date": 1689766851,
                "answer_id": 76720925,
                "question_id": 76720656,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "With\r\n&gt; ```\r\n&gt; .result[].fxid, .result[].id\r\n&gt; ```\r\nyou separately iterate twice over `.result`. Thus, `,` just then concatenates the two lists.\r\n\r\nInstead, iterate once, use a pipe to update the context, and just then concatenate the two (or more) items. That way, the iteration happens outside the concatenation:\r\n```sh\r\njq -r &#39;.result[] | .fxid, .id&#39;\r\n```\r\n```none\r\n03e401a\r\n123\r\n03e4099\r\n567\r\n867\r\n666\r\n```\r\n[Demo](https://jqplay.org/s/1oRu-5Ot7gZ)\r\n\r\nTo generate the blocks, just add more (static) items. For instance:\r\n```sh\r\njq -r &#39;.result[] | .fxid, .id, &quot;---&quot;&#39;\r\n```\r\n```none\r\n03e401a\r\n123\r\n---\r\n03e4099\r\n567\r\n---\r\n867\r\n666\r\n---\r\n```\r\n[Demo](https://jqplay.org/s/8wEo8evwYL-)\r\n\r\nIf you wanted to keep the JSON encoding for the values but not for the separators, use `@json` to re-encode them:\r\n```sh\r\njq -r &#39;.result[] | (.fxid, .id | @json), &quot;_________&quot;&#39;\r\n```\r\n```none\r\n&quot;03e401a&quot;\r\n&quot;123&quot;\r\n_________\r\n&quot;03e4099&quot;\r\n&quot;567&quot;\r\n_________\r\n&quot;867&quot;\r\n&quot;666&quot;\r\n_________\r\n```\r\n[Demo](https://jqplay.org/s/c9El_p3tkB1)",
                "title": "how to use jq to group the parsing json results"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1689768690,
        "creation_date": 1689764893,
        "question_id": 76720656,
        "body_markdown": "I am jq from the terminal , to parse and filter the rest api using curl \r\n\r\nbelow the response\r\n\r\n    {\r\n        &quot;result&quot;: [\r\n            {\r\n                &quot;fxid&quot;: &quot;03e401a&quot;,\r\n                &quot;id&quot;: &quot;123&quot;\r\n            },\r\n            {\r\n                &quot;fxid&quot;: &quot;03e4099&quot;,\r\n                &quot;id&quot;: &quot;567&quot;\r\n            },\r\n            {\r\n                &quot;fxid&quot;: &quot;867&quot;,\r\n                &quot;id&quot;: &quot;666&quot;\r\n            }   \r\n        ]\r\n    }\r\n\r\nand. jq filter am using \r\n\r\n    .result[].fxid,.result[].id\r\n\r\nand i got results as below \r\n\r\n`&quot;03e401a&quot;\r\n&quot;03e4099&quot;\r\n&quot;867&quot;\r\n&quot;123&quot;\r\n&quot;567&quot;\r\n&quot;666&quot;\r\n`\r\n\r\nbut i want the filter results as follows , like grouping for each array element from json response , can anyone help me with this jq filter\r\n\r\n    \r\n    &quot;03e401a&quot;\r\n    &quot;123&quot;\r\n    _________\r\n    &quot;03e4099&quot;\r\n    &quot;567&quot;\r\n    _______\r\n    &quot;867&quot;\r\n    &quot;666&quot;\r\n\r\nTried different jq filters , but nothing worked",
        "link": "https://stackoverflow.com/questions/76720656/how-to-use-jq-to-group-the-parsing-json-results",
        "title": "how to use jq to group the parsing json results"
    },
    {
        "tags": [
            "arrays",
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 6313442,
                    "reputation": 45115,
                    "user_id": 5625547,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/oqCND.jpg?s=256",
                    "display_name": "0stone0",
                    "link": "https://stackoverflow.com/users/5625547/0stone0"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1689771384,
                "post_id": 76721501,
                "comment_id": 135260259,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 29048464,
                    "reputation": 3,
                    "user_id": 22251789,
                    "user_type": "registered",
                    "profile_image": "https://lh3.googleusercontent.com/a/AAcHTtfc6sT8g8ueQIqLKaXwBRBnNXXeEYdt0TZW0OJm1FY9cw=k-s256",
                    "display_name": "agyuajcam",
                    "link": "https://stackoverflow.com/users/22251789/agyuajcam"
                },
                "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": 1689771888,
                "post_id": 76721501,
                "comment_id": 135260398,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1689772827,
                "creation_date": 1689772827,
                "answer_id": 76721768,
                "question_id": 76721501,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s a `reduce`-based approach which simply iterates over the `shape.json` items, adding them to the `INDEX`ed object from `colors.json`. A final `map(.)` re-converts the object into an array:\r\n```sh\r\njq &#39;\r\n  reduce input[] as $i (INDEX(.id);\r\n    .[$i.color.id | tostring].shapes += [$i | {shape, texture}]\r\n  ) | map(.)\r\n&#39; color.json shape.json\r\n```\r\n```json\r\n[\r\n  {\r\n    &quot;id&quot;: 1,\r\n    &quot;color&quot;: &quot;red&quot;,\r\n    &quot;shapes&quot;: [\r\n      {\r\n        &quot;shape&quot;: &quot;square&quot;,\r\n        &quot;texture&quot;: &quot;smooth&quot;\r\n      }\r\n    ]\r\n  },\r\n  {\r\n    &quot;id&quot;: 2,\r\n    &quot;color&quot;: &quot;green&quot;,\r\n    &quot;shapes&quot;: [\r\n      {\r\n        &quot;shape&quot;: &quot;circle&quot;,\r\n        &quot;texture&quot;: &quot;smooth&quot;\r\n      }\r\n    ]\r\n  },\r\n  {\r\n    &quot;id&quot;: 3,\r\n    &quot;color&quot;: &quot;blue&quot;,\r\n    &quot;shapes&quot;: [\r\n      {\r\n        &quot;shape&quot;: &quot;triangle&quot;,\r\n        &quot;texture&quot;: &quot;smooth&quot;\r\n      },\r\n      {\r\n        &quot;shape&quot;: &quot;triangle&quot;,\r\n        &quot;texture&quot;: &quot;rough&quot;\r\n      }\r\n    ]\r\n  }\r\n]\r\n```\r\n[Demo](https://jqplay.org/s/sZQ5z1_YBcx)",
                "title": "Insert json array to another based on key id using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1689826300,
        "creation_date": 1689771046,
        "last_edit_date": 1689826300,
        "question_id": 76721501,
        "body_markdown": "Sorry for a noob question. I got two json that I need to merge. And I&#39;m not really sure what operation/function to use in jq, so please enlighten me. Thanks! \r\n\r\ncolor.json\r\n```lang-json\r\n[{&quot;id&quot;:1,&quot;color&quot;:&quot;red&quot;},{&quot;id&quot;:2,&quot;color&quot;:&quot;green&quot;},{&quot;id&quot;:3,&quot;color&quot;:&quot;blue&quot;}]\r\n```\r\nshape.json\r\n```lang-json\r\n[\r\n  {\r\n    &quot;shape&quot;: &quot;square&quot;,\r\n    &quot;color&quot;: {\r\n      &quot;id&quot;: 1,\r\n      &quot;name&quot;: &quot;red&quot;\r\n    },\r\n    &quot;texture&quot;: &quot;smooth&quot;\r\n  },\r\n  {\r\n    &quot;shape&quot;: &quot;circle&quot;,\r\n    &quot;color&quot;: {\r\n      &quot;id&quot;: 2,\r\n      &quot;name&quot;: &quot;green&quot;\r\n    },\r\n    &quot;texture&quot;: &quot;smooth&quot;\r\n  },\r\n  {\r\n    &quot;shape&quot;: &quot;triangle&quot;,\r\n    &quot;color&quot;: {\r\n      &quot;id&quot;: 3,\r\n      &quot;name&quot;: &quot;blue&quot;\r\n    },\r\n    &quot;texture&quot;: &quot;smooth&quot;\r\n  },\r\n  {\r\n    &quot;shape&quot;: &quot;triangle&quot;,\r\n    &quot;color&quot;: {\r\n      &quot;id&quot;: 3,\r\n      &quot;name&quot;: &quot;blue&quot;\r\n    },\r\n    &quot;texture&quot;: &quot;rough&quot;\r\n  }\r\n]\r\n```\r\nDesired output\r\n```lang-json\r\n[\r\n  {\r\n    &quot;id&quot;: 1,\r\n    &quot;color&quot;: &quot;red&quot;,\r\n    &quot;shapes&quot;: [\r\n      {\r\n        &quot;shape&quot;: &quot;square&quot;,\r\n        &quot;texture&quot;: &quot;smooth&quot;\r\n      }\r\n    ]\r\n  },\r\n  {\r\n    &quot;id&quot;: 2,\r\n    &quot;color&quot;: &quot;green&quot;,\r\n    &quot;shapes&quot;: [\r\n      {\r\n        &quot;shape&quot;: &quot;circle&quot;,\r\n        &quot;texture&quot;: &quot;smooth&quot;\r\n      }\r\n    ]\r\n  },\r\n  {\r\n    &quot;id&quot;: 3,\r\n    &quot;color&quot;: &quot;blue&quot;,\r\n    &quot;shapes&quot;: [\r\n      {\r\n        &quot;shape&quot;: &quot;triangle&quot;,\r\n        &quot;texture&quot;: &quot;smooth&quot;\r\n      },\r\n      {\r\n        &quot;shape&quot;: &quot;triangle&quot;,\r\n        &quot;texture&quot;: &quot;rough&quot;\r\n      }\r\n    ]\r\n  }\r\n]\r\n```\r\n\r\n\r\n\r\n\r\nI tried using `jq &#39;JOIN(INDEX(inputs[];.id);.[];.color.id | tostring;add)&#39; shape.json color.json`. But it&#39;s not exactly what I&#39;m aiming for. ",
        "link": "https://stackoverflow.com/questions/76721501/insert-json-array-to-another-based-on-key-id-using-jq",
        "title": "Insert json array to another based on key id using jq"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1689868648,
                "creation_date": 1689868648,
                "answer_id": 76731677,
                "question_id": 76731141,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I expect there is a more succinct/idiomatic way to do this using `jq`, but here&#39;s one way.\r\n```\r\nmap(if .dns_zone_name==&quot;zone1&quot;\r\n    then . += (.a_records |= map(if .name==&quot;record1&quot; then .records=[&quot;newRecord&quot;] else . end))\r\n    else . \r\n    end)\r\n```\r\nTry it on [jqplay.org](https://jqplay.org/s/EXJ0SCd1qFG &quot;Click me!&quot;).",
                "title": "jq update value based in multiple level filtering"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1689871071,
                "creation_date": 1689871071,
                "answer_id": 76731969,
                "question_id": 76731141,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You have to separate the two conditions, and iterate in between.\r\n\r\nUsing nested `map` and an inner assignment:\r\n```sh\r\nmap(\r\n  select(.dns_zone_name == &quot;zone1&quot;).a_records |= map(\r\n    select(.name == &quot;record1&quot;).records = [&quot;NewRecord&quot;]\r\n  )\r\n)\r\n```\r\n[Demo](https://jqplay.org/s/ljSOPAqJ785)\r\n\r\nUsing nested `.[]` and an outer assignment:\r\n```sh\r\n( .[]\r\n  | select(.dns_zone_name == &quot;zone1&quot;).a_records[]\r\n  | select(.name == &quot;record1&quot;).records\r\n) = [&quot;NewRecord&quot;]\r\n```\r\n[Demo](https://jqplay.org/s/HzpqACx-Nfg)\r\n\r\nBoth produce:\r\n```json\r\n[\r\n  {\r\n    &quot;dns_zone_name&quot;: &quot;zone1&quot;,\r\n    &quot;a_records&quot;: [\r\n      {\r\n        &quot;name&quot;: &quot;record1&quot;,\r\n        &quot;records&quot;: [\r\n          &quot;NewRecord&quot;\r\n        ]\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;record2&quot;,\r\n        &quot;records&quot;: [\r\n          &quot;zone1_record2_item1&quot;\r\n        ]\r\n      }\r\n    ]\r\n  },\r\n  {\r\n    &quot;dns_zone_name&quot;: &quot;zone2&quot;,\r\n    &quot;a_records&quot;: [\r\n      {\r\n        &quot;name&quot;: &quot;record1&quot;,\r\n        &quot;records&quot;: [\r\n          &quot;zone2_record1_item1&quot;\r\n        ]\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;record2&quot;,\r\n        &quot;records&quot;: [\r\n          &quot;zone2_record2_item1&quot;\r\n        ]\r\n      }\r\n    ]\r\n  }\r\n]\r\n```\r\n\r\nNote: Replace `=` with `+=` if you want to add the new item to the array (instead of replacing the whole array with one containing just the new item).",
                "title": "jq update value based in multiple level filtering"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1689871071,
        "creation_date": 1689864786,
        "question_id": 76731141,
        "body_markdown": "I want to use jq to update the value of an item based on multiples filterings on multiples levels\r\n\r\nWhat I would like would be to update the list of records of a DNS entry stored in a json file based on the name of the DNS Zone Name and the name of the a_record stored. \r\n\r\nFor instance having the following list of DNS entries in the file\r\n\r\n```\r\n[\r\n  {\r\n    &quot;dns_zone_name&quot;: &quot;zone1&quot;,\r\n    &quot;a_records&quot;: [\r\n      {\r\n        &quot;name&quot;: &quot;record1&quot;,\r\n        &quot;records&quot;: [\r\n          &quot;zone1_record1_item1&quot;\r\n        ]\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;record2&quot;,\r\n        &quot;records&quot;: [\r\n          &quot;zone1_record2_item1&quot;\r\n        ]\r\n      }\r\n    ]\r\n  },\r\n  {\r\n    &quot;dns_zone_name&quot;: &quot;zone2&quot;,\r\n    &quot;a_records&quot;: [\r\n      {\r\n        &quot;name&quot;: &quot;record1&quot;,\r\n        &quot;records&quot;: [\r\n          &quot;zone2_record1_item1&quot;\r\n        ]\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;record2&quot;,\r\n        &quot;records&quot;: [\r\n          &quot;zone2_record2_item1&quot;\r\n        ]\r\n      }\r\n    ]\r\n  }\r\n]\r\n```\r\n\r\nThe expectation would be to being able to modify an specific entry , like the one for zone1/record1 \r\n\r\nSo we would like to have the following answer\r\n\r\n```\r\n[\r\n  {\r\n    &quot;dns_zone_name&quot;: &quot;zone1&quot;,\r\n    &quot;a_records&quot;: [\r\n      {\r\n        &quot;name&quot;: &quot;record1&quot;,\r\n        &quot;records&quot;: [\r\n          &quot;New&quot;\r\n        ]\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;record2&quot;,\r\n        &quot;records&quot;: [\r\n          &quot;zone1_record2_item1&quot;\r\n        ]\r\n      }\r\n    ]\r\n  },\r\n  {\r\n    &quot;dns_zone_name&quot;: &quot;zone2&quot;,\r\n    &quot;a_records&quot;: [\r\n      {\r\n        &quot;name&quot;: &quot;record1&quot;,\r\n        &quot;records&quot;: [\r\n          &quot;zone2_record1_item1&quot;\r\n        ]\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;record2&quot;,\r\n        &quot;records&quot;: [\r\n          &quot;zone2_record2_item1&quot;\r\n        ]\r\n      }\r\n    ]\r\n  }\r\n]\r\n```\r\n\r\nBut using the following command all records are updated (see https://jqplay.org/s/duVmyZki6r1)\r\n\r\n`. |= map (select(.dns_zone_name=&quot;zone1&quot; and .a_records[].name==&quot;record1&quot;).a_records[].records |= [&quot;NewRecord&quot;])`\r\n\r\nAnd using the following jq command 2 records are updated (see https://jqplay.org/s/RMDzux85cmD)\r\n\r\n`.[].a_records |= map (select(.name==&quot;record1&quot;).records |= [&quot;NewRecord&quot;])`",
        "link": "https://stackoverflow.com/questions/76731141/jq-update-value-based-in-multiple-level-filtering",
        "title": "jq update value based in multiple level filtering"
    },
    {
        "tags": [
            "function",
            "callback",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 682692,
                    "reputation": 49935,
                    "user_id": 535275,
                    "user_type": "registered",
                    "accept_rate": 91,
                    "profile_image": "https://i.sstatic.net/Ft2Mw.jpg?s=256",
                    "display_name": "Scott Hunter",
                    "link": "https://stackoverflow.com/users/535275/scott-hunter"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1689873299,
                "post_id": 76732198,
                "comment_id": 135278406,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 3,
                "creation_date": 1689873391,
                "post_id": 76732198,
                "comment_id": 135278419,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 166270,
                    "reputation": 135171,
                    "user_id": 390278,
                    "user_type": "registered",
                    "accept_rate": 86,
                    "profile_image": "https://www.gravatar.com/avatar/84715fec547362389d02f5be0ed12814?s=256&d=identicon&r=PG",
                    "display_name": "Jeff Mercado",
                    "link": "https://stackoverflow.com/users/390278/jeff-mercado"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1690184292,
                "post_id": 76732198,
                "comment_id": 135312419,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "is_answered": false,
        "answer_count": 0,
        "score": 0,
        "last_activity_date": 1689872837,
        "creation_date": 1689872837,
        "question_id": 76732198,
        "body_markdown": "Is it possible to pass filter to jq filter function?\r\n\r\nLike \r\n\r\n```javascript\r\ndef something:\r\n   [. | ..];\r\n\r\ndef something_else(callback):\r\n    callback | map(.some_key);\r\n\r\n\r\nsomething_else(something)\r\n```",
        "link": "https://stackoverflow.com/questions/76732198/pass-callback-as-argument-to-jq-filter-function",
        "title": "pass callback as argument to jq filter function"
    },
    {
        "tags": [
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 4133101,
                    "reputation": 26568,
                    "user_id": 3390419,
                    "user_type": "registered",
                    "accept_rate": 30,
                    "profile_image": "https://www.gravatar.com/avatar/895c1539b3062a1feadfad9d1d80e8e9?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Paolo",
                    "link": "https://stackoverflow.com/users/3390419/paolo"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1689878108,
                "post_id": 76732777,
                "comment_id": 135279365,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1689878181,
                "post_id": 76732777,
                "comment_id": 135279381,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 16164,
                    "reputation": 21603,
                    "user_id": 34935,
                    "user_type": "registered",
                    "accept_rate": 60,
                    "profile_image": "https://www.gravatar.com/avatar/27079559125269ea0a30acba3fb06235?s=256&d=identicon&r=PG",
                    "display_name": "dfrankow",
                    "link": "https://stackoverflow.com/users/34935/dfrankow"
                },
                "reply_to_user": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1689879132,
                "post_id": 76732777,
                "comment_id": 135279560,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 16164,
                    "reputation": 21603,
                    "user_id": 34935,
                    "user_type": "registered",
                    "accept_rate": 60,
                    "profile_image": "https://www.gravatar.com/avatar/27079559125269ea0a30acba3fb06235?s=256&d=identicon&r=PG",
                    "display_name": "dfrankow",
                    "link": "https://stackoverflow.com/users/34935/dfrankow"
                },
                "reply_to_user": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1694022855,
                "post_id": 76732777,
                "comment_id": 135838034,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1689945783,
                "last_edit_date": 1689945783,
                "creation_date": 1689927629,
                "answer_id": 76736295,
                "question_id": 76732777,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "What exactly is your input? If you only use `+=` (and not `| .`), it should work already:\r\n\r\n```\r\njq &#39;.[] += {&quot;changes&quot;: &quot;here&quot;}&#39; foo.json &gt; foo2.json\r\n```\r\n\r\nExample:\r\n\r\n```\r\njq &#39;.[] += {&quot;changes&quot;: &quot;here&quot;}&#39; &lt;&lt;JSON\r\n[\r\n  {&quot;a&quot;:1},\r\n  {&quot;b&quot;:2},\r\n  {&quot;c&quot;:3}\r\n]\r\nJSON\r\n[\r\n  {\r\n    &quot;a&quot;: 1,\r\n    &quot;changes&quot;: &quot;here&quot;\r\n  },\r\n  {\r\n    &quot;b&quot;: 2,\r\n    &quot;changes&quot;: &quot;here&quot;\r\n  },\r\n  {\r\n    &quot;c&quot;: 3,\r\n    &quot;changes&quot;: &quot;here&quot;\r\n  }\r\n]\r\n```\r\n\r\n`.` is the identify filter and does not change its input. `|` &quot;drills down&quot; into whatever filter you have specified to the left of it and makes it the new &quot;root&quot;.",
                "title": "In jq, what is the opposite of the array iterator (.[])?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1689945783,
        "creation_date": 1689877708,
        "last_edit_date": 1689943083,
        "question_id": 76732777,
        "body_markdown": "In [the docs][1], `jq` calls `.[]` the &quot;Array/Object Value Iterator&quot;.  What is the opposite operator?\r\n\r\nAnother way to ask it, is what should I put in this command to leave the output largely unchanged (other than formatting):\r\n\r\n```\r\ncat foo.json | jq &#39;.[] | ??what here??&#39; &gt; foo2.json\r\n```\r\n\r\nI ask because I want to manipulate each array element, then put it back together, i.e.,\r\n\r\n```\r\ncat foo.json | jq &#39;.[] | . += {&quot;changes&quot;: &quot;here&quot;} | ??what here??&#39; &gt; foo2.json\r\n```\r\n\r\n**EDIT**: I actually need to change a subpart, so:\r\n\r\n```\r\ncat foo.json | jq &#39;.[] | .subpart += {&quot;changes&quot;: &quot;here&quot;} | ??what here??&#39; &gt; foo2.json\r\n```\r\n\r\n\r\n  [1]: https://jqlang.github.io/jq/manual/",
        "link": "https://stackoverflow.com/questions/76732777/in-jq-what-is-the-opposite-of-the-array-iterator",
        "title": "In jq, what is the opposite of the array iterator (.[])?"
    },
    {
        "tags": [
            "arrays",
            "json",
            "file",
            "concatenation",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 6196394,
                    "reputation": 86601,
                    "user_id": 5291015,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/4tAvO.jpg?s=256",
                    "display_name": "Inian",
                    "link": "https://stackoverflow.com/users/5291015/inian"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1689880985,
                "post_id": 76732975,
                "comment_id": 135279913,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 16164,
                    "reputation": 21603,
                    "user_id": 34935,
                    "user_type": "registered",
                    "accept_rate": 60,
                    "profile_image": "https://www.gravatar.com/avatar/27079559125269ea0a30acba3fb06235?s=256&d=identicon&r=PG",
                    "display_name": "dfrankow",
                    "link": "https://stackoverflow.com/users/34935/dfrankow"
                },
                "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": 1689883031,
                "post_id": 76732975,
                "comment_id": 135280254,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1689927297,
                "creation_date": 1689927297,
                "answer_id": 76736261,
                "question_id": 76732975,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "jq is quite flexible. Here&#39;s a solution without slurping:\r\n\r\n```\r\njq -n &#39;[inputs[]]&#39; a1 a2\r\n```",
                "title": "How do you concatenate two files of arrays into one with jq?"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1689927297,
        "creation_date": 1689879504,
        "last_edit_date": 1689921453,
        "question_id": 76732975,
        "body_markdown": "Suppose file one:\r\n\r\n```\r\n[1, 1, 2]\r\n```\r\n\r\nand file two:\r\n\r\n```\r\n[2, 3, 3]\r\n```\r\n\r\nHow do I concatenate the arrays in the two files, otherwise leaving the contents alone?  That is, output of\r\n\r\n```\r\n[1, 1, 2, 2, 3, 3]\r\n```\r\n\r\nP.S. I want to concatenate arrays of objects, not just ints, if that makes a difference.\r\n\r\nI tried\r\n\r\n```cat one two | jq```\r\n\r\nbut that just puts them next to each other:  ```[1, 1, 2] [2, 3, 3]```\r\n",
        "link": "https://stackoverflow.com/questions/76732975/how-do-you-concatenate-two-files-of-arrays-into-one-with-jq",
        "title": "How do you concatenate two files of arrays into one with jq?"
    },
    {
        "tags": [
            "json",
            "duplicates",
            "key",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1689880127,
                "post_id": 76732978,
                "comment_id": 135279766,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 6314039,
                    "reputation": 2156,
                    "user_id": 4904673,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/vGoRq.jpg?s=256",
                    "display_name": "Shang Jian Ding",
                    "link": "https://stackoverflow.com/users/4904673/shang-jian-ding"
                },
                "reply_to_user": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1689880205,
                "post_id": 76732978,
                "comment_id": 135279780,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1689929754,
                "last_edit_date": 1689929754,
                "creation_date": 1689880962,
                "answer_id": 76733123,
                "question_id": 76732978,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If you don&#39;t mind running jq twice, you could produce the stream once &quot;externally&quot; (before collapsing duplicates) with the `--stream` flag, and once &quot;internally&quot; (after collapsing duplicates) with the `tostream` filter, and then `diff` their results (using `jq -c` further reduces the amount of output to diff):\r\n```sh\r\ndiff -qs &lt;(jq -c --stream . file.json) &lt;(jq -c tostream file.json)\r\n```\r\n\r\n",
                "title": "Report duplicate object keys"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1690056511,
                "last_edit_date": 1690056511,
                "creation_date": 1690013373,
                "answer_id": 76742865,
                "question_id": 76732978,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s an efficient solution for the case where there is exactly one top-level object.  It&#39;s efficient for several reasons, including that it&#39;s a jq-only solution (e.g., no need for `diff`), and that jq is only called once.\r\n```\r\njq -n --stream &#39;\r\n\r\n# &quot;bag of words&quot;\r\ndef bow(stream): \r\n  reduce stream as $word ({}; .[($word|tostring)] += 1);\r\n\r\n# Emit a stream of the duplicated items in the array\r\ndef duplicates:\r\n   bow(.[]) | with_entries(select(.value &gt; 1)) | keys_unsorted[];\r\n\r\n# Duplicate keys of the top-level object\r\n[inputs\r\n | select( (length == 1 and (.[0]|length==2)) or\r\n           (length == 2 and (.[0]|length==1)) )\r\n | first|first ]\r\n| duplicates\r\n&#39;\r\n```\r\nOutput for the sample input:\r\n```\r\n&quot;a&quot;\r\n```",
                "title": "Report duplicate object keys"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1690083069,
        "creation_date": 1689879532,
        "last_edit_date": 1690083069,
        "question_id": 76732978,
        "body_markdown": "How do you use jq to detect and report duplicate object keys? For example, the following JSON has duplicate key on `.a`.\r\n\r\n```\r\n{\r\n  &quot;a&quot;:{\r\n    &quot;b&quot;: 1\r\n  },\r\n  &quot;a&quot;:{\r\n    &quot;c&quot;: 1\r\n  }\r\n}\r\n```\r\n\r\nI think using --stream is required but I can&#39;t quite get it right.\r\n\r\nEdit: cannot assume the dup can exist only as the top level key. The dup may exist at any level.",
        "link": "https://stackoverflow.com/questions/76732978/report-duplicate-object-keys",
        "title": "Report duplicate object keys"
    },
    {
        "tags": [
            "if-statement",
            "boolean",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1689885664,
                "last_edit_date": 1689885664,
                "creation_date": 1689884731,
                "answer_id": 76733482,
                "question_id": 76733029,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The `not` filter also converts its input into boolean (under the same conditions, but negated), so if you want to have it shorter (and less readable), use it twice: `not|not`\r\n```sh\r\nnull, false, true, 0, 1, [], {}, &quot;&quot;\r\n| not | not\r\n```\r\n```json\r\nfalse\r\nfalse\r\ntrue\r\ntrue\r\ntrue\r\ntrue\r\ntrue\r\ntrue\r\n```\r\n[Demo](https://jqplay.org/s/Ya_ahm93m0c)\r\n\r\n---\r\nEven shorter (and even less readable) would be to use the input for some boolean operations, like a disjunction with itself: `. or .` (for golfers: you could even omit the second space character):\r\n```sh\r\nnull, false, true, 0, 1, [], {}, &quot;&quot;\r\n| . or .\r\n```\r\n```json\r\nfalse\r\nfalse\r\ntrue\r\ntrue\r\ntrue\r\ntrue\r\ntrue\r\ntrue\r\n```\r\n[Demo](https://jqplay.org/s/08pyowUQBzK)\r\n\r\n---\r\nBut seriously, just define a function yourself (most readably employing regular `if`), and then you can use that everywhere else instead:\r\n```sh\r\ndef toboolean: if . then true else false end;\r\n\r\nnull, false, true, 0, 1, [], {}, &quot;&quot;\r\n| toboolean\r\n```\r\n```json\r\nfalse\r\nfalse\r\ntrue\r\ntrue\r\ntrue\r\ntrue\r\ntrue\r\ntrue\r\n```\r\n[Demo](https://jqplay.org/s/jfxyeBSa_bf)",
                "title": "fast truthiness check / to-boolean conversion?"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1689930114,
                "creation_date": 1689930114,
                "answer_id": 76736552,
                "question_id": 76733029,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "See @pmf&#39;s answer re conversion to &quot;boolean&quot;.  I&#39;d just add that in practice it&#39;s rarely needed as a means to another end.\r\n\r\nRe checking, you might find the following points useful:\r\n\r\n1) In sufficiently recent versions of jq, `if COND then THEN else . end` can be abbreviated by dropping the `else` clause.\r\n\r\n2) `select(COND)` is equivalent to `if COND then . else empty end` and is often handy.  Similarly for `select(COND) // WHATEVER`\r\n\r\n3) You might like to take advantage of `//` in other contexts as well.\r\n\r\n",
                "title": "fast truthiness check / to-boolean conversion?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1689930187,
        "creation_date": 1689880016,
        "last_edit_date": 1689930187,
        "question_id": 76733029,
        "body_markdown": "The [manual] talks about &quot;truthiness&quot; in the &quot;if-then-else&quot; section, defining everything besides `false` and `null` as `true`.\r\n\r\nIs there a shorter way to check the truthiness of a filter `f` than a full-fledged if-then-else like this?\r\n\r\n    if f then true else false end\r\n\r\n[manual]: https://jqlang.github.io/jq/manual/#if-then-else-end",
        "link": "https://stackoverflow.com/questions/76733029/fast-truthiness-check-to-boolean-conversion",
        "title": "fast truthiness check / to-boolean conversion?"
    },
    {
        "tags": [
            "arrays",
            "json",
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1689972034,
                "post_id": 76741064,
                "comment_id": 135293344,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 28888731,
                    "reputation": 823,
                    "user_id": 22126467,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/hMLh4.png?s=256",
                    "display_name": "Grobu",
                    "link": "https://stackoverflow.com/users/22126467/grobu"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1690011903,
                "post_id": 76741064,
                "comment_id": 135295989,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 28888731,
                    "reputation": 823,
                    "user_id": 22126467,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/hMLh4.png?s=256",
                    "display_name": "Grobu",
                    "link": "https://stackoverflow.com/users/22126467/grobu"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1690012105,
                "post_id": 76741064,
                "comment_id": 135296004,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 6014861,
                    "reputation": 20007,
                    "user_id": 7939871,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/1199ba5dde05e4083823a058c5ac6bed?s=256&d=identicon&r=PG",
                    "display_name": "L&#233;a Gris",
                    "link": "https://stackoverflow.com/users/7939871/l%c3%a9a-gris"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1690025644,
                "post_id": 76741064,
                "comment_id": 135297211,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": false,
                "score": 4,
                "last_activity_date": 1690056510,
                "last_edit_date": 1690056510,
                "creation_date": 1690027973,
                "answer_id": 76743709,
                "question_id": 76741064,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here is a method with turning the json into a Bash associative array declaration for key and value pairs:\r\n\r\n```sh\r\n#!/usr/bin/env bash\r\n\r\n# Populates Bash array from json\r\n# shellcheck disable=SC2155 # Declaration safely generated by jq\r\ndeclare -A names=&quot;($(jq -r &#39;.[]|&quot;[\\(.id|@uri|@sh)]=\\(.name|@sh)&quot;&#39; a.json))&quot;\r\n\r\n# Uncomment for debug\r\ndeclare -p names; set -x\r\n\r\n# Iterates names by keys\r\nfor id in &quot;${!names[@]}&quot;; do\r\n  name=&quot;${names[$id]}&quot;\r\n  curl -s --url &quot;https://example.com/get?id=$id&quot; -o &quot;${name}.json&quot;\r\ndone\r\n```\r\n\r\n*Edit*: Adopted A.H.&#39;s suggestion for string interpolation in jq.",
                "title": "using jq to create an array of key value pairs and iterate over them"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1690105543,
        "creation_date": 1689971619,
        "last_edit_date": 1690105543,
        "question_id": 76741064,
        "body_markdown": "Given this input...\r\n```\r\n[\r\n    {\r\n    &quot;name&quot;: &quot;steve&quot;,\r\n    &quot;description&quot;: &quot;&quot;,\r\n    &quot;id&quot;: 2253,\r\n    &quot;accountGuid&quot;: &quot;12345&quot;\r\n  },\r\n    {\r\n    &quot;name&quot;: &quot;mary&quot;,\r\n    &quot;description&quot;: &quot;&quot;,\r\n    &quot;id&quot;: 2363,\r\n    &quot;accountGuid&quot;: &quot;12345&quot;\r\n  },\r\n    {\r\n    &quot;name&quot;: &quot;chris&quot;,\r\n    &quot;description&quot;: &quot;&quot;,\r\n    &quot;id&quot;: 2226,\r\n    &quot;accountGuid&quot;: &quot;12345&quot;\r\n  }\r\n]\r\n```\r\nMy end goal is to take the `id` and `name` values, iterate over them and use the id in a curl and then output the result of that to a separate json file named `[name]-[id].json`\r\n\r\nI am able to grab one value just fine using `jq -r &#39;.[] | (.id)&#39;` but can&#39;t add in `(.name)`.\r\n\r\nI have tried `to_entries` but the output of that didn&#39;t assist me, at least to my understanding. \r\n\r\nI have also tried `&#39;.[] | &quot;\\\\(.id) \\\\(.name)&quot;&#39;` - this results in an id and a name each on its own line.",
        "link": "https://stackoverflow.com/questions/76741064/using-jq-to-create-an-array-of-key-value-pairs-and-iterate-over-them",
        "title": "using jq to create an array of key value pairs and iterate over them"
    },
    {
        "tags": [
            "json",
            "string",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 1450087,
                    "reputation": 12022,
                    "user_id": 1409374,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/97d424fe924f2139812a4a6de1ef6b79?s=256&d=identicon&r=PG",
                    "display_name": "rickhg12hs",
                    "link": "https://stackoverflow.com/users/1409374/rickhg12hs"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1689982257,
                "post_id": 76741732,
                "comment_id": 135294394,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 15688806,
                    "reputation": 23,
                    "user_id": 11320597,
                    "user_type": "registered",
                    "profile_image": "https://lh5.googleusercontent.com/-HlRMijOf71c/AAAAAAAAAAI/AAAAAAAAAAc/kc1DgBD_yxQ/s256-rj/photo.jpg",
                    "display_name": "Andr&#233; Letterer",
                    "link": "https://stackoverflow.com/users/11320597/andr%c3%a9-letterer"
                },
                "reply_to_user": {
                    "account_id": 1450087,
                    "reputation": 12022,
                    "user_id": 1409374,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/97d424fe924f2139812a4a6de1ef6b79?s=256&d=identicon&r=PG",
                    "display_name": "rickhg12hs",
                    "link": "https://stackoverflow.com/users/1409374/rickhg12hs"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1690020824,
                "post_id": 76741732,
                "comment_id": 135296781,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1689983023,
                "last_edit_date": 1689983023,
                "creation_date": 1689982324,
                "answer_id": 76741748,
                "question_id": 76741732,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Using [`sub`](https://jqlang.github.io/jq/manual/#sub%28regex%3Btostring%29%2Csub%28regex%3Btostring%3Bflags%29) with a regex, `.*` will greedily match as much as it can, so the following space character is satisfied with the last ocurrence of it. Make `*` lazy by appending a `?` to have it stop before the first occurrence:\r\n```sh\r\n.key |= sub(&quot;.*? &quot;; &quot;&quot;)\r\n```\r\n[Demo](https://jqplay.org/s/dpil6RQy1-M)\r\n\r\nOr, more explicitly, replace everything from the beginning `^`, followed by any number of non-space characters `[^ ]*`, and the space itself:\r\n```sh\r\n.key |= sub(&quot;^[^ ]* &quot;; &quot;&quot;)\r\n```\r\n[Demo](https://jqplay.org/s/lv7-V1mzkBv)\r\n\r\nOr use [`index`](https://jqlang.github.io/jq/manual/#index%28s%29%2Crindex%28s%29) to get the position of the first space character, then get the substring starting one position after that index using `.[&lt;n&gt;:]`:\r\n```sh\r\n.key |= .[index(&quot; &quot;)+1:]\r\n```\r\n[Demo](https://jqplay.org/s/EVp10eD_Mby)\r\n\r\nBoth produce:\r\n```json\r\n{\r\n  &quot;key&quot;: &quot;and now comes the rest&quot;\r\n}\r\n```",
                "title": "jq value remove everything before first space"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1690019158,
        "creation_date": 1689981869,
        "last_edit_date": 1690019158,
        "question_id": 76741732,
        "body_markdown": "Could you help me please?\r\n\r\nI got a json of a format similar to this:\r\n```\r\n{&quot;key&quot;:&quot;this.part:2 and now comes the rest&quot;}\r\n```\r\n\r\nHow can I use jq only style to remove everything before the first space meaning this part: `this.part:2`?\r\n\r\n\r\n\r\nI tried already `jq &#39;.key |= sub(&quot;.* &quot;; &quot;&quot;)&#39;` but that didn&#39;t unfortunately do what I wanted to have.\r\nCan anybody help please?",
        "link": "https://stackoverflow.com/questions/76741732/jq-value-remove-everything-before-first-space",
        "title": "jq value remove everything before first space"
    },
    {
        "tags": [
            "syntax",
            "jq",
            "variable-names"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1690108349,
                "last_edit_date": 1690108349,
                "creation_date": 1690010533,
                "answer_id": 76742718,
                "question_id": 76742107,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "In jq 1.6 and earlier, keywords cannot be used in $-variable names.\r\nThis is mentioned on the [the jq wiki][1], where the following list of keywords is given: \r\n\r\n```\r\n__loc__ and as break catch def elif else end \r\nforeach if import include label module\r\nor reduce then try\r\n```\r\n\r\nThe list of keywords for any particular version of jq can be derived from the lexer.l file, the “master” version of which is https://github.com/stedolan/jq/blob/master/src/lexer.l\r\n\r\n——\r\n\r\nThe restriction was removed in the development version of jq in 2019 by https://github.com/jqlang/jq/commit/c72ed135e4f1b5a02a8fb3f6cd46f27513ecab2a\r\nand thus will no longer exist in jq 1.7\r\n\r\n  [1]: https://github.com/jqlang/jq/wiki/How-to:-Avoid-Pitfalls#keywords",
                "title": "Why can&#39;t $module be used as a variable name in jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1733657064,
        "creation_date": 1689993940,
        "last_edit_date": 1733657064,
        "question_id": 76742107,
        "body_markdown": "Is this behaviour of jq, w.r.t the non-allowed use of $module as a variable name, specified anywhere?\r\n\r\n    $ jq -n --arg &#39;module&#39; &#39;X&#39; &#39;$module&#39;\r\n    jq: error: syntax error, unexpected module, expecting IDENT or __loc__ (Unix shell quoting issues?) at &lt;top-level&gt;, line 1:\r\n    $module \r\n    jq: 1 compile error\r\n\r\nMy expectation is that jq would print &quot;X&quot;, but this is not the case. Why?",
        "link": "https://stackoverflow.com/questions/76742107/why-cant-module-be-used-as-a-variable-name-in-jq",
        "title": "Why can&#39;t $module be used as a variable name in jq?"
    },
    {
        "tags": [
            "json",
            "yaml",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 3959308,
                    "reputation": 53394,
                    "user_id": 3266847,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/U0oyt.png?s=256",
                    "display_name": "Benjamin W.",
                    "link": "https://stackoverflow.com/users/3266847/benjamin-w"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1690044514,
                "post_id": 76744674,
                "comment_id": 135299459,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 15688806,
                    "reputation": 23,
                    "user_id": 11320597,
                    "user_type": "registered",
                    "profile_image": "https://lh5.googleusercontent.com/-HlRMijOf71c/AAAAAAAAAAI/AAAAAAAAAAc/kc1DgBD_yxQ/s256-rj/photo.jpg",
                    "display_name": "Andr&#233; Letterer",
                    "link": "https://stackoverflow.com/users/11320597/andr%c3%a9-letterer"
                },
                "reply_to_user": {
                    "account_id": 3959308,
                    "reputation": 53394,
                    "user_id": 3266847,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/U0oyt.png?s=256",
                    "display_name": "Benjamin W.",
                    "link": "https://stackoverflow.com/users/3266847/benjamin-w"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1690045380,
                "post_id": 76744674,
                "comment_id": 135299594,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1690055662,
                "last_edit_date": 1690055662,
                "creation_date": 1690046770,
                "answer_id": 76745026,
                "question_id": 76744674,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "This is something probably better suited for [`yq`][1] instead of trying to re-implement a YAML parser.\r\n\r\nSomething like this would work:\r\n\r\n```sh\r\nyq eval-all -o=json &#39;[{&quot;filename&quot;: filename} + .]&#39; *.yaml\r\n```\r\n\r\nresulting in\r\n\r\n```json\r\n[\r\n  {\r\n    &quot;filename&quot;: &quot;1.yaml&quot;,\r\n    &quot;time&quot;: &quot;2020-09-14T22:33:40Z&quot;,\r\n    &quot;id&quot;: &quot;ed1d4321&quot;,\r\n    &quot;name&quot;: &quot;One&quot;,\r\n    &quot;description&quot;: &quot;Here is number \\&quot;one\\&quot; this is good&quot;\r\n  },\r\n  {\r\n    &quot;filename&quot;: &quot;2.yaml&quot;,\r\n    &quot;time&quot;: &quot;2021-09-14T22:33:40Z&quot;,\r\n    &quot;id&quot;: &quot;eg134841&quot;,\r\n    &quot;name&quot;: &quot;Two&quot;,\r\n    &quot;description&quot;: &quot;Here is number \\&quot;two\\&quot; best of all&quot;,\r\n    &quot;newkey&quot;: &quot;value&quot;\r\n  }\r\n]\r\n```\r\n\r\n  [1]: https://github.com/mikefarah/yq",
                "title": "jq split multiple text files into multiple arrays"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1690054814,
                "creation_date": 1690054814,
                "answer_id": 76745503,
                "question_id": 76744674,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "This is a partial solution -- the values are not yet &quot;cleaned&quot;. This is left as an excercise to the reader :-)\r\n\r\nStart with `jq --slurp --raw-input`:\r\n\r\n```\r\n# split lines\r\nsplit(&quot;\\n&quot;)\r\n# join lines starting with whitespace with previous line\r\n| reduce .[] as $l (\r\n    null;\r\n    if $l | startswith(&quot; &quot;) then .[-1] += $l else . += [$l] end\r\n)\r\n# split on first colon, returning an array of objects like {key: X, value: Y}\r\n| map(capture(&quot;^(?&lt;key&gt;[^:]+):\\\\s*(?&lt;value&gt;.*)$&quot;))\r\n# combine these simple objects into bigger objects but begin a new objects when encountering &quot;filename&quot;\r\n| reduce .[] as $e (null; \r\n    if $e.key == &quot;filename&quot; then . += [{}] else . end\r\n    | .[-1][$e.key] = $e.value\r\n)\r\n```\r\n\r\nThe output is this:\r\n```\r\n[\r\n  {\r\n    &quot;filename&quot;: &quot;content/1.yaml&quot;,\r\n    &quot;time&quot;: &quot;\\&quot;2020-09-14T22:33:40Z\\&quot;&quot;,\r\n    &quot;id&quot;: &quot;ed1d4321&quot;,\r\n    &quot;name&quot;: &quot;One&quot;,\r\n    &quot;description&quot;: &quot;&#39;Here is number \\&quot;one\\&quot;  this is good&#39;&quot;\r\n  },\r\n  {\r\n    &quot;filename&quot;: &quot;content/2yaml&quot;,\r\n    &quot;time&quot;: &quot;\\&quot;2021-09-14T22:33:40Z\\&quot;&quot;,\r\n    &quot;id&quot;: &quot;eg134841&quot;,\r\n    &quot;name&quot;: &quot;Two&quot;,\r\n    &quot;description&quot;: &quot;&#39;Here is number \\&quot;two\\&quot;  best of all&#39;&quot;,\r\n    &quot;newkey&quot;: &quot;value&quot;\r\n  }\r\n]\r\n```\r\n",
                "title": "jq split multiple text files into multiple arrays"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1690078523,
                "last_edit_date": 1690078523,
                "creation_date": 1690055582,
                "answer_id": 76745558,
                "question_id": 76744674,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The following handles one file at a time, and presupposes an invocation of jq using the -R and -s command-line options (`jq -Rs`).  Combining the results for more than one file is left as an exercise. (Hint: for the filename, use `input_filename`.)\r\n```\r\n  def objectify:\r\n    capture(&quot;(?&lt;key&gt;[^:]+): *(?&lt;value&gt;.*)&quot;)\r\n    | .value = (.value | (fromjson? // .))\r\n    | [.]\r\n    | from_entries;\r\n\r\n  gsub(&quot;\\n  *&quot;; &quot; &quot;)        # join dangling text\r\n  | . / &quot;\\n&quot;                # split\r\n  | map(select(length&gt;0))   # ignore &quot;&quot;\r\n  | map(objectify)          # {key, value}\r\n  | add\r\n```",
                "title": "jq split multiple text files into multiple arrays"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1690056191,
                "creation_date": 1690056191,
                "answer_id": 76745595,
                "question_id": 76744674,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Ok, I found another answer to that which is not using yq but using python which is most probably installed on lots of machines:\r\n```\r\n# for file in $(ls content/*yaml); do (echo filename: $file; cat $file) | python -c &#39;import yaml; import json; import sys; print(json.dumps(yaml.safe_load(sys.stdin)));&#39; ; done | jq -s\r\n[\r\n  {\r\n    &quot;filename&quot;: &quot;content/1.yaml&quot;,\r\n    &quot;time&quot;: &quot;2020-09-14T22:33:40Z&quot;,\r\n    &quot;id&quot;: &quot;ed1d4321&quot;,\r\n    &quot;name&quot;: &quot;One&quot;,\r\n    &quot;description&quot;: &quot;Here is number \\&quot;one\\&quot; this is good&quot;\r\n  },\r\n  {\r\n    &quot;filename&quot;: &quot;content/2yaml&quot;,\r\n    &quot;time&quot;: &quot;2021-09-14T22:33:40Z&quot;,\r\n    &quot;id&quot;: &quot;eg134841&quot;,\r\n    &quot;name&quot;: &quot;Two&quot;,\r\n    &quot;description&quot;: &quot;Here is number \\&quot;two\\&quot; best of all&quot;,\r\n    &quot;newkey&quot;: &quot;value&quot;\r\n  }\r\n]\r\n\r\n```",
                "title": "jq split multiple text files into multiple arrays"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1690078377,
                "last_edit_date": 1690078377,
                "creation_date": 1690078037,
                "answer_id": 76746421,
                "question_id": 76744674,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "For the record, you could use gojq, the Go implementation of jq, as it supports YAML:\r\n\r\n\r\n    gojq -n --yaml-input &#39;[inputs | {filename: input_filename} + .] &#39; *.yaml\r\n    \r\nNote that gojq will sort the object keys.",
                "title": "jq split multiple text files into multiple arrays"
            }
        ],
        "is_answered": true,
        "answer_count": 5,
        "score": 0,
        "last_activity_date": 1690078523,
        "creation_date": 1690041138,
        "last_edit_date": 1690078462,
        "question_id": 76744674,
        "body_markdown": "I have the issue I have some files that have as content multiple key value pairs that I&#39;d like to transform into multiple arrays.\r\n\r\nLet me illustrate what I mean with some produced examples. First the content of the files:\r\n```\r\n# cat content/1.yaml\r\ntime: &quot;2020-09-14T22:33:40Z&quot;\r\nid: ed1d4321\r\nname: One\r\ndescription: &#39;Here is number &quot;one&quot;\r\n  this is good&#39;\r\n\r\n# cat content/2yaml\r\ntime: &quot;2021-09-14T22:33:40Z&quot;\r\nid: eg134841\r\nname: Two\r\ndescription: &#39;Here is number &quot;two&quot;\r\n  best of all&#39;\r\nnewkey: value\r\n```\r\n\r\nIn the next step I merge these files together into one blob containing the filenames as well which I want to keep:\r\n```\r\n# for file in $(ls content/*yaml); do echo filename: $file; cat $file; done\r\nfilename: content/1.yaml\r\ntime: &quot;2020-09-14T22:33:40Z&quot;\r\nid: ed1d4321\r\nname: One\r\ndescription: &#39;Here is number &quot;one&quot;\r\n  this is good&#39;\r\nfilename: content/2yaml\r\ntime: &quot;2021-09-14T22:33:40Z&quot;\r\nid: eg134841\r\nname: Two\r\ndescription: &#39;Here is number &quot;two&quot;\r\n  best of all&#39;\r\nnewkey: value\r\n```\r\n\r\nAnd now the issue begins, how to bring this together into json arrays?\r\n\r\nThat&#39;s what I came up with up to now:\r\n```\r\n# for file in $(ls content/*yaml); do echo filename: $file; cat $file; done | jq -Rn &#39;[inputs|split(&quot;: &quot;)] | map({(.[0]): .[1]})&#39;\r\n[\r\n  {\r\n    &quot;filename&quot;: &quot;content/1.yaml&quot;\r\n  },\r\n  {\r\n    &quot;time&quot;: &quot;\\&quot;2020-09-14T22:33:40Z\\&quot;&quot;\r\n  },\r\n  {\r\n    &quot;id&quot;: &quot;ed1d4321&quot;\r\n  },\r\n  {\r\n    &quot;name&quot;: &quot;One&quot;\r\n  },\r\n  {\r\n    &quot;description&quot;: &quot;&#39;Here is number \\&quot;one\\&quot;&quot;\r\n  },\r\n  {\r\n    &quot;  this is good&#39;&quot;: null\r\n  },\r\n  {\r\n    &quot;filename&quot;: &quot;content/2yaml&quot;\r\n  },\r\n  {\r\n    &quot;time&quot;: &quot;\\&quot;2021-09-14T22:33:40Z\\&quot;&quot;\r\n  },\r\n  {\r\n    &quot;id&quot;: &quot;eg134841&quot;\r\n  },\r\n  {\r\n    &quot;name&quot;: &quot;Two&quot;\r\n  },\r\n  {\r\n    &quot;description&quot;: &quot;&#39;Here is number \\&quot;two\\&quot;&quot;\r\n  },\r\n  {\r\n    &quot;  best of all&#39;&quot;: null\r\n  },\r\n  {\r\n    &quot;newkey&quot;: &quot;value&quot;\r\n  }\r\n]\r\n```\r\n\r\nThat&#39;s is already close but some issues I still have to solve which I don&#39;t find a solution for:\r\n1. The filenames are not spread into separate arrays.\r\n2. the `time` field should not have the escaped quoted strings. I&#39;d like to have a solution that iterates over all fields and would expand these contents out of of the quotes like here as example `&quot;time&quot;: &quot;2021-09-14T22:33:40Z&quot;`\r\n3. `description` value is spread over multiple lines and I&#39;d like to see them merged into one value but that&#39;s not what happens as of now, so should look like that: `&quot;description&quot;: &quot;Here is number \\&quot;two\\&quot;  best of all`. The single quotes should not be kept.\r\n\r\nSo at the end the outcome should be rather like that:\r\n```\r\n[\r\n  {\r\n    &quot;filename&quot;: &quot;content/1.yaml&quot;,\r\n    &quot;time&quot;: &quot;2020-09-14T22:33:40Z&quot;,\r\n    &quot;id&quot;: &quot;ed1d4321&quot;,\r\n    &quot;name&quot;: &quot;One&quot;,\r\n    &quot;description&quot;: &quot;Here is number \\&quot;one\\&quot;  this is good&quot;\r\n  },\r\n  {\r\n    &quot;filename&quot;: &quot;content/2yaml&quot;,\r\n    &quot;time&quot;: &quot;2021-09-14T22:33:40Z&quot;,\r\n    &quot;id&quot;: &quot;eg134841&quot;,\r\n    &quot;name&quot;: &quot;Two&quot;,\r\n    &quot;description&quot;: &quot;Here is number \\&quot;two\\&quot;  best of all&quot;,\r\n    &quot;newkey&quot;: &quot;value&quot;\r\n  }\r\n]\r\n```",
        "link": "https://stackoverflow.com/questions/76744674/jq-split-multiple-text-files-into-multiple-arrays",
        "title": "jq split multiple text files into multiple arrays"
    },
    {
        "tags": [
            "json",
            "jq",
            "flatten"
        ],
        "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": 1690303232,
                "post_id": 76749701,
                "comment_id": 135333382,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1690136376,
                "creation_date": 1690136376,
                "answer_id": 76749718,
                "question_id": 76749701,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can use the following filter : \r\n\r\n    .Nemo[],.Firefox[],.Codium[],.Terminals[]\r\n\r\nYou can [try it here](https://jqplay.org/s/HiISncDcv9Z).",
                "title": "Flatten multiple arrays keeping order"
            },
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1690136539,
                "creation_date": 1690136539,
                "answer_id": 76749723,
                "question_id": 76749701,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "`keys_unsorted` gives you the keys in their original order. You can use them to iterate:\r\n```sh\r\n.[keys_unsorted[]][]\r\n```\r\n[Demo](https://jqplay.org/s/8_d6ah9aSpM)\r\n\r\nYou could also just use `.[]` to iterate over the object&#39;s fields, which for current versions of jq produces the same result, but that is not guaranteed to stay that way:\r\n```sh\r\n.[][]\r\n```\r\n[Demo](https://jqplay.org/s/2gP_nS-jXtn)",
                "title": "Flatten multiple arrays keeping order"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1690137101,
                "last_edit_date": 1690137101,
                "creation_date": 1690136720,
                "answer_id": 76749742,
                "question_id": 76749701,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Another solution ([demo][1]):\r\n\r\n```\r\ncat your_file.json | jq -r &quot;map(values) | flatten | .[]&quot;\r\n```\r\n\r\nPrints:\r\n\r\n```none\r\n3694756688\r\n3694756832\r\n3694756650\r\n3694756795\r\n3694756407\r\n3694756412\r\n3694756395\r\n3694756035\r\n3694756383\r\n3694756378\r\n3694756804\r\n3694756802\r\n3694756428\r\n```\r\n\r\n---\r\n\r\nOr just simply ([demo][2]) thanks @pmf:\r\n\r\n```none\r\ncat your_file.json | jq &quot;flatten[]&quot;\r\n```\r\n\r\n\r\n  [1]: https://jqplay.org/s/indjWd60xVV\r\n  [2]: https://jqplay.org/s/jPov74OLTRG",
                "title": "Flatten multiple arrays keeping order"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 1,
        "last_activity_date": 1690140500,
        "creation_date": 1690136205,
        "last_edit_date": 1690140500,
        "question_id": 76749701,
        "body_markdown": "I have a json object like:\r\n\r\n    {\r\n      &quot;Nemo&quot;: [\r\n        3694756688,\r\n        3694756832,\r\n        3694756650\r\n      ],\r\n      &quot;Firefox&quot;: [\r\n        3694756795,\r\n        3694756407,\r\n        3694756412,\r\n        3694756395\r\n      ],\r\n      &quot;Codium&quot;: [\r\n        3694756035,\r\n        3694756383,\r\n        3694756378\r\n      ],\r\n      &quot;Terminals&quot;: [\r\n        3694756804,\r\n        3694756802,\r\n        3694756428\r\n    }\r\n\r\nI need output like:\r\n\r\n    3694756688\r\n    3694756832\r\n    3694756650\r\n    3694756795\r\n    3694756407\r\n    3694756412\r\n    3694756395\r\n    3694756035\r\n    3694756383\r\n    3694756378\r\n    3694756804\r\n    3694756802\r\n    3694756428\r\n\r\nThe order is important. How can i do it with jq.",
        "link": "https://stackoverflow.com/questions/76749701/flatten-multiple-arrays-keeping-order",
        "title": "Flatten multiple arrays keeping order"
    },
    {
        "tags": [
            "arrays",
            "json",
            "csv",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1690176500,
                "creation_date": 1690176500,
                "answer_id": 76751634,
                "question_id": 76751224,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Since the fields you want are at varying depths and in arrays, typical strategy is to collect the values you want at each level expanding any array separately then combine them all.\r\n\r\nAssuming you want the values in file order, you could just grab all values from the bond objects.\r\n\r\n```\r\n.request | [.method, .url] + (.body.bonds[] | [.[]]) | @csv\r\n```\r\n\r\nThough in general, you probably will want to explicitly pick out the values you want.\r\n\r\n```\r\n.request | [.method, .url] + (.body.bonds[] | [\r\n  .bondDesc,\r\n  .priorPriceBid,\r\n  .priorPriceOffer,\r\n  .priorYieldBid,\r\n  .priorYieldOffer,\r\n  .updatedPriceBid,\r\n  .updatedPriceOffer,\r\n  .updatedYieldBid,\r\n  .updatedYieldOffer\r\n]) | @csv\r\n```\r\n\r\nYou had the right idea, but the parentheses around the expansion of the `bonds` array is important.\r\n\r\n[jqplay](https://jqplay.org/s/zPQqPYWmuZY)",
                "title": "How to use jq to convert json to csv from a complex json data"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1690190927,
                "last_edit_date": 1690190927,
                "creation_date": 1690188997,
                "answer_id": 76752844,
                "question_id": 76751224,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "As @Jeff_Mercado mentioned, you could potentially go with\r\n\r\n    .request | [.method, .url] + (.body.bonds[] | [.[]]) | @csv\r\n\r\nbut that assumes the ordering of keys within the objects is the same.\r\nEven if you believe that to be the case, it would be wise to adopt a more robust solution.  Listing the keys would be one way to go, but that is tedious and not robust w.r.t. the addition or deletion of keys in the future.  \r\n\r\nAssuming you want all the values corresponding to the keys in the first .bonds object, you could use the following:\r\n\r\n```\r\n.request\r\n| (.body.bonds[0] | keys_unsorted) as $keys\r\n| [.method, .url] + (.body.bonds[] | [.[$keys[]]])\r\n| @csv\r\n```",
                "title": "How to use jq to convert json to csv from a complex json data"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1690190927,
        "creation_date": 1690169405,
        "last_edit_date": 1690183653,
        "question_id": 76751224,
        "body_markdown": "I&#39;m new in using jq tool.\r\nI have a json file extracted from mongodb database to be formatted into csv:\r\n\r\n**json data in foo.json**\r\n\r\n```\r\n{\r\n\t&quot;_id&quot; : &quot;8888888888&quot;,\r\n\t&quot;unitcode&quot; : &quot;Unit123&quot;,\r\n\t&quot;purpose&quot; : &quot;Validate&quot;,\r\n\t&quot;request&quot; : {\r\n\t\t&quot;url&quot; : &quot;Brocolli&quot;,\r\n\t\t&quot;method&quot; : &quot;UPDATED&quot;,\r\n\t\t&quot;body&quot; : {\r\n\t\t\t&quot;bonds&quot; : [\r\n\t\t\t\t{\r\n\t\t\t\t\t&quot;bondDesc&quot; : &quot;bondDesc1&quot;,\r\n\t\t\t\t\t&quot;priorPriceBid&quot; : 100,\r\n\t\t\t\t\t&quot;priorPriceOffer&quot; : 101,\r\n\t\t\t\t\t&quot;priorYieldBid&quot; : 6.555,\r\n\t\t\t\t\t&quot;priorYieldOffer&quot; : 6.777,\r\n\t\t\t\t\t&quot;updatedPriceBid&quot; : 691,\r\n\t\t\t\t\t&quot;updatedPriceOffer&quot; : 169,\r\n\t\t\t\t\t&quot;updatedYieldBid&quot; : 25.2345,\r\n\t\t\t\t\t&quot;updatedYieldOffer&quot; : 25.9999\r\n\t\t\t\t},\r\n\t\t\t\t{\r\n\t\t\t\t\t&quot;bondDesc&quot; : &quot;bondDesc2&quot;,\r\n\t\t\t\t\t&quot;priorPriceBid&quot; : 200,\r\n\t\t\t\t\t&quot;priorPriceOffer&quot; : 201,\r\n\t\t\t\t\t&quot;priorYieldBid&quot; : 2.555,\r\n\t\t\t\t\t&quot;priorYieldOffer&quot; : 2.777,\r\n\t\t\t\t\t&quot;updatedPriceBid&quot; : 791,\r\n\t\t\t\t\t&quot;updatedPriceOffer&quot; : 269,\r\n\t\t\t\t\t&quot;updatedYieldBid&quot; : 35.2345,\r\n\t\t\t\t\t&quot;updatedYieldOffer&quot; : 35.9999\r\n\t\t\t\t}\r\n\t\t\t]\r\n\t\t},\r\n\t\t&quot;source&quot; : &quot;Cloud&quot;,\r\n\t\t&quot;isMultipleBond&quot; : true\r\n\t},\r\n\t&quot;response&quot; : {\r\n\t\t&quot;statusCode&quot; : 200\r\n\t}\r\n}\r\n```\r\n\r\n**Desired output:**\r\n\r\n```\r\n&quot;UPDATED&quot;,&quot;Brocolli&quot;,&quot;bondDesc1&quot;,100,101,6.555,6.777,691,169,25.2345,25.9999\r\n&quot;UPDATED&quot;,&quot;Brocolli&quot;,&quot;bondDesc2&quot;,200,201,2.555,2.777,791,269,35.2345,35.9999\r\n```\r\n\r\n**I already tried the following commands:**\r\n\r\n1) first try  \r\n    ```\r\n    jq -r &#39;[.request.method, .request.url] | @csv&#39;  foo.json\r\n    ```\r\n    \r\n    **Result:**\r\n    \r\n    ```\r\n    &quot;bondDesc1&quot;,100\r\n    ```\r\n\r\n2) next try  \r\n    ```\r\n    jq -r &#39; .request.body.bonds[] | [.bondDesc, .priorPriceBid, .priorPriceOffer, .priorYieldBid, .priorYieldOffer, .updatedPriceBid, .updatedPriceOffer, .updatedYieldBid, .updatedYieldOffer] | @csv&#39; foo.json\r\n    ```\r\n    \r\n    **Result:**\r\n    \r\n    ```\r\n    &quot;bondDesc1&quot;,100,101,6.555,6.777,691,169,25.2345,25.9999\r\n    &quot;bondDesc2&quot;,200,201,2.555,2.777,791,269,35.2345,35.9999\r\n    ```\r\n\r\n3) But I can&#39;t figure out on how to combine them, it just gave me an error:  \r\n    ```\r\n    jq -r &#39; [.request.method, .request.url], .request.body.bonds[] | [.bondDesc, .priorPriceBid, .priorPriceOffer, .priorYieldBid, .priorYieldOffer, .updatedPriceBid, .updatedPriceOffer, .updatedYieldBid, .updatedYieldOffer] | @csv&#39; foo.json\r\n    ```\r\n    \r\n    **Result:**\r\n    \r\n    ```\r\n    jq: error (at foo.json:40): Cannot index array with string &quot;bondDesc&quot;\r\n    ```\r\n\r\n",
        "link": "https://stackoverflow.com/questions/76751224/how-to-use-jq-to-convert-json-to-csv-from-a-complex-json-data",
        "title": "How to use jq to convert json to csv from a complex json data"
    },
    {
        "tags": [
            "json",
            "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": 0,
                "creation_date": 1690190910,
                "post_id": 76753081,
                "comment_id": 135313772,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 15688806,
                    "reputation": 23,
                    "user_id": 11320597,
                    "user_type": "registered",
                    "profile_image": "https://lh5.googleusercontent.com/-HlRMijOf71c/AAAAAAAAAAI/AAAAAAAAAAc/kc1DgBD_yxQ/s256-rj/photo.jpg",
                    "display_name": "Andr&#233; Letterer",
                    "link": "https://stackoverflow.com/users/11320597/andr%c3%a9-letterer"
                },
                "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": 1690208233,
                "post_id": 76753081,
                "comment_id": 135317533,
                "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": 1690280595,
                "post_id": 76753081,
                "comment_id": 135328154,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "is_answered": false,
        "answer_count": 0,
        "score": 0,
        "last_activity_date": 1690252526,
        "creation_date": 1690190789,
        "last_edit_date": 1690252526,
        "question_id": 76753081,
        "body_markdown": "Is there any chance to access a embedded json value inside a value?\r\nThe assume json example looks like this:\r\n```\r\n{\r\n  &quot;key&quot;: &quot;{\\&quot;test\\&quot;:1,\\&quot;check\\&quot;:\\&quot;default\\&quot;}&quot;\r\n}\r\n```\r\nThis is more of a curiosity question.\r\n\r\nWhat I always do today is\r\n```\r\necho &#39;{&quot;key&quot;: &quot;{\\&quot;test\\&quot;:1,\\&quot;check\\&quot;:\\&quot;default\\&quot;}&quot;}&#39; | jq -r .key | jq .test\r\n```\r\nand I get `1` for this example.\r\n\r\nHowever I am curious if there is any possibility to omit the second jq pipe and to basically dense this down to one jq command.",
        "link": "https://stackoverflow.com/questions/76753081/access-embedded-json-in-value",
        "title": "Access embedded json in value"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 6313442,
                    "reputation": 45115,
                    "user_id": 5625547,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/oqCND.jpg?s=256",
                    "display_name": "0stone0",
                    "link": "https://stackoverflow.com/users/5625547/0stone0"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1690300413,
                "post_id": 76764430,
                "comment_id": 135332761,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 9838847,
                    "reputation": 147,
                    "user_id": 7292043,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/bbf9371e6a8eab07a0152849c1a09e78?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "ICIM",
                    "link": "https://stackoverflow.com/users/7292043/icim"
                },
                "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": 1690300836,
                "post_id": 76764430,
                "comment_id": 135332856,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 6313442,
                    "reputation": 45115,
                    "user_id": 5625547,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/oqCND.jpg?s=256",
                    "display_name": "0stone0",
                    "link": "https://stackoverflow.com/users/5625547/0stone0"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1690301159,
                "post_id": 76764430,
                "comment_id": 135332932,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1690309251,
                "creation_date": 1690309251,
                "answer_id": 76765538,
                "question_id": 76764430,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If you are trying to group by `.extId` while collecting the objects under `.intIDs[]`, then `group_by` has to go between the outer and the inner mappings:\r\n```sh\r\n.users\r\n| map({extId, name, connections: .intIds | map({registeredOn, leftOn, userLeftFlag})})\r\n| group_by(.extId)\r\n| map(first + {connections: map(.connections[])})\r\n```\r\n[Demo](https://jqplay.org/s/MsceCe90UOr)\r\n\r\nAlternatively, you could iterate using `reduce`, group manually on the go by collecting into an object, and restore the array using `map(.)`:\r\n```sh\r\nreduce .users[] as $user ({}; .[$user.extId] |= (($user | {extId, name}) + (\r\n  .connections += [$user.intIds[] | {registeredOn, leftOn, userLeftFlag}]\r\n))) | map(.)\r\n```\r\n[Demo](https://jqplay.org/s/BphcXi6bAeE)\r\n\r\nBoth approaches output\r\n```json\r\n[\r\n  {\r\n    &quot;extId&quot;: &quot;186&quot;,\r\n    &quot;name&quot;: &quot;generic name 1&quot;,\r\n    &quot;connections&quot;: [\r\n      {\r\n        &quot;registeredOn&quot;: 1690289980777,\r\n        &quot;leftOn&quot;: 0,\r\n        &quot;userLeftFlag&quot;: false\r\n      }\r\n    ]\r\n  },\r\n  {\r\n    &quot;extId&quot;: &quot;95&quot;,\r\n    &quot;name&quot;: &quot;Generic name 2&quot;,\r\n    &quot;connections&quot;: [\r\n      {\r\n        &quot;registeredOn&quot;: 1690295357122,\r\n        &quot;leftOn&quot;: 1690295379924,\r\n        &quot;userLeftFlag&quot;: true\r\n      },\r\n      {\r\n        &quot;registeredOn&quot;: 1690296171797,\r\n        &quot;leftOn&quot;: 0,\r\n        &quot;userLeftFlag&quot;: false\r\n      },\r\n      {\r\n        &quot;registeredOn&quot;: 1690293905345,\r\n        &quot;leftOn&quot;: 1690294109923,\r\n        &quot;userLeftFlag&quot;: true\r\n      }\r\n    ]\r\n  }\r\n]\r\n```",
                "title": "JQ - group duplicates, not delete them"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1690357690,
        "creation_date": 1690300115,
        "last_edit_date": 1690357690,
        "question_id": 76764430,
        "body_markdown": "I am trying to group the duplicates from the following json by `extId`, but remove duplicates.\r\n\r\n(there are 2 &#39;extId&#39;, I&#39;m only interested in the one inside &#39;users&#39;)\r\n\r\n**Here is the json:**\r\n```\r\n{\r\n  &quot;intId&quot;: &quot;97210f2c23f45b55569f32309105f395c94&quot;,\r\n  &quot;extId&quot;: &quot;39e9588ee62d1cccc711d75ff86c5570&quot;,\r\n  &quot;name&quot;: &quot;generic name&quot;,\r\n  &quot;users&quot;: {\r\n    &quot;186-1&quot;: {\r\n      &quot;userKey&quot;: &quot;186-1&quot;,\r\n      &quot;extId&quot;: &quot;186&quot;,\r\n      &quot;intIds&quot;: {\r\n        &quot;w_eyvyfghz844o&quot;: {\r\n          &quot;intId&quot;: &quot;w_eyvyfghz844o&quot;,\r\n          &quot;registeredOn&quot;: 1690289980777,\r\n          &quot;leftOn&quot;: 0,\r\n          &quot;userLeftFlag&quot;: false\r\n        }\r\n      },\r\n      &quot;name&quot;: &quot;generic name 1&quot;,\r\n      &quot;isModerator&quot;: true,\r\n      &quot;isDialIn&quot;: false,\r\n      &quot;currentIntId&quot;: &quot;w_eyvyfghz844o&quot;,\r\n      &quot;answers&quot;: {},\r\n      &quot;talk&quot;: {\r\n        &quot;totalTime&quot;: 5696194,\r\n        &quot;lastTalkStartedOn&quot;: 1690297856252\r\n      },\r\n      &quot;emojis&quot;: [],\r\n      &quot;webcams&quot;: [\r\n        {\r\n          &quot;startedOn&quot;: 1690289988531,\r\n          &quot;stoppedOn&quot;: 0\r\n        }\r\n      ],\r\n      &quot;totalOfMessages&quot;: 18\r\n    },\r\n    &quot;95-1&quot;: {\r\n      &quot;userKey&quot;: &quot;95-1&quot;,\r\n      &quot;extId&quot;: &quot;95&quot;,\r\n      &quot;intIds&quot;: {\r\n        &quot;w_kegd1ecwju02&quot;: {\r\n          &quot;intId&quot;: &quot;w_kegd1ecwju02&quot;,\r\n          &quot;registeredOn&quot;: 1690295357122,\r\n          &quot;leftOn&quot;: 1690295379924,\r\n          &quot;userLeftFlag&quot;: true\r\n        },\r\n        &quot;w_nc1egwb2axbr&quot;: {\r\n          &quot;intId&quot;: &quot;w_nc1egwb2axbr&quot;,\r\n          &quot;registeredOn&quot;: 1690296171797,\r\n          &quot;leftOn&quot;: 0,\r\n          &quot;userLeftFlag&quot;: false\r\n        }\r\n      },\r\n      &quot;name&quot;: &quot;Generic name 2&quot;,\r\n      &quot;isModerator&quot;: true,\r\n      &quot;isDialIn&quot;: false,\r\n      &quot;currentIntId&quot;: &quot;w_nc1egwb2axbr&quot;,\r\n      &quot;answers&quot;: {},\r\n      &quot;talk&quot;: {\r\n        &quot;totalTime&quot;: 0,\r\n        &quot;lastTalkStartedOn&quot;: 0\r\n      },\r\n      &quot;emojis&quot;: [],\r\n      &quot;webcams&quot;: [],\r\n      &quot;totalOfMessages&quot;: 0\r\n    },\r\n    &quot;95-2&quot;: {\r\n      &quot;userKey&quot;: &quot;95-2&quot;,\r\n      &quot;extId&quot;: &quot;95&quot;,\r\n      &quot;intIds&quot;: {\r\n        &quot;w_et8i4fc0fumu&quot;: {\r\n          &quot;intId&quot;: &quot;w_et8i4fc0fumu&quot;,\r\n          &quot;registeredOn&quot;: 1690293905345,\r\n          &quot;leftOn&quot;: 1690294109923,\r\n          &quot;userLeftFlag&quot;: true\r\n        }\r\n      },\r\n      &quot;name&quot;: &quot;Generic name 2&quot;,\r\n      &quot;isModerator&quot;: true,\r\n      &quot;isDialIn&quot;: false,\r\n      &quot;answers&quot;: {},\r\n      &quot;talk&quot;: {\r\n        &quot;totalTime&quot;: 0,\r\n        &quot;lastTalkStartedOn&quot;: 0\r\n      },\r\n      &quot;emojis&quot;: [],\r\n      &quot;webcams&quot;: [],\r\n      &quot;totalOfMessages&quot;: 0\r\n    }\r\n  },\r\n  &quot;polls&quot;: {},\r\n  &quot;screenshares&quot;: [\r\n    {\r\n      &quot;startedOn&quot;: 1690290408449,\r\n      &quot;stoppedOn&quot;: 1690290573091\r\n    },\r\n    {\r\n      &quot;startedOn&quot;: 1690294824305,\r\n      &quot;stoppedOn&quot;: 1690294957331\r\n    },\r\n    {\r\n      &quot;startedOn&quot;: 1690294976792,\r\n      &quot;stoppedOn&quot;: 1690295106468\r\n    },\r\n    {\r\n      &quot;startedOn&quot;: 1690295120270,\r\n      &quot;stoppedOn&quot;: 1690295742503\r\n    },\r\n    {\r\n      &quot;startedOn&quot;: 1690295747135,\r\n      &quot;stoppedOn&quot;: 1690297603487\r\n    },\r\n    {\r\n      &quot;startedOn&quot;: 1690297609337,\r\n      &quot;stoppedOn&quot;: 0\r\n    }\r\n  ],\r\n  &quot;presentationSlides&quot;: [\r\n    {\r\n      &quot;presentationId&quot;: &quot;8b8e93774c2cebfcde9582e0f9c169&quot;,\r\n      &quot;pageNum&quot;: 1,\r\n      &quot;setOn&quot;: 1690288860858\r\n    }\r\n  ],\r\n  &quot;createdOn&quot;: 1690288854908,\r\n  &quot;endedOn&quot;: 0\r\n}\r\n```\r\nHere is what i have tried with:\r\n\r\n    jq -r &#39;.users | [.[] | { &quot;extId&quot;:(.extId),&quot;name&quot;:.name, &quot;conections&quot;:[( .intIds[] | {&quot;registeredOn&quot;:.registeredOn,&quot;leftOn&quot;:.leftOn,&quot;userLeftFlag&quot;:.userLeftFlag} )] } ] | INDEX(.extId)&#39;\r\n\r\n```\r\n{\r\n  &quot;186&quot;: {\r\n    &quot;extId&quot;: &quot;186&quot;,\r\n    &quot;name&quot;: &quot;generic name 1&quot;,\r\n    &quot;conections&quot;: [\r\n      {\r\n        &quot;registeredOn&quot;: 1690289980777,\r\n        &quot;leftOn&quot;: 0,\r\n        &quot;userLeftFlag&quot;: false\r\n      }\r\n    ]\r\n  },\r\n  &quot;95&quot;: {\r\n    &quot;extId&quot;: &quot;95&quot;,\r\n    &quot;name&quot;: &quot;Generic name 2&quot;,\r\n    &quot;conections&quot;: [\r\n      {\r\n        &quot;registeredOn&quot;: 1690293905345,\r\n        &quot;leftOn&quot;: 1690294109923,\r\n        &quot;userLeftFlag&quot;: true\r\n      }\r\n    ]\r\n  }\r\n}\r\n```\r\n\r\nBut using `INDEX(.extId)` removes the duplicates, so I understand that I need to group them before\r\n\r\n```\r\n[\r\n  {\r\n    &quot;extId&quot;: &quot;186&quot;,\r\n    &quot;name&quot;: &quot;generic name 1&quot;,\r\n    &quot;conections&quot;: [\r\n      {\r\n        &quot;registeredOn&quot;: 1690289980777,\r\n        &quot;leftOn&quot;: 0,\r\n        &quot;userLeftFlag&quot;: false\r\n      }\r\n    ]\r\n  },\r\n  {\r\n    &quot;extId&quot;: &quot;95&quot;,\r\n    &quot;name&quot;: &quot;Generic name 2&quot;,\r\n    &quot;conections&quot;: [\r\n      {\r\n        &quot;registeredOn&quot;: 1690295357122,\r\n        &quot;leftOn&quot;: 1690295379924,\r\n        &quot;userLeftFlag&quot;: true\r\n      },\r\n      {\r\n        &quot;registeredOn&quot;: 1690296171797,\r\n        &quot;leftOn&quot;: 0,\r\n        &quot;userLeftFlag&quot;: false\r\n      }\r\n    ]\r\n  },\r\n  {\r\n    &quot;extId&quot;: &quot;95&quot;,\r\n    &quot;name&quot;: &quot;Generic name 2&quot;,\r\n    &quot;conections&quot;: [\r\n      {\r\n        &quot;registeredOn&quot;: 1690293905345,\r\n        &quot;leftOn&quot;: 1690294109923,\r\n        &quot;userLeftFlag&quot;: true\r\n      }\r\n    ]\r\n  }\r\n]\r\n```\r\n\r\nI don&#39;t require objects to have a key, but I would like to keep it.\r\n\r\nAny help would be appreciated.\r\n\r\n**Expected output:**\r\n\r\n    [\r\n      &quot;186&quot;: {\r\n        &quot;extId&quot;: &quot;186&quot;,\r\n        &quot;name&quot;: &quot;generic name 1&quot;,\r\n        &quot;connections&quot;: [\r\n          {\r\n            &quot;registeredOn&quot;: 1690289980777,\r\n            &quot;leftOn&quot;: 0,\r\n            &quot;userLeftFlag&quot;: false\r\n          }\r\n        ]\r\n      },\r\n      &quot;95&quot;: {\r\n        &quot;extId&quot;: &quot;95&quot;,\r\n        &quot;name&quot;: &quot;Generic name 2&quot;,\r\n        &quot;connections&quot;: [\r\n          {\r\n            &quot;registeredOn&quot;: 1690295357122,\r\n            &quot;leftOn&quot;: 1690295379924,\r\n            &quot;userLeftFlag&quot;: true\r\n          },\r\n          {\r\n            &quot;registeredOn&quot;: 1690296171797,\r\n            &quot;leftOn&quot;: 0,\r\n            &quot;userLeftFlag&quot;: false\r\n          },\r\n          {\r\n            &quot;registeredOn&quot;: 1690293905345,\r\n            &quot;leftOn&quot;: 1690294109923,\r\n            &quot;userLeftFlag&quot;: true\r\n          }\r\n        ]\r\n      }\r\n    ]",
        "link": "https://stackoverflow.com/questions/76764430/jq-group-duplicates-not-delete-them",
        "title": "JQ - group duplicates, not delete them"
    },
    {
        "tags": [
            "csv",
            "jq",
            "export-to-csv",
            "github-cli",
            "github-issues"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 6313442,
                    "reputation": 45115,
                    "user_id": 5625547,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/oqCND.jpg?s=256",
                    "display_name": "0stone0",
                    "link": "https://stackoverflow.com/users/5625547/0stone0"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1690384044,
                "post_id": 76772664,
                "comment_id": 135346558,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 308303,
                    "reputation": 37458,
                    "user_id": 620097,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/820980fd43f2607a815c1f3dbfe152cc?s=256&d=identicon&r=PG",
                    "display_name": "shellter",
                    "link": "https://stackoverflow.com/users/620097/shellter"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1690386093,
                "post_id": 76772664,
                "comment_id": 135347003,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 308303,
                    "reputation": 37458,
                    "user_id": 620097,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/820980fd43f2607a815c1f3dbfe152cc?s=256&d=identicon&r=PG",
                    "display_name": "shellter",
                    "link": "https://stackoverflow.com/users/620097/shellter"
                },
                "edited": false,
                "score": 3,
                "creation_date": 1690386168,
                "post_id": 76772664,
                "comment_id": 135347016,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "is_answered": false,
        "answer_count": 0,
        "score": 0,
        "last_activity_date": 1690383872,
        "creation_date": 1690383872,
        "question_id": 76772664,
        "body_markdown": "this command\r\n\r\n```\r\ngh issue list --limit 10000 --state all --json number,title,assignees,state,labels,url |^\r\njq -r &#39;[&quot;number&quot;,&quot;title&quot;,&quot;assignees&quot;,&quot;state&quot;,&quot;labels&quot;,&quot;url&quot;],^\r\n       (.[] | [.number, .title,^\r\n               (.assignees | if length==0 then &quot;Unassigned&quot; else map(.login)|join(&quot;,&quot;) end),^\r\n               .state,^\r\n               (.labels | map(.name)|join(&quot;,&quot;)),^\r\n               .url^\r\n              ]^\r\n       ) | @csv&#39; &gt; issues-$(date &#39;+%Y-%m-%d&#39;).csv\r\n```\r\n\r\n\r\nreturns the following error \r\n\r\n`.number not recognized as an internal or external command operable program or batch file`\r\n\r\nAny idea?\r\n\r\nI tried the command from cli and from .bat: same behavior",
        "link": "https://stackoverflow.com/questions/76772664/command-gh-issue-list-to-export-issues-to-csv-file",
        "title": "Command gh issue list to export issues to CSV file"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1690417309,
                "post_id": 76775778,
                "comment_id": 135352436,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 12538650,
                    "reputation": 171,
                    "user_id": 9124454,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b260039dc31ad36054668bfb9727f85d?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "puter",
                    "link": "https://stackoverflow.com/users/9124454/puter"
                },
                "reply_to_user": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1690431414,
                "post_id": 76775778,
                "comment_id": 135353615,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1690522988,
                "last_edit_date": 1690522988,
                "creation_date": 1690440531,
                "answer_id": 76777130,
                "question_id": 76775778,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The following solution does not assume that the intersection of key names is a singleton\r\n```\r\njq -n --argjson a &quot;$A&quot; --argjson b &quot;$B&quot; &#39;\r\n\r\n  def i: (.[0] | unique) as $u | $u - ($u - .[1]); \r\n  def k: [$a, $b] | map(keys_unsorted) | i;\r\n  [k[] | { (.): ($b[.] + $a[.]) } ] | add\r\n&#39;\r\n```\r\n",
                "title": "Jq how to merge two json objects"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": -1,
                "last_activity_date": 1690447499,
                "creation_date": 1690447499,
                "answer_id": 76777997,
                "question_id": 76775778,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "This should achieve what&#39;s expected :\r\n\r\n```\r\n#!/usr/bin/env bash\r\n\r\nA=&#39;{\r\n  &quot;extensions&quot;: { \r\n    &quot;app_name&quot;: &quot;extensions-prod&quot;\r\n  },\r\n  &quot;plugins&quot;: { \r\n    &quot;app_name&quot;: &quot;plugins-prod&quot; \r\n  }\r\n}&#39;\r\nB=&#39;\r\n{\r\n  &quot;plugins&quot;: { \r\n    &quot;project_name&quot;: &quot;plugins-prod&quot; \r\n  }\r\n}&#39;\r\n\r\njq -s &#39;map(to_entries) |\r\n       add |\r\n       group_by(.key) |\r\n       map(select(length == 2) |\r\n           { key: first | .key,\r\n             value: map(.value) | add\r\n           }\r\n          ) |\r\n       from_entries&#39; &lt;&lt;&lt; &quot;$A $B&quot;\r\n```",
                "title": "Jq how to merge two json objects"
            },
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1690466209,
                "creation_date": 1690466209,
                "answer_id": 76780496,
                "question_id": 76775778,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "&gt; [Edit] I would not know what the common key would be\r\n\r\nWith `in` you can find out if a given key is present in a given object. Thus, you could use `with_entries` to iterate over an object&#39;s fields, and `select` (keep) only those entries whose `.key` is present in another object. If object A is &quot;trimmed&quot; that way, it can then be (deeply) merged into object B using `*`:\r\n\r\n```sh\r\njq -n --argjson objA &quot;$objA&quot; --argjson objB &quot;$objB&quot; \\\r\n  &#39;$objB * ($objA | with_entries(select(.key | in($objB))))&#39;\r\n```\r\n\r\nThis assumes (in accordance with your sample data) that object B only contains common keys, such that only object A has to be trimmed to the keys of object B. If this isn&#39;t generally the case, symmetrically treat object B using object A. In fact, you could just define the trimming in a parametrizable function, and use it mutually on both objects:\r\n\r\n```sh\r\njq -n --argjson objA &quot;$objA&quot; --argjson objB &quot;$objB&quot; &#39;\r\n  def trim_to($o): with_entries(select(.key | in($o)));\r\n  ($objB | trim_to($objA)) * ($objA | trim_to($objB))\r\n&#39;\r\n```\r\n\r\nGiven the sample data, both output:\r\n```json\r\n{\r\n  &quot;plugins&quot;: {\r\n    &quot;project_name&quot;: &quot;plugins-prod&quot;,\r\n    &quot;app_name&quot;: &quot;plugins-prod&quot;\r\n  }\r\n}\r\n```",
                "title": "Jq how to merge two json objects"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 2,
        "last_activity_date": 1690522988,
        "creation_date": 1690416519,
        "last_edit_date": 1690431317,
        "question_id": 76775778,
        "body_markdown": "I want to merge two JSON objects that has a common key \r\n\r\nObject A\r\n```json\r\n{\r\n  &quot;extensions&quot;: { \r\n    &quot;app_name&quot;: &quot;extensions-prod&quot;\r\n  },\r\n  &quot;plugins&quot;: { \r\n    &quot;app_name&quot;: &quot;plugins-prod&quot; \r\n  }\r\n}\r\n```\r\n\r\nObject B\r\n```json\r\n{\r\n  &quot;plugins&quot;: { \r\n    &quot;project_name&quot;: &quot;plugins-prod&quot; \r\n  }\r\n}\r\n```\r\n\r\nDesired output:\r\n```json\r\n{\r\n  &quot;plugins&quot;: { \r\n    &quot;project_name&quot;: &quot;plugins-prod&quot;,\r\n    &quot;app_name&quot;: &quot;plugins-prod&quot; \r\n  }\r\n}\r\n```\r\n\r\nI did look into other SO [posts](https://stackoverflow.com/questions/70567330/merge-json-arrays-with-duplicate-keys) but were not very useful as the structure I have is different. Also the json objects are bash variables and not contained in a file.\r\n\r\n[Edit]\r\nI would not know what the common key would be since the JSON objects are being generated dynamically in a CI environment.",
        "link": "https://stackoverflow.com/questions/76775778/jq-how-to-merge-two-json-objects",
        "title": "Jq how to merge two json objects"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": false,
                "score": 4,
                "last_activity_date": 1690481395,
                "creation_date": 1690481395,
                "answer_id": 76782407,
                "question_id": 76782370,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Within `with_entries`, you only need to assign the computed value (`.key | length`) to `.value` using `=`. The value of `.key` remains unaltered.\r\n```sh\r\nmap(with_entries(.value = (.key | length)))\r\n```\r\n```json\r\n[\r\n  {\r\n    &quot;kiwi&quot;: 4\r\n  },\r\n  {\r\n    &quot;apple&quot;: 5\r\n  }\r\n]\r\n```\r\n[Demo](https://jqplay.org/s/q_t1-ReVseo)",
                "title": "using jq how can i change the value of a key?"
            },
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1690495984,
                "creation_date": 1690495984,
                "answer_id": 76783720,
                "question_id": 76782370,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You want\r\n\r\n```jq\r\nmap( with_entries( .value = ( .key | length ) ) )\r\n```\r\n\r\nExplanation follows.\r\n\r\n---\r\n\r\n```jq\r\n.value |= ( . | length )\r\n```\r\n\r\nis roughly equivalent to\r\n\r\n```jq\r\n.value = ( .value | . | length )\r\n```\r\n\r\nSo you are effectively doing `3 | length` and `4 | length`. When given a number, `length` produces the number. So these produce `3` and `4` respectively.\r\n\r\nYou want the length of the *key*.\r\n\r\n```jq\r\n.value = ( .key | length )\r\n```\r\n\r\n---\r\n\r\nSimilarly, \r\n\r\n```jq\r\n.key |= &quot;\\(.)&quot;\r\n```\r\n\r\ncan be seen as \r\n\r\n```jq\r\n.key = ( .key | &quot;\\(.)&quot; )\r\n```\r\n\r\nSince the key is already a string, that&#39;s just\r\n\r\n```jq\r\n.key = .key\r\n```\r\n\r\nAnd this does nothing at all.\r\n",
                "title": "using jq how can i change the value of a key?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 2,
        "last_activity_date": 1690495984,
        "creation_date": 1690481101,
        "last_edit_date": 1690492852,
        "question_id": 76782370,
        "body_markdown": "Using jq how can i change the value of a key?\r\nI am trying to change the value of a key based on the length of the key. But it seems to not work as expected.\r\n\r\n    echo &#39;[{&quot;kiwi&quot;: 3 }, {&quot;apple&quot; : 4} ]&#39; | jq &#39;map(with_entries(.key |= &quot;\\(.)&quot;, .value |= (. | length)))&#39;\r\nactual output: \r\n\r\n    [\r\n      {\r\n        &quot;kiwi&quot;: 3\r\n      },\r\n      {\r\n        &quot;apple&quot;: 4\r\n      }\r\n    ]\r\n\r\ndesired output -\r\n\r\n    [\r\n      {\r\n        &quot;kiwi&quot;: 4\r\n      },\r\n      {\r\n        &quot;apple&quot;: 5\r\n      }\r\n    ]",
        "link": "https://stackoverflow.com/questions/76782370/using-jq-how-can-i-change-the-value-of-a-key",
        "title": "using jq how can i change the value of a key?"
    },
    {
        "tags": [
            "json",
            "jq",
            "default-value"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1690615864,
                "last_edit_date": 1690615864,
                "creation_date": 1690613178,
                "answer_id": 76792380,
                "question_id": 76791870,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If fields clash on a merge, the right one overwrites the left one. You can utilize this fact by putting default values to the left, and merge with current values on the right. The kind of iteration over &quot;current values&quot; depends on your structure and your prerequisites.\r\n\r\nA merge, for example, may (`*`) or may not (`+`) be deep. Here are examples for both: The first one updates the `.foo` field by (shallow) merging it with an object just containing values for `a`, `b`, and `c`. The second one updates the root object by (deep) merging it with an object containing values for `foo.a`, `foo.b`, and `foo.c`. Both approaches output the original root level.\r\n\r\n```sh\r\nmap(.foo |= {a:0, b:0, c:0} + .)\r\n```\r\n[Demo](https://jqplay.org/s/zNw_7ZxpnKy)\r\n\r\n```sh\r\nmap({foo: {a:0, b:0, c:0}} * .)\r\n```\r\n[Demo](https://jqplay.org/s/BEh03kBRTwK)\r\n\r\nAlternatively, if you want a path-based approach, you could provide a list of paths to iterate over, and set values at those paths as needed. The following examples make use of the alternative operator `//` from your own approach (which does set the default value even if the original one indeed exists if it evaluates to `null` or `false`):\r\n\r\n```sh\r\nmap(reduce(\r\n  [&quot;foo&quot;, &quot;a&quot;],\r\n  [&quot;foo&quot;, &quot;b&quot;],\r\n  [&quot;foo&quot;, &quot;c&quot;]\r\n) as $p (.; setpath($p; getpath($p) // 0)))\r\n```\r\n[Demo](https://jqplay.org/s/M9VigTQAFlh)\r\n\r\nYou may also provide and set the default values individually:\r\n```sh\r\nmap(reduce(\r\n  [[&quot;foo&quot;, &quot;a&quot;], 0],\r\n  [[&quot;foo&quot;, &quot;b&quot;], 0],\r\n  [[&quot;foo&quot;, &quot;c&quot;], 0]\r\n) as [$p, $v] (.; setpath($p; getpath($p) // $v)))\r\n```\r\n[Demo](https://jqplay.org/s/RDkFqN3-fPA)\r\n\r\nIn any case, use `map(...)` (or `.[] |= ...`, or `[.[] | ...]`) instead of just `.[] | ...` in order to process the top-level array&#39;s items and retain the array structure.\r\n\r\nGiven your sample input, all of these approaches output the same result (with variations in field order for the latter two, path-based examples, as ↑here the default value in some cases is &quot;introduced later&quot; than the original ones, but they are, nevertheless, logically equivalent):\r\n\r\n```json\r\n[\r\n  {\r\n    &quot;foo&quot;: {\r\n      &quot;a&quot;: 0,\r\n      &quot;b&quot;: 0,\r\n      &quot;c&quot;: 0\r\n    }\r\n  },\r\n  {\r\n    &quot;foo&quot;: {\r\n      &quot;a&quot;: 1,\r\n      &quot;b&quot;: 0,\r\n      &quot;c&quot;: 0\r\n    }\r\n  },\r\n  {\r\n    &quot;foo&quot;: {\r\n      &quot;a&quot;: 0,\r\n      &quot;b&quot;: 4,\r\n      &quot;c&quot;: 23\r\n    }\r\n  },\r\n  {\r\n    &quot;foo&quot;: {\r\n      &quot;a&quot;: 15,\r\n      &quot;b&quot;: 2,\r\n      &quot;c&quot;: 33\r\n    }\r\n  }\r\n]\r\n```",
                "title": "jq: Defaulting multiple possibly-nonexistent key, in nested path?"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1690685960,
                "creation_date": 1690685960,
                "answer_id": 76796180,
                "question_id": 76791870,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "As I understand the problem, you want a simple way to generate the output shown in the question by setting the default values in just one place.  Here&#39;s one way:\r\n```\r\ndef foo(f): {foo: ({a:0, b:0, c:0} + f)};\r\n\r\n[\r\n foo(null),\r\n foo({a: 1}),\r\n foo({b: 4, c: 23}),\r\n foo({a:15,b:2,c:33})\r\n ]\r\n```",
                "title": "jq: Defaulting multiple possibly-nonexistent key, in nested path?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1690761697,
        "creation_date": 1690598816,
        "last_edit_date": 1690761697,
        "question_id": 76791870,
        "body_markdown": "I&#39;d like to default values in place on jq, and return root document.\r\n\r\nWhat I have (&lt;!-- sorry for minimizing, it didn&#39;t allow post unless do; --&gt;note that some property is missing from the inner object) is following, but length is not fixed:\r\n\r\n```json\r\n[{&quot;foo&quot;:{}},{&quot;foo&quot;:{&quot;a&quot;:1}},{&quot;foo&quot;:{&quot;b&quot;:4,&quot;c&quot;:23}},{&quot;foo&quot;:{&quot;a&quot;:15,&quot;b&quot;:2,&quot;c&quot;:33}}]\r\n```\r\n\r\nWhat I want (default missing property with `0`) for above example:\r\n\r\n```json\r\n[\r\n  {\r\n    &quot;foo&quot;: {\r\n      &quot;a&quot;: 0,\r\n      &quot;b&quot;: 0,\r\n      &quot;c&quot;: 0\r\n    }\r\n  },\r\n  {\r\n    &quot;foo&quot;: {\r\n      &quot;a&quot;: 1,\r\n      &quot;b&quot;: 0,\r\n      &quot;c&quot;: 0,\r\n    }\r\n  },\r\n  {\r\n    &quot;foo&quot;: {\r\n      &quot;a&quot;: 0,\r\n      &quot;b&quot;: 4,\r\n      &quot;c&quot;: 23\r\n    }\r\n  },\r\n  {\r\n    &quot;foo&quot;: {\r\n      &quot;a&quot;: 15,\r\n      &quot;b&quot;: 2,\r\n      &quot;c&quot;: 33\r\n    }\r\n  }\r\n]\r\n```\r\n\r\n\r\nI&#39;ve tried something like `jq &#39;.[] | (.foo | getpath([&quot;a&quot;]) //= 0)&#39; &lt; in &gt; out`, but this returns stream of the inner object instead of root document; this is not what I wanted because there are other property to grouping record, I would like to group by it later.\r\n",
        "link": "https://stackoverflow.com/questions/76791870/jq-defaulting-multiple-possibly-nonexistent-key-in-nested-path",
        "title": "jq: Defaulting multiple possibly-nonexistent key, in nested path?"
    },
    {
        "tags": [
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1690707058,
                "post_id": 76796930,
                "comment_id": 135388631,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1690707452,
                "post_id": 76796930,
                "comment_id": 135388657,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 8422116,
                    "reputation": 81,
                    "user_id": 6320605,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/OuxoA.jpg?s=256",
                    "display_name": "Jojo Thomas",
                    "link": "https://stackoverflow.com/users/6320605/jojo-thomas"
                },
                "reply_to_user": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1690710742,
                "post_id": 76796930,
                "comment_id": 135388946,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 8422116,
                    "reputation": 81,
                    "user_id": 6320605,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/OuxoA.jpg?s=256",
                    "display_name": "Jojo Thomas",
                    "link": "https://stackoverflow.com/users/6320605/jojo-thomas"
                },
                "reply_to_user": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1690711054,
                "post_id": 76796930,
                "comment_id": 135388984,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 8422116,
                    "reputation": 81,
                    "user_id": 6320605,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/OuxoA.jpg?s=256",
                    "display_name": "Jojo Thomas",
                    "link": "https://stackoverflow.com/users/6320605/jojo-thomas"
                },
                "reply_to_user": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1690711456,
                "post_id": 76796930,
                "comment_id": 135388999,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1690711821,
                "post_id": 76796930,
                "comment_id": 135389037,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 8422116,
                    "reputation": 81,
                    "user_id": 6320605,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/OuxoA.jpg?s=256",
                    "display_name": "Jojo Thomas",
                    "link": "https://stackoverflow.com/users/6320605/jojo-thomas"
                },
                "reply_to_user": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1690712809,
                "post_id": 76796930,
                "comment_id": 135389137,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1690712880,
                "last_edit_date": 1690712880,
                "creation_date": 1690711235,
                "answer_id": 76797247,
                "question_id": 76796930,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can use map_values together with select :\r\n\r\n```\r\njq &#39;map_values(select(. &gt; 128))&#39; session_len.json\r\n```\r\n\r\nTo sort data by numerical value, following seems to work :\r\n\r\n```\r\njq &#39;to_entries |\r\n    map(select(.value &gt; 128)) |\r\n    sort_by(.value) |\r\n    from_entries&#39; session_len.json\r\n```\r\n\r\n(I&#39;m not totally sure if `from_entries` guarantees the order in all cases)",
                "title": "For a simple key-value pair list JSON, use jq to print only key-value pairs where value is greater than a given constant number"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1690712880,
        "creation_date": 1690705416,
        "last_edit_date": 1690710638,
        "question_id": 76796930,
        "body_markdown": "Consider the following JSON having a list of key-value pairs\r\n\r\n```\r\n{\r\n  &quot;session1&quot;: 128,\r\n  &quot;session2&quot;: 1024,\r\n  &quot;session3&quot;: 258,\r\n  &quot;session4&quot;: 128,\r\n  &quot;session5&quot;: 32456,\r\n  &quot;session6&quot;: 128\r\n}\r\n```\r\n\r\nThe key is a session identifier, and the value is the length of the value stored in the session.\r\n\r\n**FYI** - The above JSON is created with the following\r\n```\r\ncat session_detail.json | jq &#39;.[]&#39; | jq -c &#39;with_entries(.value |= length)&#39; &gt; session_len.json\r\n```\r\n\r\nI want to print only those key-value pairs where value &gt; 128.\r\n\r\nThe expected output is\r\n\r\n```\r\n{\r\n  &quot;session2&quot;: 1024,\r\n  &quot;session3&quot;: 258,\r\n  &quot;session5&quot;: 32456\r\n}\r\n```\r\n\r\nI have tried to use **select**.",
        "link": "https://stackoverflow.com/questions/76796930/for-a-simple-key-value-pair-list-json-use-jq-to-print-only-key-value-pairs-wher",
        "title": "For a simple key-value pair list JSON, use jq to print only key-value pairs where value is greater than a given constant number"
    },
    {
        "tags": [
            "json",
            "jq",
            "frequency-distribution"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1690717205,
                "last_edit_date": 1690717205,
                "creation_date": 1690715693,
                "answer_id": 76797482,
                "question_id": 76797427,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The following should work:\r\n\r\n```\r\nto_entries\r\n| map(.value / 1048576 | floor | [tostring, &quot;-&quot;, (.+1 | tostring), &quot;MB&quot;] | add)\r\n| group_by(.)\r\n| map({&quot;key&quot;: .[0], &quot;value&quot;: length})\r\n| from_entries\r\n```\r\n\r\nFor your input, it produces the following output:\r\n\r\n```\r\n{\r\n  &quot;0-1MB&quot;: 1,\r\n  &quot;1-2MB&quot;: 1,\r\n  &quot;11-12MB&quot;: 2,\r\n  &quot;2-3MB&quot;: 1,\r\n  &quot;3-4MB&quot;: 2\r\n}\r\n```\r\n\r\n(11534338 and 11544336 are counted in the &quot;11-12MB&quot; bucket rather than the &quot;10-11MB&quot; one, because 11*2^20 = 11534336, and those numbers are larger than that.)\r\n\r\nIf you wanted the keys in numeric order, you could also convert them to your preferred string labels after the `group_by`:\r\n\r\n```\r\nto_entries\r\n| map(.value / 1048576 | floor)\r\n| group_by(.)\r\n| map({&quot;key&quot;: [(.[0] | tostring), &quot;-&quot;, (.[0]+1 | tostring), &quot;MB&quot;] | add, &quot;value&quot;: length})\r\n| from_entries\r\n```\r\n\r\nWhich produces:\r\n\r\n```\r\n{\r\n  &quot;0-1MB&quot;: 1,\r\n  &quot;1-2MB&quot;: 1,\r\n  &quot;2-3MB&quot;: 1,\r\n  &quot;3-4MB&quot;: 2,\r\n  &quot;11-12MB&quot;: 2\r\n}\r\n```\r\n\r\nBoth solutions have the same basic steps:\r\n\r\n1. Convert the input object to an array of `{&quot;key&quot;: x, &quot;value&quot;: y}` entries (`to_entries`).\r\n1. Map the entries into something that identifies the range they&#39;re in, by rouding down to the nearest megabyte (`.value / 1048576 | floor`).\r\n1. Group by the value (`group_by`). This produces an array like `[[0], [1], [2], [3, 3], [11, 11]]` for your input.\r\n1. For each group, produce an entry where the &quot;key&quot; field is the range label (&quot;X-YMB&quot;) and the &quot;value&quot; is the number of elements in the group (`length`).\r\n1. Convert the list of entries back to a single object (`from_entries`).",
                "title": "For a simple key-value pair list JSON, use jq to print a summary by range of values"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1690721841,
                "creation_date": 1690721841,
                "answer_id": 76797849,
                "question_id": 76797427,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s an approach using `reduce` which simply iterates over the input values integer-divided by 1MB, and successively increments the according result field by one.\r\n```sh\r\nreduce (.[] / 1048576 | floor) as $k ({}; .&quot;\\($k)-\\($k+1)MB&quot; += 1)\r\n```\r\n```json\r\n{\r\n  &quot;0-1MB&quot;: 1,\r\n  &quot;1-2MB&quot;: 1,\r\n  &quot;3-4MB&quot;: 2,\r\n  &quot;11-12MB&quot;: 2,\r\n  &quot;2-3MB&quot;: 1\r\n}\r\n```\r\n[Demo](https://jqplay.org/s/jNEgRfD1A_b)\r\n\r\nThe stream of numbers iterated over can, of course, be sorted first to get an object with increasing field names:\r\n```sh\r\nreduce (map(.) | sort[] / 1048576 | floor) as $k ({}; .&quot;\\($k)-\\($k+1)MB&quot; += 1)\r\n```\r\n```json\r\n{\r\n  &quot;0-1MB&quot;: 1,\r\n  &quot;1-2MB&quot;: 1,\r\n  &quot;2-3MB&quot;: 1,\r\n  &quot;3-4MB&quot;: 2,\r\n  &quot;11-12MB&quot;: 2\r\n}\r\n```\r\n[Demo](https://jqplay.org/s/iNYRkExSsZ7)",
                "title": "For a simple key-value pair list JSON, use jq to print a summary by range of values"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1690722514,
        "creation_date": 1690714611,
        "last_edit_date": 1690722514,
        "question_id": 76797427,
        "body_markdown": "Consider the following JSON having a list of key-value pairs\r\n\r\n```\r\n{\r\n  &quot;session1&quot;: 128,\r\n  &quot;session2&quot;: 1048596,\r\n  &quot;session3&quot;: 3145728,\r\n  &quot;session4&quot;: 3145828,\r\n  &quot;session5&quot;: 11534338,\r\n  &quot;session6&quot;: 11544336,\r\n  &quot;session7&quot;: 2097252\r\n}\r\n```\r\n\r\nThe key is a session identifier, and the value is the length of the value stored in the session.\r\n\r\nI want to print counts of values by range - the ranges being (lower bound included, high bound excluded); 0-1MB, 1-2MB, 2-3MB, ... 12-13MB.\r\n\r\n```\r\n 1MB =  1048576\r\n 2MB =  2097152\r\n 3MB =  3145728\r\n 4MB =  4194304\r\n 5MB =  5242880\r\n 6MB =  6291456\r\n 7MB =  7340032\r\n 8MB =  8388608\r\n 9MB =  9437184\r\n10MB = 10485760\r\n11MB = 11534336\r\n12MB = 12582912\r\n13MB = 13631488\r\n```\r\n\r\nThe expected output is\r\n```\r\n{\r\n  &quot;0-1MB&quot;: 1,\r\n  &quot;1-2MB&quot;: 1,\r\n  &quot;2-3MB&quot;: 1,\r\n  &quot;3-4MB&quot;: 2,\r\n  &quot;10-11MB&quot;: 2\r\n}\r\n```\r\n\r\nThe above is just representative, suggestions are welcome.",
        "link": "https://stackoverflow.com/questions/76797427/for-a-simple-key-value-pair-list-json-use-jq-to-print-a-summary-by-range-of-val",
        "title": "For a simple key-value pair list JSON, use jq to print a summary by range of values"
    },
    {
        "tags": [
            "json",
            "stream",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1690723788,
                "creation_date": 1690723788,
                "answer_id": 76797968,
                "question_id": 76797917,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You need to `truncate_stream` by two levels: `.results` and `.[]`. Use `inputs` (and the `-n` flag) for the input, and `fromstream` to construct the output:\r\n```sh\r\njq --stream -cn &#39;fromstream(2|truncate_stream(inputs))&#39;\r\n```\r\n\r\nIf you want to specify `.results` explicitly (necessary if the input contains more than just this one field), use `select` on the input:\r\n```sh\r\njq --stream -cn &#39;fromstream(2|truncate_stream(inputs | select(.[0][0] == &quot;results&quot;)))&#39;\r\n```\r\n\r\nOutput:\r\n```json\r\n{&quot;data&quot;:[{&quot;row&quot;:[{&quot;key1&quot;:&quot;row1&quot;,&quot;key2&quot;:&quot;row1&quot;}]},{&quot;row&quot;:[{&quot;key1&quot;:&quot;row2&quot;,&quot;key2&quot;:&quot;row2&quot;}]}]}\r\n{&quot;data&quot;:[{&quot;row&quot;:[{&quot;key1&quot;:&quot;row3&quot;,&quot;key2&quot;:&quot;row3&quot;}]},{&quot;row&quot;:[{&quot;key1&quot;:&quot;row4&quot;,&quot;key2&quot;:&quot;row4&quot;}]}]}\r\n```\r\n",
                "title": "jq: Using stream and not"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1690787904,
        "creation_date": 1690722953,
        "last_edit_date": 1690787904,
        "question_id": 76797917,
        "body_markdown": "This is likely a shamefully simple problem, but I cannot figure it out. I am trying to use [this question][1] to extract some data using the --stream option of jq. Here is my sample json:\r\n\r\n    {\r\n      &quot;date&quot;: &quot;2023-07-30&quot;,\r\n      &quot;results&quot;:[\r\n        {\r\n          &quot;data&quot;: [    \r\n            {&quot;row&quot;: [{&quot;key1&quot;: &quot;row1&quot;, &quot;key2&quot;: &quot;row1&quot;}]},\r\n            {&quot;row&quot;: [{&quot;key1&quot;: &quot;row2&quot;, &quot;key2&quot;: &quot;row2&quot;}]}\r\n          ]\r\n        },\r\n        {\r\n          &quot;data&quot;: [    \r\n            {&quot;row&quot;: [{&quot;key1&quot;: &quot;row3&quot;, &quot;key2&quot;: &quot;row3&quot;}]},\r\n            {&quot;row&quot;: [{&quot;key1&quot;: &quot;row4&quot;, &quot;key2&quot;: &quot;row4&quot;}]}\r\n          ]\r\n        }\r\n      ]\r\n    }\r\n\r\nWithout stream, I can use the following to extract what I want:\r\n\r\n    jq -rc &quot;.results[]&quot; my_json.json\r\nand this would give me the desired result:\r\n\r\n    {&quot;data&quot;:[{&quot;row&quot;:[{&quot;key1&quot;:&quot;row1&quot;,&quot;key2&quot;:&quot;row1&quot;}]},{&quot;row&quot;:[{&quot;key1&quot;:&quot;row2&quot;,&quot;key2&quot;:&quot;row2&quot;}]}]}\r\n    {&quot;data&quot;:[{&quot;row&quot;:[{&quot;key1&quot;:&quot;row3&quot;,&quot;key2&quot;:&quot;row3&quot;}]},{&quot;row&quot;:[{&quot;key1&quot;:&quot;row4&quot;,&quot;key2&quot;:&quot;row4&quot;}]}]}\r\n\r\nThis output is one json object per line, just what I would like.\r\n\r\nHowever, if I want to do the same thing using the stream option, I am unable to get the same output.\r\n\r\n    jq -rc --stream &#39;fromstream(1|truncate_stream(inputs | select(.[0][0] == &quot;results&quot;)))&#39; my_json.json\r\nwhich gives:\r\n\r\n    [\r\n      {&quot;data&quot;:[{&quot;row&quot;:[{&quot;key1&quot;:&quot;row1&quot;,&quot;key2&quot;:&quot;row1&quot;}]},{&quot;row&quot;:[{&quot;key1&quot;:&quot;row2&quot;,&quot;key2&quot;:&quot;row2&quot;}]}]},\r\n      {&quot;data&quot;:[{&quot;row&quot;:[{&quot;key1&quot;:&quot;row3&quot;,&quot;key2&quot;:&quot;row3&quot;}]},{&quot;row&quot;:[{&quot;key1&quot;:&quot;row4&quot;,&quot;key2&quot;:&quot;row4&quot;}]}]}\r\n    ]\r\nI feel like I am missing one simple step to getting the answer I need.\r\n\r\n  [1]: https://stackoverflow.com/questions/39232060/process-large-json-stream-with-jq",
        "link": "https://stackoverflow.com/questions/76797917/jq-using-stream-and-not",
        "title": "jq: Using stream and not"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1690737231,
                "last_edit_date": 1690737231,
                "creation_date": 1690729967,
                "answer_id": 76798381,
                "question_id": 76798065,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "In analogy to your [other question](https://stackoverflow.com/a/76797849/2158479), iterate over the values before dividing, and add them instead of `1`:\r\n```sh\r\nreduce (map(.) | sort[]) as $n ({}; .[$n / 1048576 | floor | &quot;\\(.)-\\(.+1)MB&quot;] += $n)\r\n```\r\n```json\r\n{\r\n  &quot;0-1MB&quot;: 128,\r\n  &quot;1-2MB&quot;: 1048596,\r\n  &quot;2-3MB&quot;: 2097252,\r\n  &quot;3-4MB&quot;: 6291556,\r\n  &quot;11-12MB&quot;: 23078674\r\n}\r\n```\r\n[Demo](https://jqplay.org/s/H_8fzKrz6WH)",
                "title": "For a simple key-value pair list JSON, use jq to print the sum of values by range"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1690737231,
        "creation_date": 1690725240,
        "question_id": 76798065,
        "body_markdown": "Consider the following JSON having a list of key-value pairs\r\n\r\n```\r\n{\r\n  &quot;session1&quot;: 128,\r\n  &quot;session2&quot;: 1048596,\r\n  &quot;session3&quot;: 3145728,\r\n  &quot;session4&quot;: 3145828,\r\n  &quot;session5&quot;: 11534338,\r\n  &quot;session6&quot;: 11544336,\r\n  &quot;session7&quot;: 2097252\r\n}\r\n```\r\n\r\nThe value is number of bytes\r\n\r\nI want to print sum of values by range - the ranges being (lower bound included, high bound excluded); 0-1MB, 1-2MB, 2-3MB, ... 12-13MB.\r\n\r\n```\r\n 1MB =  1048576\r\n 2MB =  2097152\r\n 3MB =  3145728\r\n 4MB =  4194304\r\n 5MB =  5242880\r\n 6MB =  6291456\r\n 7MB =  7340032\r\n 8MB =  8388608\r\n 9MB =  9437184\r\n10MB = 10485760\r\n11MB = 11534336\r\n12MB = 12582912\r\n13MB = 13631488\r\n```\r\n\r\nThe expected output is\r\n\r\n```\r\n{\r\n  &quot;0-1MB&quot;: 128,\r\n  &quot;1-2MB&quot;: 1048596,\r\n  &quot;2-3MB&quot;: 2097252,\r\n  &quot;3-4MB&quot;: 6291556,\r\n  &quot;11-12MB&quot;: 23078674\r\n}\r\n```\r\n\r\nThe above is just representative, suggestions are welcome (*like having the value output in human readable format*).",
        "link": "https://stackoverflow.com/questions/76798065/for-a-simple-key-value-pair-list-json-use-jq-to-print-the-sum-of-values-by-rang",
        "title": "For a simple key-value pair list JSON, use jq to print the sum of values by range"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 6196394,
                    "reputation": 86601,
                    "user_id": 5291015,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/4tAvO.jpg?s=256",
                    "display_name": "Inian",
                    "link": "https://stackoverflow.com/users/5291015/inian"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1690807622,
                "post_id": 76803755,
                "comment_id": 135400066,
                "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": 1690807660,
                "post_id": 76803755,
                "comment_id": 135400080,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1690808702,
                "last_edit_date": 1690808702,
                "creation_date": 1690808226,
                "answer_id": 76803860,
                "question_id": 76803755,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "[tag:jq] doesn&#39;t have any file IO facilities, so you can&#39;t output multiple files.\r\n\r\nYou can output each piece of data with it&#39;s key and post-process it:\r\n\r\n```sh\r\njq -r &#39;\r\n    to_entries[]\r\n    | select(.key != &quot;date&quot;)\r\n    | .key as $k\r\n    | .value[]\r\n    | [$k, @json]\r\n    | @tsv\r\n&#39; my_json.json\r\n```\r\noutputs\r\n```none\r\nresults1\t{&quot;data&quot;:[{&quot;row&quot;:[{&quot;key1&quot;:&quot;row1&quot;,&quot;key2&quot;:&quot;row1&quot;}]},{&quot;row&quot;:[{&quot;key1&quot;:&quot;row2&quot;,&quot;key2&quot;:&quot;row2&quot;}]}]}\r\nresults1\t{&quot;data&quot;:[{&quot;row&quot;:[{&quot;key1&quot;:&quot;row3&quot;,&quot;key2&quot;:&quot;row3&quot;}]},{&quot;row&quot;:[{&quot;key1&quot;:&quot;row4&quot;,&quot;key2&quot;:&quot;row4&quot;}]}]}\r\nresults2\t{&quot;data&quot;:[{&quot;row&quot;:[{&quot;key3&quot;:&quot;row1&quot;,&quot;key4&quot;:&quot;row1&quot;}]},{&quot;row&quot;:[{&quot;key3&quot;:&quot;row2&quot;,&quot;key4&quot;:&quot;row2&quot;}]}]}\r\nresults2\t{&quot;data&quot;:[{&quot;row&quot;:[{&quot;key3&quot;:&quot;row3&quot;,&quot;key4&quot;:&quot;row3&quot;}]},{&quot;row&quot;:[{&quot;key3&quot;:&quot;row4&quot;,&quot;key4&quot;:&quot;row4&quot;}]}]}\r\n```\r\n\r\nSo: \r\n```sh\r\nwhile IFS=$&#39;\\t&#39; read -r key json; do\r\n    printf &#39;%s\\n&#39; &quot;$json&quot; &gt;&gt; &quot;${key}.jsonl&quot;\r\ndone &lt; &lt;(\r\n    jq -r &#39;...&#39; my_json.json\r\n)\r\n```\r\nor\r\n```sh\r\njq -r &#39;...&#39; my_json.json | awk -F &#39;\\t&#39; &#39;{print $2 &gt; ($1 &quot;.jsonl&quot;)}&#39;\r\n```",
                "title": "Using jq to extract multiple json objects"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1690809905,
                "creation_date": 1690809905,
                "answer_id": 76804085,
                "question_id": 76803755,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "With Bash ≥ 4, processing bigger chunks could be improved by reading n lines at once using `mapfile`:\r\n```sh\r\njq -cr &#39;$ARGS.positional[] as $key | .[$key] | $key, length, .[]&#39; input.json \\\r\n  --args results1 results2 | while read -r key; read -r len\r\ndo mapfile -t -n $len\r\n  printf &#39;%s\\n&#39; &quot;${MAPFILE[@]}&quot; &gt; &quot;$key.jsonl&quot;\r\ndone\r\n```",
                "title": "Using jq to extract multiple json objects"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1690809905,
        "creation_date": 1690807377,
        "last_edit_date": 1690808315,
        "question_id": 76803755,
        "body_markdown": "I have been using `jq` to successfully extract one JSON blob at a time from some relatively large files and write it out to a file of one JSON object per line for further processing. Here is an example of the JSON format:\r\n\r\n    {\r\n      &quot;date&quot;: &quot;2023-07-30&quot;,\r\n      &quot;results1&quot;:[\r\n        {\r\n          &quot;data&quot;: [    \r\n            {&quot;row&quot;: [{&quot;key1&quot;: &quot;row1&quot;, &quot;key2&quot;: &quot;row1&quot;}]},\r\n            {&quot;row&quot;: [{&quot;key1&quot;: &quot;row2&quot;, &quot;key2&quot;: &quot;row2&quot;}]}\r\n          ]\r\n        },\r\n        {\r\n          &quot;data&quot;: [    \r\n            {&quot;row&quot;: [{&quot;key1&quot;: &quot;row3&quot;, &quot;key2&quot;: &quot;row3&quot;}]},\r\n            {&quot;row&quot;: [{&quot;key1&quot;: &quot;row4&quot;, &quot;key2&quot;: &quot;row4&quot;}]}\r\n          ]\r\n        }\r\n      ],\r\n      &quot;results2&quot;:[\r\n        {\r\n          &quot;data&quot;: [    \r\n            {&quot;row&quot;: [{&quot;key3&quot;: &quot;row1&quot;, &quot;key4&quot;: &quot;row1&quot;}]},\r\n            {&quot;row&quot;: [{&quot;key3&quot;: &quot;row2&quot;, &quot;key4&quot;: &quot;row2&quot;}]}\r\n          ]\r\n        },\r\n        {\r\n          &quot;data&quot;: [    \r\n            {&quot;row&quot;: [{&quot;key3&quot;: &quot;row3&quot;, &quot;key4&quot;: &quot;row3&quot;}]},\r\n            {&quot;row&quot;: [{&quot;key3&quot;: &quot;row4&quot;, &quot;key4&quot;: &quot;row4&quot;}]}\r\n          ]\r\n        }\r\n      ]\r\n    }\r\nMy current approach is to run the following and redirect the stdout to a file:\r\n\r\n    jq -rc &quot;.results1[]&quot; my_json.json\r\n\r\nThis works fine, however, it seems like `jq` reads the entire file into memory in order to extract the chunk I am interested in.\r\n\r\nQuestions:\r\n\r\n 1. Does jq read the entire file into memory when I execute the above\r\n    statement? \r\n 2. Assuming the answer is yes, is there a way that I can extract `results1[]` and `results2[]` on the same call to avoid reading the file twice?\r\n\r\nI have used the `--stream` option but it is very slow. I also read that it sacrifices speed for memory savings, but memory is not an issue at this time so I would prefer to avoid using this option. Basically, what I need is to read in the above json once and output two files in JSON lines format.\r\n\r\nEdit: (I changed the input data a bit to show the differences in the output)\r\n\r\nOutput file 1:\r\n\r\n    {&quot;data&quot;:[{&quot;row&quot;:[{&quot;key1&quot;:&quot;row1&quot;,&quot;key2&quot;:&quot;row1&quot;}]},{&quot;row&quot;:[{&quot;key1&quot;:&quot;row2&quot;,&quot;key2&quot;:&quot;row2&quot;}]}]}\r\n    {&quot;data&quot;:[{&quot;row&quot;:[{&quot;key1&quot;:&quot;row3&quot;,&quot;key2&quot;:&quot;row3&quot;}]},{&quot;row&quot;:[{&quot;key1&quot;:&quot;row4&quot;,&quot;key2&quot;:&quot;row4&quot;}]}]}\r\n\r\nOutput file 2:\r\n\r\n    {&quot;data&quot;:[{&quot;row&quot;:[{&quot;key3&quot;:&quot;row1&quot;,&quot;key4&quot;:&quot;row1&quot;}]},{&quot;row&quot;:[{&quot;key3&quot;:&quot;row2&quot;,&quot;key4&quot;:&quot;row2&quot;}]}]}\r\n    {&quot;data&quot;:[{&quot;row&quot;:[{&quot;key3&quot;:&quot;row3&quot;,&quot;key4&quot;:&quot;row3&quot;}]},{&quot;row&quot;:[{&quot;key3&quot;:&quot;row4&quot;,&quot;key4&quot;:&quot;row4&quot;}]}]}\r\n\r\nIt seems pretty well known that the streaming option is slow. See the discussion [here][1].\r\n\r\nMy attempt at implementing it followed the answer [here][2].\r\n\r\n\r\n  [1]: https://stackoverflow.com/questions/62825963/improving-performance-when-using-jq-to-process-large-files\r\n  [2]: https://stackoverflow.com/questions/76797917/jq-using-stream-and-not/76797968#76797968",
        "link": "https://stackoverflow.com/questions/76803755/using-jq-to-extract-multiple-json-objects",
        "title": "Using jq to extract multiple json objects"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1690824886,
                "post_id": 76805892,
                "comment_id": 135403800,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1690825277,
                "last_edit_date": 1690825277,
                "creation_date": 1690824866,
                "answer_id": 76805934,
                "question_id": 76805892,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You need to &#39;save&#39; the `.value` in a variable before looping over the locations to update them using `|=`:\r\n```\r\n.value as $val | .location[] |= (.calc = $val * .lvalue)\r\n```\r\n\r\n-------\r\n\r\n#### [JqPlay Demo](https://jqplay.org/s/cmbon4D0hTc)",
                "title": "Add calculated value from an array field to the same array"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1690855744,
        "creation_date": 1690824409,
        "last_edit_date": 1690855744,
        "question_id": 76805892,
        "body_markdown": "Not sure if it is possible. I want multiply the &quot;value&quot; field with the &quot;lvalue&quot; field an put the result in a new field &quot;calc&quot; in the corresponding array entry.\r\n\r\nGiven JSON:\r\n\r\n```\r\n{\r\n  &quot;value&quot;: 5,\r\n  &quot;location&quot;: [{\r\n    &quot;city&quot;: &quot;San Fracisco&quot;,\r\n    &quot;lvalue&quot;: 10\r\n  },\r\n  {\r\n    &quot;city&quot;: &quot;Los Angeles&quot;,\r\n    &quot;lvalue&quot;: 20\r\n  }]\r\n}\r\n```\r\n\r\nExpected Value in one JSON:\r\n\r\n```\r\n{\r\n  &quot;value&quot;: 5,\r\n  &quot;location&quot;: [{\r\n    &quot;city&quot;: &quot;San Fracisco&quot;,\r\n    &quot;lvalue&quot;: 10,\r\n    &quot;calc&quot;: 50\r\n  },\r\n  {\r\n    &quot;city&quot;: &quot;Los Angeles&quot;,\r\n    &quot;lvalue&quot;: 20,\r\n    &quot;calc&quot;: 100\r\n  }]\r\n}\r\n```",
        "link": "https://stackoverflow.com/questions/76805892/add-calculated-value-from-an-array-field-to-the-same-array",
        "title": "Add calculated value from an array field to the same array"
    },
    {
        "tags": [
            "json",
            "select",
            "key",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1690992669,
                "post_id": 76821662,
                "comment_id": 135431234,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1691031092,
                "last_edit_date": 1691031092,
                "creation_date": 1690992384,
                "answer_id": 76821700,
                "question_id": 76821662,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "WIth a valid JSON input it&#39;s straightforward using `del` and `select`:\r\n```sh\r\ndel(.app.sig[] | select(.enabled | not))\r\n```\r\n[Demo](https://jqplay.org/s/aYTxP3JefIY)\r\n\r\nAlternatively, use `map` to reset the array with what you want to keep:\r\n```sh\r\n.app.sig |= map(select(.enabled))\r\n```\r\n[Demo](https://jqplay.org/s/if3aIr-TBxP)\r\n\r\nIn both cases, you can directly use the (possibly negated) boolean value within `select`. Output:\r\n```json\r\n{\r\n  &quot;app&quot;: {\r\n    &quot;id&quot;: &quot;11111111&quot;,\r\n    &quot;name&quot;: &quot;test&quot;,\r\n    &quot;general&quot;: {\r\n      &quot;allow&quot;: &quot;sdasdass&quot;\r\n    },\r\n    &quot;settings&quot;: {\r\n      &quot;max&quot;: &quot;8192&quot;\r\n    },\r\n    &quot;sig&quot;: [\r\n      {\r\n        &quot;enabled&quot;: true,\r\n        &quot;Staging&quot;: false,\r\n        &quot;sId&quot;: &quot;200101556&quot;\r\n      },\r\n      {\r\n        &quot;enabled&quot;: true,\r\n        &quot;Staging&quot;: false,\r\n        &quot;sId&quot;: &quot;200012002&quot;\r\n      }\r\n    ],\r\n    &quot;version&quot;: &quot;v1&quot;\r\n  }\r\n}\r\n```",
                "title": "jq del: Remove elements from a list"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1691044628,
        "creation_date": 1690992115,
        "last_edit_date": 1691044628,
        "question_id": 76821662,
        "body_markdown": "I want to delete the entries in a JSON list that have the &quot;enabled&quot; key with the value `false`.  \r\n\r\nThe following jq cmd does select the false entries but now I want to remove those entries and keep the rest of the structure.\r\n\r\n\r\n```\r\njq &#39;.app.sig[] | select(.enabled==false)&#39;  app-test.json\r\n```\r\n\r\n\r\nExample JSON input\r\n ```\r\n{\r\n   &quot;app&quot; : {\r\n\t\t&quot;id&quot; : &quot;11111111&quot;,\r\n\t\t&quot;name&quot; : &quot;test&quot;,\r\n\t\t&quot;general&quot; : {\r\n\t\t\t&quot;allow&quot; : &quot;sdasdass&quot;,\r\n\t\t},\r\n\t\t&quot;settings&quot; : {\r\n\t\t\t&quot;max&quot; : &quot;8192&quot;,\r\n\t\t},\r\n\t\t&quot;sig&quot; : [\r\n\t\t\t{\r\n\t\t\t\t&quot;enabled&quot; : true,\r\n\t\t\t\t&quot;Staging&quot; : false,\r\n\t\t\t\t&quot;sId&quot; : &quot;200101556&quot;\r\n\t\t\t},\r\n\t\t\t{\r\n\t\t\t\t&quot;enabled&quot; : false,\r\n\t\t\t\t&quot;Staging&quot; : false,\r\n\t\t\t\t&quot;sId&quot; : &quot;200012071&quot;\r\n\t\t\t},\r\n\t\t\t{\r\n\t\t\t\t&quot;enabled&quot; : true,\r\n\t\t\t\t&quot;Staging&quot; : false,\r\n\t\t\t\t&quot;sId&quot; : &quot;200012002&quot;\r\n\t\t\t},\r\n\t\t],\r\n\t\t&quot;version&quot; : &quot;v1&quot;,\r\n\t}\r\n}\r\n```\r\n\r\nAny help appreciated.\r\n\r\nThanks",
        "link": "https://stackoverflow.com/questions/76821662/jq-del-remove-elements-from-a-list",
        "title": "jq del: Remove elements from a list"
    },
    {
        "tags": [
            "json",
            "bash",
            "key",
            "jq",
            "logical-operators"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1690993593,
                "post_id": 76821746,
                "comment_id": 135431444,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 9853256,
                    "reputation": 490,
                    "user_id": 7298643,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/2D13T.png?s=256",
                    "display_name": "Jengels",
                    "link": "https://stackoverflow.com/users/7298643/jengels"
                },
                "reply_to_user": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1690993759,
                "post_id": 76821746,
                "comment_id": 135431474,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1690994141,
                "post_id": 76821746,
                "comment_id": 135431552,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 4879,
                    "reputation": 248190,
                    "user_id": 7552,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/b60298053f87465641c1b1192338c8cd?s=256&d=identicon&r=PG",
                    "display_name": "glenn jackman",
                    "link": "https://stackoverflow.com/users/7552/glenn-jackman"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1690999264,
                "post_id": 76821746,
                "comment_id": 135432518,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1691004909,
                "last_edit_date": 1691004909,
                "creation_date": 1690994026,
                "answer_id": 76821897,
                "question_id": 76821746,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Use the boolean [conjunction](https://en.wikipedia.org/wiki/Logical_conjunction) [operator](https://jqlang.github.io/jq/manual/#and%2Cor%2Cnot) `and` based on `.foo`&#39;s and `.bar`&#39;s (in)equality to `null`, [assign](https://jqlang.github.io/jq/manual/#Plainassignment%3A%3D) the result to a new key `.baz`, and [`map`](https://jqlang.github.io/jq/manual/#map%28f%29%2Cmap_values%28f%29) the input using this filter.\r\n\r\n```sh\r\nmap(.baz = .foo != null and .bar != null)\r\n```\r\n```json\r\n[\r\n  {\r\n    &quot;foo&quot;: &quot;fooValue&quot;,\r\n    &quot;bar&quot;: &quot;barValue&quot;,\r\n    &quot;baz&quot;: true\r\n  },\r\n  {\r\n    &quot;foo&quot;: null,\r\n    &quot;bar&quot;: null,\r\n    &quot;baz&quot;: false\r\n  }\r\n]\r\n```\r\n[Demo](https://jqplay.org/s/nAYZIB-bmtJ)\r\n\r\n---\r\nIf the new values should indeed be strings, simply [interpolate](https://jqlang.github.io/jq/manual/#Stringinterpolation%3A%5C%28exp%29) the computed booleans:\r\n```sh\r\nmap(.baz = &quot;\\(.foo != null and .bar != null)&quot;)\r\n```\r\n```json\r\n[\r\n  {\r\n    &quot;foo&quot;: &quot;fooValue&quot;,\r\n    &quot;bar&quot;: &quot;barValue&quot;,\r\n    &quot;baz&quot;: &quot;true&quot;\r\n  },\r\n  {\r\n    &quot;foo&quot;: null,\r\n    &quot;bar&quot;: null,\r\n    &quot;baz&quot;: &quot;false&quot;\r\n  }\r\n]\r\n```\r\n[Demo](https://jqplay.org/s/55FYRy9PRsL)",
                "title": "How to add conditionally add a new key value pair to a json using jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -1,
        "last_activity_date": 1691004909,
        "creation_date": 1690992762,
        "last_edit_date": 1691001860,
        "question_id": 76821746,
        "body_markdown": "I have a json file formatted as below\r\n\r\n    [\r\n    \t{\r\n    \t \t&quot;foo&quot; : &quot;fooValue&quot;,\r\n    \t \t&quot;bar&quot; : &quot;barValue&quot;\r\n    \t},\r\n    \t{\r\n    \t \t&quot;foo&quot; : null,\r\n    \t \t&quot;bar&quot; : null\r\n    \t}\r\n    ]\r\n\r\nI want to add a new key value pair `baz` to this json using jq based on the existence of values for keys foo and bar. If foo and bar are both not null, then `baz` should be the string &quot;true&quot;. If either foo or bar are null or both are null, then `baz` should be string &quot;false&quot;. What is the best way to accomplish this using jq? I understand how to append a key value pair to a json, but I am not sure how to do this process conditionally. Thank you ",
        "link": "https://stackoverflow.com/questions/76821746/how-to-add-conditionally-add-a-new-key-value-pair-to-a-json-using-jq",
        "title": "How to add conditionally add a new key value pair to a json using jq?"
    },
    {
        "tags": [
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1691010003,
                "post_id": 76823338,
                "comment_id": 135434494,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "is_answered": false,
        "answer_count": 0,
        "score": 1,
        "last_activity_date": 1691008784,
        "creation_date": 1691008438,
        "last_edit_date": 1691008784,
        "question_id": 76823338,
        "body_markdown": "I have a JSON file something like below. Now I want to list where conditions is matching with type as `google_project_iam_binding` and delete or update.\r\n\r\n\r\nWith below jq I was able to get the details.\r\n\r\n    jq &#39;.resource_changes[] | select(any(.change.actions[]; .==&quot;delete&quot; or .==&quot;update&quot;))&#39;\r\n\r\nWith below jq select getting an error.\r\n\r\n    jq &#39;.resource_changes[] | select((.type == &quot;google_project_iam_binding&quot;) and (.change.actions[]; .==&quot;delete&quot; or .==&quot;update&quot;))&#39;\r\n\r\n```json\r\n&quot;resource_changes&quot; : [\r\n   {\r\n      &quot;address&quot;:&quot;module.gke-cluster.module.gke.random_shuffle.available_zones&quot;,\r\n      &quot;module_address&quot;:&quot;module.gke-cluster.module.gke&quot;,\r\n      &quot;mode&quot;:&quot;managed&quot;,\r\n      &quot;type&quot;:&quot;random_shuffle&quot;,\r\n      &quot;name&quot;:&quot;available_zones&quot;,\r\n      &quot;provider_name&quot;:&quot;registry.terraform.io/hashicorp/random&quot;,\r\n      &quot;change&quot;:{\r\n         &quot;actions&quot;:[\r\n            &quot;delete&quot;,\r\n            &quot;create&quot;\r\n         ]\r\n      }\r\n   },\r\n   {\r\n      &quot;address&quot;:&quot;module.serviceproject.module.project-cfg.google_project_iam_binding.roles[\\&quot;roles/cloudkms.admin\\&quot;]&quot;,\r\n      &quot;module_address&quot;:&quot;module.serviceproject.module.project-cfg&quot;,\r\n      &quot;mode&quot;:&quot;managed&quot;,\r\n      &quot;type&quot;:&quot;google_project_iam_binding&quot;,\r\n      &quot;name&quot;:&quot;roles&quot;,\r\n      &quot;index&quot;:&quot;roles/cloudkms.admin&quot;,\r\n      &quot;provider_name&quot;:&quot;registry.terraform.io/hashicorp/google&quot;,\r\n      &quot;change&quot;:{\r\n         &quot;actions&quot;:[\r\n            &quot;delete&quot;\r\n            &quot;update&quot;\r\n         ]\r\n      }\r\n   }\r\n]",
        "link": "https://stackoverflow.com/questions/76823338/how-to-use-multiple-select-conditions-with-jq",
        "title": "How to use multiple select conditions with JQ"
    },
    {
        "tags": [
            "jq",
            "yq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1691062522,
                "post_id": 76826665,
                "comment_id": 135442333,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1691138616,
                "last_edit_date": 1691138616,
                "creation_date": 1691056115,
                "answer_id": 76826877,
                "question_id": 76826665,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "There&#39;s no need to use `with_entries` (which provides `.key`) as you can directly access the key using `key`. Add `.image` to descend into each (selected) image, and assign your new value(s).\r\n```sh\r\n.services[] |= select(key == &quot;app_sandbox*&quot;).image = &quot;some-image:latest&quot;\r\n```\r\n\r\nUpdating (`|=`) with an assignment (`=`) filter, however, may be hard to read (or to know of the individual precedences involved). It might be more convenient to wrap (at least the traversal part of) the LHS in parens, and use the assignment on that:\r\n```sh\r\n(.services[] | select(key == &quot;app_sandbox*&quot;)).image = &quot;some-image:latest&quot;\r\n```",
                "title": "yq: change multiple values selected by regex"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1691138616,
        "creation_date": 1691054775,
        "question_id": 76826665,
        "body_markdown": "I want to change my docker-compose file service images via yq tool. The problem is that I have several services which have the same name prefix and I need to select their image fields and update them:\r\n\r\ninput example:\r\n\r\n    ---\r\n    version: &#39;3.4&#39;\r\n    services:\r\n\r\n      app_sandbox_zeta:\r\n        image: some-image:not-latest\r\n       \r\n      app_sandbox_sigma:\r\n        image: some-image:not-latest\r\n\r\n      general_app: ...\r\n      some_app: ...\r\n\r\n\r\n\r\nexpected output:\r\n\r\n    ---\r\n    version: &#39;3.4&#39;\r\n    services:\r\n\r\n      app_sandbox_zeta:\r\n        image: some-image:latest\r\n       \r\n      app_sandbox_sigma:\r\n        image: some-image:latest\r\n\r\n      general_app: ...\r\n      some_app: ...\r\n\r\nSo, how can I achieve it? I&#39;ve tried to select keys, but I can not get the `image` key underneath:\r\n\r\n    cat docker-compose.yml | yq &#39;.services |= with_entries(select(.key == &quot;app_sandbox*&quot;))&#39;\r\n\r\n*yq (https://github.com/mikefarah/yq/) version 4.27.3",
        "link": "https://stackoverflow.com/questions/76826665/yq-change-multiple-values-selected-by-regex",
        "title": "yq: change multiple values selected by regex"
    },
    {
        "tags": [
            "arrays",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1691143071,
                "post_id": 76834777,
                "comment_id": 135455020,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1691144781,
                "last_edit_date": 1691144781,
                "creation_date": 1691143845,
                "answer_id": 76834951,
                "question_id": 76834777,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can get there in two steps: First, compute the max value of all `.sitem` values and store it in a variable, then iterate through all items and change `.status` if its `.sitem` matches the stored max value.\r\n\r\n##### Store the max value:\r\n- `max_by` finds the item with the matching condition\r\n- `.sitem` retrieves its value\r\n- `as $max` stores it in a variable\r\n```sh\r\nmax_by(.sitem).sitem as $max\r\n```\r\nNote: If you are looking for the numeric max value of `.sitem`, change the condition inside `max_by` from just `.sitem` to `.sitem | tonumber`:\r\n```sh\r\nmax_by(.sitem | tonumber).sitem as $max\r\n```\r\n\r\n\r\n##### Update the matching items:\r\n- `map` iterates through the array with each item in context\r\n- `select` filters for items matching a condition\r\n- `.sitem == $max` is the boolean condition\r\n- `.status = &quot;100&quot;` updates the field\r\n```sh\r\nmap(select(.sitem == $max).status = &quot;100&quot;)\r\n```\r\n\r\n---\r\nYou can either append the above to your existing filter, or combine it with the part generating `.status`. For the latter, first store the max value as described above, then (replacing the second `to_entries` from your filter) iterate over the items and generate `.status` on condition, e.g. using an `if` expression:\r\n- `map` iterates through the array with each item in context\r\n- `if` evaluates to either &quot;10&quot; or &quot;100&quot;, based on the condition\r\n```\r\nmap(.status = if .sitem == $max then &quot;100&quot; else &quot;10&quot; end)\r\n```\r\n\r\nAlternatively, you can first simplify both of your `to_entries` expressions by combining them into one, and include the `if` expression into that, e.g. by adding a objects:\r\n```sh\r\n…\r\n| max_by(.sitem).sitem as $max\r\n| to_entries | map(.value + {\r\n    sindex: &quot;\\(1+.key)&quot;,\r\n    status: (if .value.sitem == $max then &quot;100&quot; else &quot;10&quot; end)\r\n  })\r\n```",
                "title": "Change value in jq array on base if condition"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1691144781,
        "creation_date": 1691142509,
        "question_id": 76834777,
        "body_markdown": "I would like to ask for help. How can I change value in jq array on base if condition.\r\nMy input is ...\r\n\r\n    [\r\n      {\r\n        &quot;main&quot;: [\r\n          {\r\n            &quot;drink&quot;: &quot;cola&quot;,\r\n            &quot;sitem&quot;: &quot;10&quot;\r\n          },\r\n          {\r\n            &quot;drink&quot;: &quot;pepsi&quot;,\r\n            &quot;sitem&quot;: &quot;20&quot;\r\n          }\r\n        ]\r\n      }\r\n    ]\r\n\r\nThis input I am extending with new items. \r\nMy jq call\r\n\r\n&gt; jq &#39;.[] | [.main[] | {drink,sitem}] | to_entries | map( (.value.sindex\r\n&gt; = &quot;\\(1+.key)&quot; ) | .value) | to_entries | map( (.value.status = &quot;10&quot; ) | .value) &#39;\r\n\r\nThan is generate new array \r\n\r\n    [\r\n      {\r\n        &quot;drink&quot;: &quot;cola&quot;,\r\n        &quot;sitem&quot;: &quot;10&quot;,\r\n        &quot;sindex&quot;: &quot;1&quot;,\r\n        &quot;status&quot;: &quot;10&quot;\r\n      },\r\n      {\r\n        &quot;drink&quot;: &quot;pepsi&quot;,\r\n        &quot;sitem&quot;: &quot;20&quot;,\r\n        &quot;sindex&quot;: &quot;2&quot;,\r\n        &quot;status&quot;: &quot;10&quot;\r\n      }\r\n    ]\r\n\r\nChange &quot;status&quot; from 10 to 100 where is max value for &quot;sitem&quot;\r\nAnd I like to expect this...\r\n\r\n    [\r\n      {\r\n        &quot;drink&quot;: &quot;cola&quot;,\r\n        &quot;sitem&quot;: &quot;10&quot;,\r\n        &quot;sindex&quot;: &quot;1&quot;,\r\n        &quot;status&quot;: &quot;10&quot;\r\n      },\r\n      {\r\n        &quot;drink&quot;: &quot;pepsi&quot;,\r\n        &quot;sitem&quot;: &quot;20&quot;,\r\n        &quot;sindex&quot;: &quot;2&quot;,\r\n        &quot;status&quot;: &quot;100&quot;\r\n      }\r\n    ]\r\n\r\n",
        "link": "https://stackoverflow.com/questions/76834777/change-value-in-jq-array-on-base-if-condition",
        "title": "Change value in jq array on base if condition"
    },
    {
        "tags": [
            "bash",
            "shell",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 4663062,
                    "reputation": 89888,
                    "user_id": 3776858,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/Cagbk.jpg?s=256",
                    "display_name": "Cyrus",
                    "link": "https://stackoverflow.com/users/3776858/cyrus"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1691145240,
                "post_id": 76835075,
                "comment_id": 135455387,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1691145905,
                "creation_date": 1691145905,
                "answer_id": 76835197,
                "question_id": 76835075,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "According to what your posted, the content of `extracted_content` is `{&quot;ntpServers&quot;:&quot;10.9.221.1&quot;}`. Interpolating this into your heredoc produces\r\n\r\n     jq --argjson data &quot;{&quot;ntpServers&quot;:&quot;10.9.221.1&quot;}&quot; &#39;. += $data&#39;\r\n\r\nAfter the shell resolves the quotes, `jq` receives the following arguments:\r\n\r\n - Argument 1:  `--argjson`\r\n - Argument 2:  `data`\r\n - Argument 3:  `{ntpServers:10.9.221.1} \r\n - Argument 4:  `. += XXX`\r\n\r\nwhere XXX is the content of your variable `data`. You don&#39;t set this variable in the code you posted, so I guess it is an environment variable inherited from the parent process. If it&#39;s really unset, argument 4 becomes just `. += `.\r\n\r\nSo the arguments to `jq` simply don&#39;t look right.\r\n",
                "title": "Invalid JSON text passed"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1691162551,
                "last_edit_date": 1691162551,
                "creation_date": 1691161562,
                "answer_id": 76837152,
                "question_id": 76835075,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can pass variable extracted_content (via `declare`) and then escape the dollar (\\$) sign (for `extracted_content` and `data`):\r\n\r\n```\r\nssh -tt -o StrictHostKeyChecking=no -i sac_key root@${ip} -p22222 &lt;&lt;- _connect_\r\n        $(declare -p extracted_content)\r\n        # --- Append the extracted content to the target JSON ---                       \r\n        if ! jq --argjson data &quot;\\$extracted_content&quot; &#39;. += \\$data&#39; &quot;$TO&quot; &gt; &quot;$TO.tmp&quot;; then\r\n           echo &quot;ERROR: Error appending content to destination JSON.&quot; \r\n           exit 1                                       \r\n        fi    \r\n\r\n        # --- Rename the temporary file to the original target ---\r\n        mv &quot;$TO.tmp&quot; &quot;$TO&quot;     \r\n_connect_\r\n```",
                "title": "Invalid JSON text passed"
            },
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1691186389,
                "last_edit_date": 1691186389,
                "creation_date": 1691185166,
                "answer_id": 76839226,
                "question_id": 76835075,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The answer by @Phillippe is good, but not perfect, because it requires you to escape the code in your heredoc yourself. Better practice is to have the shell do that escaping for you: Write the code you want to run remotely in a function, then tell the shell to serialize that function with `declare -f` just the same as how you serialize the data the function uses with `declare -p`.\r\n\r\n```\r\nremote_function() {\r\n\r\n    # --- Append the extracted content to the target JSON ---\r\n    jq --argjson data &quot;$extracted_content&quot; &#39;. += $data&#39; &quot;$TO&quot; &gt; &quot;$TO.tmp&quot; || {\r\n       rc=$?\r\n       echo &quot;ERROR: Error appending content to destination JSON.&quot; \r\n       exit &quot;$rc&quot;\r\n    }\r\n\r\n    # --- Rename the temporary file to the original target ---\r\n    mv &quot;$TO.tmp&quot; &quot;$TO&quot;\r\n}\r\n\r\nssh -tt -o StrictHostKeyChecking=no -i sac_key root@&quot;$ip&quot; -p22222 &lt;&lt;-_connect_\r\n  $(declare -p extracted_content TO)  # define remote variables\r\n  $(declare -f remote_function)       # define remote function\r\n  remote_function                     # call remote function\r\n_connect_                   \r\n```",
                "title": "Invalid JSON text passed"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 0,
        "last_activity_date": 1691186389,
        "creation_date": 1691144894,
        "last_edit_date": 1691145565,
        "question_id": 76835075,
        "body_markdown": "I am having a problem merging json files via ssh. I always get the error\r\n~~~\r\njq: invalid JSON text passed to --argjson\r\nUse jq --help for help with command-line options,\r\nor see the jq manpage, or online docs  at https://stedolan.github.io/jq\r\n~~~\r\n\r\nEven though I pass a vlid json text.\r\n\r\n```\r\n# check if the content of the input file is valid JSONn  \r\nif ! echo &quot;$content&quot; | jq empty &gt; /dev/null 2&gt;&amp;1; then                                               \r\n    echo &quot;ERROR: The content of the input file is not valid JSON.&quot;\r\n    exit 1                                                                                        \r\nfi                                                                \r\n                                                 \r\n# extract the text inside the curly brackets from the JSON content                  \r\nextracted_content=$(echo &quot;$content&quot; | jq .)    \r\n  \r\n# check if the extracted content is valid JSON                       \r\nif ! echo &quot;$extracted_content&quot; | jq empty &gt; /dev/null 2&gt;&amp;1; then              \r\n    echo &quot;ERROR: The content of the input file contains no or invalid curly braces.&quot;  \r\n    exit 1                                                  \r\nfi                                                                \r\n\r\nwhile read ip \r\ndo                                                                                                                         \r\n        echo &quot;Doing changes to machine $ip&quot;\r\n                                                                            \r\n        # --- Connect to machine ---        \r\n\r\n                 \r\n        cd /home/root/.ssh                                                                 \r\n        ssh -tt -o StrictHostKeyChecking=no -i sac_key root@${ip} -p22222 &lt;&lt;- _connect_      \r\n\r\n        # --- Append the extracted content to the target JSON ---                       \r\n        if ! jq --argjson data &quot;$extracted_content&quot; &#39;. += $data&#39; &quot;$TO&quot; &gt; &quot;$TO.tmp&quot;; then\r\n           echo &quot;ERROR: Error appending content to destination JSON.&quot; \r\n           exit 1                                       \r\n        fi    \r\n\r\n        # --- Rename the temporary file to the original target ---\r\n        mv &quot;$TO.tmp&quot; &quot;$TO&quot;     \r\n_connect_                   \r\ndone &lt; $1\r\n```\r\n\r\nSo I tried to change the line\r\n\r\n```\r\nif ! jq --argjson data &quot;$extracted_content&quot; &#39;. += $data&#39; &quot;$TO&quot; &gt; &quot;$TO.tmp&quot;; then\r\n```\r\n\r\nlike doing only $extracted_content or like $(cat $extracted_content).\r\nOr showing me the contenct of $extracted_content with echo\r\n\r\n```\r\nextracted conent before ssh =\r\n{&quot;ntpServers&quot;:&quot;10.9.221.1&quot;}\r\n```\r\n\r\nAlso using a json validator (https://jsonformatter.net/json-validator/) to check if the file is valid.",
        "link": "https://stackoverflow.com/questions/76835075/invalid-json-text-passed",
        "title": "Invalid JSON text passed"
    },
    {
        "tags": [
            "json",
            "shell",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 5476147,
                    "reputation": 2045,
                    "user_id": 5763564,
                    "user_type": "registered",
                    "accept_rate": 89,
                    "profile_image": "https://www.gravatar.com/avatar/7e5e0ffb79f1ef8a5b6efa0331cc539f?s=256&d=identicon&r=PG",
                    "display_name": "Marijn",
                    "link": "https://stackoverflow.com/users/5763564/marijn"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1691258625,
                "post_id": 76842785,
                "comment_id": 135468902,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 9297133,
                    "reputation": 177,
                    "user_id": 6903701,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/1b81fa53609a7a4254a0b4f8bd65a53a?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "user6903701",
                    "link": "https://stackoverflow.com/users/6903701/user6903701"
                },
                "reply_to_user": {
                    "account_id": 5476147,
                    "reputation": 2045,
                    "user_id": 5763564,
                    "user_type": "registered",
                    "accept_rate": 89,
                    "profile_image": "https://www.gravatar.com/avatar/7e5e0ffb79f1ef8a5b6efa0331cc539f?s=256&d=identicon&r=PG",
                    "display_name": "Marijn",
                    "link": "https://stackoverflow.com/users/5763564/marijn"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1691260976,
                "post_id": 76842785,
                "comment_id": 135469181,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1691259306,
                "creation_date": 1691259306,
                "answer_id": 76842956,
                "question_id": 76842785,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Use `group_by` to group the objects.\r\n\r\n    jq -cs &#39;group_by(.id)[] | {id: .[0].id, count: map(.count) | add}&#39; &lt; file.json\r\n\r\n- `-s` wraps the whole input into a large array so you can process all the objects instead of iterating them one by one;\r\n- `-c` compresses the output so it looks like the desired one.",
                "title": "Group and Sum value with JQ"
            },
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1691260889,
                "creation_date": 1691260889,
                "answer_id": 76843053,
                "question_id": 76842785,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If the input is large, and you don&#39;t want to `--slurp` (or `-s`) all items into memory (only effective if there are at least some duplicate IDs), you can take a `reduce`-based approach which iterates over the `inputs` collecting only the aggregated values:\r\n```sh\r\njq -cn &#39;\r\n  reduce inputs as {$count, $id} ({}; .[$id] += $count)\r\n  | to_entries[] | {id: .key, count: .value}\r\n&#39;\r\n```\r\n```json\r\n{&quot;id&quot;:&quot;123&quot;,&quot;count&quot;:65}\r\n{&quot;id&quot;:&quot;456&quot;,&quot;count&quot;:77}\r\n{&quot;id&quot;:&quot;789&quot;,&quot;count&quot;:44}\r\n```\r\n[Demo](https://jqplay.org/s/raTaXueaQDm)\r\n",
                "title": "Group and Sum value with JQ"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1691260889,
        "creation_date": 1691256488,
        "question_id": 76842785,
        "body_markdown": "I&#39;ve got a file with these jsons:\r\n\r\n```\r\n{&quot;count&quot;:42,&quot;day&quot;:&quot;2023-06-22&quot;,&quot;id&quot;:&quot;123&quot;}\r\n{&quot;count&quot;:12,&quot;day&quot;:&quot;2023-06-22&quot;,&quot;id&quot;:&quot;456&quot;}\r\n{&quot;count&quot;:23,&quot;day&quot;:&quot;2023-06-23&quot;,&quot;id&quot;:&quot;123&quot;}\r\n{&quot;count&quot;:44,&quot;day&quot;:&quot;2023-06-23&quot;,&quot;id&quot;:&quot;789&quot;}\r\n{&quot;count&quot;:65,&quot;day&quot;:&quot;2023-06-21&quot;,&quot;id&quot;:&quot;456&quot;}\r\n```\r\nActually I don&#39;t care about the `day` and want to group my records by `id` and sum the `count`. Expected result:\r\n```\r\n{&quot;id&quot;:&quot;123&quot;,&quot;count&quot;:65}\r\n{&quot;id&quot;:&quot;456&quot;,&quot;count&quot;:77}\r\n{&quot;id&quot;:&quot;789&quot;,&quot;count&quot;:44}\r\n```\r\n\r\nHow would I achieve this with JQ? ",
        "link": "https://stackoverflow.com/questions/76842785/group-and-sum-value-with-jq",
        "title": "Group and Sum value with JQ"
    },
    {
        "tags": [
            "json",
            "curl",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1691262496,
                "post_id": 76843139,
                "comment_id": 135469336,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1691263947,
                "creation_date": 1691263947,
                "answer_id": 76843239,
                "question_id": 76843139,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You never include `.parent` in your result. If you do, you must use parentheses:\r\n\r\n```\r\n.parent, (.children[] | .first, .last)\r\n```",
                "title": "How to get JSON object field value and field values in next array of the same JSON object?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1691263947,
        "creation_date": 1691262267,
        "last_edit_date": 1691262505,
        "question_id": 76843139,
        "body_markdown": "If I have JSON like below returned from my curl response:\r\n\r\n\r\n```json\r\n{\r\n  &quot;parent&quot;: &quot;John Smith&quot;,\r\n  &quot;dob&quot;: &quot;August 6, 2020&quot;,\r\n  &quot;children&quot;: [\r\n    {\r\n      &quot;first&quot;: &quot;Bob&quot;,\r\n      &quot;last&quot;: &quot;Smith&quot;\r\n    },\r\n    {\r\n      &quot;first&quot;: &quot;John&quot;,\r\n      &quot;last&quot;: &quot;Smith&quot;\r\n    }\r\n  ]\r\n}\r\n```\r\n\r\nI would like to get field parent in JSON object and first, last fields in nested JSON array above.\r\n\r\nI have tried using this `curl` command with `jq` and I can get first and last fields from the children array, but I cannot figure out how to get both parent field _and_ first and last fields from same response.\r\n\r\nHere is my command to filter first and last fields:\r\n\r\n    curl -G &#39;http://someapi&#39; | jq &#39;.childrens | .[] | .first, .last&#39;\r\n\r\nIt returns\r\n\r\n    Bob\r\n    Smith\r\n    John\r\n    Smith\r\n\r\n\r\n\r\nI would like to get the following:\r\n\r\n    John Smith\r\n    Bob\r\n    Smith\r\n    John\r\n    Smith\r\n\r\nHow do I use `jq` to get values for parent field and each child first and last name fields?",
        "link": "https://stackoverflow.com/questions/76843139/how-to-get-json-object-field-value-and-field-values-in-next-array-of-the-same-js",
        "title": "How to get JSON object field value and field values in next array of the same JSON object?"
    },
    {
        "tags": [
            "json",
            "jq",
            "export-to-csv"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1691397857,
                "creation_date": 1691397857,
                "answer_id": 76850086,
                "question_id": 76849848,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Nesting iterations and variable bindings:\r\n```sh\r\n.[].body                                                   # top-level iteration\r\n| to_entries[] as {key: $i, value: {$title, $longText}}    # collect values\r\n| $longText / &quot;|&quot;                                          # split at &quot;|&quot;\r\n| map(select(. != &quot;&quot;))                                     # remove empty items(?)\r\n| (                                                        # open grouping context\r\n    to_entries[] as {key: $j, $value}                      # collect values\r\n    | [$title, $i+1, $j+1, $value]                         # prepare output line\r\n    | join(&quot;;&quot;)                                            # join to string\r\n  ), &quot;&quot;                                                    # add empty line\r\n```\r\n```csv\r\ntopinfo;1;1;item1\r\ntopinfo;1;2;details item 1\r\ntopinfo;1;3;details sdfdfdfd \r\ntopinfo;1;4;details gbgfgghmhjmh\r\ntopinfo;1;5;details 5348786\r\n\r\ntopinfo;2;1;item2\r\ntopinfo;2;2;details item 2\r\ntopinfo;2;3;details sdfdfdfd \r\ntopinfo;2;4;details gbgfgghmhjmh\r\ntopinfo;2;5;details 9784561\r\n\r\n```\r\n[Demo](https://jqplay.org/s/76cw8olnozZ)\r\n\r\nTo properly escape for a CSV output, use `@csv` instead of `join(&quot;;&quot;)`. Note that this would &quot;join&quot; by comma instead of semicolon, and quote the items if necessary:\r\n```csv\r\n&quot;topinfo&quot;,1,1,&quot;item1&quot;\r\n&quot;topinfo&quot;,1,2,&quot;details item 1&quot;\r\n&quot;topinfo&quot;,1,3,&quot;details sdfdfdfd &quot;\r\n&quot;topinfo&quot;,1,4,&quot;details gbgfgghmhjmh&quot;\r\n&quot;topinfo&quot;,1,5,&quot;details 5348786&quot;\r\n\r\n&quot;topinfo&quot;,2,1,&quot;item2&quot;\r\n&quot;topinfo&quot;,2,2,&quot;details item 2&quot;\r\n&quot;topinfo&quot;,2,3,&quot;details sdfdfdfd &quot;\r\n&quot;topinfo&quot;,2,4,&quot;details gbgfgghmhjmh&quot;\r\n&quot;topinfo&quot;,2,5,&quot;details 9784561&quot;\r\n\r\n```\r\n[Demo](https://jqplay.org/s/j4KA_mTGGcC)",
                "title": "Iterate items json array"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1691399228,
        "creation_date": 1691395639,
        "last_edit_date": 1691399228,
        "question_id": 76849848,
        "body_markdown": "I would like to ask for help. \r\nI have json array.\r\nHow can I make iterating array after split and create csv output\r\n\r\n&lt;br&gt;My input is...\r\n\r\n    [\r\n        {\r\n    \t\t&quot;body&quot;: [\r\n    \t\t\t{\r\n    \t\t\t    &quot;title&quot;: &quot;topinfo&quot;,\r\n    \t\t\t\t&quot;longText&quot;: &quot;item1|details item 1|details sdfdfdfd ||details gbgfgghmhjmh||details 5348786&quot;\r\n    \t\t\t},\r\n    \t\t\t{\r\n    \t\t\t    &quot;title&quot;: &quot;topinfo&quot;,\r\n    \t\t\t\t&quot;longText&quot;: &quot;item2|details item 2|details sdfdfdfd ||details gbgfgghmhjmh||details 9784561&quot;\r\n    \t\t\t}\r\n                ]\r\n        }\r\n    ]\r\n\r\n&lt;br&gt;My actually call for jq ...\r\n\r\n    jq &#39;.[] | [.body[] | {longText,title} ] | to_entries | map( (.value.level = &quot;\\(1+.key)&quot; ) | .value) | .[] | [.title,.level,(.longText|split(&quot;|&quot;))] &#39;\r\n\r\n&lt;br&gt;Actually result\r\n\r\n    [\r\n      &quot;topinfo&quot;,\r\n      &quot;1&quot;,\r\n      [\r\n        &quot;item1&quot;,\r\n        &quot;details item 1&quot;,\r\n        &quot;details sdfdfdfd&quot;,\r\n        &quot;details gbgfgghmhjmh&quot;,\r\n        &quot;details 5348786&quot;\r\n      ]\r\n    ]\r\n    [\r\n      &quot;topinfo&quot;,\r\n      &quot;2&quot;,\r\n      [\r\n        &quot;item2&quot;,\r\n        &quot;details item 2&quot;,\r\n        &quot;details sdfdfdfd&quot;,\r\n        &quot;details gbgfgghmhjmh&quot;,\r\n        &quot;details 9784561&quot;\r\n      ]\r\n    ]\r\n\r\n&lt;br&gt;And I would like to expect this csv...\r\n\r\n&gt;     topinfo;1;1;item1\r\n&gt;     topinfo;1;2;details item 1\r\n&gt;     topinfo;1;3;details sdfdfdfd\r\n&gt;     topinfo;1;4;details gbgfgghmhjmh\r\n&gt;     topinfo;1;5;details 5348786\r\n&gt;     \r\n&gt;     topinfo;2;1;item2\r\n&gt;     topinfo;2;2;details item 2\r\n&gt;     topinfo;2;3;details sdfdfdfd\r\n&gt;     topinfo;2;4;details gbgfgghmhjmh\r\n&gt;     topinfo;2;5;details 9784561\r\n\r\n",
        "link": "https://stackoverflow.com/questions/76849848/iterate-items-json-array",
        "title": "Iterate items json array"
    },
    {
        "tags": [
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 6196394,
                    "reputation": 86601,
                    "user_id": 5291015,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/4tAvO.jpg?s=256",
                    "display_name": "Inian",
                    "link": "https://stackoverflow.com/users/5291015/inian"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1691688807,
                "post_id": 76878039,
                "comment_id": 135528800,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1691688885,
                "post_id": 76878039,
                "comment_id": 135528819,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 6023763,
                    "reputation": 1275,
                    "user_id": 7805363,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/SjBaF.jpg?s=256",
                    "display_name": "Programming-Lover",
                    "link": "https://stackoverflow.com/users/7805363/programming-lover"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1691691411,
                "post_id": 76878039,
                "comment_id": 135529301,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 6023763,
                    "reputation": 1275,
                    "user_id": 7805363,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/SjBaF.jpg?s=256",
                    "display_name": "Programming-Lover",
                    "link": "https://stackoverflow.com/users/7805363/programming-lover"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1691691465,
                "post_id": 76878039,
                "comment_id": 135529312,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1691692806,
                "creation_date": 1691692806,
                "answer_id": 76878519,
                "question_id": 76878039,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "i am able to solve this like below\r\n```\r\ngojq.Parse(`.data[]|{&quot;.id&quot;: .id, &quot;.name&quot;: .name, &quot;.disks[].capacityGB&quot;: .disks[].capacityGB,  &quot;.disks[]|.name&quot;: .disks[]|.name,}`)\r\n```",
                "title": "Handle special character in Key in Jq query"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1691692806,
        "creation_date": 1691688445,
        "question_id": 76878039,
        "body_markdown": "I have this jq query where i am adding path as a key so later i can get the value for the path but this is giving the error\r\n```\r\ngojq.Parse(&quot;.data[]|{.id: .id, name: .name, disk_capacity: .disks[].capacityGB,  disk_name: .disks[]|.name,}&quot;)\r\n```\r\nError\r\n```\r\npanic: runtime error: invalid memory address or nil pointer dereference\r\n[signal SIGSEGV: segmentation violation code=0x1 addr=0x8 pc=0x1119d71]\r\n```",
        "link": "https://stackoverflow.com/questions/76878039/handle-special-character-in-key-in-jq-query",
        "title": "Handle special character in Key in Jq query"
    },
    {
        "tags": [
            "json",
            "gitlab",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 3597514,
                    "reputation": 122820,
                    "user_id": 3001761,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/feZwC.jpg?s=256",
                    "display_name": "jonrsharpe",
                    "link": "https://stackoverflow.com/users/3001761/jonrsharpe"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1691709218,
                "post_id": 76879777,
                "comment_id": 135532033,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 39208,
                    "reputation": 267964,
                    "user_id": 112968,
                    "user_type": "registered",
                    "accept_rate": 68,
                    "profile_image": "https://i.sstatic.net/zHTaT.png?s=256",
                    "display_name": "knittl",
                    "link": "https://stackoverflow.com/users/112968/knittl"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1691736763,
                "post_id": 76879777,
                "comment_id": 135534649,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1691742261,
                "last_edit_date": 1691742261,
                "creation_date": 1691709211,
                "answer_id": 76879836,
                "question_id": 76879777,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can use `scan` (or `capture`) :\r\n\r\n```\r\n#!/bin/bash\r\n\r\necho &#39;{&quot;labels&quot;: [\r\n   &quot;AI::Assessed&quot;,\r\n   &quot;Pri::1 - High&quot;,\r\n   &quot;Type::Investigation&quot;,\r\n   &quot;v::Backlog&quot;\r\n]}&#39; | jq -r &#39;.labels[] | scan(&quot;v::(.*)&quot;)[]&#39;\r\n\r\n# Output : Backlog\r\n```",
                "title": "How to use jq to obtain the value of a GitLab issue label"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1691743949,
                "last_edit_date": 1691743949,
                "creation_date": 1691736833,
                "answer_id": 76881309,
                "question_id": 76879777,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "A trivial and straightforward solution with [`startswith`](https://jqlang.github.io/jq/manual/#startswith) and [substring/string-slicing](https://jqlang.github.io/jq/manual/#array-string-slice):\r\n\r\n```\r\n.labels[] | select(startswith(&quot;v::&quot;))[3:]\r\n```\r\n\r\nIf you need it to be more dynamic:\r\n\r\n```\r\njq --arg scope &#39;v::&#39; &#39;.labels[] | select(startswith($scope))[$scope|length:]&#39;\r\n```",
                "title": "How to use jq to obtain the value of a GitLab issue label"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1691743949,
        "creation_date": 1691708309,
        "last_edit_date": 1691735542,
        "question_id": 76879777,
        "body_markdown": "GitLab allows one to attach labels to issues. I would like to use jq to dig into the JSON representation of these labels. Here&#39;s the labels section of the JSON file for one issue:\r\n```json\r\n&quot;labels&quot;: [\r\n   &quot;AI::Assessed&quot;,\r\n   &quot;Pri::1 - High&quot;,\r\n   &quot;Type::Investigation&quot;,\r\n   &quot;v::Backlog&quot;\r\n]\r\n```\r\nHow, with jq, can I get at the value of the &quot;v&quot; label, which here is &quot;Backlog&quot;?\r\n\r\nNote that the number of labels varies from issue to issue. The `::` signifies that a label is a _scoped_ label.\r\n\r\n",
        "link": "https://stackoverflow.com/questions/76879777/how-to-use-jq-to-obtain-the-value-of-a-gitlab-issue-label",
        "title": "How to use jq to obtain the value of a GitLab issue label"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 6313442,
                    "reputation": 45115,
                    "user_id": 5625547,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/oqCND.jpg?s=256",
                    "display_name": "0stone0",
                    "link": "https://stackoverflow.com/users/5625547/0stone0"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1691759249,
                "post_id": 76883696,
                "comment_id": 135538959,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 17223915,
                    "reputation": 368,
                    "user_id": 12470058,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/5e37eed6235c37eafa4fdaa4376e9623?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Bsh",
                    "link": "https://stackoverflow.com/users/12470058/bsh"
                },
                "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": 1691768642,
                "post_id": 76883696,
                "comment_id": 135541046,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1692019415,
                "last_edit_date": 1692019415,
                "creation_date": 1691759453,
                "answer_id": 76883858,
                "question_id": 76883696,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The key can be changed using the following JQ filter:\r\n```\r\njq &#39;.counter |= with_entries(.key = &quot;5&quot;)&#39; input.json\r\n```\r\n\r\n##### [JqPlay Demo](https://jqplay.org/s/LI5Mh8UQxn2)\r\n\r\n----------\r\n\r\n\r\nThen, using a bash loop where we append all 10 objects to a new file, use:\r\n```bash\r\nfor round in {1..10}; do \r\n    jq --arg counter &quot;$round&quot; &#39;.counter |= with_entries(.key = $counter)&#39; input.json &gt;&gt; output.txt\r\ndone\r\n```\r\n\r\nThis will generate `output.txt` and will append all 10 objects to it.\r\n\r\n\r\n----------\r\n\r\nIf you don&#39;t really need bash, you can use `range(10)` to let JQ do the looping, use the same filter as above and if needed, wrap it in an array, a single file with the 10 objects could be generated using:\r\n```\r\njq &#39;range(10) as $n | .counter |= with_entries(.key = &quot;\\($n)&quot;)&#39; input.json\r\n```\r\n\r\nThis uses `range(10)` and sets it to the `.key` using `|=`. Using [string interpolation](https://jqlang.github.io/jq/manual/#string-interpolation) to convert the integers to strings. This approach is a lot more efficient since we don&#39;t need to remember the original object. Thanks to [@pmf](https://stackoverflow.com/questions/76883696/how-to-change-a-particular-value-in-a-json-file-in-a-bash-script?noredirect=1#comment135539846_76883858) for pointing this out in the comments.",
                "title": "How to change a particular value in a JSON file in a bash script?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1692019415,
        "creation_date": 1691758255,
        "last_edit_date": 1691768567,
        "question_id": 76883696,
        "body_markdown": "I have a JSON file as follows:\r\n\r\n```\r\n{\r\n  &quot;A&quot;: {\r\n    &quot;i&quot;: &quot;user_defined&quot;,\r\n    &quot;j&quot;: 678,\r\n    &quot;k&quot;: 1.75,\r\n    &quot;l&quot;: 6.7,\r\n    &quot;m&quot;: 1.2\r\n  },\r\n  &quot;W&quot;: &quot;10&quot;,\r\n  &quot;counter&quot;: {\r\n    &quot;0&quot;: {\r\n      &quot;p&quot;: 34,\r\n      &quot;q&quot;: &quot;returned&quot;,\r\n      &quot;r&quot;: 98,\r\n      &quot;s&quot;: &quot;wait&quot;,\r\n      &quot;t&quot;: &quot;done&quot;,\r\n      &quot;u&quot;: &quot;8.9&quot;\r\n    }\r\n  },\r\n  &quot;z&quot;: &quot;th&quot;\r\n}\r\n```\r\n\r\nI want in each round of a loop of 10 rounds, the key in the value of &quot;counter&quot; (which is 0 now) to get changed to the number of the loop. This means if it is the first round of the loop the above file should be changed to:\r\n\r\n```\r\n{\r\n  &quot;A&quot;: {\r\n    &quot;i&quot;: &quot;user_defined&quot;,\r\n    &quot;j&quot;: 678,\r\n    &quot;k&quot;: 1.75,\r\n    &quot;l&quot;: 6.7,\r\n    &quot;m&quot;: 1.2\r\n  },\r\n  &quot;W&quot;: &quot;10&quot;,\r\n  &quot;counter&quot;: {\r\n    &quot;1&quot;: {\r\n      &quot;p&quot;: 34,\r\n      &quot;q&quot;: &quot;returned&quot;,\r\n      &quot;r&quot;: 98,\r\n      &quot;s&quot;: &quot;wait&quot;,\r\n      &quot;t&quot;: &quot;done&quot;,\r\n      &quot;u&quot;: &quot;8.9&quot;\r\n    }\r\n  },\r\n  &quot;z&quot;: &quot;th&quot;\r\n}\r\n```\r\nand if it is the 8th round of the loop, it will be:\r\n\r\n```\r\n{\r\n  &quot;A&quot;: {\r\n    &quot;i&quot;: &quot;user_defined&quot;,\r\n    &quot;j&quot;: 678,\r\n    &quot;k&quot;: 1.75,\r\n    &quot;l&quot;: 6.7,\r\n    &quot;m&quot;: 1.2\r\n  },\r\n  &quot;W&quot;: &quot;10&quot;,\r\n  &quot;counter&quot;: {\r\n    &quot;8&quot;: {\r\n      &quot;p&quot;: 34,\r\n      &quot;q&quot;: &quot;returned&quot;,\r\n      &quot;r&quot;: 98,\r\n      &quot;s&quot;: &quot;wait&quot;,\r\n      &quot;t&quot;: &quot;done&quot;,\r\n      &quot;u&quot;: &quot;8.9&quot;\r\n    }\r\n  },\r\n  &quot;z&quot;: &quot;th&quot;\r\n}\r\n```\r\n\r\nAlso, in each round, the previous JSON file will be overwritten by the current round. I tried the following code but it didn&#39;t change anything:\r\n\r\n\r\n```\r\n#!/bin/bash\r\n\r\n# Read initial JSON content from file\r\ninitial_json=$(cat config.json)\r\n\r\n# Loop for 10 rounds\r\nfor round in {1..10}; do\r\n  # Modify JSON content\r\n  modified_json=$(echo &quot;$initial_json&quot; | jq --argjson round &quot;$round&quot; &#39;.counter = {($round|tostring): .counter.&quot;0&quot;}&#39;)\r\n\r\n  # Write modified JSON back to the file\r\n  echo &quot;$modified_json&quot; &gt; config.json\r\n\r\n  echo &quot;Round $round: JSON updated&quot;\r\ndone\r\n```\r\n\r\nHow to fix the code?",
        "link": "https://stackoverflow.com/questions/76883696/how-to-change-a-particular-value-in-a-json-file-in-a-bash-script",
        "title": "How to change a particular value in a JSON file in a bash script?"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1692018924,
                "post_id": 76899217,
                "comment_id": 135565011,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1692019183,
                "creation_date": 1692019183,
                "answer_id": 76899296,
                "question_id": 76899217,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can use `with_entries` to get the index of an object, add 1 and convert to string to use that as the index.\r\n\r\nThen update the .value with a custom object were you get the keys you&#39;d like, something like:\r\n```\r\nwith_entries(.key = (.key + 1 | tostring) | .value = (.value.venue | { \r\n    name,\r\n    county: .city.country.name,\r\n    city: .city.name,\r\n    stateCode: .city.stateCode,\r\n    setlistfmId: .id\r\n}))\r\n```\r\n\r\nWill output:\r\n```json\r\n{\r\n  &quot;1&quot;: {\r\n    &quot;name&quot;: &quot;Joe Robbie Stadium&quot;,\r\n    &quot;county&quot;: &quot;United States&quot;,\r\n    &quot;city&quot;: &quot;Miami Gardens&quot;,\r\n    &quot;stateCode&quot;: &quot;FL&quot;,\r\n    &quot;setlistfmId&quot;: &quot;63d706ff&quot;\r\n  }\r\n}\r\n```\r\n\r\nAs you can play around in this [online demo](https://jqplay.org/s/k5XKKVMqK-H).",
                "title": "Reformatting a JSON output with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1692019183,
        "creation_date": 1692018562,
        "question_id": 76899217,
        "body_markdown": "I have this JSON file that looks like this:\r\n\r\n```\r\n[\r\n  {\r\n    &quot;venue&quot;: {\r\n      &quot;id&quot;: &quot;63d706ff&quot;,\r\n      &quot;name&quot;: &quot;Joe Robbie Stadium&quot;,\r\n      &quot;city&quot;: {\r\n        &quot;id&quot;: &quot;4164167&quot;,\r\n        &quot;name&quot;: &quot;Miami Gardens&quot;,\r\n        &quot;state&quot;: &quot;Florida&quot;,\r\n        &quot;stateCode&quot;: &quot;FL&quot;,\r\n        &quot;coords&quot;: {\r\n          &quot;lat&quot;: 25.9420377,\r\n          &quot;long&quot;: -80.2456045\r\n        },\r\n        &quot;country&quot;: {\r\n          &quot;code&quot;: &quot;US&quot;,\r\n          &quot;name&quot;: &quot;United States&quot;\r\n        }\r\n      },\r\n    }\r\n  },\r\n  {\r\n    &quot;venue&quot;: {\r\n      ...\r\n]\r\n```\r\n\r\nSo it has venues in it with some details. Now I&#39;d need to format the file to look like this:\r\n\r\n\r\n```\r\n{\r\n  &quot;1&quot;: {\r\n    &quot;id&quot;: 1,\r\n    &quot;name&quot;: &quot;Joe Robbie Stadium&quot;,\r\n    &quot;country&quot;: &quot;United States&quot;,\r\n    &quot;city&quot;: &quot;Miami Gardens&quot;,\r\n    &quot;state&quot;: &quot;Florida&quot;,\r\n    &quot;stateCode&quot;: &quot;FL&quot;,\r\n    &quot;setlistfmId&quot;: &quot;63d706ff&quot;,\r\n  },\r\n  &quot;2&quot;: {\r\n    &quot;id&quot;: 2,\r\n    ...\r\n}\r\n```\r\n\r\nBasically it would have a running integer as the key for each venue and the details inside it. I&#39;ve used `jq` in the past to do some minor formatting, but this I just can&#39;t complete. I&#39;ve tried with different approaches, like building a new array/object using `map()` or just by `=` and then `del(.[].venue)` but I&#39;m stuck and frustrated.\r\n\r\nWhat should I be looking for in the [jq manual](https://jqlang.github.io/jq/manual/)?\r\n\r\nDon&#39;t laugh, I&#39;m really no expert with `jq`, but to just get a couple of fields I started with e.g.:\r\n\r\n```\r\ncat data.json | jq &#39;{\r\n  testObject: {\r\n    name: map(.venue.name),\r\n    country: map(.venue.city.country.name)\r\n  }\r\n  | add\r\n}&#39;\r\n```\r\n\r\nWhich does get the name of the venue and the country name, but it&#39;s all just flat like:\r\n\r\n\r\n```\r\n{\r\n  &quot;testObject&quot;: [\r\n    &quot;Joe Robbie Stadium&quot;,\r\n    &quot;Florida Suncoast Dome&quot;,\r\n    &quot;Spectrum&quot;,\r\n    .....\r\n    &quot;United States&quot;,\r\n    &quot;United States&quot;,\r\n    &quot;United States&quot;,\r\n  ]\r\n}\r\n```\r\n\r\n",
        "link": "https://stackoverflow.com/questions/76899217/reformatting-a-json-output-with-jq",
        "title": "Reformatting a JSON output with jq"
    },
    {
        "tags": [
            "json",
            "linux",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1692019700,
                "post_id": 76899286,
                "comment_id": 135565204,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1692038397,
                "last_edit_date": 1692038397,
                "creation_date": 1692019720,
                "answer_id": 76899357,
                "question_id": 76899286,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If you `echo $DATA`, you&#39;ll see that the quotes are missing.\r\n\r\n\r\n----------\r\n\r\n\r\nUse\r\n```\r\nDATA=&#39;[{&quot;name&quot;: &quot;&#39;&quot;$NAME&quot;&#39;&quot;, &quot;age&quot;: 22}]&#39;\r\n```\r\n\r\nTo make sure the double quotes around the key are preserved, then your jq filter works just fine:\r\n```\r\n➜  /tmp jq . sample.json\r\n{\r\n  &quot;persons&quot;: [\r\n    {\r\n      &quot;name&quot;: &quot;test1&quot;,\r\n      &quot;age&quot;: 20\r\n    },\r\n    {\r\n      &quot;name&quot;: &quot;test2&quot;,\r\n      &quot;age&quot;: 21\r\n    }\r\n  ]\r\n}\r\n➜  /tmp\r\n➜  /tmp NAME=&quot;namevar&quot;\r\n➜  /tmp DATA=&#39;[{&quot;name&quot;: &quot;&#39;&quot;$NAME&quot;&#39;&quot;, &quot;age&quot;: 22}]&#39;\r\n➜  /tmp\r\n➜  /tmp\r\n➜  /tmp jq --argjson newdata &quot;$DATA&quot; &#39;.persons = $newdata&#39; sample.json\r\n{\r\n  &quot;persons&quot;: [\r\n    {\r\n      &quot;name&quot;: &quot;namevar&quot;,\r\n      &quot;age&quot;: 22\r\n    }\r\n  ]\r\n}\r\n```",
                "title": "How to replace array dictionary in json with dictionary with variables in linux"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1692038397,
        "creation_date": 1692019112,
        "question_id": 76899286,
        "body_markdown": "I have a need to batch replace an array structure in several json files.\r\n\r\nI can replace the array in sample.json with plain text\r\n```\r\n# sample.json\r\n{ \r\n  &quot;persons&quot;: [ \r\n    { \r\n      &quot;name&quot;: &quot;test1&quot;, \r\n      &quot;age&quot;: 20 \r\n \r\n    }, \r\n    { \r\n      &quot;name&quot;: &quot;test2&quot;, \r\n      &quot;age&quot;: 21 \r\n    } \r\n  ] \r\n} \r\n```\r\n```\r\nDATA=&#39;[{&quot;name&quot;: &quot;tony&quot;, &quot;age&quot;: 22}]&#39;   \r\njq --argjson newdata &quot;$DATA&quot; &#39;.persons[0] = $newdata&#39; sample.json &gt; tmp &amp;&amp; mv tmp sample.json   \r\n```\r\n\r\nBut when the text I replace **contains variables**, I get an error\r\n```\r\nNAME=&quot;namevar&quot;\r\nDATA=&quot;[{&quot;name&quot;: &quot;$NAME&quot;, &quot;age&quot;: 22}]&quot; \r\njq --argjson newdata &quot;$DATA&quot; &#39;.persons = $newdata&#39; sample.json &gt; tmp &amp;&amp; mv tmp sample.json \r\n```\r\nThe error is as follows and an empty *tmp* file is generated\r\n```\r\njq: invalid JSON text passed to --argjson\r\nUse jq --help for help with command-line options,\r\nor see the jq manpage, or online docs  at https://stedolan.github.io/jq\r\n```\r\n\r\nHow can I modify the replaced text to carry variables and replace them correctly? Looking forward to your reply.\r\n\r\nThat is, the expected result is\r\n```\r\n# sample.json after replace\r\n{ \r\n  &quot;persons&quot;: [ \r\n    { \r\n      &quot;name&quot;: &quot;namevar&quot;, \r\n      &quot;age&quot;: 20 \r\n    }\r\n  ] \r\n} \r\n```",
        "link": "https://stackoverflow.com/questions/76899286/how-to-replace-array-dictionary-in-json-with-dictionary-with-variables-in-linux",
        "title": "How to replace array dictionary in json with dictionary with variables in linux"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1692100199,
                "creation_date": 1692100199,
                "answer_id": 76905723,
                "question_id": 76905302,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I can think of two ways to generate your output:\r\n\r\n##### Null input\r\n\r\nThis will read the first JSON entity from the input and then terminate\r\n\r\n```\r\njq -n &#39;input&#39;\r\n```\r\n\r\n##### Slurping\r\n\r\nThis will read the full JSON input into an array and then return the first item of the array\r\n\r\n```\r\njq -s &#39;first&#39;\r\n```",
                "title": "JQ - Extract one part of a 2 part JSON"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1692100199,
        "creation_date": 1692096834,
        "question_id": 76905302,
        "body_markdown": "Consider the below 2 part JSON. \r\n\r\nContext: I have this JSON data from a OCI Bucket upload and I want to extract a specific part of it.\r\n\r\n```\r\n{\r\n  &quot;a&quot;: &quot;1&quot;,\r\n  &quot;b&quot;: &quot;2&quot;\r\n}\r\n{\r\n  &quot;A&quot;: &quot;1&quot;,\r\n  &quot;B&quot;: &quot;2&quot;\r\n}\r\n```\r\n\r\nExpected output\r\n\r\n```\r\n{\r\n  &quot;a&quot;: &quot;1&quot;,\r\n  &quot;b&quot;: &quot;2&quot;\r\n}\r\n```\r\n\r\nI am interested in extracting the first part of the JSON and then get the value.",
        "link": "https://stackoverflow.com/questions/76905302/jq-extract-one-part-of-a-2-part-json",
        "title": "JQ - Extract one part of a 2 part JSON"
    },
    {
        "tags": [
            "json",
            "path",
            "bigdata",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1692168905,
                "last_edit_date": 1692168905,
                "creation_date": 1692106926,
                "answer_id": 76906431,
                "question_id": 76905501,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s a solution to the first (revised) problem. It addresses the size problem by using &quot;JSON Machine&quot; to break up the giant blob, which hopefully can then be handled by jq in a straightforward way.\r\n\r\nIn the following, the `jm` command-line tool is used to simplify use of &quot;JSON Machine&quot;. If you prefer a similar Python-based interface, you could use the jm.py command-line tool. See https://github.com/pkoppstein/jm for further details about jm and jm.py\r\n```\r\njm &lt; input.json |\r\n jq -c &#39;to_entries[] \r\n  | .key as $uid\r\n  | .value.things\r\n  | to_entries[]\r\n  | {path: &quot;data/\\($uid)/things/\\(.key)&quot;, value}\r\n&#39;\r\n```\r\n\r\nThis produces the required output for the first example.\r\n\r\nThe above can be made more general in several ways, but the approach is so straightforward that it might be easier to adapt the program as needed.",
                "title": "Include path of object when streaming out JSON from JQ"
            },
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1692135932,
                "creation_date": 1692135932,
                "answer_id": 76909303,
                "question_id": 76905501,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You could still `--stream` the input but write your own interpreter that extracts and processes the parts needed. Here&#39;s an example that collects the content parts (having a value at position `1`) into a result object (using `setpath`). The original path is split at two levels below the deepest occurrence of either `things` or `users` (or ignored, if neither was present), with the lower part being used for `setpath`, and the higher part being compared to the previously processed items&#39;s higher part path. If they match, the next item is added, otherwise a new result object is started while the old, &quot;finished&quot; one is returned (and discarded from memory after the first item of the next result object is added).\r\n```sh\r\n#!/usr/bin/env -S jq --stream -ncf\r\n\r\nforeach (\r\n\r\n  ( inputs | select(has(1))\r\n  | (first | [rindex(&quot;things&quot;, &quot;users&quot;)] | max | values) as $p\r\n  | [.[0][$p+2:], (.[0][:$p+2] | join(&quot;/&quot;)), .[1]]), [[]]\r\n\r\n) as [$vpath, $path, $value] ([];\r\n\r\n  if [first.path, $path] | unique[1]\r\n  then [{$path}, first] else .[:1] end\r\n  | first.value |= setpath($vpath; $value);\r\n\r\n  .[1] | values\r\n)\r\n```\r\n```json\r\n{&quot;path&quot;:&quot;data/&lt;userId1&gt;/things/&lt;thingId1&gt;&quot;,&quot;value&quot;:{&quot;subfield1&quot;:&quot;blah1&quot;,&quot;subfield3&quot;:&quot;foobar&quot;}}\r\n{&quot;path&quot;:&quot;data/&lt;userId1&gt;/things/&lt;thingId2&gt;&quot;,&quot;value&quot;:{&quot;subfield2&quot;:&quot;blah2&quot;}}\r\n{&quot;path&quot;:&quot;data/&lt;userId2&gt;/things/&lt;thingId1&gt;&quot;,&quot;value&quot;:{&quot;subfield4&quot;:&quot;blah3&quot;}}\r\n{&quot;path&quot;:&quot;data/&lt;userId2&gt;/things/&lt;thingId2&gt;&quot;,&quot;value&quot;:{&quot;subfield3&quot;:&quot;blah4&quot;}}\r\n{&quot;path&quot;:&quot;users/&lt;userId1&gt;&quot;,&quot;value&quot;:{&quot;name&quot;:&quot;user1&quot;,&quot;email&quot;:&quot;foo@bar.com&quot;}}\r\n{&quot;path&quot;:&quot;users/&lt;userId2&gt;&quot;,&quot;value&quot;:{&quot;name&quot;:&quot;user2&quot;}}\r\n{&quot;path&quot;:&quot;users/&lt;userId3&gt;&quot;,&quot;value&quot;:{&quot;email&quot;:&quot;hello@world.com&quot;}}\r\n```\r\n[Demo](https://jqplay.org/s/WhfkoOCIUJO) (faking the stream with the `tostream` filter added, as there&#39;s no `--stream` option in jqplay)",
                "title": "Include path of object when streaming out JSON from JQ"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1692169745,
                "creation_date": 1692169745,
                "answer_id": 76911261,
                "question_id": 76905501,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s a solution to the first (revised) problem using jq&#39;s streaming parser.\r\n```\r\njq -cn --stream &#39;fromstream(1|truncate_stream(inputs))\r\n  | to_entries[] \r\n  | .key as $uid\r\n  | .value.things\r\n  | to_entries[]\r\n  | {path: &quot;data/\\($uid)/things/\\(.key)&quot;, value}\r\n&#39; input.json\r\n```\r\n\r\nThe first line of the jq program (i.e., the `fromstream` line) breaks up the giant blob into pieces that can then be handled in a straightforward way.\r\n\r\nThe above program of course is not generic but its approach (first breaking up the giant blob, and then managing the pieces) is.\r\n\r\n\r\n",
                "title": "Include path of object when streaming out JSON from JQ"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1692173960,
                "last_edit_date": 1692173960,
                "creation_date": 1692173486,
                "answer_id": 76911672,
                "question_id": 76905501,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s a generic approach that can be used with jq&#39;s streaming parser, or with &quot;JSON Machine&quot; as described elsewhere on this page.\r\n\r\nFirst, start with:\r\n```\r\n&lt; input.json jq -cn --stream &#39;\r\n  def pathValue($n):\r\n    if $n == 1 \r\n    then to_entries[]\r\n    | {path: .key, value}\r\n    else to_entries[]\r\n    | (.value|pathValue($n-1)) as $pv\r\n    | {path: (.key + &quot;/&quot; + $pv.path), value: $pv.value}\r\n    end;\r\n\r\n  fromstream(1|truncate_stream(inputs))\r\n  | pathValue(3)\r\n&#39;\r\n```\r\n\r\nFor the first example, this produces:\r\n\r\n```\r\n{&quot;path&quot;:&quot;&lt;userId1&gt;/things/&lt;thingId1&gt;&quot;,&quot;value&quot;:{&quot;subfield1&quot;:&quot;blah1&quot;,&quot;subfield3&quot;:&quot;foobar&quot;}}\r\n{&quot;path&quot;:&quot;&lt;userId1&gt;/things/&lt;thingId2&gt;&quot;,&quot;value&quot;:{&quot;subfield2&quot;:&quot;blah2&quot;}}\r\n{&quot;path&quot;:&quot;&lt;userId2&gt;/things/&lt;thingId1&gt;&quot;,&quot;value&quot;:{&quot;subfield4&quot;:&quot;blah3&quot;}}\r\n{&quot;path&quot;:&quot;&lt;userId2&gt;/things/&lt;thingId2&gt;&quot;,&quot;value&quot;:{&quot;subfield3&quot;:&quot;blah4&quot;}}\r\n\r\n```\r\n\r\nThe first step loses the top-level key, so you&#39;d have to add it back in if you really want it.  If you want to determine it programatically without consuming more than a trivial amount of memory or time, you could, for example,\r\nuse \r\n```\r\njq -n --stream &#39;first(inputs|first|first)&#39;\r\n```\r\n\r\nFor the second example, you&#39;d call `pathValue(1)`.\r\n",
                "title": "Include path of object when streaming out JSON from JQ"
            }
        ],
        "is_answered": true,
        "answer_count": 4,
        "score": 1,
        "last_activity_date": 1692198587,
        "creation_date": 1692098444,
        "last_edit_date": 1692198587,
        "question_id": 76905501,
        "body_markdown": "I&#39;ve got the following (100GB+) JSON file which includes the following top level key:\r\n\r\n```json\r\n{\r\n   &quot;data&quot;: {\r\n      &quot;&lt;userId1&gt;&quot;: {\r\n         &quot;things&quot;: {\r\n            &quot;&lt;thingId1&gt;&quot;: {\r\n               &quot;subfield1&quot;: &quot;blah1&quot;,\r\n               &quot;subfield3&quot;: &quot;foobar&quot;,\r\n            },\r\n            &quot;&lt;thingId2&gt;&quot;: {\r\n               &quot;subfield2&quot;: &quot;blah2&quot;\r\n            }\r\n         }\r\n      },\r\n      &quot;&lt;userId2&gt;&quot;: {\r\n         &quot;things&quot;: {\r\n            &quot;&lt;thingId1&gt;&quot;: {\r\n               &quot;subfield4&quot;: &quot;blah3&quot;\r\n            },\r\n            &quot;&lt;thingId2&gt;&quot;: {\r\n               &quot;subfield3&quot;: &quot;blah4&quot;\r\n            }\r\n         }\r\n      }\r\n   }\r\n}\r\n```\r\n\r\nI&#39;d like each `things` object outputted with its path on a new line (for later newline delimited JSON usage down the pipeline), e.g. with the above it would output:\r\n\r\n```\r\n{ &quot;path&quot;: &quot;data/&lt;userId1&gt;/things/&lt;thingId1&gt;&quot;, &quot;value&quot;: { &quot;subfield1&quot;: &quot;blah1&quot;, &quot;subfield3&quot;: &quot;foobar&quot; } }\r\n{ &quot;path&quot;: &quot;data/&lt;userId1&gt;/things/&lt;thingId2&gt;&quot;, &quot;value&quot;: { &quot;subfield2&quot;: &quot;blah2&quot; } }\r\n{ &quot;path&quot;: &quot;data/&lt;userId2&gt;/things/&lt;thingId1&gt;&quot;, &quot;value&quot;: { &quot;subfield4&quot;: &quot;blah3&quot; } }\r\n{ &quot;path&quot;: &quot;data/&lt;userId2&gt;/things/&lt;thingId2&gt;&quot;, &quot;value&quot;: { &quot;subfield3&quot;: &quot;blah4&quot; } }\r\n```\r\n\r\nThe separators in `path` can be `.` if needed but would be most useful if it was an actual string array of keys.\r\n\r\nIt also needs to be a bit generic as I&#39;d also like the simpler case of:\r\n\r\n\r\n```json\r\n{\r\n   &quot;users&quot;: {\r\n      &quot;&lt;userId1&gt;&quot;: {\r\n         &quot;name&quot;: &quot;user1&quot;,\r\n         &quot;email&quot;: &quot;foo@bar.com&quot;\r\n      },\r\n      &quot;&lt;userId2&gt;&quot;: {\r\n         &quot;name&quot;: &quot;user2&quot;\r\n      },\r\n      &quot;&lt;userId3&gt;&quot;: {\r\n         &quot;email&quot;: &quot;hello@world.com&quot;\r\n      }\r\n   }\r\n}\r\n```\r\n\r\nTo produce the output of:\r\n\r\n```\r\n{ &quot;path&quot;: &quot;users/&lt;userId1&gt;&quot;, &quot;value&quot;: { &quot;name&quot;: &quot;user1&quot;, &quot;email&quot;: &quot;foo@bar.com&quot; } }\r\n{ &quot;path&quot;: &quot;users/&lt;userId2&gt;&quot;, &quot;value&quot;: { &quot;name&quot;: &quot;user2&quot; } }\r\n{ &quot;path&quot;: &quot;users/&lt;userId3&gt;&quot;, &quot;value&quot;: { &quot;email&quot;: &quot;hello@world.com&quot; } }\r\n```\r\n\r\nFor the simpler case, I&#39;ve managed to get JQ to output the `key` of each object with:\r\n\r\n```sh\r\necho &#39;{&quot;users&quot;:{&quot;&lt;userId1&gt;&quot;:{&quot;name&quot;:&quot;user1&quot;},&quot;&lt;userId2&gt;&quot;:{&quot;name&quot;:&quot;user2&quot;}}}&#39; | jq -rn --stream &#39;fromstream(1 | truncate_stream(inputs | select(.[0][0] == &quot;users&quot;))) | to_entries | map(&quot;\\(. | tojson)&quot;) | join(&quot;\\n&quot;)&#39;\r\n```\r\n\r\nAnd while that works, I can&#39;t quite work out how to adapt it to output paths for the nested objects in the more complex example.\r\n\r\nAlso JQ-wise I don&#39;t know if piping the output of `fromstream` to more functions is realistic memory wise? We&#39;re talking about 10s of millions of `users`/`data` sub objects and possibly a similar amount of `things` sub objects.",
        "link": "https://stackoverflow.com/questions/76905501/include-path-of-object-when-streaming-out-json-from-jq",
        "title": "Include path of object when streaming out JSON from JQ"
    },
    {
        "tags": [
            "shell",
            "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": 1692185414,
                "post_id": 76913125,
                "comment_id": 135588779,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 25387243,
                    "reputation": 41,
                    "user_id": 19198847,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/969210b84f03cbea4a7cb3312e96e325?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Umang Pachaury",
                    "link": "https://stackoverflow.com/users/19198847/umang-pachaury"
                },
                "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": 1692185524,
                "post_id": 76913125,
                "comment_id": 135588802,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1692185597,
                "post_id": 76913125,
                "comment_id": 135588816,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 25387243,
                    "reputation": 41,
                    "user_id": 19198847,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/969210b84f03cbea4a7cb3312e96e325?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Umang Pachaury",
                    "link": "https://stackoverflow.com/users/19198847/umang-pachaury"
                },
                "reply_to_user": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1692187274,
                "post_id": 76913125,
                "comment_id": 135589144,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1692187660,
                "post_id": 76913125,
                "comment_id": 135589232,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "reply_to_user": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1692212748,
                "post_id": 76913125,
                "comment_id": 135594449,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1692270214,
                "post_id": 76913125,
                "comment_id": 135601833,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1692212630,
                "creation_date": 1692212630,
                "answer_id": 76916385,
                "question_id": 76913125,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can use jq to transform small quasi-JSON texts such as shown by treating it as a program, e.g. along the following lines:\r\n\r\n```\r\nfunction text {\r\n    cat&lt;&lt;EOF\r\n[\r\n    {\r\n        id:1,\r\n        &quot;term&quot;:&quot;term1&quot;\r\n    },\r\n    {\r\n        id:2,\r\n        &quot;term&quot;:&quot;term2&quot;\r\n    },\r\n    {\r\n        id:3,\r\n        &quot;term&quot;:&quot;term3&quot;\r\n    }\r\n]\r\nEOF\r\n}\r\n\r\njq -n -f &lt;(text)\r\n``` ",
                "title": "Parsing Array of Objects with JQ"
            },
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1692269680,
                "creation_date": 1692269680,
                "answer_id": 76920829,
                "question_id": 76913125,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "jq can generally only parse JSON-encoded data as JSON if it is valid JSON.\r\nThis is how jq reads from STDIN, an input file, or when using the `--argjson`, `--jsonargs`, `--argfile`, or `--slurpfile` options.\r\nIf your input is initially interpreted as raw string data (by using the `--raw-input`, `--rawfile`, `--arg`, or `--args` options), you can still use the `fromjson` filter from within your jq code on JSON-encoded strings to parse them but a valid encoding is still required.\r\n\r\nIf your input data is not valid JSON (see https://www.json.org/ for a full specification), your options depend on how (much) it differs from JSON. Here are some of them:\r\n\r\n- jq has many built-in functions to handle string data, so you could write anything from a converter to JSON that addresses your specific format violations, to a full-blown interpreter tailored to your overall target objectives. This is, of course, true to any capable programming language, I just wanted to point out that jq is indeed one them, and could infact be a reasonable choice if you already have jq code for a subsequent processing of your input.\r\n\r\n- The jq language itself is a superset of JSON, and your sample data happens to be valid jq code. So, you could use jq to interpret your data as code, although this is generally regarded bad practice when processing unknown input data, especially in a production environment). See @peak&#39;s [answer](https://stackoverflow.com/a/76916385/2158479) for an example.\r\n\r\n- YAML is also a superset of JSON, and your sample data also happens to be valid YAML data (so you could use any YAML interpreter to at least parse the input), but in this case the wording of `id:1` would not be interpreted as a value `1` under key `id` but rather as an undefined value under key `id:1`. (If there was a space between `id:` and `1`, it would, however). Nevertheless, you could still attempt to use a tool that either just converts YAML to JSON, or directly processes YAML the way you wanted to process the (almost valid) JSON input, and fix the issue with `id:1` on the go. Despite the more effort, this is, generally speaking, still better practice since the YAML data is still treated as data, not as code.\r\n\r\n  - [yq](https://github.com/kislyuk/yq) (kislyuk&#39;s implementation) is a YAML processor that is built on top of jq. It converts the YAML input into JSON, then invokes jq to process it. The advantage with this solution is that you can use your original jq code without limitations. Here&#39;s how to fix the `id:1` issue (drop `| tonumber` if the value should remain a string):\r\n    ```sh\r\n    yq &#39;map(with_entries(\r\n      select(.key | startswith(&quot;id:&quot;)) |= {key: &quot;id&quot;, value: (.key[3:] | tonumber)}\r\n    ))&#39; invalid.json\r\n    ```\r\n\r\n  - [gojq](https://github.com/itchyny/gojq) is a rewrite of jq in Go with some additional features, including a YAML interpreter that can be activated using the `--yaml-input` option. Its language is quasi-identical to jq&#39;s (some [minor differences](https://github.com/itchyny/gojq#difference-to-jq) exist, though), so the same fix can be applied and virtually the same advantage can be taken with this solution.\r\n    ```sh\r\n    gojq --yaml-input &#39;map(with_entries(\r\n      select(.key | startswith(&quot;id:&quot;)) |= {key: &quot;id&quot;, value: (.key[3:] | tonumber)}\r\n    ))&#39; invalid.json\r\n    ```\r\n\r\n  - [yq](https://github.com/kislyuk/yq) (mikefarah&#39;s implementation) is another YAML processor, built with jq in mind yet independently of it. Thus, their languages by design share many similarities but are not always interchangable. So, with this solution, the fix is somewhat different (drop `| . tag = &quot;!!int&quot;` if the value should remain a string), and re-using your original jq code may also be limited.\r\n    ```sh\r\n    yq -py -oj &#39;map(\r\n      .&quot;id:*&quot; |= (key | sub(&quot;...&quot;, &quot;&quot;) | . tag = &quot;!!int&quot; | key = &quot;id&quot;)\r\n    )&#39; invalid.json\r\n    ```\r\n\r\n- [Hjson](https://github.com/hjson/hjson-py) is a syntax extension to JSON. It describes itself as &quot;a user interface for humans, to read and edit before passing the JSON data to the machine&quot;. As such, it allows for features disallowed by JSON (like comments), and your sample data happens to be covered. This solution also treats the input as data.\r\n  ```sh\r\n  hjson -j invalid.json\r\n  ```",
                "title": "Parsing Array of Objects with JQ"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1692269680,
        "creation_date": 1692185330,
        "question_id": 76913125,
        "body_markdown": "I am calling a curl request and receiving the data as an Array of Json Objects. I want to use this array of JSON Objects as a value in other JSON. This second JSON will be sent as a Request Body of an api call.\r\n\r\nResponse recieved from the curl request\r\n\r\n    [\r\n    \t{\r\n    \t\tid:1,\r\n    \t\t&quot;term&quot;:&quot;term1&quot;\r\n    \t},\r\n    \t{\r\n    \t\tid:2,\r\n    \t\t&quot;term&quot;:&quot;term2&quot;\r\n    \t},\r\n    \t{\r\n    \t\tid:3,\r\n    \t\t&quot;term&quot;:&quot;term3&quot;\r\n    \t}\r\n    ]\r\n\r\nI am contructing the new json with the help of jq and I am parsing the array of JSON as --arg. So because of this the array gets parsed as string so my question is how can I pass the array in the JSON so that it does not get escape characters i.e. does not get parsed as string. ",
        "link": "https://stackoverflow.com/questions/76913125/parsing-array-of-objects-with-jq",
        "title": "Parsing Array of Objects with JQ"
    },
    {
        "tags": [
            "json",
            "ansible",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1692193775,
                "creation_date": 1692193775,
                "answer_id": 76914248,
                "question_id": 76914159,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s a `reduce`-based approach which iterates over the entries, and successively assigns each item to its intended path in the result object:\r\n```sh\r\nreduce .json.result.entry[] as $entry ({};\r\n  .[$entry.&quot;@location&quot;][$entry.&quot;@name&quot;] = $entry\r\n)\r\n```\r\n```json\r\n{\r\n  &quot;shared&quot;: {\r\n    &quot;bgp_routers&quot;: {\r\n      &quot;@location&quot;: &quot;shared&quot;,\r\n      &quot;@name&quot;: &quot;bgp_routers&quot;,\r\n      &quot;static&quot;: {\r\n        &quot;member&quot;: [\r\n          &quot;core-1&quot;,\r\n          &quot;core-2&quot;,\r\n          &quot;core-3&quot;,\r\n          &quot;supercore&quot;\r\n        ]\r\n      }\r\n    },\r\n    &quot;web_servers&quot;: {\r\n      &quot;@location&quot;: &quot;shared&quot;,\r\n      &quot;@name&quot;: &quot;web_servers&quot;,\r\n      &quot;description&quot;: &quot;req-5&quot;,\r\n      &quot;static&quot;: {\r\n        &quot;member&quot;: [\r\n          &quot;web001&quot;,\r\n          &quot;web002&quot;,\r\n          &quot;web004&quot;\r\n        ]\r\n      }\r\n    }\r\n  },\r\n  &quot;remote-site-1&quot;: {\r\n    &quot;web_servers-2&quot;: {\r\n      &quot;@location&quot;: &quot;remote-site-1&quot;,\r\n      &quot;@name&quot;: &quot;web_servers-2&quot;,\r\n      &quot;description&quot;: &quot;req-100&quot;,\r\n      &quot;static&quot;: {\r\n        &quot;member&quot;: [\r\n          &quot;web001&quot;,\r\n          &quot;web003&quot;,\r\n          &quot;web004&quot;\r\n        ]\r\n      }\r\n    }\r\n  }\r\n}\r\n```\r\n[Demo](https://jqplay.org/s/hoYCHJY02UY)",
                "title": "jq need to re-arrange a list of objects to be a nested single object"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1692338447,
        "creation_date": 1692193177,
        "last_edit_date": 1692338447,
        "question_id": 76914159,
        "body_markdown": "I have found myself needing to search through a few large large json responses via Ansible which has been quite slow. This appears to be related to the structure of the json response, so I need to convert it to a singular nested dictionary instead of the current list of dictionaries. Looking around, jmespath that comes with Ansible doesn&#39;t like to move a value to a key it seems. I have had some luck with a community plugin that adds jq support, but only if I hard code the top level dictionary.\r\n\r\n\r\n\r\n\r\n\r\nwith the following sample...\r\n\r\n```\r\n{\r\n  &quot;json&quot;: {\r\n    &quot;@code&quot;: &quot;19&quot;,\r\n    &quot;@status&quot;: &quot;success&quot;,\r\n    &quot;result&quot;: {\r\n      &quot;@count&quot;: &quot;7003&quot;,\r\n      &quot;@total-count&quot;: &quot;7003&quot;,\r\n      &quot;entry&quot;: [\r\n        {\r\n          &quot;@location&quot;: &quot;shared&quot;,\r\n          &quot;@name&quot;: &quot;bgp_routers&quot;,\r\n          &quot;static&quot;: {\r\n            &quot;member&quot;: [\r\n              &quot;core-1&quot;,\r\n              &quot;core-2&quot;,\r\n              &quot;core-3&quot;,\r\n              &quot;supercore&quot;\r\n            ]\r\n          }\r\n        },\r\n        {\r\n          &quot;@location&quot;: &quot;shared&quot;,\r\n          &quot;@name&quot;: &quot;web_servers&quot;,\r\n          &quot;description&quot;: &quot;req-5&quot;,\r\n          &quot;static&quot;: {\r\n            &quot;member&quot;: [\r\n              &quot;web001&quot;,\r\n              &quot;web002&quot;,\r\n              &quot;web004&quot;\r\n            ]\r\n          }\r\n        },\r\n        {\r\n          &quot;@location&quot;: &quot;remote-site-1&quot;,\r\n          &quot;@name&quot;: &quot;web_servers-2&quot;,\r\n          &quot;description&quot;: &quot;req-100&quot;,\r\n          &quot;static&quot;: {\r\n            &quot;member&quot;: [\r\n              &quot;web001&quot;,\r\n              &quot;web003&quot;,\r\n              &quot;web004&quot;\r\n            ]\r\n          }\r\n        }\r\n      ]\r\n    }\r\n  }\r\n}\r\n```\r\n\r\nId like to re-arrange it to look like this.\r\n\r\n```\r\n{\r\n    &quot;shared&quot;: {\r\n      &quot;bgp_routers&quot;: {\r\n        &quot;@location&quot;: &quot;shared&quot;,\r\n        &quot;@name&quot;: &quot;bgp_routers&quot;,\r\n        &quot;static&quot;: {\r\n          &quot;member&quot;: [\r\n            &quot;core-1&quot;,\r\n            &quot;core-2&quot;,\r\n            &quot;core-3&quot;,\r\n            &quot;supercore&quot;\r\n          ]\r\n        }\r\n      },\r\n      &quot;web_servers&quot;: {\r\n        &quot;@location&quot;: &quot;shared&quot;,\r\n        &quot;@name&quot;: &quot;web_servers&quot;,\r\n        &quot;description&quot;: &quot;req-5&quot;,\r\n        &quot;static&quot;: {\r\n          &quot;member&quot;: [\r\n            &quot;web001&quot;,\r\n            &quot;web002&quot;,\r\n            &quot;web004&quot;\r\n          ]\r\n        }\r\n      }\r\n    },\r\n      &quot;remote-site-1&quot;: {\r\n      &quot;web_servers-2&quot;: {\r\n        &quot;@location&quot;: &quot;remote-site-1&quot;,\r\n        &quot;@name&quot;: &quot;web_servers-2&quot;,\r\n        &quot;description&quot;: &quot;req-100&quot;,\r\n        &quot;static&quot;: {\r\n          &quot;member&quot;: [\r\n            &quot;web001&quot;,\r\n            &quot;web003&quot;,\r\n            &quot;web004&quot;\r\n          ]\r\n        }\r\n      }\r\n    }\r\n}\r\n```\r\n\r\n\r\nSo far, I can get to the object below but am unsure of how to merge the two &quot;shared&quot; keys\r\n`.json.result.entry  | map({ (.[&quot;@location&quot;]):  {( .[&quot;@name&quot;] ): . }}) `\r\n\r\nUsing add, it just seems to keep the last &quot;shared&quot; key. \r\n\r\n```\r\n[\r\n  {\r\n    &quot;shared&quot;: {\r\n      &quot;bgp_routers&quot;: {\r\n        &quot;@location&quot;: &quot;shared&quot;,\r\n        &quot;@name&quot;: &quot;bgp_routers&quot;,\r\n        &quot;static&quot;: {\r\n          &quot;member&quot;: [\r\n            &quot;core-1&quot;,\r\n            &quot;core-2&quot;,\r\n            &quot;core-3&quot;,\r\n            &quot;supercore&quot;\r\n          ]\r\n        }\r\n      }\r\n    }\r\n  },\r\n  {\r\n    &quot;shared&quot;: {\r\n      &quot;web_servers&quot;: {\r\n        &quot;@location&quot;: &quot;shared&quot;,\r\n        &quot;@name&quot;: &quot;web_servers&quot;,\r\n        &quot;description&quot;: &quot;req-5&quot;,\r\n        &quot;static&quot;: {\r\n          &quot;member&quot;: [\r\n            &quot;web001&quot;,\r\n            &quot;web002&quot;,\r\n            &quot;web004&quot;\r\n          ]\r\n        }\r\n      }\r\n    }\r\n  },\r\n  {\r\n    &quot;remote-site-1&quot;: {\r\n      &quot;web_servers-2&quot;: {\r\n        &quot;@location&quot;: &quot;remote-site-1&quot;,\r\n        &quot;@name&quot;: &quot;web_servers-2&quot;,\r\n        &quot;description&quot;: &quot;req-100&quot;,\r\n        &quot;static&quot;: {\r\n          &quot;member&quot;: [\r\n            &quot;web001&quot;,\r\n            &quot;web003&quot;,\r\n            &quot;web004&quot;\r\n          ]\r\n        }\r\n      }\r\n    }\r\n  }\r\n]\r\n```\r\n\r\n\r\n\r\n\r\nAs to why I&#39;m not using the |combine filter in ansible, its really slow and resource intensive when larger loops are thrown at it. It removes and re-creates the dictionary on each iteration...",
        "link": "https://stackoverflow.com/questions/76914159/jq-need-to-re-arrange-a-list-of-objects-to-be-a-nested-single-object",
        "title": "jq need to re-arrange a list of objects to be a nested single object"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 4,
                "creation_date": 1692270059,
                "post_id": 76920821,
                "comment_id": 135601794,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 171611,
                    "reputation": 18377,
                    "user_id": 399145,
                    "user_type": "registered",
                    "accept_rate": 58,
                    "profile_image": "https://www.gravatar.com/avatar/c639d6740f34adc3e7219ade978abcfe?s=256&d=identicon&r=PG",
                    "display_name": "Samselvaprabu",
                    "link": "https://stackoverflow.com/users/399145/samselvaprabu"
                },
                "reply_to_user": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1692270838,
                "post_id": 76920821,
                "comment_id": 135601938,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2186012,
                    "reputation": 22650,
                    "user_id": 1934428,
                    "user_type": "registered",
                    "accept_rate": 86,
                    "profile_image": "https://www.gravatar.com/avatar/072774c5d4204a1c2385560e6114a887?s=256&d=identicon&r=PG",
                    "display_name": "user1934428",
                    "link": "https://stackoverflow.com/users/1934428/user1934428"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1692272818,
                "post_id": 76920821,
                "comment_id": 135602303,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2186012,
                    "reputation": 22650,
                    "user_id": 1934428,
                    "user_type": "registered",
                    "accept_rate": 86,
                    "profile_image": "https://www.gravatar.com/avatar/072774c5d4204a1c2385560e6114a887?s=256&d=identicon&r=PG",
                    "display_name": "user1934428",
                    "link": "https://stackoverflow.com/users/1934428/user1934428"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1692273190,
                "post_id": 76920821,
                "comment_id": 135602372,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 3468753,
                    "reputation": 116,
                    "user_id": 2903690,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/62bf56dc9a31d6b72bc8dbac7a519ec3?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Ilkiv Yuriy",
                    "link": "https://stackoverflow.com/users/2903690/ilkiv-yuriy"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1692353469,
                "post_id": 76920821,
                "comment_id": 135614565,
                "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": 3468753,
                    "reputation": 116,
                    "user_id": 2903690,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/62bf56dc9a31d6b72bc8dbac7a519ec3?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Ilkiv Yuriy",
                    "link": "https://stackoverflow.com/users/2903690/ilkiv-yuriy"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1692598504,
                "post_id": 76920821,
                "comment_id": 135639725,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1692612069,
                "creation_date": 1692612069,
                "answer_id": 76944247,
                "question_id": 76920821,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "To modify several files through a text-filter program, you&#39;d generally want to use a loop with POSIX shells (e.g. bash).\r\n\r\n```\r\nfor file in *.json; do\r\n  jq . &lt; &quot;$file&quot; &gt; &quot;$file.out&quot; &amp;&amp; mv &quot;$file.out&quot; &quot;$file&quot;\r\ndone\r\n```\r\n\r\nReading and writing to different file names is crucial, because the `&gt;` IO redirect operator truncates the file _before_ the application is started and you would end up with an empty file.\r\n\r\nAlso be careful with vanilla jq and numbers in your input files, because it does not handle arbitrary precision numbers and will produce &quot;rounded&quot; numbers (up to IEEE floating point precision); if that is a requirement, switch to one of the jq clones such as [gojq](https://github.com/itchyny/gojq).\r\n\r\nOr use [python itself](https://stackoverflow.com/a/32228333/112968) to pretty-print your JSON: `python3 -m json.tool &quot;$file&quot;`",
                "title": "How to format multiple json file in a dir using cli?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1692612069,
        "creation_date": 1692269625,
        "question_id": 76920821,
        "body_markdown": "My python program generates multiple json file as output.\r\nBut those json are not formatted by default .\r\nI would like to format them and save it back using cli. Currently I am doing format document option in vscode but that i have to do one by one file. \r\n\r\n```\r\ncat file.json | jq .\r\n```\r\n\r\nThe above command displays it but do not know how to save it back to the same file. Also i would like to do it for entire folder.\r\n\r\n",
        "link": "https://stackoverflow.com/questions/76920821/how-to-format-multiple-json-file-in-a-dir-using-cli",
        "title": "How to format multiple json file in a dir using cli?"
    },
    {
        "tags": [
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 6313442,
                    "reputation": 45115,
                    "user_id": 5625547,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/oqCND.jpg?s=256",
                    "display_name": "0stone0",
                    "link": "https://stackoverflow.com/users/5625547/0stone0"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1692299909,
                "post_id": 76924368,
                "comment_id": 135608221,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 16815333,
                    "reputation": 23,
                    "user_id": 12157270,
                    "user_type": "registered",
                    "profile_image": "https://lh6.googleusercontent.com/-0P_AI8IpaqA/AAAAAAAAAAI/AAAAAAAAAAA/ACHi3rfpX72KfZ6qO9P-M2aq5VmvpvyNGQ/s256-rj/photo.jpg",
                    "display_name": "Alex Elam",
                    "link": "https://stackoverflow.com/users/12157270/alex-elam"
                },
                "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": 1692300740,
                "post_id": 76924368,
                "comment_id": 135608368,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 6313442,
                    "reputation": 45115,
                    "user_id": 5625547,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/oqCND.jpg?s=256",
                    "display_name": "0stone0",
                    "link": "https://stackoverflow.com/users/5625547/0stone0"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1692301455,
                "post_id": 76924368,
                "comment_id": 135608490,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 16815333,
                    "reputation": 23,
                    "user_id": 12157270,
                    "user_type": "registered",
                    "profile_image": "https://lh6.googleusercontent.com/-0P_AI8IpaqA/AAAAAAAAAAI/AAAAAAAAAAA/ACHi3rfpX72KfZ6qO9P-M2aq5VmvpvyNGQ/s256-rj/photo.jpg",
                    "display_name": "Alex Elam",
                    "link": "https://stackoverflow.com/users/12157270/alex-elam"
                },
                "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": 1692302222,
                "post_id": 76924368,
                "comment_id": 135608611,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1692303227,
                "last_edit_date": 1692303227,
                "creation_date": 1692301463,
                "answer_id": 76924656,
                "question_id": 76924368,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "This should generate expected output :\r\n\r\n```\r\n.aggregations.user_data.buckets[]\r\n|.response_status.buckets\r\n|map(.roles.buckets|map(select(has(&quot;key&quot;)).key))\r\n|flatten\r\n|first\r\n```\r\n\r\nVersion without `select`\r\n\r\n```\r\n.aggregations.user_data.buckets[]\r\n|.response_status.buckets\r\n|map(.roles.buckets|map(.key // empty))\r\n|flatten|first\r\n```",
                "title": "Conditionally pull value from one of two different fields"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1692305000,
                "creation_date": 1692305000,
                "answer_id": 76924997,
                "question_id": 76924368,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s a solution using `first/1` which evaluates to the first item of the stream provided. This way, branches can already be cut after finding the first occurrence, and there&#39;s no need to further process (`flatten/0`) and extract (`first/0`) from a fully computed structure.\r\n```sh\r\n.aggregations.user_data.buckets[].response_status.buckets\r\n| first(.[].roles.buckets[].key, null)\r\n```\r\n```json\r\n&quot;example-role&quot;\r\n&quot;example-role&quot;\r\nnull\r\n&quot;example-role&quot;\r\n```\r\n[Demo](https://jqplay.org/s/rlIn6W7Po60)",
                "title": "Conditionally pull value from one of two different fields"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1692305000,
        "creation_date": 1692298396,
        "last_edit_date": 1692302038,
        "question_id": 76924368,
        "body_markdown": "I&#39;m new to jq and am attempting to grab a few fields from a json response. The field of note is the &quot;key&quot; field under the &quot;roles&quot; subsection. Here is an example of the response format: \r\n\r\n```\r\n{\r\n  &quot;took&quot;: 755,\r\n  &quot;timed_out&quot;: false,\r\n  &quot;_shards&quot;: {\r\n    &quot;total&quot;: 3,\r\n    &quot;successful&quot;: 3,\r\n    &quot;skipped&quot;: 0,\r\n    &quot;failed&quot;: 0\r\n  },\r\n  &quot;hits&quot;: {\r\n    &quot;total&quot;: {\r\n      &quot;value&quot;: 10000,\r\n      &quot;relation&quot;: &quot;gte&quot;\r\n    },\r\n    &quot;max_score&quot;: null,\r\n    &quot;hits&quot;: []\r\n  },\r\n  &quot;aggregations&quot;: {\r\n    &quot;user_data&quot;: {\r\n      &quot;doc_count_error_upper_bound&quot;: 0,\r\n      &quot;sum_other_doc_count&quot;: 0,\r\n      &quot;buckets&quot;: [\r\n        {\r\n          &quot;key&quot;: &quot;user1&quot;,\r\n          &quot;doc_count&quot;: 872721,\r\n          &quot;response_status&quot;: {\r\n            &quot;buckets&quot;: {\r\n              &quot;success&quot;: {\r\n                &quot;from&quot;: 200,\r\n                &quot;to&quot;: 300,\r\n                &quot;doc_count&quot;: 872709,\r\n                &quot;roles&quot;: {\r\n                  &quot;doc_count_error_upper_bound&quot;: 0,\r\n                  &quot;sum_other_doc_count&quot;: 0,\r\n                  &quot;buckets&quot;: [\r\n                    {\r\n                      &quot;key&quot;: &quot;example-role&quot;,\r\n                      &quot;doc_count&quot;: 872709\r\n                    }\r\n                  ]\r\n                }\r\n              },\r\n              &quot;failure&quot;: {\r\n                &quot;from&quot;: 400,\r\n                &quot;to&quot;: 500,\r\n                &quot;doc_count&quot;: 0,\r\n                &quot;roles&quot;: {\r\n                  &quot;doc_count_error_upper_bound&quot;: 0,\r\n                  &quot;sum_other_doc_count&quot;: 0,\r\n                  &quot;buckets&quot;: []\r\n                }\r\n              }\r\n            }\r\n          }\r\n        },\r\n        {\r\n          &quot;key&quot;: &quot;user2&quot;,\r\n          &quot;doc_count&quot;: 2286,\r\n          &quot;response_status&quot;: {\r\n            &quot;buckets&quot;: {\r\n              &quot;success&quot;: {\r\n                &quot;from&quot;: 200,\r\n                &quot;to&quot;: 300,\r\n                &quot;doc_count&quot;: 2285,\r\n                &quot;roles&quot;: {\r\n                  &quot;doc_count_error_upper_bound&quot;: 0,\r\n                  &quot;sum_other_doc_count&quot;: 2285,\r\n                  &quot;buckets&quot;: [\r\n                    {\r\n                      &quot;key&quot;: &quot;example-role&quot;,\r\n                      &quot;doc_count&quot;: 2285\r\n                    }\r\n                  ]\r\n                }\r\n              },\r\n              &quot;failure&quot;: {\r\n                &quot;from&quot;: 400,\r\n                &quot;to&quot;: 500,\r\n                &quot;doc_count&quot;: 1,\r\n                &quot;roles&quot;: {\r\n                  &quot;doc_count_error_upper_bound&quot;: 0,\r\n                  &quot;sum_other_doc_count&quot;: 1,\r\n                  &quot;buckets&quot;: [\r\n                    {\r\n                      &quot;key&quot;: &quot;example-role&quot;,\r\n                      &quot;doc_count&quot;: 1\r\n                    }\r\n                  ]\r\n                }\r\n              }\r\n            }\r\n          }\r\n        },\r\n        {\r\n          &quot;key&quot;: &quot;user4&quot;,\r\n          &quot;doc_count&quot;: 872721,\r\n          &quot;response_status&quot;: {\r\n            &quot;buckets&quot;: {\r\n              &quot;success&quot;: {\r\n                &quot;from&quot;: 200,\r\n                &quot;to&quot;: 300,\r\n                &quot;doc_count&quot;: 872709,\r\n                &quot;roles&quot;: {\r\n                  &quot;doc_count_error_upper_bound&quot;: 0,\r\n                  &quot;sum_other_doc_count&quot;: 0,\r\n                  &quot;buckets&quot;: []\r\n                }\r\n              },\r\n              &quot;failure&quot;: {\r\n                &quot;from&quot;: 400,\r\n                &quot;to&quot;: 500,\r\n                &quot;doc_count&quot;: 0,\r\n                &quot;roles&quot;: {\r\n                  &quot;doc_count_error_upper_bound&quot;: 0,\r\n                  &quot;sum_other_doc_count&quot;: 0,\r\n                  &quot;buckets&quot;: []\r\n                }\r\n              }\r\n            }\r\n          }\r\n        },\r\n        {\r\n          &quot;key&quot;: &quot;user4&quot;,\r\n          &quot;doc_count&quot;: 1,\r\n          &quot;response_status&quot;: {\r\n            &quot;buckets&quot;: {\r\n              &quot;success&quot;: {\r\n                &quot;from&quot;: 200,\r\n                &quot;to&quot;: 300,\r\n                &quot;doc_count&quot;: 0,\r\n                &quot;roles&quot;: {\r\n                  &quot;doc_count_error_upper_bound&quot;: 0,\r\n                  &quot;sum_other_doc_count&quot;: 0,\r\n                  &quot;buckets&quot;: []\r\n                }\r\n              },\r\n              &quot;failure&quot;: {\r\n                &quot;from&quot;: 400,\r\n                &quot;to&quot;: 500,\r\n                &quot;doc_count&quot;: 1,\r\n                &quot;roles&quot;: {\r\n                  &quot;doc_count_error_upper_bound&quot;: 0,\r\n                  &quot;sum_other_doc_count&quot;: 0,\r\n                  &quot;buckets&quot;: [\r\n                    {\r\n                      &quot;key&quot;: &quot;example-role&quot;,\r\n                      &quot;doc_count&quot;: 1\r\n                    }\r\n                  ]\r\n                }\r\n              }\r\n            }\r\n          }\r\n        }\r\n      ]\r\n    }\r\n  }\r\n}\r\n```\r\n\r\nTo explain the end goal, I&#39;m gathering aggregate data on http success/failures by user and user role. Not all users have roles but I still want data for those users, which is why the query is structured this way.\r\n\r\nMy question is how to pull the role of a user, or null if they have no roles. There are 3 clear cases in the example above: a user with either successes and no failures or vice versa that has a role, a user with both that has a role, and a user that has no roles. I&#39;ve managed to write this jq command in order to filter which users do/don&#39;t have roles:\r\n\r\n```\r\n.aggregations|.user_data|.buckets[]|.response_status|.buckets|map(.roles|.buckets|map(has(&quot;key&quot;)))|flatten|any\r\n```\r\n\r\nWhich for this data returns this: \r\n\r\n```\r\ntrue\r\ntrue\r\nfalse\r\ntrue\r\n```\r\n\r\nHow do I get from this to returning the role itself if true, or null if false so that for this example I would return:\r\n\r\n```\r\n&quot;example-role&quot;\r\n&quot;example-role&quot;\r\nnull\r\n&quot;example-role&quot;\r\n```\r\n\r\nThanks in advance.",
        "link": "https://stackoverflow.com/questions/76924368/conditionally-pull-value-from-one-of-two-different-fields",
        "title": "Conditionally pull value from one of two different fields"
    },
    {
        "tags": [
            "azure",
            "powershell",
            "devops",
            "jq",
            "azure-cli"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1692352833,
                "post_id": 76928274,
                "comment_id": 135614467,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1692364532,
                "creation_date": 1692364532,
                "answer_id": 76929699,
                "question_id": 76928274,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Thanks @pmf. Here is the updated command.\r\n\r\n    az vmss identity show -g group-name -n vmss-name -o json | jq --arg test &quot;$test&quot; &#39;.userAssignedIdentities | with_entries(select(.key | contains($test)))&#39; \r\n\r\n",
                "title": "unable to execute the command the jq command in azure devops pipeline"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1692364532,
        "creation_date": 1692352686,
        "question_id": 76928274,
        "body_markdown": "I have this command where I am trying to validate whether managed identity is already assigned to a particular resource or not. I am getting the managed identity dynamically so, I am keeping it as pipeline variable. when I run this command on azure portal by opening the cli, its running successfully.\r\n\r\n    $test = &quot;name&quot;\r\n    az vmss identity show -g group-name -n vmss-name -o json | jq &#39;.userAssignedIdentities | with_entries(select(.key | contains(&quot;$test&quot;)))&#39;\r\n\r\nwhen I run the exact same command in the pipeline I am getting error.\r\n\r\n&gt; jq: error: $test is not defined at &lt;top-level&gt;, line 1:\r\n\r\nhere is the task\r\n\r\n        \r\n\r\n    - task: AzureCLI@2\r\n              inputs:\r\n                azureSubscription: $(sub)\r\n                scriptType: &#39;pscore&#39;\r\n                scriptLocation: &#39;inlineScript&#39;\r\n                inlineScript: |\r\n                   az vmss identity show -g group-name -n vmss-name -o json | jq &#39;.userAssignedIdentities | with_entries(select(.key | contains(&quot;$test&quot;)))&#39;\r\n\r\n            azurePowerShellVersion: &#39;latestVersion&#39;",
        "link": "https://stackoverflow.com/questions/76928274/unable-to-execute-the-command-the-jq-command-in-azure-devops-pipeline",
        "title": "unable to execute the command the jq command in azure devops pipeline"
    },
    {
        "tags": [
            "arrays",
            "json",
            "jq",
            "tabular"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1692384811,
                "creation_date": 1692384811,
                "answer_id": 76931943,
                "question_id": 76931778,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s a strating point you can build on, especially wrt refining some visual aspects not entirely explicated in your question. Use `.columns[:2]` and `.rows[][:2]` if you only want the first two columns.\r\n```sh\r\njq -r &#39;.properties\r\n  | (.columns | map(.name) | join(&quot; | &quot;) | ., gsub(&quot;.&quot;; &quot;-&quot;))\r\n  , (.rows[] | join(&quot; | &quot;))\r\n&#39;\r\n```\r\n```none\r\nCost | UsageDate | CostStatus | Currency\r\n----------------------------------------\r\n15.87 | 20230818 | Cost | USD\r\n17 | 20230819 | Cost | USD\r\n16.27 | 20230820 | Cost | USD\r\n```\r\n[Demo](https://jqplay.org/s/0y0Y-eqCwcJ)\r\n",
                "title": "json output to table using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1692413503,
        "creation_date": 1692383201,
        "last_edit_date": 1692413503,
        "question_id": 76931778,
        "body_markdown": "I am trying to convert json output to a table format using jq.\r\n\r\nhere is my input\r\n```\r\n{\r\n   &quot;eTag&quot; : null,\r\n   &quot;id&quot; : &quot;providers/Microsoft.Billing/billingAccounts/8000000/providers/Microsoft.CostManagement/query/7acd05b7-5aff-49df-b7db-4d7f111eecf1&quot;,\r\n   &quot;location&quot; : null,\r\n   &quot;name&quot; : &quot;7acd05b7-5aff-49df-b7db-4d7f111eecf1&quot;,\r\n   &quot;properties&quot; : {\r\n      &quot;columns&quot; : [\r\n         {\r\n            &quot;name&quot; : &quot;Cost&quot;,\r\n            &quot;type&quot; : &quot;Number&quot;\r\n         },\r\n         {\r\n            &quot;name&quot; : &quot;UsageDate&quot;,\r\n            &quot;type&quot; : &quot;Number&quot;\r\n         },\r\n         {\r\n            &quot;name&quot; : &quot;CostStatus&quot;,\r\n            &quot;type&quot; : &quot;String&quot;\r\n         },\r\n         {\r\n            &quot;name&quot; : &quot;Currency&quot;,\r\n            &quot;type&quot; : &quot;String&quot;\r\n         }\r\n      ],\r\n      &quot;nextLink&quot; : null,\r\n      &quot;rows&quot; : [\r\n         \r\n         [\r\n            15.87,\r\n            20230818,\r\n            &quot;Cost&quot;,\r\n            &quot;USD&quot;\r\n         ],\r\n         [\r\n            17.00,\r\n            20230819,\r\n            &quot;Cost&quot;,\r\n            &quot;USD&quot;\r\n         ],\r\n         [\r\n            16.27,\r\n            20230820,\r\n            &quot;Cost&quot;,\r\n            &quot;USD&quot;\r\n         ]\r\n      ]\r\n   },\r\n   &quot;type&quot; : &quot;Microsoft.CostManagement/query&quot;\r\n}\r\n```\r\n\r\nMy desired output\r\n\r\n```\r\nCost | UsageDate \r\n----------------\r\n15.87  | 20230818 \r\n17.00  | 20230818\r\n16.27  | 20230818 \r\n```\r\n\r\nI am trying with jq so far i have only got but not the desired output format. Can you please share jq filter query to get the desired output\r\n`.properties | (.columns[].name, .rows[])`",
        "link": "https://stackoverflow.com/questions/76931778/json-output-to-table-using-jq",
        "title": "json output to table using jq"
    },
    {
        "tags": [
            "go",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1692553658,
                "post_id": 76940632,
                "comment_id": 135636018,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1692554278,
                "post_id": 76940632,
                "comment_id": 135636091,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 10477927,
                    "reputation": 5076,
                    "user_id": 7723882,
                    "user_type": "registered",
                    "accept_rate": 85,
                    "profile_image": "https://i.sstatic.net/6aUwy.png?s=256",
                    "display_name": "Matias Barrios",
                    "link": "https://stackoverflow.com/users/7723882/matias-barrios"
                },
                "reply_to_user": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1692561212,
                "post_id": 76940632,
                "comment_id": 135636763,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1692601780,
                "last_edit_date": 1692601780,
                "creation_date": 1692601135,
                "answer_id": 76943026,
                "question_id": 76940632,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If the list is that long, best to create a lookup table.\r\n\r\n```jq\r\n(\r\n   [ &quot;type1&quot;, &quot;type2&quot;, &quot;type3&quot; ] |\r\n   map( { (.): true } ) |\r\n   add\r\n) as $lkup |\r\n\r\n.stores |\r\n( map( select( .is_open ) ) | length &gt; 1 )\r\n   and\r\n( map( select( $lkup[ .type_identifier ] ) ) | length == 1 )\r\n```\r\n\r\nI factored out the common `.stores`, and I replaced `[ .[] | ... ]` with `map( ... )`.\r\n\r\n[Demo](https://jqplay.org/s/rI85iwBijWq) on jqplay.\r\n\r\n---\r\n\r\nYou could also use `INDEX`.\r\n\r\n```jq\r\n(\r\n   [ &quot;type1&quot;, &quot;type2&quot;, &quot;type3&quot; ] |\r\n   INDEX( .[]; . )\r\n) as $lkup |\r\n\r\n.stores |\r\n( map( select( .is_open ) ) | length &gt; 1 )\r\n   and\r\n( map( select( $lkup[ .type_identifier ] ) ) | length == 1 )\r\n```\r\n\r\n[Demo](https://jqplay.org/s/heOiuYDUBOT) on jqplay.",
                "title": "Having a &quot;value in list&quot; condition when using JQ&#39;s Golang implementation"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1692601780,
        "creation_date": 1692553138,
        "question_id": 76940632,
        "body_markdown": "I am using this library in my Go app: https://github.com/itchyny/gojq\r\nIt&#39;s working perfectly fine but I cannot find in JQ documentation how to do something. I have a jq query which input is a list of available stores in a config file that looks like this:\r\n\r\n```\r\n( [.stores[] | select( .is_open == true )] | length  &gt; 1 ) \r\n     and \r\n( [.stores[] | select( .name == &quot;Some store&quot; )] | length == 1 ) \r\n```\r\n\r\nBasically says that from the list of available stores in my area at least one is open and also, from the list of available stores in my area at least one is called &quot;Some store&quot;. ( Notice that its two SEPARATED conditions, I dont care if &quot;Some store&quot; is closed ).\r\n\r\nNow I need to change this condition so instead of having the second condition to look into the name, every store will have a &quot;type_identifier&quot; which is a string. And basically what I want is to have something like:\r\n\r\n```\r\n( [.stores[] | select( .type_identifier in [&quot;type1&quot;,&quot;type2&quot;, &quot;type2&quot;...] )] | length == 1 ) \r\n```\r\n\r\nWhere the list of available types have like 600 different types.\r\nSo my questions are:\r\n\r\n 1. Is there a &quot;in&quot; selector in JQ. What would be the right syntax?\r\n 2. The list of available &quot;types&quot; is another field of the same object along with the list of stores, how can I read the list directly from this property?\r\n\r\nThanks in advance",
        "link": "https://stackoverflow.com/questions/76940632/having-a-value-in-list-condition-when-using-jqs-golang-implementation",
        "title": "Having a &quot;value in list&quot; condition when using JQ&#39;s Golang implementation"
    },
    {
        "tags": [
            "bash",
            "docker",
            "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": 1692613889,
                "post_id": 76944425,
                "comment_id": 135642579,
                "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": 1692614011,
                "post_id": 76944425,
                "comment_id": 135642605,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 7960219,
                    "reputation": 739,
                    "user_id": 6008271,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/5458df19acfdce3ccc4cb9a28012c1a3?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "OscarVanL",
                    "link": "https://stackoverflow.com/users/6008271/oscarvanl"
                },
                "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": 1692614114,
                "post_id": 76944425,
                "comment_id": 135642624,
                "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": 1692614221,
                "post_id": 76944425,
                "comment_id": 135642650,
                "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": 1692614260,
                "post_id": 76944425,
                "comment_id": 135642659,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1692615311,
                "post_id": 76944425,
                "comment_id": 135642854,
                "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": 1692623297,
                "post_id": 76944425,
                "comment_id": 135644642,
                "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": 1692623421,
                "post_id": 76944425,
                "comment_id": 135644660,
                "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": 1692628912,
                "post_id": 76944425,
                "comment_id": 135645934,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 7960219,
                    "reputation": 739,
                    "user_id": 6008271,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/5458df19acfdce3ccc4cb9a28012c1a3?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "OscarVanL",
                    "link": "https://stackoverflow.com/users/6008271/oscarvanl"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1692637244,
                "post_id": 76944425,
                "comment_id": 135647800,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1692618901,
                "last_edit_date": 1692618901,
                "creation_date": 1692616832,
                "answer_id": 76944820,
                "question_id": 76944425,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You redirect stdout to be processed by the first jq. The second jq inherits this redirection. This causes garbage.\r\n\r\nLet&#39;s demo this.\r\n\r\n```bash\r\njsonify() {\r\n   local sev=$1\r\n   shift\r\n   jq -cR --arg sev &quot;$sev&quot; &#39;\r\n      split(&quot;\\n&quot;) |\r\n      { service: &quot;foo&quot;, msg: .[0], severity: $sev }\r\n   &#39; &quot;$@&quot;\r\n}\r\n\r\ndriver() {\r\n   echo &quot;Message 1&quot;\r\n   echo &quot;Message 2&quot; &gt;&amp;2\r\n   echo &quot;Message 3&quot; &gt;&amp;2\r\n   echo &quot;Message 4&quot;\r\n}\r\n\r\ndriver &gt; &gt;( jsonify stdout ) 2&gt; &gt;( jsonify stderr )\r\n```\r\n\r\nOutput:\r\n\r\n```none\r\n{&quot;service&quot;:&quot;foo&quot;,&quot;msg&quot;:&quot;Message 1&quot;,&quot;severity&quot;:&quot;stdout&quot;}\r\n{&quot;service&quot;:&quot;foo&quot;,&quot;msg&quot;:&quot;Message 4&quot;,&quot;severity&quot;:&quot;stdout&quot;}\r\n{&quot;service&quot;:&quot;foo&quot;,&quot;msg&quot;:&quot;{\\&quot;service\\&quot;:\\&quot;foo\\&quot;,\\&quot;msg\\&quot;:\\&quot;Message 2\\&quot;,\\&quot;severity\\&quot;:\\&quot;stderr\\&quot;}&quot;,&quot;severity&quot;:&quot;stdout&quot;}\r\n{&quot;service&quot;:&quot;foo&quot;,&quot;msg&quot;:&quot;{\\&quot;service\\&quot;:\\&quot;foo\\&quot;,\\&quot;msg\\&quot;:\\&quot;Message 3\\&quot;,\\&quot;severity\\&quot;:\\&quot;stderr\\&quot;}&quot;,&quot;severity&quot;:&quot;stdout&quot;}\r\n```\r\n\r\nWe can fix this by duplication stdout before it&#39;s redirection.\r\n\r\n```bash\r\ndriver 3&gt;&amp;1 &gt; &gt;( jsonify stdout ) 2&gt; &gt;( jsonify stderr &gt;&amp;3 )\r\n```\r\n\r\nOutput:\r\n\r\n```none\r\n{&quot;service&quot;:&quot;foo&quot;,&quot;msg&quot;:&quot;Message 2&quot;,&quot;severity&quot;:&quot;stderr&quot;}\r\n{&quot;service&quot;:&quot;foo&quot;,&quot;msg&quot;:&quot;Message 3&quot;,&quot;severity&quot;:&quot;stderr&quot;}\r\n{&quot;service&quot;:&quot;foo&quot;,&quot;msg&quot;:&quot;Message 1&quot;,&quot;severity&quot;:&quot;stdout&quot;}\r\n{&quot;service&quot;:&quot;foo&quot;,&quot;msg&quot;:&quot;Message 4&quot;,&quot;severity&quot;:&quot;stdout&quot;}\r\n```\r\n\r\n---\r\n\r\nThere&#39;s a second issue. The output of the jq processes can come after the command completes.\r\n\r\n```none\r\n$ driver 3&gt;&amp;1 &gt; &gt;( jsonify stdout ) 2&gt; &gt;( jsonify stderr &gt;&amp;3 )\r\n\r\n$ {&quot;service&quot;:&quot;foo&quot;,&quot;msg&quot;:&quot;Message 2&quot;,&quot;severity&quot;:&quot;stderr&quot;}\r\n{&quot;service&quot;:&quot;foo&quot;,&quot;msg&quot;:&quot;Message 1&quot;,&quot;severity&quot;:&quot;stdout&quot;}\r\n{&quot;service&quot;:&quot;foo&quot;,&quot;msg&quot;:&quot;Message 3&quot;,&quot;severity&quot;:&quot;stderr&quot;}\r\n{&quot;service&quot;:&quot;foo&quot;,&quot;msg&quot;:&quot;Message 4&quot;,&quot;severity&quot;:&quot;stdout&quot;}\r\n```\r\n\r\nThis is easily solved by adding a `wait`.\r\n\r\n```bash\r\ndriver 3&gt;&amp;1 &gt; &gt;( jsonify stdout ) 2&gt; &gt;( jsonify stderr &gt;&amp;3 ); wait   # Fixed version\r\n```\r\n\r\nI don&#39;t know why you get *nothing*, but I presume one of these two problems is somehow responsible.\r\n\r\n\r\n---\r\n\r\nBUT! As nice as it is to put everything in one command, having two programs write to the same handle can&#39;t end well. Fixed:\r\n\r\n```bash\r\nout=&quot;$( mktemp )&quot;\r\nerr=&quot;$( mktemp )&quot;\r\n\r\ndriver &gt;&quot;$out&quot; 2&gt;&quot;$err&quot;\r\n\r\njsonify stdout &quot;$out&quot;\r\njsonify stderr &quot;$err&quot;\r\n\r\nrm &quot;$out&quot; &quot;$err&quot;\r\n```\r\n",
                "title": "Stream unstructured logs into structured format using jq"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1692629198,
                "last_edit_date": 1692629198,
                "creation_date": 1692620676,
                "answer_id": 76945250,
                "question_id": 76944425,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "It seems you need to redirect stderr before stdout.\r\n\r\nIf you want to see output when you `docker run`, add `--tty`. Or use `stdbuf -oL` (or better `jq --unbuffered`) before `jq` as suggested by @CharlesDuffy\r\n\r\nDockerfile ==&gt;\r\n\r\n```\r\nFROM ubuntu\r\nENV ACCEPT_EULA=Y DEBIAN_FRONTEND=noninteractive\r\nRUN apt-get update &amp;&amp; apt-get install -y jq\r\nWORKDIR /tmp\r\nCOPY entrypoint.sh entrypoint2.sh /tmp/\r\nRUN chmod +x entrypoint.sh entrypoint2.sh\r\nENTRYPOINT ./entrypoint2.sh\r\n```\r\n\r\nentrypoint.sh ==&gt;\r\n```\r\n#!/bin/bash\r\nc=0\r\nwhile sleep 1; do\r\n    ((c=1-c)) &amp;&amp; date || date &gt;&amp;2\r\ndone\r\n```\r\n\r\nentrypoint2.sh ==&gt;\r\n```\r\n#!/bin/bash\r\n./entrypoint.sh \\\r\n   2&gt; &gt;( jq -R &#39;{service:&quot;foo&quot;, msg:., severity:&quot;stderr&quot;}&#39; ) \\\r\n    &gt; &gt;( jq -R &#39;{service:&quot;foo&quot;, msg:., severity:&quot;stdout&quot;}&#39; )\r\n```\r\n\r\nRun the whole thing with :\r\n\r\n```\r\ndocker build -t test . &amp;&amp; docker run --tty --rm --name test test\r\n```\r\n",
                "title": "Stream unstructured logs into structured format using jq"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1692631599,
                "creation_date": 1692631599,
                "answer_id": 76946712,
                "question_id": 76944425,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Using [TXR](https://nongnu.org/txr) Lisp:\r\n\r\n```\r\n$ txr -e &#39;(whilet ((ln (get-line)))\r\n            (put-jsonl #J^{&quot;service&quot;:&quot;foo&quot;, &quot;msg&quot;:~ln,\r\n                           &quot;severity&quot;:&quot;sdout&quot;, &quot;t&quot;:~(* 1,000,000.0 (time))}))&#39;\r\nfoo\r\n{&quot;msg&quot;:&quot;foo&quot;,&quot;service&quot;:&quot;foo&quot;,&quot;t&quot;:1.692631417e15,&quot;severity&quot;:&quot;sdout&quot;}\r\nfoo&quot;bar\r\n{&quot;msg&quot;:&quot;foo\\&quot;bar&quot;,&quot;service&quot;:&quot;foo&quot;,&quot;t&quot;:1.692631419e15,&quot;severity&quot;:&quot;sdout&quot;}\r\n[Ctrl-D][Enter]\r\n$\r\n```\r\n",
                "title": "Stream unstructured logs into structured format using jq"
            },
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1692871400,
                "creation_date": 1692871400,
                "answer_id": 76968225,
                "question_id": 76944425,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The solution was found by @Charles Duffy, which was that we want to use jq with `--unbuffered` as my entrypoint is a long-running job. The outputs were being buffered and not appearing.\r\n\r\nMy fixed attempt from the original post is:\r\n\r\n```bash\r\n#! /bin/bash\r\n\r\nexec /entrypoint.sh \\\r\n    2&gt; &gt;( jq -R --unbuffered &#39;split(&quot;\\n&quot;)|{service:&quot;foo&quot;, msg:.[0], severity:&quot;stderr&quot;}&#39; &gt; /dev/stderr) \\\r\n    &gt;  &gt;( jq -R --unbuffered &#39;split(&quot;\\n&quot;)|{service:&quot;foo&quot;, msg:.[0], severity:&quot;stdout&quot;}&#39; &gt; /dev/stdout)\r\n```",
                "title": "Stream unstructured logs into structured format using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 4,
        "score": 1,
        "last_activity_date": 1692871400,
        "creation_date": 1692613694,
        "question_id": 76944425,
        "body_markdown": "I have a container with an entrypoint that runs a long-lived service.\r\n\r\n`ENTRYPOINT /entrypoint.sh`\r\n\r\nThe service outputs logs to stdout and stderr in an unstructured format:\r\n\r\n```\r\nInformational message\r\nAn error\r\n```\r\n\r\nI need to wrap these logs in a JSON-structured format in order for them to be machine parsable, but I don&#39;t have control over the binary being run. The output should be like this:\r\n```json\r\n{\r\n    &quot;service&quot;: &quot;foo&quot;,\r\n    &quot;msg&quot;: &quot;Informational message&quot;,\r\n    &quot;severity&quot;: &quot;stdout&quot;,\r\n    &quot;t&quot;: 1692606427758000000,\r\n}\r\n{\r\n    &quot;service&quot;: &quot;foo&quot;,\r\n    &quot;msg&quot;: &quot;An error&quot;,\r\n    &quot;severity&quot;: &quot;stderr&quot;,\r\n    &quot;t&quot;: 1692606427772000000,\r\n}\r\n```\r\n\r\n\r\nMy idea was to create a wrapper entrypoint and then stream the output of the entrypoint into jq to generate the structure I want. I came up with this:\r\n\r\n```\r\n#! /bin/bash\r\n\r\nexec /entrypoint.sh | jq -R &#39;split(&quot;\\n&quot;)|{service:&quot;foo&quot;, msg:.[0], severity:&quot;stdout&quot;}&#39;\r\n```\r\n\r\nThis works, but I want to separately handle stdout and stderr to change the `severity` field accordingly. \r\n\r\nI tried using redirects but can&#39;t figure out how to make jq ingest from them, my attempt below results in nothing being output:\r\n\r\n```\r\n#! /bin/bash\r\n\r\nexec /entrypoint.sh \\\r\n    &gt;  &gt;( jq -R &#39;split(&quot;\\n&quot;)|{service:&quot;foo&quot;, msg:.[0], severity:&quot;stdout&quot;}&#39; ) \\\r\n    2&gt; &gt;( jq -R &#39;split(&quot;\\n&quot;)|{service:&quot;foo&quot;, msg:.[0], severity:&quot;stderr&quot;}&#39; )\r\n```\r\n\r\nAny tips to how I can make jq behave how I want?",
        "link": "https://stackoverflow.com/questions/76944425/stream-unstructured-logs-into-structured-format-using-jq",
        "title": "Stream unstructured logs into structured format using jq"
    },
    {
        "tags": [
            "json",
            "csv",
            "jq",
            "csvtojson",
            "json2csv"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 28666351,
                    "reputation": 175,
                    "user_id": 21950267,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/6ff41229bcd335957fae47e54cd28369?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "CodeBot",
                    "link": "https://stackoverflow.com/users/21950267/codebot"
                },
                "reply_to_user": {
                    "account_id": 2244313,
                    "reputation": 17526,
                    "user_id": 3387716,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/bcad6c8d7a64b0e16fd59996e3835ee9?s=256&d=identicon&r=PG",
                    "display_name": "Fravadona",
                    "link": "https://stackoverflow.com/users/3387716/fravadona"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1692702963,
                "post_id": 76952578,
                "comment_id": 135657233,
                "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": 1692703126,
                "post_id": 76952578,
                "comment_id": 135657263,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 28666351,
                    "reputation": 175,
                    "user_id": 21950267,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/6ff41229bcd335957fae47e54cd28369?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "CodeBot",
                    "link": "https://stackoverflow.com/users/21950267/codebot"
                },
                "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": 1692703521,
                "post_id": 76952578,
                "comment_id": 135657337,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1692703218,
                "creation_date": 1692703218,
                "answer_id": 76952769,
                "question_id": 76952578,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I would use &lt;a href=&quot;https://miller.readthedocs.io/en/latest/&quot;&gt;Miller&lt;/a&gt; (available &lt;a href=&quot;https://github.com/johnkerl/miller/releases&quot;&gt;here&lt;/a&gt; for several OSs) for this task:\r\n\r\n```sh\r\nmlr --c2j cat foo.csv\r\n```\r\n\r\nOutput:\r\n\r\n```json\r\n[\r\n{\r\n  &quot;foo&quot;: 1,\r\n  &quot;bar&quot;: 2,\r\n  &quot;quux&quot;: 3\r\n},\r\n{\r\n  &quot;foo&quot;: 4,\r\n  &quot;bar&quot;: 5,\r\n  &quot;quux&quot;: 6\r\n},\r\n{\r\n  &quot;foo&quot;: 7,\r\n  &quot;bar&quot;: 8,\r\n  &quot;quux&quot;: 9\r\n}\r\n]\r\n```",
                "title": "converting csv to json not working as expected?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1692703218,
        "creation_date": 1692701789,
        "last_edit_date": 1692702928,
        "question_id": 76952578,
        "body_markdown": "I am following [this][1] article to convert csv to json. But I am not getting required output.\r\n\r\nstep 1 - \r\n  \r\n    $ echo -e &quot;foo,bar,quux\\n1,2,3\\n4,5,6\\n7,8,9&quot; &gt; foo.csv\r\n\r\nTest Step 2 - \r\n\r\n    $ jq -R &#39;split(&quot;,&quot;)&#39; foo.csv | jq -cs\r\n\r\nThe output is as expected as below - \r\n\r\n    [[&quot;foo&quot;,&quot;bar&quot;,&quot;quux&quot;],[&quot;1&quot;,&quot;2&quot;,&quot;3&quot;],[&quot;4&quot;,&quot;5&quot;,&quot;6&quot;],[&quot;7&quot;,&quot;8&quot;,&quot;9&quot;]]\r\n\r\n\r\nNext i copied the code from  [jq cookbook][2] in to `csv2json.jq` and executed below command. \r\n\r\n    $ jq -cR &#39;split(&quot;,&quot;)&#39; foo.csv | jq -csf csv2json.jq\r\n\r\nBut i am not getting expected output, I am getting below output - \r\n\r\n    [[&quot;foo&quot;,&quot;bar&quot;,&quot;quux&quot;],[&quot;1&quot;,&quot;2&quot;,&quot;3&quot;],[&quot;4&quot;,&quot;5&quot;,&quot;6&quot;],[&quot;7&quot;,&quot;8&quot;,&quot;9&quot;]]\r\n\r\n\r\nCould someone help me fix this. Thanks in advance. \r\n\r\nThe expected or required output is - \r\n\r\n    [\r\n     {\r\n       &quot;foo&quot;: 1,\r\n       &quot;bar&quot;: 2,\r\n       &quot;quux&quot;: 3\r\n     },\r\n     {\r\n       &quot;foo&quot;: 4,\r\n       &quot;bar&quot;: 5,\r\n       &quot;quux&quot;: 6\r\n     },\r\n     {\r\n       &quot;foo&quot;: 7,\r\n       &quot;bar&quot;: 8,\r\n       &quot;quux&quot;: 9\r\n     }\r\n    ]\r\n\r\n\r\n  [1]: https://news.ycombinator.com/item?id=27379423\r\n  [2]: https://github.com/jqlang/jq/wiki/Cookbook#convert-a-csv-file-with-headers-to-json",
        "link": "https://stackoverflow.com/questions/76952578/converting-csv-to-json-not-working-as-expected",
        "title": "converting csv to json not working as expected?"
    },
    {
        "tags": [
            "arrays",
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1692788206,
                "last_edit_date": 1692788206,
                "creation_date": 1692787836,
                "answer_id": 76960661,
                "question_id": 76960613,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Use the [alternative-operator](https://jqlang.github.io/jq/manual/#alternative-operator): `// &quot;no certificates&quot;`:\r\n\r\n```\r\n(.Certificates[] | .) // &quot;no certificates&quot;\r\n```\r\n\r\n\r\n----------\r\n\r\nUsing [string interpolation][1], your filter will look like:\r\n```\r\n(.Certificates[] | &quot; -subject: \\(.Data.Subject)&quot;) // &quot;no certificates&quot;\r\n```\r\n\r\n\r\n----------\r\n\r\n##### Online JqPlay Demo&#39;s:\r\n\r\n* ##### [With data][2]\r\n* ##### [Without data][3]\r\n\r\n\r\n  [1]: https://jqlang.github.io/jq/manual/#string-interpolation\r\n  [2]: https://jqplay.org/s/atpw7H6XdB5\r\n  [3]: https://jqplay.org/s/Q6c4Mp1Gppe",
                "title": "jq: print array elements if present, print &quot;array is empty&quot; if array is empty, how?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1692788338,
        "creation_date": 1692787404,
        "question_id": 76960613,
        "body_markdown": "I have a json object that looks like this when empty:\r\n\r\n```\r\n{\r\n  &quot;Certificates&quot;: [],\r\n  &quot;Chains&quot;: [],\r\n  &quot;Keys&quot;: []\r\n}\r\n```\r\n\r\nUsing jq, I am able to print the contents of the above when the Certificates array is not empty, like this:\r\n\r\n```\r\njq -r &#39;. | .Certificates[] | &quot;    - subject: &quot; + .Data.Subject&quot;&#39;\r\n```\r\n\r\nWhat I also need to do is output &quot;no certificates&quot; when the above array is empty.\r\n\r\nWhat modification do I need to make to the jq line above to achieve that?\r\n",
        "link": "https://stackoverflow.com/questions/76960613/jq-print-array-elements-if-present-print-array-is-empty-if-array-is-empty-h",
        "title": "jq: print array elements if present, print &quot;array is empty&quot; if array is empty, how?"
    },
    {
        "tags": [
            "json",
            "linux",
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 6014861,
                    "reputation": 20007,
                    "user_id": 7939871,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/1199ba5dde05e4083823a058c5ac6bed?s=256&d=identicon&r=PG",
                    "display_name": "L&#233;a Gris",
                    "link": "https://stackoverflow.com/users/7939871/l%c3%a9a-gris"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1692807245,
                "post_id": 76962746,
                "comment_id": 135675403,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 29284027,
                    "reputation": 11,
                    "user_id": 22436019,
                    "user_type": "registered",
                    "profile_image": "https://lh3.googleusercontent.com/a/AAcHTtcHISysOKjQWv-1l1NPa_Alj-wYRPzSXF76LK6uQ6R-3g=k-s256",
                    "display_name": "DSTV",
                    "link": "https://stackoverflow.com/users/22436019/dstv"
                },
                "reply_to_user": {
                    "account_id": 6014861,
                    "reputation": 20007,
                    "user_id": 7939871,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/1199ba5dde05e4083823a058c5ac6bed?s=256&d=identicon&r=PG",
                    "display_name": "L&#233;a Gris",
                    "link": "https://stackoverflow.com/users/7939871/l%c3%a9a-gris"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1692809182,
                "post_id": 76962746,
                "comment_id": 135675787,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1300809,
                    "reputation": 58943,
                    "user_id": 1250772,
                    "user_type": "registered",
                    "accept_rate": 45,
                    "profile_image": "https://www.gravatar.com/avatar/633e1f643d2c9b043231b4a32b078907?s=256&d=identicon&r=PG",
                    "display_name": "Kaz",
                    "link": "https://stackoverflow.com/users/1250772/kaz"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1692814608,
                "post_id": 76962746,
                "comment_id": 135676735,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1692824365,
                "post_id": 76962746,
                "comment_id": 135678381,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1692818070,
                "creation_date": 1692818070,
                "answer_id": 76964305,
                "question_id": 76962746,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Solution in [TXR](https://nongnu.org/txr) Lisp:\r\n\r\n\r\n\r\n```\r\n$ txr merge-conf.tl old.conf new.conf\r\n{\r\n  &quot;ru_conf&quot; : {\r\n    &quot;network&quot; : {\r\n      &quot;int&quot; : 0,\r\n      &quot;partitions&quot; : [\r\n        {\r\n          &quot;threshold&quot; : 0,\r\n          &quot;dev1&quot; : &quot;str&quot;\r\n        }\r\n      ],\r\n      &quot;mac_address&quot; : &quot;str&quot;,\r\n      &quot;interface&quot; : &quot;str&quot;,\r\n      &quot;setup&quot; : true,\r\n      &quot;numbers&quot; : [\r\n        0,\r\n        0,\r\n        0\r\n      ],\r\n      &quot;interfaceы&quot; : [\r\n        &quot;str1&quot;,\r\n        &quot;str2&quot;\r\n      ]\r\n    }\r\n  }\r\n}\r\n```\r\n\r\nNote that this solution does not take care of renaming `&quot;&quot;interfaceы&quot;` to `&quot;interfaces&quot;`. That looks like a typo.\r\n\r\nWe define a `hash-merge` function which merges two hash tables using a `merge-fun` functional argument to decide what to do. It calls `merge-fun` with four arguments: a keyword which is { `:both`, `:left-only` or `:right-only` }, the hash key being merged and the left and right values.\r\n\r\nThe function calculates and returns the merged value.\r\n\r\nIn the `:left-only` and `:right-only` cases, if the function returns `nil`, the object will not appear in the merged hash. \r\n\r\nThe function `funny-merge` then does some argument pattern matching to determine what to do. For instance one pattern says that if we have a `&quot;float&quot;` or `&quot;int&quot;` element that is on the left side only (old config), then that does not appear.  Another rule says that the left side&#39;s `&quot;setup&quot;` is taken, rather than the right.\r\n\r\n```\r\n(defun hash-merge (lhash rhash merge-fun)\r\n  (let ((ohash (copy lhash)))\r\n    (dohash (key val ohash)\r\n      (unless (in rhash key)\r\n        (iflet ((nval [merge-fun :only-left key val nil]))\r\n          (set [ohash key] nval)\r\n          (del [ohash key]))))\r\n    (dohash (key val rhash ohash)\r\n      (if (in ohash key)\r\n        (set [ohash key] [merge-fun :both key [lhash key] val])\r\n        (iflet ((nval [merge-fun :only-right key nil val]))\r\n          (set [ohash key] nval)\r\n          (del [ohash key]))))))\r\n\r\n(defun-match funny-merge\r\n  ((@nil @nil @(hashp @left) @(hashp @right)) [hash-merge left right funny-merge])\r\n  ((:both &quot;setup&quot; @left @right) left)\r\n  ((:left-only @(or &quot;float&quot; &quot;int&quot;) @nil @nil) nil)\r\n  ((:left-only @nil @left @nil) left)\r\n  ((@(or :both :right-only) @nil @nil @right) right))\r\n\r\n(let ((*read-bad-json* t)\r\n      (*print-json-format* :standard))\r\n  (match (@(@oconf (file-get-json)) @(@nconf (file-get-json))) *args*\r\n    (put-jsonl (funny-merge nil nil oconf nconf))))\r\n\r\n```",
                "title": "Merge 2 JSON files with jq"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1692818070,
        "creation_date": 1692803686,
        "question_id": 76962746,
        "body_markdown": "I need to write a command via jq which is:\r\n1. compares old and new config json files (old-o-ru.conf and new-o-ru.conf).\r\n2. Copies the value of the element from the old config to the new one, if the new one has this element and their types match.\r\n3. Unaffected elements in the new config should remain.\r\n\r\n**old.conf:**\r\n```\r\n{\r\n    &quot;ru_conf&quot;: {\r\n        &quot;network&quot;: {\r\n            &quot;interface&quot;: &quot;eth1&quot;,\r\n            &quot;mac_address&quot;: &quot;FF:FF:FF:FF:FF:FF&quot;,\r\n            &quot;setup&quot;: true,\r\n            &quot;interfaceы&quot;: [&quot;eth0&quot;, &quot;eth1&quot;],\r\n            &quot;numbers&quot;: [1, 2, 3],\r\n            &quot;float&quot;: 1111.1111,\r\n            &quot;partitions&quot;: [\r\n                {\r\n                  &quot;dev1&quot;: &quot;/mnt/data/&quot;,\r\n                  &quot;threshold&quot;: 20,\r\n                }\r\n            ]\r\n        }\r\n    }\r\n}\r\n```\r\n\r\n**new.conf:**\r\n```\r\n{\r\n    &quot;ru_conf&quot;: {\r\n        &quot;network&quot;: {\r\n            &quot;interface&quot;: &quot;str&quot;,\r\n            &quot;mac_address&quot;: &quot;str&quot;,\r\n            &quot;setup&quot;: false,\r\n            &quot;interfaceы&quot;: [&quot;str1&quot;, &quot;str2&quot;],\r\n            &quot;numbers&quot;: [0, 0, 0],\r\n            &quot;int&quot;: 0,\r\n            &quot;partitions&quot;: [\r\n                {\r\n                  &quot;dev1&quot;: &quot;str&quot;,\r\n                  &quot;threshold&quot;: 0,\r\n                }\r\n            ]\r\n        }\r\n    }\r\n}\r\n```\r\n\r\nDifferences in configs:\r\nthere is no &quot;int&quot; field in old.conf\r\nthere is no &quot;float&quot; field in new.conf\r\n\r\nI am using the **command**:\r\n```\r\njq -s &#39;.[1].ru_conf as $new | .[0] | .ru_conf |= reduce paths(scalars) as $p (.; if ($new | getpath($p)) and (getpath($p) | type) == ($new | getpath($p) | type) then setpath($p; $new | getpath($p)) else . end)&#39; ./new.conf ./old.conf &gt; merged-config.conf\r\n```\r\n\r\n**Result:**\r\n\r\n```\r\n{\r\n  &quot;ru_conf&quot;: {\r\n    &quot;network&quot;: {\r\n      &quot;interface&quot;: &quot;eth1&quot;,\r\n      &quot;mac_address&quot;: &quot;FF:FF:FF:FF:FF:FF&quot;,\r\n      &quot;setup&quot;: false,\r\n      &quot;interfaces&quot;: [\r\n        &quot;eth0&quot;,\r\n        &quot;eth1&quot;\r\n      ],\r\n      &quot;numbers&quot;: [\r\n        1,\r\n        2,\r\n        3\r\n      ],\r\n      &quot;int&quot;: 0,\r\n      &quot;partitions&quot;: [\r\n        {\r\n          &quot;dev1&quot;: &quot;/mnt/data/&quot;,\r\n          &quot;threshold&quot;: 20\r\n        }\r\n      ]\r\n    }\r\n  }\r\n}\r\n```\r\n\r\n\r\n**Expected output**:\r\n```\r\n{\r\n    &quot;ru_conf&quot;: {\r\n        &quot;network&quot;: {\r\n            &quot;interface&quot;: &quot;str&quot;,\r\n            &quot;mac_address&quot;: &quot;str&quot;,\r\n            &quot;setup&quot;: true,\r\n            &quot;interfaces&quot;: [&quot;str1&quot;, &quot;str2&quot;],\r\n            &quot;numbers&quot;: [0, 0, 0],\r\n            &quot;int&quot;: 0,\r\n            &quot;partitions&quot;: [\r\n                {\r\n                  &quot;dev1&quot;: &quot;str&quot;,\r\n                  &quot;threshold&quot;: 0\r\n                }\r\n            ]\r\n        }\r\n    }\r\n}\r\n```\r\n\r\nDifferences from result and expected result:\r\n&quot;setup&quot;: false\r\n\r\nAlso tried this:\r\n\r\n```\r\njq \\\r\n --argjson a &quot;$(cat ./new.conf)&quot; \\\r\n --argjson b &quot;$(cat ./old.conf)&quot; \\\r\n -n &#39;\r\n   $a | .ru_conf | keys_unsorted as $whitelist \r\n | $b | .ru_conf | with_entries( select(.key | IN($whitelist[])) ) as $update\r\n | $a | .ru_conf += $update &#39;\r\n```\r\n\r\n**Result:**\r\n\r\n```\r\n{\r\n  &quot;ru_conf&quot;: {\r\n    &quot;network&quot;: {\r\n      &quot;interface&quot;: &quot;eth1&quot;,\r\n      &quot;mac_address&quot;: &quot;FF:FF:FF:FF:FF:FF&quot;,\r\n      &quot;setup&quot;: true,\r\n      &quot;interfaces&quot;: [\r\n        &quot;eth0&quot;,\r\n        &quot;eth1&quot;\r\n      ],\r\n      &quot;numbers&quot;: [\r\n        1,\r\n        2,\r\n        3\r\n      ],\r\n      &quot;float&quot;: 1111.1111,\r\n      &quot;partitions&quot;: [\r\n        {\r\n          &quot;dev1&quot;: &quot;/mnt/data/&quot;,\r\n          &quot;threshold&quot;: 20\r\n        }\r\n      ]\r\n    }\r\n  }\r\n}\r\n```\r\n\r\nBut the second command does not support type comparison and nesting\r\n\r\nHow can I achieve the required result?",
        "link": "https://stackoverflow.com/questions/76962746/merge-2-json-files-with-jq",
        "title": "Merge 2 JSON files with jq"
    },
    {
        "tags": [
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 39208,
                    "reputation": 267964,
                    "user_id": 112968,
                    "user_type": "registered",
                    "accept_rate": 68,
                    "profile_image": "https://i.sstatic.net/zHTaT.png?s=256",
                    "display_name": "knittl",
                    "link": "https://stackoverflow.com/users/112968/knittl"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1692866871,
                "post_id": 76966282,
                "comment_id": 135683072,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 39208,
                    "reputation": 267964,
                    "user_id": 112968,
                    "user_type": "registered",
                    "accept_rate": 68,
                    "profile_image": "https://i.sstatic.net/zHTaT.png?s=256",
                    "display_name": "knittl",
                    "link": "https://stackoverflow.com/users/112968/knittl"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1692866915,
                "post_id": 76966282,
                "comment_id": 135683077,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1692863209,
                "creation_date": 1692863209,
                "answer_id": 76967195,
                "question_id": 76966282,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Quoting is crucial in shell scripts. If you do not quote your parameters when expanding, word splitting and glob expansion is performed. You don&#39;t want that to happen here.\r\n\r\n```\r\nUPDATED_JSON=$(jq &#39;.&#39; ../some_file.json)\r\n\r\n# ...\r\n\r\nUPDATED_JSON=$(\r\n    echo &quot;$UPDATED_JSON&quot; | jq -r &#39;.topLevelObject.leafNode = false&#39; \r\n)\r\n\r\necho &quot;$UPDATED_JSON&quot;\r\n```\r\n\r\n`echo` should be safe with JSON content in the variable, but you might want to consider replacing it with `printf &#39;%s\\n&#39; &quot;$UPDATE_JSON&quot;` just in case.",
                "title": "JQ - Store and Update JSON Over Time"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1692863209,
        "creation_date": 1692852415,
        "question_id": 76966282,
        "body_markdown": "I&#39;m trying to read some JSON data from file and then, via a series of prompts in a shell script, *update* that JSON over time to eventually write it back to disk later.\r\n\r\nI&#39;ve come to the following where I first read the original JSON into an `UPDATED_JSON` variable and then mutate it over time.\r\n\r\n```\r\nUPDATED_JSON=$(\r\n\tcat ../some_file.json | jq\r\n)\r\n\r\n...\r\n\r\nUPDATED_JSON=$(\r\n\techo $UPDATED_JSON | jq -r &#39;.topLevelObject.leafNode = false&#39; \r\n    # note that `topLevelObject` is guaranteed to exist but `leafNode` might not, in which case I want to insert it\r\n)\r\n\r\necho $UPDATED_JSON\r\n```\r\n\r\nHowever this outputs `parse error: Invalid escape at line 1, column 18629`.\r\n\r\nI suspect it&#39;s something to do with `UPDATED_JSON` not being in a format jq can later process due to how I assigned it?\r\n\r\nAlso note that I&#39;ll again be using jq for updating the file on disk with the updated JSON.",
        "link": "https://stackoverflow.com/questions/76966282/jq-store-and-update-json-over-time",
        "title": "JQ - Store and Update JSON Over Time"
    },
    {
        "tags": [
            "json",
            "csv",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1692908123,
                "last_edit_date": 1692908123,
                "creation_date": 1692905160,
                "answer_id": 76972407,
                "question_id": 76972248,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You only want to apply the `join` to the products, not all the columns. You need to apply it to each product separately.\r\n```\r\njq -r &#39;\r\n[&quot;account_id&quot;, &quot;account_status&quot;, &quot;name&quot;, &quot;email&quot;, &quot;product 1&quot;, &quot;product 2&quot;, &quot;product 3&quot;],\r\n(.data[]\r\n    | [.account_id, .account_status, .name, .email,\r\n      ([.product_access[] | select(.key == &quot;product1&quot;).url] | join(&quot;,&quot;)),\r\n      ([.product_access[] | select(.key == &quot;product2&quot;).url] | join(&quot;,&quot;)),\r\n      ([.product_access[] | select(.key == &quot;product3&quot;).url] | join(&quot;,&quot;))\r\n     ] ) | @csv&#39;\r\n```",
                "title": "jq filtering on specific key and collating values into single csv cell"
            },
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1692910468,
                "creation_date": 1692910468,
                "answer_id": 76972877,
                "question_id": 76972248,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Try this :\r\n\r\n```\r\njq -r &#39;\r\n[&quot;account_id&quot;, &quot;account_status&quot;, &quot;name&quot;, &quot;email&quot;, &quot;product 1&quot;, &quot;product 2&quot;, &quot;product 3&quot;],\r\n(.data[]\r\n | [.account_id, .account_status, .name, .email,\r\n    (&quot;product1&quot;,&quot;product2&quot;,&quot;product3&quot;) as $prod\r\n    | [(.product_access[] | select(.key == $prod).url)] | join(&quot;,&quot;)\r\n   ]\r\n)\r\n| @csv&#39; input.json\r\n```",
                "title": "jq filtering on specific key and collating values into single csv cell"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1692910468,
        "creation_date": 1692903511,
        "question_id": 76972248,
        "body_markdown": "Given this json:\r\n\r\n```\r\n{&quot;data&quot;: [\r\n  {\r\n    &quot;account_id&quot;: &quot;123&quot;,\r\n    &quot;account_status&quot;: &quot;active&quot;,\r\n    &quot;name&quot;: &quot;john doe&quot;,\r\n    &quot;email&quot;: &quot;johndoe@anywhere.com&quot;,\r\n    &quot;product_access&quot;: []\r\n  },\r\n  {\r\n    &quot;account_id&quot;: &quot;345&quot;,\r\n    &quot;account_status&quot;: &quot;active&quot;,\r\n    &quot;name&quot;: &quot;jane doe&quot;,\r\n    &quot;email&quot;: &quot;janedoe@anywhere.com&quot;,\r\n    &quot;last_active&quot;: &quot;2023-08-23T13:03:27.811473590Z&quot;,\r\n    &quot;product_access&quot;: [\r\n      {\r\n        &quot;name&quot;: &quot;Product 1&quot;,\r\n        &quot;key&quot;: &quot;product1&quot;,\r\n        &quot;url&quot;: &quot;acme1.com&quot;\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;Product 1&quot;,\r\n        &quot;key&quot;: &quot;product1&quot;,\r\n        &quot;url&quot;: &quot;acme2.com&quot;\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;Product 1&quot;,\r\n        &quot;key&quot;: &quot;product1&quot;,\r\n        &quot;url&quot;: &quot;acme3.com&quot;\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;Product 2&quot;,\r\n        &quot;key&quot;: &quot;product2&quot;,\r\n        &quot;url&quot;: &quot;acme4.com&quot;,\r\n        &quot;last_active&quot;: &quot;2023-08-23T13:03:27.811473590Z&quot;\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;Product 3&quot;,\r\n        &quot;key&quot;: &quot;product3&quot;,\r\n        &quot;url&quot;: &quot;acme5.com&quot;\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;Product 1&quot;,\r\n        &quot;key&quot;: &quot;product1&quot;,\r\n        &quot;url&quot;: &quot;acme4.com&quot;,\r\n        &quot;last_active&quot;: &quot;2023-08-17T18:21:52.472085713Z&quot;\r\n      }\r\n    ]\r\n  }\r\n]\r\n}\r\n```\r\n\r\nI am trying to write a jq expression such that the output is the following in a csv file (not adding escape characters here for simplicity):\r\n\r\n```\r\n&quot;account_id&quot;, &quot;account_status&quot;, &quot;name&quot;, &quot;email&quot;, &quot;Product 1&quot;, &quot;Product 2&quot;, &quot;Product 3&quot;\r\n&quot;123&quot;, &quot;active&quot;, &quot;john doe&quot;, &quot;johndoe@anywhere.com&quot;, &quot;,,&quot;\r\n&quot;345&quot;, &quot;active&quot;, &quot;jane doe&quot;, &quot;janedoe@anywhere.com&quot;, &quot;acme1.com, acme2.com, acme3.com, acme4.com&quot;, &quot;acme4.com&quot;, &quot;acme5.com&quot;\r\n```\r\n\r\nI&#39;ve tried this so far...\r\n```\r\njq -r &#39;[&quot;account_id&quot;, &quot;account_status&quot;, &quot;name&quot;, &quot;email&quot;, &quot;product 1&quot;, &quot;product 2&quot;, &quot;product 3&quot;],\r\n        (.data[] | [.account_id, .account_status, .name, .email,\r\n                    (.product_access[] | select(.key == &quot;product1&quot;).url // &quot;&quot;),\r\n                    (.product_access[] | select(.key == &quot;product2&quot;).url // &quot;&quot;),\r\n                    (.product_access[] | select(.key == &quot;product3&quot;).url // &quot;&quot;)] | join(&quot;,&quot;)) | @csv&#39;\r\n```\r\nIt doesn&#39;t collate the Product n urls into the single cells.  \r\n",
        "link": "https://stackoverflow.com/questions/76972248/jq-filtering-on-specific-key-and-collating-values-into-single-csv-cell",
        "title": "jq filtering on specific key and collating values into single csv cell"
    },
    {
        "tags": [
            "json",
            "path",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 1650243,
                    "reputation": 3125,
                    "user_id": 1520991,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/wjeZtWcY.png?s=256",
                    "display_name": "dikesh",
                    "link": "https://stackoverflow.com/users/1520991/dikesh"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1692968395,
                "post_id": 76977329,
                "comment_id": 135700832,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 6313442,
                    "reputation": 45115,
                    "user_id": 5625547,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/oqCND.jpg?s=256",
                    "display_name": "0stone0",
                    "link": "https://stackoverflow.com/users/5625547/0stone0"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1692968903,
                "post_id": 76977329,
                "comment_id": 135700969,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 6313442,
                    "reputation": 45115,
                    "user_id": 5625547,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/oqCND.jpg?s=256",
                    "display_name": "0stone0",
                    "link": "https://stackoverflow.com/users/5625547/0stone0"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1692969281,
                "post_id": 76977329,
                "comment_id": 135701062,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 29297448,
                    "reputation": 11,
                    "user_id": 22446477,
                    "user_type": "registered",
                    "profile_image": "https://lh3.googleusercontent.com/a/AAcHTtegg7eHlVztbCi75UgLOReYmryznb3cgfLDiEDV9JyEqg=k-s256",
                    "display_name": "Enry",
                    "link": "https://stackoverflow.com/users/22446477/enry"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1692969921,
                "post_id": 76977329,
                "comment_id": 135701238,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 29297448,
                    "reputation": 11,
                    "user_id": 22446477,
                    "user_type": "registered",
                    "profile_image": "https://lh3.googleusercontent.com/a/AAcHTtegg7eHlVztbCi75UgLOReYmryznb3cgfLDiEDV9JyEqg=k-s256",
                    "display_name": "Enry",
                    "link": "https://stackoverflow.com/users/22446477/enry"
                },
                "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": 1692970231,
                "post_id": 76977329,
                "comment_id": 135701311,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1692974387,
                "last_edit_date": 1692974387,
                "creation_date": 1692972673,
                "answer_id": 76978004,
                "question_id": 76977329,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You cannot use `--arg` or `--argjson` to import (and then &quot;evaluate&quot;) jq code. These are only meant to import data (as a string or as JSON). You *could* inject code from shell by presetting a shell variable with `.Serilog.WriteTo[0].Name`, and then having it expanded by the shell by wrapping the code inside double quotes, but this is generally regarded bad practice, and introduces other risks on various levels. Better provide the insert location as data, i.e. in a format that jq filters can operate with. One example could be `setpath` which expects the path to be an array of strings (for object fields) and numbers (for array indices).\r\n\r\nUsing `--argjson` (providing the formatted array) for the path:\r\n```sh\r\njq --argjson path &#39;[&quot;Serilog&quot;, &quot;WriteTo&quot;, 0, &quot;Name&quot;]&#39; --arg value &#39;Pluto&#39; &#39;setpath($path; $value)&#39; input.json\r\n```\r\n\r\nUsing `--jsonargs` (providing the array&#39;s items individuallay) for the path:\r\n```sh\r\njq --arg value &#39;Pluto&#39; &#39;setpath($ARGS.positional; $value)&#39; --jsonargs &#39;&quot;Serilog&quot;&#39; &#39;&quot;WriteTo&quot;&#39; 0 &#39;&quot;Name&quot;&#39; input.json\r\n```\r\n\r\nUsing `--args` (providing strings only) for the path, and converting strings that look like numbers into actual numbers (to ease formatting the args):\r\n```sh\r\njq --arg value &#39;Pluto&#39; &#39;setpath($ARGS.positional | map(tonumber? // .); $value)&#39; input.json --args Serilog WriteTo 0 Name\r\n```\r\n\r\nWith an empty input, all of these produce\r\n```json\r\n{\r\n  &quot;Serilog&quot;: {\r\n    &quot;WriteTo&quot;: [\r\n      {\r\n        &quot;Name&quot;: &quot;Pluto&quot;\r\n      }\r\n    ]\r\n  }\r\n}\r\n```\r\n\r\nAlternatively, you would have to write your own parser for expressions of that kind (which is, of course, possible with jq). However, there are other JSON processors that already do have an `eval` function. One of them is [mikefarah/yq](https://github.com/mikefarah/yq) which is similar to jq in many ways (and different in a lot of others) but it can read, modify and output JSON data, and has an [`eval`](https://mikefarah.gitbook.io/yq/operators/eval) function.\r\n\r\n```sh\r\nname=&#39;.Serilog.WriteTo[0].Name&#39; value=&#39;Pluto&#39; yq -oj &#39;eval(env(name)) = env(value)&#39; input.json\r\n```\r\n```json\r\n{\r\n  &quot;Serilog&quot;: {\r\n    &quot;WriteTo&quot;: [\r\n      {\r\n        &quot;Name&quot;: &quot;Pluto&quot;\r\n      }\r\n    ]\r\n  }\r\n}\r\n```",
                "title": "Add/replace key&gt;value from variable with jq"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1693161296,
        "creation_date": 1692967631,
        "last_edit_date": 1693161296,
        "question_id": 76977329,
        "body_markdown": "I want to update (or insert as a new entry if it doesn&#39;t already exist) a key=value with bash and jq:\r\n\r\n```\r\njq --arg name &quot;Serilog.WriteTo[0].Name&quot; --arg value &quot;Pluto&quot; &#39;.$name = $value&#39; appsettings.json.tpl &gt; appsettings.json\r\n```\r\n\r\nBut I got this result:\r\n\r\n```\r\njq: error: syntax error, unexpected &#39;$&#39; (Unix shell quoting issues?) at &lt;top-level&gt;, line 1:\r\n.$name = $value \r\njq: error: try .[&quot;field&quot;] instead of .field for unusually named fields at &lt;top-level&gt;, line 1:\r\n.$name = $value\r\njq: 2 compile errors\r\n```\r\n\r\nIf I add the [ as suggested:\r\n\r\n```\r\njq --arg name &quot;Serilog.WriteTo[0].Name&quot; --arg value &quot;Pluto&quot; &#39;.[$name] = $value&#39; appsettings.json.tpl &gt; appsettings.json\r\n\r\n```\r\nI get this result:\r\n\r\n```\r\nroot@ip-10-1-5-215:~# cat appsettings.json\r\n{\r\n  &quot;Serilog.WriteTo[0].Name&quot;: &quot;Pluto&quot;\r\n}\r\n```\r\n\r\n\r\nBut the right result should be like as with this syntax:\r\n\r\n```\r\njq --arg value &quot;Pluto&quot; &#39;.Serilog.WriteTo[0].Name = $value&#39; appsettings.json.tpl &gt; appsettings.json\r\n\r\n```\r\n\r\n```\r\nroot@ip-10-1-5-215:~# cat appsettings.json\r\n{\r\n  &quot;Serilog&quot;: {\r\n    &quot;WriteTo&quot;: [\r\n      {\r\n        &quot;Name&quot;: &quot;Pluto&quot;\r\n      }\r\n    ]\r\n  }\r\n}\r\n```\r\n\r\nHow can I solve this issue?",
        "link": "https://stackoverflow.com/questions/76977329/add-replace-keyvalue-from-variable-with-jq",
        "title": "Add/replace key&gt;value from variable with jq"
    },
    {
        "tags": [
            "jq",
            "jsonlines",
            "ndjson"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1693046875,
                "post_id": 76982456,
                "comment_id": 135710165,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2702639,
                    "reputation": 4867,
                    "user_id": 2333021,
                    "user_type": "registered",
                    "accept_rate": 70,
                    "profile_image": "https://www.gravatar.com/avatar/46a7056aa498c93ef3e4819d4967a847?s=256&d=identicon&r=PG",
                    "display_name": "Christopher Rucinski",
                    "link": "https://stackoverflow.com/users/2333021/christopher-rucinski"
                },
                "reply_to_user": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1693048019,
                "post_id": 76982456,
                "comment_id": 135710266,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1693048862,
                "post_id": 76982456,
                "comment_id": 135710365,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1693056162,
                "creation_date": 1693056162,
                "answer_id": 76983160,
                "question_id": 76982456,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "100 milestones: https://jqplay.org/s/hmpl7oz5K2z\r\n```jq\r\n[ \r\n  .data.repository \r\n  | .nameWithOwner as $repo \r\n  | .milestones.nodes[] \r\n  | select(\r\n      .progressPercentage == 100 and \r\n      (.title | contains(&quot;withdrawn&quot;) | not) and \r\n      .issues.nodes[]\r\n    )\r\n  | \r\n  { \r\n    (.title | splits(&quot;,? &quot;)): (\r\n        { $repo, milestone: .number } + \r\n        (.issues.nodes[] | { issue: .number, labels: [ .labels.nodes[].name ] }))\r\n  }\r\n] \r\n| add\r\n```\r\n```json\r\n{\r\n  &quot;C.1&quot;: {\r\n    &quot;repo&quot;: &quot;cov-lineages/pango-designation&quot;,\r\n    &quot;milestone&quot;: 1,\r\n    &quot;issue&quot;: 2,\r\n    &quot;labels&quot;: [\r\n      &quot;proposed&quot;,\r\n      &quot;designated&quot;\r\n    ]\r\n  },\r\n  &quot;EXAMPLE_SPLIT&quot;: {\r\n    &quot;repo&quot;: &quot;cov-lineages/pango-designation&quot;,\r\n    &quot;milestone&quot;: 1,\r\n    &quot;issue&quot;: 2,\r\n    &quot;labels&quot;: [\r\n      &quot;proposed&quot;,\r\n      &quot;designated&quot;\r\n    ]\r\n  },\r\n  &quot;B.1.429&quot;: {\r\n    &quot;repo&quot;: &quot;cov-lineages/pango-designation&quot;,\r\n    &quot;milestone&quot;: 2,\r\n    &quot;issue&quot;: 3,\r\n    &quot;labels&quot;: [\r\n      &quot;proposed&quot;,\r\n      &quot;designated&quot;\r\n    ]\r\n  }\r\n}\r\n```",
                "title": "Need to modify an existing JQ filter of a GitHub CLI GraphQL response"
            },
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1693065685,
                "last_edit_date": 1693065685,
                "creation_date": 1693056221,
                "answer_id": 76983168,
                "question_id": 76982456,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Something like this?\r\n\r\n```\r\n.data.repository\r\n| .nameWithOwner as $repo\r\n| .milestones.nodes\r\n| map( # create a new array containing the milestones\r\nselect(.progressPercentage == 100) | select(.title | contains(&quot;withdrawn&quot;) | not) | select(.issues.nodes | length &gt; 0) # filter interesting milestone nodes\r\n  | {\r\n    (.title | splits(&quot;,? &quot;)): [ # one object per title part, each object containing an array\r\n        { $repo, milestone: .number } # base milestone data, plus …\r\n        + (.issues.nodes[] | {\r\n          issue: .number,\r\n          labels: [.labels.nodes[].name] # collect all label names in an array\r\n        })\r\n    ]\r\n  })\r\n| add # merge all objects of the array into a single object\r\n```\r\n\r\nMight not be the most efficient solution compared to a reduce-based approach (creates intermediate arrays), but can be easily followed and divided into &quot;logical&quot; parts.\r\n\r\nRun with plain jq (no slurping, there&#39;s only a single top-level element)\r\n\r\nOutput with the example data from the question:\r\n\r\n```\r\n{\r\n  &quot;C.1&quot;: [\r\n    {\r\n      &quot;repo&quot;: &quot;cov-lineages/pango-designation&quot;,\r\n      &quot;milestone&quot;: 1,\r\n      &quot;issue&quot;: 2,\r\n      &quot;labels&quot;: [\r\n        &quot;proposed&quot;,\r\n        &quot;designated&quot;\r\n      ]\r\n    }\r\n  ],\r\n  &quot;EXAMPLE_SPLIT&quot;: [\r\n    {\r\n      &quot;repo&quot;: &quot;cov-lineages/pango-designation&quot;,\r\n      &quot;milestone&quot;: 1,\r\n      &quot;issue&quot;: 2,\r\n      &quot;labels&quot;: [\r\n        &quot;proposed&quot;,\r\n        &quot;designated&quot;\r\n      ]\r\n    }\r\n  ],\r\n  &quot;B.1.429&quot;: [\r\n    {\r\n      &quot;repo&quot;: &quot;cov-lineages/pango-designation&quot;,\r\n      &quot;milestone&quot;: 2,\r\n      &quot;issue&quot;: 3,\r\n      &quot;labels&quot;: [\r\n        &quot;proposed&quot;,\r\n        &quot;designated&quot;\r\n      ]\r\n    }\r\n  ]\r\n}\r\n```\r\n\r\n*****\r\n\r\nIf your input contains multiple objects and you want the final output to be a single object, use `-s` (`--slurp`) in combination with `map(…)`:\r\n\r\n```\r\njq -s &#39;map( # -s reads everything as one big array, `map` transforms the elements of this array\r\n  .data.repository\r\n  | .nameWithOwner as $repo\r\n  | .milestones.nodes\r\n  | map( # create a new array containing the milestones\r\n    select(.progressPercentage == 100) | select(.title | contains(&quot;withdrawn&quot;) | not) | select(.issues.nodes | length &gt; 0) # filter interesting milestone nodes\r\n    | {\r\n      (.title | splits(&quot;,? &quot;)): [ # one object per title part containing an array\r\n          { $repo, milestone: .number } # base milestone data, plus …\r\n          + (.issues.nodes[] | {\r\n            issue: .number,\r\n            labels: [.labels.nodes[].name] # collect all label names in an array\r\n          })\r\n      ]\r\n    }\r\n  )\r\n)\r\n| add # merge all objects of the array into a single object\r\n&#39;\r\n```",
                "title": "Need to modify an existing JQ filter of a GitHub CLI GraphQL response"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1693065685,
        "creation_date": 1693044221,
        "last_edit_date": 1693063674,
        "question_id": 76982456,
        "body_markdown": "I am creating a GitHub Action workflow which will call a [GitHub CLI API request using GraphQL](https://cli.github.com/manual/gh_api). This `gh api graphql` response is `--paginate` and returns JSON Lines (ndjson). \r\n\r\nI created the GraphQL and jq queries, and I am close to the desired output; however, my jq query needs to be modified and I can&#39;t figure out what to change.\r\n\r\nFirst, here is the desired output format I want to achieve. Notice the single object that holds all the key-value lineage information.\r\n```\r\n[\r\n  {\r\n    KEY: VALUE,\r\n    KEY: VALUE,\r\n    ...\r\n  }\r\n]\r\n\r\n```\r\n\r\nAnd here is the actual format of the output that I am getting. Notice that every single key-value information is wrapped within its own object.\r\n```\r\n[\r\n  {\r\n    KEY: VALUE,\r\n  },\r\n  {\r\n    KEY: VALUE,\r\n  },\r\n  ...\r\n]\r\n\r\n```\r\n\r\nHere is [my current jq query filter along with a snippet of the GraphQL response in jq play](https://jqplay.org/s/fZKG5E9OIiG). It contains a snippet of 2 JSON Lines (jsonl, ndjson) entries (pretty printed). Search for `data` to see each individual response.\r\n\r\nI need to `--slurp/-s` my jq query due to the paginated results.\r\n\r\nI want to only include milestones which:\r\n- have 100% progress\r\n- don&#39;t include the word &quot;withdrawn&quot; within the title\r\n- have issues associated with them.\r\n\r\nAlso, if the milestone title contains either ` ` or `, `, then I need to split the title. Each split will be its own key with identical values.\r\n\r\nHere is my jq query that needs to be modified:\r\n```jq\r\n.[] | .data.repository as {\r\n    nameWithOwner: $name, \r\n    milestones: { \r\n        nodes: $milestones\r\n    }\r\n}\r\n| [\r\n    foreach $milestones[] as $milestone (\r\n        null; $milestone ; \r\n        $milestone\r\n        | select($milestone.progressPercentage == 100)\r\n        | select($milestone.title | contains(&quot;withdrawn&quot;) | not)\r\n        | select($milestone.issues.nodes[])\r\n        |\r\n        {\r\n            (($milestone.title | gsub(&quot;, &quot;; &quot; &quot;) | split(&quot; &quot;))[]) : \r\n            [\r\n                foreach $milestone.issues.nodes[] as $issue (\r\n                    {}; . + { $issue };\r\n                    $issue as $issue | $issue\r\n                    | (reduce $issue.labels.nodes[] as $item ([]; . + [$item.name])) as $labels\r\n                    |\r\n                    {\r\n                        repo: $name,\r\n                        issue: $issue.number,\r\n                        milestone: $milestone.number,\r\n                        labels: $labels\r\n                    }\r\n                    \r\n                )\r\n            ]\r\n        }\r\n    )\r\n]\r\n| .\r\n```\r\n\r\nHere is a small JSON snippet which needs to be filtered by jq. It has 2 milestones but will output 3 key-value pairs (keys: `C.1`, `EXAMPLE_SPLIT`, and `B.1.429`):\r\n\r\n```json\r\n{\r\n  &quot;data&quot;: {\r\n    &quot;repository&quot;: {\r\n      &quot;nameWithOwner&quot;: &quot;cov-lineages/pango-designation&quot;,\r\n      &quot;milestones&quot;: {\r\n        &quot;pageInfo&quot;: {\r\n          &quot;hasNextPage&quot;: true,\r\n          &quot;endCursor&quot;: &quot;Y3Vyc29yOnYyOpHOAGviZA==&quot;\r\n        },\r\n        &quot;nodes&quot;: [\r\n          {\r\n            &quot;number&quot;: 1,\r\n            &quot;title&quot;: &quot;C.1, EXAMPLE_SPLIT&quot;,\r\n            &quot;progressPercentage&quot;: 100,\r\n            &quot;issues&quot;: {\r\n              &quot;nodes&quot;: [\r\n                {\r\n                  &quot;number&quot;: 2,\r\n                  &quot;labels&quot;: {\r\n                    &quot;nodes&quot;: [\r\n                      {\r\n                        &quot;name&quot;: &quot;proposed&quot;\r\n                      },\r\n                      {\r\n                        &quot;name&quot;: &quot;designated&quot;\r\n                      }\r\n                    ]\r\n                  }\r\n                }\r\n              ]\r\n            }\r\n          },\r\n          {\r\n            &quot;number&quot;: 2,\r\n            &quot;title&quot;: &quot;B.1.429&quot;,\r\n            &quot;progressPercentage&quot;: 100,\r\n            &quot;issues&quot;: {\r\n              &quot;nodes&quot;: [\r\n                {\r\n                  &quot;number&quot;: 3,\r\n                  &quot;labels&quot;: {\r\n                    &quot;nodes&quot;: [\r\n                      {\r\n                        &quot;name&quot;: &quot;proposed&quot;\r\n                      },\r\n                      {\r\n                        &quot;name&quot;: &quot;designated&quot;\r\n                      }\r\n                    ]\r\n                  }\r\n                }\r\n              ]\r\n            }\r\n          }\r\n        ]\r\n      }\r\n    }\r\n  }\r\n}\r\n```",
        "link": "https://stackoverflow.com/questions/76982456/need-to-modify-an-existing-jq-filter-of-a-github-cli-graphql-response",
        "title": "Need to modify an existing JQ filter of a GitHub CLI GraphQL response"
    },
    {
        "tags": [
            "amazon-web-services",
            "bash",
            "aws-cloudformation",
            "jq",
            "aws-cli"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1693123940,
                "last_edit_date": 1693123940,
                "creation_date": 1693075710,
                "answer_id": 76984372,
                "question_id": 76984135,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Parameter expansion + word/field splitting of your shell is biting you.\r\n\r\n```\r\naws cloudformation deploy --parameter-overrides &quot;$parameter_overrides&quot;\r\n```\r\n\r\nis equivalent to:\r\n\r\n```\r\naws cloudformation deploy --parameter-overrides &#39;key1=value1 key2=value2&#39;\r\n```\r\n\r\nwhich is very different from\r\n\r\n```\r\naws cloudformation deploy --parameter-overrides &#39;key1=value1&#39; &#39;key2=value2&#39;\r\n```\r\n\r\n(1 override vs 2 overrides)\r\n\r\nUnfortunately, that&#39;s how shells expand parameters.\r\n\r\nNot quoting the parameter would perform field splitting, but at the same time, pathname expansion will be performed too, which is going to be problematic if your parameter value contains any of `*`, `?`, `[…]`, or `[^…]`. Additionally, it would be impossible to have keys or values with whitespace in them.\r\n\r\nIf you know your keys, you can define a function and pass multiple evaluations of said function:\r\n\r\n```\r\noverride() {\r\n  jq -r --arg key &quot;$1&quot; &#39;.[] | select(.ParameterKey == $key) | &quot;\\(.ParameterKey)=\\(env[.[1:]] // .ParameterValue)&quot;&#39; myfile.json\r\n}\r\naws cloudformation deploy --parameter-overrides &quot;$(override Key1)&quot; &quot;$(override Key2)&quot;\r\n```\r\n\r\nAlternatively, if you are certain/can guarantee that your keys nor values will never contain line breaks or trailing blanks, the following might work:\r\n\r\n```\r\njq -r &#39;.[] | .ParameterValue |= (env[.[1:]] // .) | [.ParameterKey, .ParameterValue] | join(&quot;=&quot;)&#39; myfile.json \\\r\n| xargs -L10 aws cloudformation deploy --parameter-overrides\r\n```\r\n\r\n`xargs -L10` calls `aws` with at most 10 arguments (each line becomes one argument). Adjust to your requirements.",
                "title": "aws cloudformation deploy and --parameter-overrides syntax"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1693226632,
        "creation_date": 1693071558,
        "last_edit_date": 1693226632,
        "question_id": 76984135,
        "body_markdown": "I&#39;m using aws cli v1 (`aws-cli/1.29.8 Python/3.9.17 Linux/4.14.291-218.527.amzn2.x86_64 exec-env/AWS_ECS_EC2 botocore/1.31.`) within CodeBuild, and reading the [documentation](https://docs.aws.amazon.com/cli/latest/reference/cloudformation/deploy/) for the `--parameter-overrides` that is passed to the `aws cloudformation deploy` command it says:\r\n\r\n\r\n&gt; --parameter-overrides (list) A list of parameter structures that specify input parameters for your stack template. If you&#39;re updating a stack and you don&#39;t specify a parameter, the command uses the stack&#39;s existing value. For new stacks, you must specify parameters that don&#39;t have a default value. Syntax: ParameterKey1=ParameterValue1 ParameterKey2=ParameterValue2 ...(string)\r\n\r\nSo basically, i can just pass the `--parameter-overrides` like:\r\n\r\n```bash\r\n&gt; aws cloudformation deploy --parameter-overrides Key1=value1 Key2=value2\r\n\r\n# or\r\n\r\n&gt; aws cloudformation deploy --parameter-overrides Key1=value1 \\\r\nKey2=value2\r\n\r\n# or\r\n\r\n&gt; aws cloudformation deploy --parameter-overrides \\\r\nKey1=value1 \\\r\nKey2=value2\r\n```\r\n\r\nI understand that I can also quote each `key=value` pair like `&#39;Key1=value1&#39;` (or use double quote).\r\n\r\nI have the following json file for my parameters:\r\n\r\n```json\r\n[\r\n  {\r\n    &quot;ParameterKey&quot;: &quot;Key1&quot;,\r\n    &quot;ParameterValue&quot;: &quot;value1&quot;\r\n  },\r\n  {\r\n    &quot;ParameterKey&quot;: &quot;Key2&quot;,\r\n    &quot;ParameterValue&quot;: &quot;$ENV_VALUE2&quot;\r\n  }\r\n]\r\n\r\n```\r\nBoth Key1 and Key2 are required in my CloudFormation template (have no default value specified)\r\n\r\nI use the following `jq` command to convert to the `--parameter-overrides` syntax:\r\n\r\n```bash\r\n&gt; export ENV_VALUE2=value2\r\n\r\n&gt; parameter_overrides=&quot;$(jq -r &#39;.[] | .ParameterValue |= (env[.[1:]] // .) | [.ParameterKey, .ParameterValue] | join(&quot;=&quot;)&#39; myfile.json)&quot;\r\n\r\n&gt; echo &quot;$parameter_overrides&quot;\r\nKey1=value1\r\nKey2=value2\r\n```\r\n\r\nBut running the command `aws cloudformation deploy --parameter-overrides &quot;$parameter_overrides&quot;` results in the following error:\r\n\r\n```bash\r\nAn error occurred (ValidationError) when calling the CreateChangeSet operation: Parameters: [Key2] must have values\r\n```\r\n\r\nMaybe, this is happening because with the `jq` conversion i don&#39;t have a trailling  `\\` to escape the line break, so I did a few tests.\r\n\r\n**test1**\r\n\r\n```bash\r\n&gt; export parameter_overrides=Key1=value Key2=value2\r\n&gt; aws cloudformation deploy --parameter-overrides &quot;$parameter_overrides&quot;\r\n\r\n&gt; An error occurred (ValidationError) when calling the CreateChangeSet operation: Parameters: [Key2] must have values\r\n```\r\n\r\nThe same happens if i try to export with single and double quotes, like:\r\n\r\n```bash\r\n&gt; export parameter_overrides=&quot;Key1=value Key2=value2&quot;\r\nor\r\n&gt; export parameter_overrides=&#39;Key1=value Key2=value2&#39;\r\n```\r\n\r\n**test2**\r\n\r\n```bash\r\n&gt; export parameter_overrides=&quot;&#39;Key1=value&#39; &#39;Key2=value2&#39;&quot;\r\n&gt; aws cloudformation deploy --parameter-overrides &quot;$parameter_overrides&quot;\r\n\r\n&gt; An error occurred (ValidationError) when calling the CreateChangeSet operation: Parameters: [Key2, Key2] must have values\r\n```\r\n\r\nThe same happens if I swap the quotes.\r\n\r\n**test3**\r\n\r\n```bash\r\n&gt; export parameter_overrides=&quot;&#39;Key1=value Key2=value2&#39;&quot;\r\n&gt; aws cloudformation deploy --parameter-overrides &quot;$parameter_overrides&quot;\r\n\r\n&gt; An error occurred (ValidationError) when calling the CreateChangeSet operation: Parameters: [Key2, Key2] must have values\r\n```\r\n\r\nThe same happens if I swap the quotes.\r\n\r\n**test4**\r\n\r\nAs the last resource, I tried to pass a json string:\r\n\r\n```bash\r\nexport parameter_overrides=&#39;[ &quot;Key1=value1&quot;, &quot;Key2=value2&quot; ]&#39;\r\n```\r\n\r\nAnd the deploy just worked.\r\n\r\nI can change my `jq` command to convert from one format to the other, but I&#39;m really curious why everything other than passing a json string didn&#39;t worked as expected.\r\n\r\nEDITED:\r\n\r\nBased on the answer from @knittl, I&#39;m using the following as a solution:\r\n\r\n```bash\r\nparameter_overrides=$(jq -r &#39;.[] | .ParameterValue |= (env[.[1:]] // .) | [.ParameterKey, .ParameterValue] | join(&quot;=&quot;) | @sh&#39; myfile.json | tr &quot;\\n&quot; &quot; &quot;)\r\n\r\necho &quot;$parameter_overrides&quot; | xargs aws cloudformation deploy \\\r\n    --template-file &#39;my_cfn_stack.yml&#39; \\\r\n    --stack-name &#39;my-stack-name&#39; \\\r\n    --capabilities &#39;CAPABILITY_NAMED_IAM&#39; &#39;CAPABILITY_AUTO_EXPAND&#39; \\\r\n    --no-fail-on-empty-changeset \\\r\n    --parameter-overrides\r\n```\r\n\r\nI just discovered that `jq` have the function/operator `@sh` which will quote the output. Without the `tr`, the result of the `$override_parameters` variable is:\r\n\r\n```bash\r\n&gt; echo &quot;$override_parameters&quot;\r\n&#39;Key1=value1&#39;\r\n&#39;Key2=value2&#39;\r\n```\r\n\r\nUsing the `tr &quot;\\n&quot; &quot; &quot;` results, worked like a charm:\r\n\r\n```bash\r\n&gt; echo &quot;$override_parameters&quot;\r\n&#39;Key1=value1&#39; &#39;Key2=value2&#39;\r\n```\r\n\r\nBut without the `xargs` it still doesn&#39;t works. Thank you @knittl",
        "link": "https://stackoverflow.com/questions/76984135/aws-cloudformation-deploy-and-parameter-overrides-syntax",
        "title": "aws cloudformation deploy and --parameter-overrides syntax"
    },
    {
        "tags": [
            "jq",
            "semantics"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1693076063,
                "creation_date": 1693076063,
                "answer_id": 76984397,
                "question_id": 76984368,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Exactly after posting my question I stumbled over the exact answer in the manual of the developer version. :shrug:\r\n\r\nSo far the manual page for [jq 1.5] says about `//`: \r\n\r\n&gt; A filter of the form `a // b` produces the same results as `a`, if a produces results other than `false` and `null`. Otherwise, `a // b` produces the same results as `b`.\r\n\r\nThe [developer version] says *additionally*:\r\n\r\n&gt; [...]Note: `some_generator // defaults_here` is not the same as `some_generator | . // defaults_here`. The latter will produce default values for all non-`false`, non-`null` values of the left-hand side, while the former will not. [...] In `(false, null, 1) | . // 42` the left-hand side of `//` is `.`, which always produces just one value, while in `(false, null, 1) // 42` the left-hand side is a generator of three values, and since it produces a value other `false` and `null`, the default `42` is not produced.\r\n\r\n\r\n[jq 1.5]: https://jqlang.github.io/jq/manual/v1.5/#alternative-operator\r\n[developer version]: https://jqlang.github.io/jq/manual/#alternative-operator",
                "title": "Strange behaviour of the alternative operator //"
            },
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1693093073,
                "creation_date": 1693093073,
                "answer_id": 76985217,
                "question_id": 76984368,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The 1.5 documentation is, to put it bluntly, just wrong.\r\n\r\nThe [jq FAQ][1] provides this succinct and useful summary:\r\n\r\n```\r\n&quot;A // B&quot; either produces the truthy elements of A if there are any,\r\nor else the entire stream B.\r\n```\r\n\r\n\r\n  [1]: https://github.com/jqlang/jq/wiki/FAQ#or-versus-",
                "title": "Strange behaviour of the alternative operator //"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1729609155,
        "creation_date": 1693075657,
        "last_edit_date": 1729609155,
        "question_id": 76984368,
        "body_markdown": "Using JQ 1.5 I&#39;ve problems understanding the output of the alternative operator `//` in a specific situation.\r\n\r\nGiven this input:\r\n\r\n```json\r\n{\r\n    &quot;a&quot;: 42,\r\n    &quot;b&quot;: false,\r\n    &quot;c&quot;: null\r\n}\r\n```\r\n\r\nI expected the expression `(.a, .b, .c, .d) // -1` to return this:\r\n\r\n```json\r\n42\r\n-1\r\n-1\r\n-1\r\n```\r\n\r\nBut in fact it returns this instead:\r\n\r\n```json\r\n42\r\n```\r\n\r\nIf I replace `//` with another operator like `&lt;` then I indeed get four results instead of just one (the actual results are not important here, just their number):\r\n\r\n```\r\n&gt; jq &#39;(.a, .b, .c, .d) &lt; -1&#39; input.json\r\nfalse\r\ntrue\r\ntrue\r\ntrue\r\n```\r\n\r\n**Note:** The expression `(.a, .b, .c, .d) | . // -1` returns the expected output. This is not the question. I&#39;d like to know why the initial expression does not work.",
        "link": "https://stackoverflow.com/questions/76984368/strange-behaviour-of-the-alternative-operator",
        "title": "Strange behaviour of the alternative operator //"
    },
    {
        "tags": [
            "arrays",
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 3842961,
                    "reputation": 93062,
                    "user_id": 3185459,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/u8EuP.jpg?s=256",
                    "display_name": "RomanPerekhrest",
                    "link": "https://stackoverflow.com/users/3185459/romanperekhrest"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1693079205,
                "post_id": 76984525,
                "comment_id": 135713626,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 5124727,
                    "reputation": 25,
                    "user_id": 4107232,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f2f8b847bef13ce7e68c2d21bdc94dd4?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "dreaminCode",
                    "link": "https://stackoverflow.com/users/4107232/dreamincode"
                },
                "reply_to_user": {
                    "account_id": 3842961,
                    "reputation": 93062,
                    "user_id": 3185459,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/u8EuP.jpg?s=256",
                    "display_name": "RomanPerekhrest",
                    "link": "https://stackoverflow.com/users/3185459/romanperekhrest"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1693079391,
                "post_id": 76984525,
                "comment_id": 135713649,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1693080153,
                "post_id": 76984525,
                "comment_id": 135713727,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 5124727,
                    "reputation": 25,
                    "user_id": 4107232,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f2f8b847bef13ce7e68c2d21bdc94dd4?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "dreaminCode",
                    "link": "https://stackoverflow.com/users/4107232/dreamincode"
                },
                "reply_to_user": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1693080333,
                "post_id": 76984525,
                "comment_id": 135713749,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1450087,
                    "reputation": 12022,
                    "user_id": 1409374,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/97d424fe924f2139812a4a6de1ef6b79?s=256&d=identicon&r=PG",
                    "display_name": "rickhg12hs",
                    "link": "https://stackoverflow.com/users/1409374/rickhg12hs"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1693143263,
                "post_id": 76984525,
                "comment_id": 135718332,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1693205744,
                "last_edit_date": 1693205744,
                "creation_date": 1693080499,
                "answer_id": 76984667,
                "question_id": 76984525,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The following should work:\r\n\r\n    jq &#39;.result[].fields | {&quot;fields&quot;: map(.name), &quot;Brand&quot;: &quot;Kroger&quot;,\r\n        &quot;fruitNames&quot;: map({(.name): .displayName}) | add}&#39; test.json\r\n\r\n\r\n----------\r\n\r\n    {\r\n      &quot;fields&quot;: [\r\n        &quot;apple&quot;,\r\n        &quot;Banana__c&quot;\r\n      ],\r\n      &quot;Brand&quot;: &quot;Kroger&quot;,\r\n      &quot;fruitNames&quot;: {\r\n        &quot;apple&quot;: &quot;Apple&quot;,\r\n        &quot;Banana__c&quot;: &quot;Banana&quot;\r\n      }\r\n    }\r\n\r\n\r\n",
                "title": "jq: format array of objects using map or from_entries"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1693080559,
                "creation_date": 1693080559,
                "answer_id": 76984670,
                "question_id": 76984525,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s one way using `from_entries`:\r\n```sh\r\n.result[].fields | map(.value = .displayName)\r\n| {fields: map(.name), Brand: &quot;Kroger&quot;, fruitNames: from_entries}\r\n```\r\n```json\r\n{\r\n  &quot;fields&quot;: [\r\n    &quot;apple&quot;,\r\n    &quot;Banana__c&quot;\r\n  ],\r\n  &quot;Brand&quot;: &quot;Kroger&quot;,\r\n  &quot;fruitNames&quot;: {\r\n    &quot;apple&quot;: &quot;Apple&quot;,\r\n    &quot;Banana__c&quot;: &quot;Banana&quot;\r\n  }\r\n}\r\n```\r\n[Demo](https://jqplay.org/s/FZ3dpfM5LLP)",
                "title": "jq: format array of objects using map or from_entries"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1693100328,
                "last_edit_date": 1693100328,
                "creation_date": 1693081428,
                "answer_id": 76984713,
                "question_id": 76984525,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Or even another way:\r\n```\r\n.result[].fields |\r\n      {\r\n       &quot;fields&quot;: map(.name),\r\n       &quot;Brand&quot;: &quot;Kroger&quot;,\r\n       &quot;fruitNames&quot;: (reduce .[] as $f ({}; . + {($f.name): $f.displayName}))\r\n      }\r\n```\r\n\r\nTry it on [jqplay.org](https://jqplay.org/s/Gf7PlspL3bK).\r\n",
                "title": "jq: format array of objects using map or from_entries"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 0,
        "last_activity_date": 1693205744,
        "creation_date": 1693078230,
        "last_edit_date": 1693080297,
        "question_id": 76984525,
        "body_markdown": "I have a massive JSON output like this\r\n\r\n    {\r\n        &quot;result&quot;: [\r\n            {\r\n                &quot;name&quot;: &quot;Fields&quot;,\r\n                &quot;listFields&quot;: [\r\n                    [\r\n                        &quot;apple&quot;\r\n                    ],\r\n                    [\r\n                        &quot;Banana__c&quot;\r\n                    ]\r\n                ],                    \r\n                &quot;fields&quot;: [\r\n                    {\r\n                        &quot;name&quot;: &quot;apple&quot;,\r\n                        &quot;displayName&quot;: &quot;Apple&quot;,\r\n                        &quot;color&quot;: &quot;red&quot;,\r\n                        &quot;price&quot;: 20\r\n                    },\r\n                    {\r\n                        &quot;name&quot;: &quot;Banana__c&quot;,\r\n                        &quot;displayName&quot;: &quot;Banana&quot;,\r\n                        &quot;color&quot;: &quot;yellow&quot;,\r\n                        &quot;price&quot;: 18\r\n                    }\r\n                ]\r\n            }\r\n        ],\r\n        &quot;success&quot;: true\r\n    }\r\n\r\nThe desired output would be\r\n\r\n    {\r\n       &quot;fields&quot;: [\r\n          &quot;apple&quot;,\r\n          &quot;Banana__c&quot;\r\n       ],\r\n       &quot;Brand&quot;: &quot;Kroger&quot;,\r\n       &quot;fruitNames&quot;: {\r\n          &quot;apple&quot;: &quot;Apple&quot;,\r\n          &quot;Banana__c&quot;: &quot;Banana&quot;\r\n       }\r\n    }\r\n\r\n`{(.name)[], &quot;Brand&quot;: &quot;Kroger&quot;, &quot;fruitNames&quot; .fields|map({(.name): .displayName})}` \r\nor\r\n `.result[] | (.fields | map({key: &quot;fields.name.\\(.name)&quot;, value}) | from_entries)`\r\nin https://jqplay.org/# throw syntax errors. Helpful manual here: https://jqlang.github.io/jq/manual/v1.5/",
        "link": "https://stackoverflow.com/questions/76984525/jq-format-array-of-objects-using-map-or-from-entries",
        "title": "jq: format array of objects using map or from_entries"
    },
    {
        "tags": [
            "json",
            "shell",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 2809052,
                    "reputation": 32576,
                    "user_id": 2415684,
                    "user_type": "registered",
                    "accept_rate": 88,
                    "profile_image": "https://www.gravatar.com/avatar/e0fb12778bde5d0dddddd3b8b619681b?s=256&d=identicon&r=PG",
                    "display_name": "Rorschach",
                    "link": "https://stackoverflow.com/users/2415684/rorschach"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1693229826,
                "post_id": 76993197,
                "comment_id": 135728897,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 4133101,
                    "reputation": 26568,
                    "user_id": 3390419,
                    "user_type": "registered",
                    "accept_rate": 30,
                    "profile_image": "https://www.gravatar.com/avatar/895c1539b3062a1feadfad9d1d80e8e9?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Paolo",
                    "link": "https://stackoverflow.com/users/3390419/paolo"
                },
                "edited": false,
                "score": 3,
                "creation_date": 1693230319,
                "post_id": 76993197,
                "comment_id": 135729029,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1693231958,
                "creation_date": 1693231958,
                "answer_id": 76993592,
                "question_id": 76993197,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "There&#39;s no need for the `.versions` if you want each components `name` and `version` this is enough:\r\n```\r\n.product[].components[] | &quot;\\(.name): \\(.version)&quot;\r\n```\r\n\r\nOutput\r\n```none\r\nJVM: 11.0.16\r\nTOMCAT: 9.0.56\r\nJVM: 11.0.16\r\nTOMCAT: 9.0.56\r\n```\r\n\r\n\r\n----------\r\n\r\nIf you want to include the `versions` from the product themself, you can loop over the components after showing `.versions`, for example the following filter\r\n```\r\n.product[] | .versions, (.components[] | &quot;\\t\\(.name): \\(.version)&quot;)\r\n```\r\n\r\nOutputs\r\n```none\r\n1.0\r\n\tJVM: 11.0.16\r\n\tTOMCAT: 9.0.56\r\n1.1\r\n\tJVM: 11.0.16\r\n\tTOMCAT: 9.0.56\r\n```\r\n\r\n\r\n----------\r\n\r\nIf you don&#39;t need the string interpolation, `&quot;\\(.name): \\(.version)&quot;` can be replaced with `join(&quot;: &quot;)`, eg:\r\n```none\r\n.product[].components[] | join(&quot;: &quot;)\r\n```",
                "title": "jq with json Cannot index string with string &quot;version&quot;"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1693231958,
        "creation_date": 1693228937,
        "question_id": 76993197,
        "body_markdown": "\r\nSample Json\r\n```\r\n{\r\n  &quot;product&quot;: [\r\n    {\r\n      &quot;versions&quot;: &quot;1.0&quot;,\r\n      &quot;components&quot;: [\r\n        {\r\n          &quot;name&quot;: &quot;JVM&quot;,\r\n          &quot;version&quot;: &quot;11.0.16&quot;\r\n        },\r\n        {\r\n          &quot;name&quot;: &quot;TOMCAT&quot;,\r\n          &quot;version&quot;: &quot;9.0.56&quot;\r\n        }\r\n      ]\r\n    },\r\n    {\r\n      &quot;versions&quot;: &quot;1.1&quot;,\r\n      &quot;components&quot;: [\r\n        {\r\n          &quot;name&quot;: &quot;JVM&quot;,\r\n          &quot;version&quot;: &quot;11.0.16&quot;\r\n        },\r\n        {\r\n          &quot;name&quot;: &quot;TOMCAT&quot;,\r\n          &quot;version&quot;: &quot;9.0.56&quot;\r\n        }\r\n      ]\r\n    }\r\n  ]\r\n}\r\n```\r\n\r\nCommand\r\n\r\n```\r\njq -r &#39;.product[] | .versions, .components[] | &quot;\\(.name): \\(.version)&quot;&#39; version_mapper.json\r\n```\r\n\r\nOutput \r\n\r\n```\r\njq: error (at version_mapper.json:29): Cannot index string with string &quot;version&quot;\r\n```\r\n\r\nWrong Command\r\n```\r\njq -r &#39;.product[] | .wrongKey, .components[] | &quot;\\(.name): \\(.version)&quot;&#39; version_mapper.json\r\n```\r\n\r\nOutput \r\n```\r\nnull: null\r\nJVM: 11.0.16\r\nTOMCAT: 9.0.56\r\nnull: null\r\nJVM: 11.0.16\r\nTOMCAT: 9.0.56\r\n```\r\n\r\nNot sure what is happening ",
        "link": "https://stackoverflow.com/questions/76993197/jq-with-json-cannot-index-string-with-string-version",
        "title": "jq with json Cannot index string with string &quot;version&quot;"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq",
            "aws-cli",
            "jmespath"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 100740,
                    "reputation": 79490,
                    "user_id": 271415,
                    "user_type": "registered",
                    "accept_rate": 91,
                    "profile_image": "https://www.gravatar.com/avatar/8648256cc53b261c5e1d266380a256fc?s=256&d=identicon&r=PG",
                    "display_name": "jarmod",
                    "link": "https://stackoverflow.com/users/271415/jarmod"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1693240159,
                "post_id": 76994251,
                "comment_id": 135731321,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 29237790,
                    "reputation": 13,
                    "user_id": 22400057,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/62b152e484bc1aa35cd48cb56bfad676?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Zak25",
                    "link": "https://stackoverflow.com/users/22400057/zak25"
                },
                "reply_to_user": {
                    "account_id": 100740,
                    "reputation": 79490,
                    "user_id": 271415,
                    "user_type": "registered",
                    "accept_rate": 91,
                    "profile_image": "https://www.gravatar.com/avatar/8648256cc53b261c5e1d266380a256fc?s=256&d=identicon&r=PG",
                    "display_name": "jarmod",
                    "link": "https://stackoverflow.com/users/271415/jarmod"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1693240497,
                "post_id": 76994251,
                "comment_id": 135731396,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 100740,
                    "reputation": 79490,
                    "user_id": 271415,
                    "user_type": "registered",
                    "accept_rate": 91,
                    "profile_image": "https://www.gravatar.com/avatar/8648256cc53b261c5e1d266380a256fc?s=256&d=identicon&r=PG",
                    "display_name": "jarmod",
                    "link": "https://stackoverflow.com/users/271415/jarmod"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1693241251,
                "post_id": 76994251,
                "comment_id": 135731542,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 29237790,
                    "reputation": 13,
                    "user_id": 22400057,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/62b152e484bc1aa35cd48cb56bfad676?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Zak25",
                    "link": "https://stackoverflow.com/users/22400057/zak25"
                },
                "reply_to_user": {
                    "account_id": 100740,
                    "reputation": 79490,
                    "user_id": 271415,
                    "user_type": "registered",
                    "accept_rate": 91,
                    "profile_image": "https://www.gravatar.com/avatar/8648256cc53b261c5e1d266380a256fc?s=256&d=identicon&r=PG",
                    "display_name": "jarmod",
                    "link": "https://stackoverflow.com/users/271415/jarmod"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1693241961,
                "post_id": 76994251,
                "comment_id": 135731651,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 100740,
                    "reputation": 79490,
                    "user_id": 271415,
                    "user_type": "registered",
                    "accept_rate": 91,
                    "profile_image": "https://www.gravatar.com/avatar/8648256cc53b261c5e1d266380a256fc?s=256&d=identicon&r=PG",
                    "display_name": "jarmod",
                    "link": "https://stackoverflow.com/users/271415/jarmod"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1693243382,
                "post_id": 76994251,
                "comment_id": 135731903,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1693249422,
                "creation_date": 1693249422,
                "answer_id": 76995442,
                "question_id": 76994251,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If you&#39;re just trying to sort items in the `IpRanges` fields, you could do this:\r\n\r\n```\r\n.[].IpPermissions[].IpRanges |= sort_by(.CidrIp)\r\n```\r\n\r\nYou should be able to then compare for deep equality. You&#39;ll probably want to do this for all arrays that may be ordered differently.",
                "title": "sort_by function when using AWS CLI for aws ec2 describe-security-groups"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1693249943,
                "creation_date": 1693249943,
                "answer_id": 76995488,
                "question_id": 76994251,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Try this :\r\n\r\n```\r\n#!/bin/bash\r\n\r\nsecurity-groups(){\r\naws ec2 describe-security-groups \\\r\n    --filters Name=&quot;tag:Name&quot;,Values=&quot;$1&quot; \\\r\n    --query &#39;SecurityGroups[].{\r\n    IpPermissions:IpPermissions[].{\r\n                    IpProtocol: IpProtocol,\r\n                    IpRanges: IpRanges[].{CidrIp:CidrIp},\r\n                    FromPort: FromPort,\r\n                    ToPort: ToPort\r\n    },\r\n    IpPermissionsEgress:IpPermissionsEgress[].{\r\n                    IpProtocol: IpProtocol,\r\n                    IpRanges: IpRanges[].{CidrIp:CidrIp},\r\n                    FromPort: FromPort,\r\n                    ToPort: ToPort\r\n    }\r\n    }&#39; \\\r\n    --output json \\\r\n| jq &#39;.[][][].IpRanges |= sort_by(.CidrIp)&#39;\r\n}\r\n\r\nsg=MainSG\r\n\r\nif diff -q &lt;(security-groups $sg) &lt;(security-groups $sg); then\r\n    echo &quot;SAME&quot;\r\nelse\r\n    echo &quot;DIFFERENT&quot;\r\nfi\r\n```\r\n\r\nYou need to adapt shell function `security-groups` in order to get raw data from two different AWS accounts.",
                "title": "sort_by function when using AWS CLI for aws ec2 describe-security-groups"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1693249943,
        "creation_date": 1693237181,
        "last_edit_date": 1693241935,
        "question_id": 76994251,
        "body_markdown": "I am trying to compare 2 security groups in AWS that are in 2 different accounts, using aws ec2 describe-security-groups. Even if the security groups are exactly the same, it&#39;s impossible for me to detect that because the json response is sorted differently in the 2 accounts. \r\n\r\n```\r\nSG_1=$(aws ec2 describe-security-groups \\\r\n--filters Name=&quot;tag:Name&quot;,Values=&quot;MainSG&quot; \\\r\n--query &#39;SecurityGroups[].{\r\nIpPermissions:IpPermissions[].{\r\n\t\t\t\tIpProtocol: IpProtocol,\r\n\t\t\t\tIpRanges: IpRanges[].{CidrIp:CidrIp},\r\n\t\t\t\tFromPort: FromPort,\r\n\t\t\t\tToPort: ToPort\r\n},\r\nIpPermissionsEgress:IpPermissionsEgress[].{\r\n\t\t\t\tIpProtocol: IpProtocol,\r\n\t\t\t\tIpRanges: IpRanges[].{CidrIp:CidrIp},\r\n\t\t\t\tFromPort: FromPort,\r\n\t\t\t\tToPort: ToPort\r\n}\r\n}&#39; \\\r\n--output json)\r\n\r\nSG_2=$(aws ec2 describe-security-groups \\\r\n--filters Name=&quot;tag:Name&quot;,Values=&quot;MainSG&quot; \\\r\n--query &#39;SecurityGroups[].{\r\nIpPermissions:IpPermissions[].{\r\n\t\t\t\tIpProtocol: IpProtocol,\r\n\t\t\t\tIpRanges: IpRanges[].{CidrIp:CidrIp},\r\n\t\t\t\tFromPort: FromPort,\r\n\t\t\t\tToPort: ToPort\r\n},\r\nIpPermissionsEgress:IpPermissionsEgress[].{\r\n\t\t\t\tIpProtocol: IpProtocol,\r\n\t\t\t\tIpRanges: IpRanges[].{CidrIp:CidrIp},\r\n\t\t\t\tFromPort: FromPort,\r\n\t\t\t\tToPort: ToPort\r\n}\r\n}&#39; \\\r\n--output json)\r\n\r\nif &quot;$SG_1&quot; = &quot;$SG_2&quot; ]; then\r\n\techo &quot;SAME&quot;\r\nelse\r\n\techo &quot;DIFFERENT&quot;\r\nfi\r\n```\r\n\r\nThe output for SG_1 is : \r\n\r\n    [\r\n      {\r\n        &quot;IpPermissions&quot;: [\r\n          {\r\n            &quot;IpProtocol&quot;: &quot;-1&quot;,\r\n            &quot;IpRanges&quot;: [\r\n              {\r\n                &quot;CidrIp&quot;: &quot;10.192.55.56/32&quot;\r\n              },\r\n              {\r\n                &quot;CidrIp&quot;: &quot;10.111.11.0/26&quot;\r\n              }\r\n            ],\r\n            &quot;FromPort&quot;: null,\r\n            &quot;ToPort&quot;: null\r\n          },\r\n\r\n\r\nThe output for SG_2 is :\r\n\r\n    [\r\n      {\r\n        &quot;IpPermissions&quot;: [\r\n          {\r\n            &quot;IpProtocol&quot;: &quot;-1&quot;,\r\n            &quot;IpRanges&quot;: [\r\n              {\r\n                &quot;CidrIp&quot;: &quot;10.111.11.0/26&quot;\r\n              },\r\n              {\r\n                &quot;CidrIp&quot;: &quot;10.192.55.56/32&quot;\r\n              }\r\n            ],\r\n            &quot;FromPort&quot;: null,\r\n            &quot;ToPort&quot;: null\r\n          },\r\n\r\nI have tried to use jq but the response is still sorted differently.\r\nHere is the jq command I have tried to use : \r\n\r\n```\r\njq &#39;.[0].IpPermissions |= sort_by(.IpRanges[].CidrIp) | .[0].IpPermissionsEgress |= sort_by(.IpRanges[].CidrIp)&#39;)\r\n```\r\n\r\nI have also tried something simple : \r\n\r\n    aws ec2 describe-security-groups --query &#39;sort_by(SecurityGroups, &amp;CidrIp)[].{CidrIp: CidrIp}&#39;\r\n\r\nIn function sort_by(), invalid type for value:\r\nexpected one of: [&#39;string&#39;, &#39;number&#39;], received: &quot;null&quot;\r\n\r\n",
        "link": "https://stackoverflow.com/questions/76994251/sort-by-function-when-using-aws-cli-for-aws-ec2-describe-security-groups",
        "title": "sort_by function when using AWS CLI for aws ec2 describe-security-groups"
    },
    {
        "tags": [
            "linux",
            "bash",
            "curl",
            "sh",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 32384,
                    "reputation": 127026,
                    "user_id": 89817,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/df253c3b6533949ea94f31f328f3e769?s=256&d=identicon&r=PG",
                    "display_name": "Gordon Davisson",
                    "link": "https://stackoverflow.com/users/89817/gordon-davisson"
                },
                "edited": false,
                "score": 4,
                "creation_date": 1693248387,
                "post_id": 76995284,
                "comment_id": 135732827,
                "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": 1,
                "creation_date": 1693248474,
                "post_id": 76995284,
                "comment_id": 135732839,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1693253360,
                "last_edit_date": 1693253360,
                "creation_date": 1693249634,
                "answer_id": 76995460,
                "question_id": 76995284,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The error message is definitely that you feed `jq` with non-valid JSON.\r\n\r\nYou have two possible errors (or both):\r\n\r\n1. You convert the `curl` output to a non-JSON string with `jq -r`\r\n\r\n2. `echo` interprets the C-style escape sequences present in the JSON\r\n\r\nThe following should fix those problems:\r\n\r\n```sh\r\nresponse=$(\r\n    curl -s \\\r\n         -X &#39;POST&#39; \\\r\n         -H &#39;accept: application/json&#39; \\\r\n         &#39;.../api/generated_message/action/generate&#39;\r\n)\r\n\r\nprintf &#39;%s\\n&#39; &quot;$response&quot; | jq\r\n\r\ngenerated_message_id=$(\r\n    printf &#39;%s\\n&#39; &quot;$response&quot; |\r\n    jq -r &#39;.generated_message_id&#39;\r\n)\r\n```",
                "title": "JSON escape CURL/JQ output"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1693251707,
                "creation_date": 1693251707,
                "answer_id": 76995620,
                "question_id": 76995284,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If you don&#39;t need `$response` in the following part of the script, you should do it in a single step :\r\n\r\n```\r\ngenerated_message_id=$(\r\n    curl -s \\\r\n         -X &#39;POST&#39; \\\r\n         -H &#39;accept: application/json&#39; \\\r\n         &#39;.../api/generated_message/action/generate&#39; |\r\n    jq -r &#39;.generated_message_id&#39;\r\n)\r\n```",
                "title": "JSON escape CURL/JQ output"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 2,
        "last_activity_date": 1693253360,
        "creation_date": 1693247572,
        "question_id": 76995284,
        "body_markdown": "From API I get JSON that has a string fields with multiple lines and different escape characters. I try to both output this JSON and get one of it&#39;s values.\r\n\r\nI tried different combinations like this:\r\n\r\n```\r\nresponse=$(curl -s -X &#39;POST&#39; \\\r\n  &quot;.../api/generated_message/action/generate&quot; \\\r\n  -H &#39;accept: application/json&#39; | jq -r .)\r\n\r\necho $response\r\ngenerated_message_id=$(echo $response | jq -r &#39;.generated_message_id&#39;)\r\n```\r\n\r\nHowever, I always get `parse error: Invalid string: control characters from U+0000 through U+001F must be escaped at line 17, column 96`. Seems like I need somehow to get an escaped answer from CURL. ",
        "link": "https://stackoverflow.com/questions/76995284/json-escape-curl-jq-output",
        "title": "JSON escape CURL/JQ output"
    },
    {
        "tags": [
            "json",
            "group-by",
            "aggregate",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1693635240,
                "last_edit_date": 1693635240,
                "creation_date": 1693253579,
                "answer_id": 76995762,
                "question_id": 76995730,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Yes, it is.\r\n\r\n1. Extract all genres into array\r\n2. Group genres\r\n3. Map to a key-value pair (key = any element of the group, we&#39;ll take the first; value = count of elements in the group)\r\n4. Build object from key-value pairs\r\n\r\n```\r\nmap(.genres[].tag)\r\n| group_by(.)\r\n| map({ key:first, value:length })\r\n| from_entries\r\n```\r\n\r\nOutput:\r\n\r\n```\r\n{\r\n  &quot;Drama&quot;: 1,\r\n  &quot;History&quot;: 1,\r\n  &quot;Horror&quot;: 1,\r\n  &quot;Mystery&quot;: 1,\r\n  &quot;Thriller&quot;: 2,\r\n  &quot;War&quot;: 1\r\n}\r\n```\r\n\r\n*****\r\n\r\nAlternatively, use a `reduce` based approach and simply increase a counter:\r\n\r\n```\r\nreduce .[].genres[].tag as $genre ({}; .[$genre] += 1)\r\n```\r\n\r\nThis is likely more efficient than building an array and grouping.\r\n\r\n*****\r\n\r\nTo select only non-null tags, filter through [`values`](https://jqlang.github.io/jq/manual/v1.6/#arrays-objects-iterables-booleans-numbers-normals-finites-strings-nulls-values-scalars):\r\n\r\n```\r\nmap(.genres[].tag | values)\r\n| group_by(.)\r\n| map({ key:first, value:length })\r\n| from_entries\r\n```\r\n\r\nor\r\n\r\n```\r\nreduce (.[].genres[].tag|values) as $genre ({}; .[$genre] += 1)\r\n```\r\n\r\n`values` is internally defined as `select(. != null)`.",
                "title": "Use jq to count elements based on group by"
            },
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1693255409,
                "creation_date": 1693255409,
                "answer_id": 76995908,
                "question_id": 76995730,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "There is a generic &quot;bag of words&quot; function that makes it easy to solve this task efficiently:\r\n```\r\ndef bow(stream): \r\n  reduce stream as $word ({}; .[($word|tostring)] += 1);\r\n```\r\n\r\nWith this arrow in your quiver, there are many ways to solve the specific problem at hand.  Here&#39;s one that assumes all .tag values are relevant:\r\n\r\n    bow(.. | objects | .tag // empty)",
                "title": "Use jq to count elements based on group by"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1693635240,
        "creation_date": 1693253130,
        "last_edit_date": 1693598820,
        "question_id": 76995730,
        "body_markdown": "I have a list of movies like this:\r\n\r\n```json\r\n[\r\n   {\r\n      &quot;title&quot;:&quot;X&quot;,\r\n      &quot;genres&quot;:[\r\n         {\r\n            &quot;tag&quot;:&quot;Horror&quot;\r\n         },\r\n         {\r\n            &quot;tag&quot;:&quot;Thriller&quot;\r\n         },\r\n         {\r\n            &quot;tag&quot;:&quot;Mystery&quot;\r\n         }\r\n      ]\r\n   },\r\n   {\r\n      &quot;title&quot;:&quot;Zero Dark Thirty&quot;,\r\n      &quot;genres&quot;:[\r\n         {\r\n            &quot;tag&quot;:&quot;Thriller&quot;\r\n         },\r\n         {\r\n            &quot;tag&quot;:&quot;Drama&quot;\r\n         },\r\n         {\r\n            &quot;tag&quot;:&quot;History&quot;\r\n         },\r\n         {\r\n            &quot;tag&quot;:&quot;War&quot;\r\n         }\r\n      ]\r\n   }\r\n]\r\n```\r\n\r\nI want to query all unique genres and count the number of movies, where the output looks like this:\r\n\r\n```json\r\n{\r\n   &quot;Horror&quot;:1,\r\n   &quot;Thriller&quot;:2,\r\n   &quot;Mystery&quot;:1,\r\n   &quot;Drama&quot;:1,\r\n   &quot;History&quot;:1,\r\n   &quot;War&quot;:1\r\n}\r\n```\r\n\r\nIs this possible with `jq`?\r\n\r\nEdit: I also need to be able to handle movies without genres. These can be ignored. For example:\r\n\r\n```json\r\n[\r\n   {\r\n      &quot;title&quot;:&quot;Some movie&quot;,\r\n      &quot;genres&quot;:[\r\n         {\r\n            &quot;tag&quot;: null\r\n         }\r\n      ]\r\n   },\r\n   {\r\n      &quot;title&quot;:&quot;Some other movies&quot;,\r\n      &quot;genres&quot;:[\r\n         {\r\n            &quot;tag&quot;:&quot;Comedy&quot;\r\n         },\r\n         {\r\n            &quot;tag&quot;:&quot;Drama&quot;\r\n         }\r\n      ]\r\n   }\r\n]\r\n```",
        "link": "https://stackoverflow.com/questions/76995730/use-jq-to-count-elements-based-on-group-by",
        "title": "Use jq to count elements based on group by"
    },
    {
        "tags": [
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 39208,
                    "reputation": 267964,
                    "user_id": 112968,
                    "user_type": "registered",
                    "accept_rate": 68,
                    "profile_image": "https://i.sstatic.net/zHTaT.png?s=256",
                    "display_name": "knittl",
                    "link": "https://stackoverflow.com/users/112968/knittl"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1693319644,
                "post_id": 77000924,
                "comment_id": 135743179,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 39208,
                    "reputation": 267964,
                    "user_id": 112968,
                    "user_type": "registered",
                    "accept_rate": 68,
                    "profile_image": "https://i.sstatic.net/zHTaT.png?s=256",
                    "display_name": "knittl",
                    "link": "https://stackoverflow.com/users/112968/knittl"
                },
                "edited": false,
                "score": 4,
                "creation_date": 1693320172,
                "post_id": 77000924,
                "comment_id": 135743312,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 15688806,
                    "reputation": 23,
                    "user_id": 11320597,
                    "user_type": "registered",
                    "profile_image": "https://lh5.googleusercontent.com/-HlRMijOf71c/AAAAAAAAAAI/AAAAAAAAAAc/kc1DgBD_yxQ/s256-rj/photo.jpg",
                    "display_name": "Andr&#233; Letterer",
                    "link": "https://stackoverflow.com/users/11320597/andr%c3%a9-letterer"
                },
                "reply_to_user": {
                    "account_id": 39208,
                    "reputation": 267964,
                    "user_id": 112968,
                    "user_type": "registered",
                    "accept_rate": 68,
                    "profile_image": "https://i.sstatic.net/zHTaT.png?s=256",
                    "display_name": "knittl",
                    "link": "https://stackoverflow.com/users/112968/knittl"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1693344065,
                "post_id": 77000924,
                "comment_id": 135747912,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 39208,
                    "reputation": 267964,
                    "user_id": 112968,
                    "user_type": "registered",
                    "accept_rate": 68,
                    "profile_image": "https://i.sstatic.net/zHTaT.png?s=256",
                    "display_name": "knittl",
                    "link": "https://stackoverflow.com/users/112968/knittl"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1693375241,
                "post_id": 77000924,
                "comment_id": 135750514,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 15688806,
                    "reputation": 23,
                    "user_id": 11320597,
                    "user_type": "registered",
                    "profile_image": "https://lh5.googleusercontent.com/-HlRMijOf71c/AAAAAAAAAAI/AAAAAAAAAAc/kc1DgBD_yxQ/s256-rj/photo.jpg",
                    "display_name": "Andr&#233; Letterer",
                    "link": "https://stackoverflow.com/users/11320597/andr%c3%a9-letterer"
                },
                "reply_to_user": {
                    "account_id": 39208,
                    "reputation": 267964,
                    "user_id": 112968,
                    "user_type": "registered",
                    "accept_rate": 68,
                    "profile_image": "https://i.sstatic.net/zHTaT.png?s=256",
                    "display_name": "knittl",
                    "link": "https://stackoverflow.com/users/112968/knittl"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1693406598,
                "post_id": 77000924,
                "comment_id": 135757174,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 15688806,
                    "reputation": 23,
                    "user_id": 11320597,
                    "user_type": "registered",
                    "profile_image": "https://lh5.googleusercontent.com/-HlRMijOf71c/AAAAAAAAAAI/AAAAAAAAAAc/kc1DgBD_yxQ/s256-rj/photo.jpg",
                    "display_name": "Andr&#233; Letterer",
                    "link": "https://stackoverflow.com/users/11320597/andr%c3%a9-letterer"
                },
                "reply_to_user": {
                    "account_id": 39208,
                    "reputation": 267964,
                    "user_id": 112968,
                    "user_type": "registered",
                    "accept_rate": 68,
                    "profile_image": "https://i.sstatic.net/zHTaT.png?s=256",
                    "display_name": "knittl",
                    "link": "https://stackoverflow.com/users/112968/knittl"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1694426657,
                "post_id": 77000924,
                "comment_id": 135884882,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "is_answered": false,
        "answer_count": 0,
        "score": 0,
        "last_activity_date": 1693343757,
        "creation_date": 1693317853,
        "last_edit_date": 1693343757,
        "question_id": 77000924,
        "body_markdown": "I tried to find an answer but didn&#39;t unfortunately find a good answer.\r\nI am having following json source that I am trying to normalize into one specific field for all values that contain `true` or `false`.\r\nAt the same time there is a special key `e` that I want to copy over to specific keys.\r\n\r\nThat&#39;s the json:\r\n```\r\n{\r\n  &quot;an&quot;: {\r\n    &quot;e&quot;: false\r\n  },\r\n  &quot;at&quot;: {\r\n    &quot;c&quot;: {\r\n      &quot;e&quot;: false\r\n    }\r\n  },\r\n  &quot;b&quot;: {\r\n    &quot;s&quot;: true\r\n  },\r\n  &quot;e&quot;: {\r\n    &quot;d&quot;: true,\r\n    &quot;e&quot;: true,\r\n    &quot;f&quot;: true,\r\n    &quot;n&quot;: true,\r\n    &quot;p&quot;: true,\r\n    &quot;r&quot;: true,\r\n    &quot;s&quot;: true\r\n  },\r\n  &quot;l&quot;: {\r\n    &quot;f&quot;: &quot;info&quot;\r\n  },\r\n  &quot;m&quot;: {\r\n    &quot;b&quot;: true\r\n  },\r\n  &quot;ma&quot;: {\r\n    &quot;mo&quot;: &quot;pov&quot;,\r\n    &quot;s&quot;: true\r\n  },\r\n  &quot;r&quot;: {\r\n    &quot;mo&quot;: &quot;pov&quot;,\r\n    &quot;s&quot;: true\r\n  }\r\n}\r\n```\r\nThat&#39;s the output I am aiming for. The `val` key should be basically in the second hierarchy at the same place. The keys and values have been basically anonymized.\r\n```\r\n{\r\n  &quot;an&quot;: {\r\n    &quot;e&quot;: false,\r\n    &quot;val&quot;: false\r\n  },\r\n  &quot;at&quot;: {\r\n    &quot;c&quot;: {\r\n      &quot;e&quot;: false\r\n    },\r\n    &quot;val&quot;: false\r\n  },\r\n  &quot;b&quot;: {\r\n    &quot;s&quot;: true,\r\n    &quot;val&quot;: true\r\n  },\r\n  &quot;e&quot;: {\r\n    &quot;d&quot;: true,\r\n    &quot;e&quot;: true,\r\n    &quot;f&quot;: true,\r\n    &quot;n&quot;: true,\r\n    &quot;p&quot;: true,\r\n    &quot;r&quot;: true,\r\n    &quot;s&quot;: true\r\n  },\r\n  &quot;ed&quot;: {\r\n    &quot;val&quot;: true\r\n  },\r\n  &quot;ee&quot;:{\r\n    &quot;val&quot;: true\r\n  },\r\n  &quot;ef&quot;: {\r\n    &quot;val&quot;: true\r\n  },\r\n  &quot;en&quot;: {\r\n    &quot;val&quot;: true\r\n  },\r\n  &quot;ep&quot;: {\r\n    &quot;val&quot;: true\r\n  },\r\n  &quot;er&quot;: {\r\n    &quot;val&quot;: true\r\n  },\r\n  &quot;es&quot;: {\r\n    &quot;val&quot;: true\r\n  },\r\n  &quot;l&quot;: {\r\n    &quot;f&quot;: &quot;info&quot;\r\n  },\r\n  &quot;m&quot;: {\r\n    &quot;b&quot;: true,\r\n    &quot;val&quot;: true\r\n  },\r\n  &quot;ma&quot;: {\r\n    &quot;mo&quot;: &quot;pov&quot;,\r\n    &quot;s&quot;: true,\r\n    &quot;val&quot;: true\r\n  },\r\n  &quot;r&quot;: {\r\n    &quot;mo&quot;: &quot;pov&quot;,\r\n    &quot;s&quot;: true,\r\n    &quot;val&quot;: true\r\n  }\r\n}\r\n```\r\n\r\nI basically wanted to collect these fields all into a val field on the same place.&lt;br /&gt;\r\nMaybe this breakdown would help to make that more clear&lt;br /&gt;\r\n```\r\n  &quot;an&quot;: {\r\n    &quot;e&quot;: false\r\n  },\r\n```\r\nto\r\n```\r\n  &quot;an&quot;: {\r\n    &quot;e&quot;: false,\r\n    &quot;val&quot;: false\r\n\r\n  },\r\n```\r\nshould be copied the field value from `an.e` to `an.val`:&lt;br /&gt;\r\n```\r\n  &quot;an&quot;: {\r\n    &quot;e&quot;: false\r\n  },\r\n```\r\nSame for keys &lt;br /&gt;\r\n  `at.c.e` to `at.val`&lt;br /&gt;\r\n  `b.s` to `b.val`&lt;br /&gt;\r\n  `m.b` to `m.val`&lt;br /&gt;\r\n  `ma.s` to `ma.val`&lt;br /&gt;\r\n  `r.s` to `r.val`&lt;br /&gt;\r\nkey `f` doesn&#39;t contain a subfield contaning `true` or `false`&lt;br /&gt;\r\nkey `e` has the issue the it contains multiple subfields with `true`&lt;br /&gt; or `false`&lt;br /&gt;\r\nThat&#39;s why following copy scheme basically merged main and subkey together:&lt;br /&gt;\r\n  `e.d` to `ed.val`&lt;br /&gt;\r\n  `e.e` to `ee.val`&lt;br /&gt;\r\n  `e.f` to `ef.val`&lt;br /&gt;\r\n  `e.n` to `en.val`&lt;br /&gt;\r\n  `e.p` to `ep.val`&lt;br /&gt;\r\n  `e.r` to `er.val`&lt;br /&gt;\r\n  `e.s` to `es.val`&lt;br /&gt;\r\nHope that helps for clarification.&lt;br /&gt;\r\n&lt;br /&gt;\r\n\r\nThanks a lot.",
        "link": "https://stackoverflow.com/questions/77000924/jq-copy-fields-from-multiple-source-fields-down-to-one-field",
        "title": "jq copy fields from multiple source fields down to one field"
    },
    {
        "tags": [
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 39208,
                    "reputation": 267964,
                    "user_id": 112968,
                    "user_type": "registered",
                    "accept_rate": 68,
                    "profile_image": "https://i.sstatic.net/zHTaT.png?s=256",
                    "display_name": "knittl",
                    "link": "https://stackoverflow.com/users/112968/knittl"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1693375433,
                "post_id": 77004829,
                "comment_id": 135750539,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2702639,
                    "reputation": 4867,
                    "user_id": 2333021,
                    "user_type": "registered",
                    "accept_rate": 70,
                    "profile_image": "https://www.gravatar.com/avatar/46a7056aa498c93ef3e4819d4967a847?s=256&d=identicon&r=PG",
                    "display_name": "Christopher Rucinski",
                    "link": "https://stackoverflow.com/users/2333021/christopher-rucinski"
                },
                "reply_to_user": {
                    "account_id": 39208,
                    "reputation": 267964,
                    "user_id": 112968,
                    "user_type": "registered",
                    "accept_rate": 68,
                    "profile_image": "https://i.sstatic.net/zHTaT.png?s=256",
                    "display_name": "knittl",
                    "link": "https://stackoverflow.com/users/112968/knittl"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1693377086,
                "post_id": 77004829,
                "comment_id": 135750766,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1693377897,
                "post_id": 77004829,
                "comment_id": 135750872,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 39208,
                    "reputation": 267964,
                    "user_id": 112968,
                    "user_type": "registered",
                    "accept_rate": 68,
                    "profile_image": "https://i.sstatic.net/zHTaT.png?s=256",
                    "display_name": "knittl",
                    "link": "https://stackoverflow.com/users/112968/knittl"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1693377942,
                "post_id": 77004829,
                "comment_id": 135750880,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2702639,
                    "reputation": 4867,
                    "user_id": 2333021,
                    "user_type": "registered",
                    "accept_rate": 70,
                    "profile_image": "https://www.gravatar.com/avatar/46a7056aa498c93ef3e4819d4967a847?s=256&d=identicon&r=PG",
                    "display_name": "Christopher Rucinski",
                    "link": "https://stackoverflow.com/users/2333021/christopher-rucinski"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1693386846,
                "post_id": 77004829,
                "comment_id": 135752618,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 39208,
                    "reputation": 267964,
                    "user_id": 112968,
                    "user_type": "registered",
                    "accept_rate": 68,
                    "profile_image": "https://i.sstatic.net/zHTaT.png?s=256",
                    "display_name": "knittl",
                    "link": "https://stackoverflow.com/users/112968/knittl"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1693394578,
                "post_id": 77004829,
                "comment_id": 135754259,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "is_answered": false,
        "answer_count": 0,
        "score": 0,
        "last_activity_date": 1693366429,
        "creation_date": 1693366429,
        "question_id": 77004829,
        "body_markdown": "I am in the process of needing to pass the contents of 2 JSON files through a jq query. I wasn&#39;t exactly sure how to create the jq filter at first due to being uncertain how the input would look like. In fact, I was going to submit an issue to jq play to allow for multiple inputs, until I realized this might already be allowed.\r\n\r\nSo I made the decision that the input from different files would basically be JSON Lines (ndjson) input. Something like the following, which should emulate 2 JSON files, I believe.\r\n\r\n```json\r\n{\r\n  KEY1: [VALUE1, VALUE2],\r\n  KEY2: [VALUE3]\r\n}\r\n{\r\n  KEY1: [VALUE4],\r\n  KEY3: [VALUE5]\r\n}\r\n```\r\n\r\nFrom there I started to build my jq filter (which assumes the above format). This filter correctly merges the two files together.\r\n\r\n```jq\r\n[inputs | to_entries | sort] | add\r\n| map(.value[] + {&quot;lineage&quot;: .key})\r\n| group_by(.lineage) | add | unique | sort_by(.repo, .issue)\r\n| group_by(.lineage)\r\n| map({(.[].lineage) : [.[] | del(.lineage)]}) | add \r\n```\r\nHere is a more detail set of input: https://jqplay.org/s/Tle2W8PIgQj\r\n\r\nNow, I am stuck figuring out whether I made the right assumption above and how to correctly input the 2 files into the jq command\r\n\r\nThere seem to be several different ways to do this, and so far all seem to fail for me. Here is the latest version I have tried (this is implemented within GitHub Actions)\r\n```\r\njq --null-input --raw-inputs \\\r\n  &lt;filter&gt; \\\r\n  mappings.json ${owner}_${repository}.json |\r\n  &gt; merged.json\r\n```\r\n\r\nBoth `mappings.json` and the file `${owner}_${repository}.json` have their content pretty printed in each file.\r\n\r\nBut I am getting the following error\r\n```\r\njq: error (at mappings.json:1): string (&quot;{&quot;) has no keys\r\n```\r\nWhen I look at the content of `mappings.json`, it is a valid json structure without additional quotes\r\n\r\nSo I am wondering what the correct way of inputting file content for use with the built-in `inputs`. And was I correct in my way of emulating 2 input files when building my jq filter? My current hypothesis is that my assumption was wrong, and that is why my actual jq command is erroring.",
        "link": "https://stackoverflow.com/questions/77004829/how-to-emulate-multiple-jq-inputs-while-developing-filters-to-seamlessly-allow-m",
        "title": "How to emulate multiple jq inputs while developing filters to seamlessly allow multiple files as inputs"
    },
    {
        "tags": [
            "json",
            "amazon-web-services",
            "jq",
            "fromjson"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 1042959,
                    "reputation": 668672,
                    "user_id": 1048572,
                    "user_type": "registered",
                    "accept_rate": 77,
                    "profile_image": "https://www.gravatar.com/avatar/7f2c4de95e8f4f8f5a71c3aaf0ed312a?s=256&d=identicon&r=PG",
                    "display_name": "Bergi",
                    "link": "https://stackoverflow.com/users/1048572/bergi"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1693371583,
                "post_id": 77004832,
                "comment_id": 135750138,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 5348104,
                    "reputation": 82,
                    "user_id": 4263059,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/05d55faba7130d0fd455ee025d558dbd?s=256&d=identicon&r=PG",
                    "display_name": "Matt",
                    "link": "https://stackoverflow.com/users/4263059/matt"
                },
                "reply_to_user": {
                    "account_id": 1042959,
                    "reputation": 668672,
                    "user_id": 1048572,
                    "user_type": "registered",
                    "accept_rate": 77,
                    "profile_image": "https://www.gravatar.com/avatar/7f2c4de95e8f4f8f5a71c3aaf0ed312a?s=256&d=identicon&r=PG",
                    "display_name": "Bergi",
                    "link": "https://stackoverflow.com/users/1048572/bergi"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1693375430,
                "post_id": 77004832,
                "comment_id": 135750537,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 39208,
                    "reputation": 267964,
                    "user_id": 112968,
                    "user_type": "registered",
                    "accept_rate": 68,
                    "profile_image": "https://i.sstatic.net/zHTaT.png?s=256",
                    "display_name": "knittl",
                    "link": "https://stackoverflow.com/users/112968/knittl"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1693375502,
                "post_id": 77004832,
                "comment_id": 135750550,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1693371523,
                "creation_date": 1693371523,
                "answer_id": 77005088,
                "question_id": 77004832,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can use the [`fromjson` function](https://jqlang.github.io/jq/manual/#convert-to-from-json) for parsing JSON-encoded values. In your case, that would be\r\n\r\n    jq &#39;.Messages | .[] | .Body | fromjson&#39;",
                "title": "JQ parsing of escaped quotes"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1693393075,
        "creation_date": 1693366471,
        "last_edit_date": 1693393075,
        "question_id": 77004832,
        "body_markdown": "We have an AWS autoscaling lifecycle hook that is placing messages on an SQS queue.  We are trying to parse these with JQ, and while the format is mostly JSON, all the key/value pairs within the body object have escaped double quotes.  Can&#39;t seem to find an AWS option to not escape the quotes, or a JQ option to successfully parse them.  Example here:\r\n\r\n        {\r\n        &quot;Messages&quot;: [\r\n            {\r\n                &quot;Body&quot;: &quot;{\r\n    \\&quot;Origin\\&quot;:\\&quot;AutoScalingGroup\\&quot;,\r\n    \\&quot;LifecycleHookName\\&quot;:\\&quot;termination_lifecycle_hook\\&quot;,\r\n    \\&quot;Destination\\&quot;:\\&quot;EC2\\&quot;,\r\n    \\&quot;AccountId\\&quot;:\\&quot;&lt;redacted&gt;\\&quot;,\r\n    \\&quot;RequestId\\&quot;:\\&quot;65e1eaeb-1bde-42ef-93b5-ac14987a2848\\&quot;,\r\n    \\&quot;LifecycleTransition\\&quot;:\\&quot;autoscaling:EC2_INSTANCE_TERMINATING\\&quot;,\r\n    \\&quot;AutoScalingGroupName\\&quot;:\\&quot;test-um-prod-20230822043811258400000005\\&quot;,\r\n    \\&quot;Service\\&quot;:\\&quot;AWS Auto Scaling\\&quot;,\r\n    \\&quot;Time\\&quot;:\\&quot;2023-08-29T20:42:36.581Z\\&quot;,\r\n    \\&quot;EC2InstanceId\\&quot;:\\&quot;i-02ca28b1a415a4d48\\&quot;,\r\n    \\&quot;LifecycleActionToken\\&quot;:\\&quot;1e7f23b9-4a9a-4cad-9051-6039d815e9b1\\&quot;\r\n    }&quot;,\r\n                &quot;ReceiptHandle&quot;: &quot;AQEBN8E7SCNS44lemWqlfMVvOl9EfGo7Yb5b+VhF5jXlw2i41pwQJFvfaAFwBEquO8SOsGyaIUfFiE9qEUQoQOgyUoz5a+Rx/yD9jq2qfz/gRcSwhfCAPHyBvhjJdIGmlyKtNnTzuL183Wti4BO4G+Z7bLzn/WiIT+JrSfn/VofI34HnB0w0Om3UYTnd6OoXuCu2WxzasyMeFcImuCYdt+5+tMzauEtsL7EVdSZwpW3S4oatkuxfzzyxHsP4X0IIKt6fwIzHzCRhi9kmo5QnZAQCnjHo+RBNZXWU9wbk3SToE3nCdLJhbups5SOHAUHLO1PwdVb7RvKMmYYdHfzoTQBLeWJ1w7MEMrhANC9uOu7cVzS0hAAc9qPLzzoV1TkIBn/0Q597cl6dNyfkWpPQEOKtUg==&quot;, \r\n                &quot;MD5OfBody&quot;: &quot;fa2bc63f28d96c532288b09831a8b73f&quot;, \r\n                &quot;MessageId&quot;: &quot;4c5b0c2c-9085-4bde-8de3-49ae3f63afd4&quot;\r\n            }\r\n        ]\r\n    }\r\n\r\nAs you can see, all objects except &quot;Body&quot; are fine, but all the key/values within &quot;Body&quot; are escaped.",
        "link": "https://stackoverflow.com/questions/77004832/jq-parsing-of-escaped-quotes",
        "title": "JQ parsing of escaped quotes"
    },
    {
        "tags": [
            "json",
            "shell",
            "command-line-interface",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 1450087,
                    "reputation": 12022,
                    "user_id": 1409374,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/97d424fe924f2139812a4a6de1ef6b79?s=256&d=identicon&r=PG",
                    "display_name": "rickhg12hs",
                    "link": "https://stackoverflow.com/users/1409374/rickhg12hs"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1693454479,
                "post_id": 77012572,
                "comment_id": 135763941,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1450087,
                    "reputation": 12022,
                    "user_id": 1409374,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/97d424fe924f2139812a4a6de1ef6b79?s=256&d=identicon&r=PG",
                    "display_name": "rickhg12hs",
                    "link": "https://stackoverflow.com/users/1409374/rickhg12hs"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1693455246,
                "post_id": 77012572,
                "comment_id": 135763979,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 17939587,
                    "reputation": 107,
                    "user_id": 13035171,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/8bf123429e4133c94eac4b4c7ed3f896?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Evadore",
                    "link": "https://stackoverflow.com/users/13035171/evadore"
                },
                "reply_to_user": {
                    "account_id": 1450087,
                    "reputation": 12022,
                    "user_id": 1409374,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/97d424fe924f2139812a4a6de1ef6b79?s=256&d=identicon&r=PG",
                    "display_name": "rickhg12hs",
                    "link": "https://stackoverflow.com/users/1409374/rickhg12hs"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1693457070,
                "post_id": 77012572,
                "comment_id": 135764108,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1450087,
                    "reputation": 12022,
                    "user_id": 1409374,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/97d424fe924f2139812a4a6de1ef6b79?s=256&d=identicon&r=PG",
                    "display_name": "rickhg12hs",
                    "link": "https://stackoverflow.com/users/1409374/rickhg12hs"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1693457506,
                "post_id": 77012572,
                "comment_id": 135764136,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 17939587,
                    "reputation": 107,
                    "user_id": 13035171,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/8bf123429e4133c94eac4b4c7ed3f896?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Evadore",
                    "link": "https://stackoverflow.com/users/13035171/evadore"
                },
                "reply_to_user": {
                    "account_id": 1450087,
                    "reputation": 12022,
                    "user_id": 1409374,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/97d424fe924f2139812a4a6de1ef6b79?s=256&d=identicon&r=PG",
                    "display_name": "rickhg12hs",
                    "link": "https://stackoverflow.com/users/1409374/rickhg12hs"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1693458848,
                "post_id": 77012572,
                "comment_id": 135764240,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 39208,
                    "reputation": 267964,
                    "user_id": 112968,
                    "user_type": "registered",
                    "accept_rate": 68,
                    "profile_image": "https://i.sstatic.net/zHTaT.png?s=256",
                    "display_name": "knittl",
                    "link": "https://stackoverflow.com/users/112968/knittl"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1693461742,
                "post_id": 77012572,
                "comment_id": 135764547,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1693465390,
                "last_edit_date": 1693465390,
                "creation_date": 1693462072,
                "answer_id": 77013185,
                "question_id": 77012572,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "A simple solution is readily obtained if the following stream-oriented &quot;coalesce&quot; function is used:\r\n```\r\n# s is assumed to be a stream of objects for which\r\n# the values for each distinct key are summable.\r\n# Output: a single object formed by adding \r\n# the $v values of each distinct key.\r\ndef coalesce(s):\r\n  reduce (s | to_entries[]) as {key: $k, value: $v} ({};\r\n    .[$k] += $v);\r\n```\r\nThe solution is now simply:\r\n```\r\ncoalesce(to_entries[]\r\n         | .key as $key\r\n         | .value[]\r\n         | {(.name): {($key): .value}})\r\n| {output: [.]}\r\n```",
                "title": "How to group json objects by using keys of sub value objects using jq"
            },
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1693471363,
                "last_edit_date": 1693471363,
                "creation_date": 1693463007,
                "answer_id": 77013286,
                "question_id": 77012572,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "It doesn&#39;t win a beauty contest, but it works:\r\n\r\n```\r\nwith_entries(.value |= from_entries)\r\n| with_entries(.key as $key | .value[] |= {($key):.})\r\n| reduce .[] as $item ({}; . * $item)\r\n| {output: to_entries | map({(.key):.value})}\r\n```\r\n\r\nWith a single call to `with_entries`:\r\n\r\n```\r\nwith_entries(.key as $key | .value |= (from_entries | map_values({($key):.})))\r\n| reduce .[] as $item ({}; . * $item)\r\n| {output: to_entries | map({(.key):.value})}\r\n```\r\n\r\nOutput:\r\n\r\n```\r\n{\r\n  &quot;output&quot;: [\r\n    {\r\n      &quot;var1&quot;: {\r\n        &quot;hello&quot;: &quot;1234&quot;,\r\n        &quot;hi&quot;: &quot;3412&quot;,\r\n        &quot;bye&quot;: &quot;1294&quot;\r\n      }\r\n    },\r\n    {\r\n      &quot;var2&quot;: {\r\n        &quot;hello&quot;: &quot;2356&quot;,\r\n        &quot;hi&quot;: &quot;2563&quot;,\r\n        &quot;bye&quot;: &quot;8356&quot;\r\n      }\r\n    },\r\n    {\r\n      &quot;var3&quot;: {\r\n        &quot;hello&quot;: &quot;2356&quot;,\r\n        &quot;hi&quot;: &quot;4256&quot;,\r\n        &quot;bye&quot;: &quot;5356&quot;\r\n      }\r\n    }\r\n  ]\r\n}\r\n```",
                "title": "How to group json objects by using keys of sub value objects using jq"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1693468976,
                "creation_date": 1693468976,
                "answer_id": 77013900,
                "question_id": 77012572,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "This generates what&#39;s expected :\r\n\r\n```\r\n{ output:\r\n    to_entries |\r\n    map(.key as $key|.value|map(.nn=.name|.name=$key)) |\r\n    add |\r\n    group_by(.nn) |\r\n    map({(first|.nn) : from_entries})\r\n}\r\n```",
                "title": "How to group json objects by using keys of sub value objects using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 1,
        "last_activity_date": 1693471363,
        "creation_date": 1693449989,
        "last_edit_date": 1693458784,
        "question_id": 77012572,
        "body_markdown": "I have a json file in the format\r\n\r\n```\r\n{\r\n  &quot;hello&quot;: [\r\n    {\r\n      &quot;name&quot;: &quot;var1&quot;,\r\n      &quot;value&quot;: &quot;1234&quot;\r\n    },\r\n    {\r\n      &quot;name&quot;: &quot;var2&quot;,\r\n      &quot;value&quot;: &quot;2356&quot;\r\n    },\r\n    {\r\n      &quot;name&quot;: &quot;var3&quot;,\r\n      &quot;value&quot;: &quot;2356&quot;\r\n    }\r\n  ],\r\n  &quot;hi&quot;: [\r\n    {\r\n      &quot;name&quot;: &quot;var1&quot;,\r\n      &quot;value&quot;: &quot;3412&quot;\r\n    },\r\n    {\r\n      &quot;name&quot;: &quot;var2&quot;,\r\n      &quot;value&quot;: &quot;2563&quot;\r\n    },\r\n    {\r\n      &quot;name&quot;: &quot;var3&quot;,\r\n      &quot;value&quot;: &quot;4256&quot;\r\n    }\r\n  ],\r\n  &quot;bye&quot;: [\r\n    {\r\n      &quot;name&quot;: &quot;var1&quot;,\r\n      &quot;value&quot;: &quot;1294&quot;\r\n    },\r\n    {\r\n      &quot;name&quot;: &quot;var2&quot;,\r\n      &quot;value&quot;: &quot;8356&quot;\r\n    },\r\n    {\r\n      &quot;name&quot;: &quot;var3&quot;,\r\n      &quot;value&quot;: &quot;5356&quot;\r\n    }\r\n  ]\r\n}\r\n```\r\n\r\nI want to convert this object into this format\r\n\r\n```\r\n{\r\n  &quot;output&quot;: [\r\n    {\r\n      &quot;var1&quot;: {\r\n        &quot;hello&quot;: &quot;1234&quot;,\r\n        &quot;hi&quot;: &quot;3412&quot;,\r\n        &quot;bye&quot;: &quot;1294&quot;\r\n      }\r\n    },\r\n    {\r\n      &quot;var2&quot;: {\r\n        &quot;hello&quot;: &quot;2356&quot;,\r\n        &quot;hi&quot;: &quot;2563&quot;,\r\n        &quot;bye&quot;: &quot;8356&quot;\r\n      }\r\n    },\r\n    {\r\n      &quot;var3&quot;: {\r\n        &quot;hello&quot;: &quot;2356&quot;,\r\n        &quot;hi&quot;: &quot;4256&quot;,\r\n        &quot;bye&quot;: &quot;5356&quot;\r\n      }\r\n    }\r\n  ]\r\n}\r\n```\r\n\r\n\r\n\r\nso far i&#39;ve tried multiple ways using to_entries and map functions in jq to create the contents inside the output variable\r\n`jq &#39;to_entries | map(.value[]| . += {&quot;key_v&quot; : (.key)} )&#39; input.json &gt; output.json` this is the closest i came to a solution \r\n- extracting keys and add to the key value pair of the object\r\n- use map(select()) to group by keys \r\nbut i am getting errors in both the steps such as cannot index array with string name or string value.",
        "link": "https://stackoverflow.com/questions/77012572/how-to-group-json-objects-by-using-keys-of-sub-value-objects-using-jq",
        "title": "How to group json objects by using keys of sub value objects using jq"
    },
    {
        "tags": [
            "yaml",
            "jq",
            "yq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 6313442,
                    "reputation": 45115,
                    "user_id": 5625547,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/oqCND.jpg?s=256",
                    "display_name": "0stone0",
                    "link": "https://stackoverflow.com/users/5625547/0stone0"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1693495470,
                "post_id": 77017183,
                "comment_id": 135771629,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 6313442,
                    "reputation": 45115,
                    "user_id": 5625547,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/oqCND.jpg?s=256",
                    "display_name": "0stone0",
                    "link": "https://stackoverflow.com/users/5625547/0stone0"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1693495942,
                "post_id": 77017183,
                "comment_id": 135771724,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 289134,
                    "reputation": 389369,
                    "user_id": 589924,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/b2cf53d5a3d25f95c0db4e025aed4153?s=256&d=identicon&r=PG",
                    "display_name": "ikegami",
                    "link": "https://stackoverflow.com/users/589924/ikegami"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1693496830,
                "post_id": 77017183,
                "comment_id": 135771924,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 166270,
                    "reputation": 135171,
                    "user_id": 390278,
                    "user_type": "registered",
                    "accept_rate": 86,
                    "profile_image": "https://www.gravatar.com/avatar/84715fec547362389d02f5be0ed12814?s=256&d=identicon&r=PG",
                    "display_name": "Jeff Mercado",
                    "link": "https://stackoverflow.com/users/390278/jeff-mercado"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1693500909,
                "post_id": 77017183,
                "comment_id": 135772812,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 29129369,
                    "reputation": 1,
                    "user_id": 22315027,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/edace3c9f3b716c42b252296416b6aa5?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Amey",
                    "link": "https://stackoverflow.com/users/22315027/amey"
                },
                "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": 1693501307,
                "post_id": 77017183,
                "comment_id": 135772893,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 39208,
                    "reputation": 267964,
                    "user_id": 112968,
                    "user_type": "registered",
                    "accept_rate": 68,
                    "profile_image": "https://i.sstatic.net/zHTaT.png?s=256",
                    "display_name": "knittl",
                    "link": "https://stackoverflow.com/users/112968/knittl"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1693501449,
                "post_id": 77017183,
                "comment_id": 135772917,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 29129369,
                    "reputation": 1,
                    "user_id": 22315027,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/edace3c9f3b716c42b252296416b6aa5?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Amey",
                    "link": "https://stackoverflow.com/users/22315027/amey"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1693502114,
                "post_id": 77017183,
                "comment_id": 135773056,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 39208,
                    "reputation": 267964,
                    "user_id": 112968,
                    "user_type": "registered",
                    "accept_rate": 68,
                    "profile_image": "https://i.sstatic.net/zHTaT.png?s=256",
                    "display_name": "knittl",
                    "link": "https://stackoverflow.com/users/112968/knittl"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1693504854,
                "post_id": 77017183,
                "comment_id": 135773559,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 29129369,
                    "reputation": 1,
                    "user_id": 22315027,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/edace3c9f3b716c42b252296416b6aa5?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Amey",
                    "link": "https://stackoverflow.com/users/22315027/amey"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1693506103,
                "post_id": 77017183,
                "comment_id": 135773776,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 29129369,
                    "reputation": 1,
                    "user_id": 22315027,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/edace3c9f3b716c42b252296416b6aa5?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Amey",
                    "link": "https://stackoverflow.com/users/22315027/amey"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1693506150,
                "post_id": 77017183,
                "comment_id": 135773783,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 29129369,
                    "reputation": 1,
                    "user_id": 22315027,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/edace3c9f3b716c42b252296416b6aa5?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Amey",
                    "link": "https://stackoverflow.com/users/22315027/amey"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1693506195,
                "post_id": 77017183,
                "comment_id": 135773795,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1693509852,
                "last_edit_date": 1693509852,
                "creation_date": 1693501690,
                "answer_id": 77017964,
                "question_id": 77017183,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "What do you want to happen when there are multiple values for your key?\r\n\r\nIf you only want to take the first value, then several equivalent solutions exist:\r\n\r\n* `{ (.name): .values[0] }`\r\n* `[.value = .values[0]] | from_entries`",
                "title": "Processing key and value pair using yq"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": -1,
        "last_activity_date": 1693509852,
        "creation_date": 1693495069,
        "last_edit_date": 1693495129,
        "question_id": 77017183,
        "body_markdown": "I&#39;m new to for yq parser tool, I&#39;m am trying convert json into yaml\r\n\r\n**Input json**\r\n```json\r\n{\r\n  &quot;name&quot;: &quot;Fruit&quot;,\r\n  &quot;values&quot;: [\r\n    &quot;banana&quot;\r\n  ]\r\n}\r\n```\r\n\r\n**Output Yaml**\r\n```yaml\r\n{\r\nFruit : banana\r\n}\r\n```\r\nHow can I achieve this result using yq\r\n\r\n\r\n\r\ncould you please suggest on this.\r\n\r\ncommand I was trying \r\n```\r\nyq -r &#39;(.name):(.[].values)&#39; keys.yaml\r\n```\r\n\r\n",
        "link": "https://stackoverflow.com/questions/77017183/processing-key-and-value-pair-using-yq",
        "title": "Processing key and value pair using yq"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 1450087,
                    "reputation": 12022,
                    "user_id": 1409374,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/97d424fe924f2139812a4a6de1ef6b79?s=256&d=identicon&r=PG",
                    "display_name": "rickhg12hs",
                    "link": "https://stackoverflow.com/users/1409374/rickhg12hs"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1693536152,
                "post_id": 77020143,
                "comment_id": 135777242,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1450087,
                    "reputation": 12022,
                    "user_id": 1409374,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/97d424fe924f2139812a4a6de1ef6b79?s=256&d=identicon&r=PG",
                    "display_name": "rickhg12hs",
                    "link": "https://stackoverflow.com/users/1409374/rickhg12hs"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1693539699,
                "post_id": 77020143,
                "comment_id": 135777454,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1450087,
                    "reputation": 12022,
                    "user_id": 1409374,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/97d424fe924f2139812a4a6de1ef6b79?s=256&d=identicon&r=PG",
                    "display_name": "rickhg12hs",
                    "link": "https://stackoverflow.com/users/1409374/rickhg12hs"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1693540179,
                "post_id": 77020143,
                "comment_id": 135777483,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 15587847,
                    "reputation": 57,
                    "user_id": 11245815,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/0abce05fe475f3428133b1ca273282e0?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "infotechsups",
                    "link": "https://stackoverflow.com/users/11245815/infotechsups"
                },
                "reply_to_user": {
                    "account_id": 1450087,
                    "reputation": 12022,
                    "user_id": 1409374,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/97d424fe924f2139812a4a6de1ef6b79?s=256&d=identicon&r=PG",
                    "display_name": "rickhg12hs",
                    "link": "https://stackoverflow.com/users/1409374/rickhg12hs"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1693543097,
                "post_id": 77020143,
                "comment_id": 135777642,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 15587847,
                    "reputation": 57,
                    "user_id": 11245815,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/0abce05fe475f3428133b1ca273282e0?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "infotechsups",
                    "link": "https://stackoverflow.com/users/11245815/infotechsups"
                },
                "reply_to_user": {
                    "account_id": 1450087,
                    "reputation": 12022,
                    "user_id": 1409374,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/97d424fe924f2139812a4a6de1ef6b79?s=256&d=identicon&r=PG",
                    "display_name": "rickhg12hs",
                    "link": "https://stackoverflow.com/users/1409374/rickhg12hs"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1693543132,
                "post_id": 77020143,
                "comment_id": 135777647,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1694021792,
                "last_edit_date": 1694021792,
                "creation_date": 1693539726,
                "answer_id": 77020384,
                "question_id": 77020143,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Lets assume you are storing the key-value pairs in the variable which you will pass as json argument to your query like below,\r\n\r\n    input=&#39;{&quot;house&quot;:true,&quot;colour&quot;:&quot;orange&quot;}&#39;\r\n\r\nNow if you use the above input in the following query all of your scenarios will work out,\r\n\r\n    jq --argjson input &quot;$input&quot; &#39;.spec.asset+= $input&#39; &lt;original_file&gt;.json",
                "title": "JQ logic for json modification"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1693569174,
                "last_edit_date": 1693569174,
                "creation_date": 1693550318,
                "answer_id": 77020996,
                "question_id": 77020143,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "So you _always_ want to have an asset with house=true and colour=orange in your output, potentially overwriting any existing values, but keeping other properties?\r\n\r\nIf that&#39;s the case, then simply merge the `asset` object with the desired properties. There is no logic involved:\r\n\r\n```\r\njq &#39;.spec.asset += {house:true, colour:&quot;orange&quot;}&#39;\r\n```\r\n\r\nInput:\r\n\r\n```json\r\n{\r\n  &quot;name&quot;: &quot;Paul&quot;,\r\n  &quot;country&quot;: &quot;USA&quot;,\r\n  &quot;spec&quot;: {\r\n    &quot;asset&quot;: {\r\n      &quot;yard&quot;: true\r\n    }\r\n  }\r\n}\r\n{\r\n  &quot;name&quot;: &quot;Paul&quot;,\r\n  &quot;country&quot;: &quot;USA&quot;,\r\n  &quot;spec&quot;: {}\r\n}\r\n{\r\n  &quot;name&quot;: &quot;Paul&quot;,\r\n  &quot;country&quot;: &quot;USA&quot;,\r\n  &quot;spec&quot;: {\r\n    &quot;asset&quot;: {\r\n      &quot;house&quot;: false,\r\n      &quot;colour&quot;: &quot;black&quot;\r\n    }\r\n  }\r\n}\r\n```\r\n\r\nOutput:\r\n\r\n```json\r\n{\r\n  &quot;name&quot;: &quot;Paul&quot;,\r\n  &quot;country&quot;: &quot;USA&quot;,\r\n  &quot;spec&quot;: {\r\n    &quot;asset&quot;: {\r\n      &quot;yard&quot;: true,\r\n      &quot;house&quot;: true,\r\n      &quot;colour&quot;: &quot;orange&quot;\r\n    }\r\n  }\r\n}\r\n{\r\n  &quot;name&quot;: &quot;Paul&quot;,\r\n  &quot;country&quot;: &quot;USA&quot;,\r\n  &quot;spec&quot;: {\r\n    &quot;asset&quot;: {\r\n      &quot;house&quot;: true,\r\n      &quot;colour&quot;: &quot;orange&quot;\r\n    }\r\n  }\r\n}\r\n{\r\n  &quot;name&quot;: &quot;Paul&quot;,\r\n  &quot;country&quot;: &quot;USA&quot;,\r\n  &quot;spec&quot;: {\r\n    &quot;asset&quot;: {\r\n      &quot;house&quot;: true,\r\n      &quot;colour&quot;: &quot;orange&quot;\r\n    }\r\n  }\r\n}\r\n```",
                "title": "JQ logic for json modification"
            }
        ],
        "is_answered": false,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1694021792,
        "creation_date": 1693534391,
        "question_id": 77020143,
        "body_markdown": "I have system that output multiple types of JSON file with data\r\n\r\nIs there any chance to implement above three conditions using **JQ package**? I am exploring *map*, *arg* and *argjson* command. But I am having tough time\r\n\r\n**First JSON** of where I do have **asset** object and I want to add following key value pair \r\n\r\n&gt; &quot;house&quot;: true and &quot;colour&quot;: &quot;orange&quot;\r\n\r\n            \r\n\r\n\r\n    {\r\n        &quot;name&quot;: &quot;Paul&quot;,\r\n        &quot;country&quot;: &quot;USA&quot;,\r\n        &quot;spec&quot;: {\r\n            ...\r\n            &quot;asset&quot;: {\r\n                &quot;yard&quot;: true\r\n            },        \r\n        }    \r\n    }\r\n\r\n**Desired output:**\r\n\r\n    {\r\n        &quot;name&quot;: &quot;Paul&quot;,\r\n        &quot;country&quot;: &quot;USA&quot;,\r\n        &quot;spec&quot;: {\r\n            ...\r\n            &quot;asset&quot;: {\r\n                &quot;house&quot;: true,\r\n                &quot;colour&quot;: &quot;orange&quot;,\r\n                &quot;yard&quot;: true\r\n            },        \r\n        }    \r\n    }\r\n\r\n**2nd JSON** of where I do not have **asset** object so I want to add the object and following key value pair \r\n\r\n&gt; &quot;house&quot;: true and &quot;colour&quot;: &quot;orange&quot;\r\n\r\n    {\r\n        &quot;name&quot;: &quot;Paul&quot;,\r\n        &quot;country&quot;: &quot;USA&quot;,\r\n        &quot;spec&quot;: {\r\n            ...\r\n        }    \r\n    }\r\n\r\nDesired output:\r\n\r\n    {\r\n        &quot;name&quot;: &quot;Paul&quot;,\r\n        &quot;country&quot;: &quot;USA&quot;,\r\n        &quot;spec&quot;: {\r\n            ...\r\n            &quot;asset&quot;: {\r\n                &quot;house&quot;: true,\r\n                &quot;colour&quot;: &quot;orange&quot;\r\n            },        \r\n        }    \r\n    }\r\n\r\n**3rd JSON** of where I do have **asset** object but I would like to change key value pair of house if it has set to false and set colour to orange\r\n\r\n    {\r\n        &quot;name&quot;: &quot;Paul&quot;,\r\n        &quot;country&quot;: &quot;USA&quot;,\r\n        &quot;spec&quot;: {\r\n            ...\r\n            &quot;asset&quot;: {\r\n                &quot;house&quot;: false,\r\n                &quot;colour&quot;: &quot;black&quot;\r\n            },        \r\n        }    \r\n    }\r\n\r\nDesired output:\r\n\r\n    {\r\n        &quot;name&quot;: &quot;Paul&quot;,\r\n        &quot;country&quot;: &quot;USA&quot;,\r\n        &quot;spec&quot;: {\r\n            ...\r\n            &quot;asset&quot;: {\r\n                &quot;house&quot;: true,\r\n                &quot;colour&quot;: &quot;orange&quot;\r\n            },        \r\n        }    \r\n    }\r\n\r\nBasically what I am trying to do is - If there is no asset object -&gt; Create asset object, put house set to true and colour ornage in the element. If there is asset object already -&gt; check if house is set to something else AND check colour is SET to something else, if that is the case then set hosue back to true and colour to orange. If there is asset class already in place, but house and colour key is not present in the object, then add house to true and colour to orange",
        "link": "https://stackoverflow.com/questions/77020143/jq-logic-for-json-modification",
        "title": "JQ logic for json modification"
    },
    {
        "tags": [
            "json",
            "jq",
            "negation"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1693568138,
                "creation_date": 1693568138,
                "answer_id": 77022766,
                "question_id": 77022681,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Operator precedence:\r\n\r\n```\r\nselect(.hostname | startswith(&quot;startstring&quot;) and (contains(&quot;-c&quot;)|not))\r\n```\r\n\r\nWithout the parentheses, the filter would be parsed as:\r\n\r\n```\r\nselect(.hostname | (startswith(&quot;startstring&quot;) and contains(&quot;-c&quot;)) | not)\r\n```",
                "title": "Trying to select a value that does not contain using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1693679805,
        "creation_date": 1693567304,
        "last_edit_date": 1693679805,
        "question_id": 77022681,
        "body_markdown": "We have many racks of servers of three types.  One type is our storage cluster using weka.  All of the hostnames begin with weka.  The other two are compute and GPU nodes.  Both start with a common string.  Next is &#39;r&#39; followed by the rack number.  For the compute nodes a &#39;-c&#39; followed by the compute node number in that rack.  Both types are then followed by a &#39;-n&#39; followed by the node number in the rack.  I&#39;m an API call to weka which brings back all three types.  I want to be able to filter based on type.  I can get the weka and compute nodes, but can&#39;t quite get the GPU nodes.  I have:\r\n\r\n```\r\n# for Weka nodes:\r\ncurl --insecure --silent --header &quot;authorization: Bearer ${ATKN}&quot; --request GET https://weka01:14000/api/v2/processes | jq -r &#39;.data[] | select(.hostname | startswith(&quot;weka&quot;))&#39;\r\n#\r\n# for compute nodes:\r\ncurl --insecure --silent --header &quot;authorization: Bearer ${ATKN}&quot; --request GET https://weka01:14000/api/v2/processes | jq -r &#39;.data[] | select(.hostname | startswith(&quot;startstring&quot;) and contains(&quot;-c&quot;))&quot;\r\n```\r\nFor the GPU nodes, I tried:\r\n```\r\ncurl --insecure --silent --header &quot;authorization: Bearer ${ATKN}&quot; --request GET https://weka01:14000/api/v2/processes | jq -r &#39;.data[] | select(.hostname | startswith(&quot;startstring&quot;) and contains(&quot;-c&quot;)|not)&#39;\r\n```\r\nwhich gets me both the GPU and weka nodes.  Anyone know what I am doing wrong?\r\nJust for clarification, the GPU node hostnames look like:\r\n\r\n    startstring-r1-n3\r\n\r\nThe compute nodes hostnames look like:\r\n\r\n    startstring-r2-c17-n2",
        "link": "https://stackoverflow.com/questions/77022681/trying-to-select-a-value-that-does-not-contain-using-jq",
        "title": "Trying to select a value that does not contain using jq"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1693618997,
                "creation_date": 1693618997,
                "answer_id": 77026659,
                "question_id": 77026555,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can do it with just `reduce`:\r\n```jq\r\nreduce .[] as {$Id, $Contents} ({}; .[$Contents[]] += [$Id])\r\n```\r\n```json\r\n{\r\n  &quot;foo&quot;: [\r\n    &quot;abc&quot;,\r\n    &quot;def&quot;\r\n  ],\r\n  &quot;bar&quot;: [\r\n    &quot;abc&quot;,\r\n    &quot;ghi&quot;\r\n  ],\r\n  &quot;baz&quot;: [\r\n    &quot;def&quot;,\r\n    &quot;ghi&quot;\r\n  ],\r\n  &quot;ding&quot;: [\r\n    &quot;def&quot;\r\n  ],\r\n  &quot;dang&quot;: [\r\n    &quot;ghi&quot;\r\n  ]\r\n}\r\n```\r\nhttps://jqplay.org/s/qSACI2lkcW3",
                "title": "Swap key and array value, turning old keys into new array values, using jq"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1693652095,
                "last_edit_date": 1693652095,
                "creation_date": 1693637648,
                "answer_id": 77027272,
                "question_id": 77026555,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You could also use `group_by`:\r\n\r\n```\r\nmap({ Id, Content: .Contents[] })\r\n| group_by(.Content)\r\n| map({ key: first.Content, value: map(.Id) })\r\n| from_entries\r\n```\r\n\r\nIf you are using the function definitions from https://stackoverflow.com/questions/73893818/reusable-function-to-group-by-but-return-an-object-with-group-as-key, this can be simplified to:\r\n\r\n```\r\nmap({ Id, Content: .Contents[] }) | group(.Content; .Id)\r\n```\r\n\r\nOutput:\r\n\r\n```json\r\n{\r\n  &quot;bar&quot;: [\r\n    &quot;abc&quot;,\r\n    &quot;ghi&quot;\r\n  ],\r\n  &quot;baz&quot;: [\r\n    &quot;def&quot;,\r\n    &quot;ghi&quot;\r\n  ],\r\n  &quot;dang&quot;: [\r\n    &quot;ghi&quot;\r\n  ],\r\n  &quot;ding&quot;: [\r\n    &quot;def&quot;\r\n  ],\r\n  &quot;foo&quot;: [\r\n    &quot;abc&quot;,\r\n    &quot;def&quot;\r\n  ]\r\n}\r\n```",
                "title": "Swap key and array value, turning old keys into new array values, using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 2,
        "last_activity_date": 1693652095,
        "creation_date": 1693615696,
        "question_id": 77026555,
        "body_markdown": "I&#39;d like to invert the keys and values of some data where the values are arrays, such that every unique element of the value arrays becomes a key in the output, whose value is an array containing every input key whose value contained that element originally.\r\n\r\nAs an example, I&#39;ve got some data like this:\r\n\r\n```json\r\n[\r\n  {\r\n    &quot;Id&quot;: &quot;abc&quot;,\r\n    &quot;Contents&quot;: [\r\n      &quot;foo&quot;,\r\n      &quot;bar&quot;\r\n    ]\r\n  },\r\n  {\r\n    &quot;Id&quot;: &quot;def&quot;,\r\n    &quot;Contents&quot;: [\r\n      &quot;foo&quot;,\r\n      &quot;baz&quot;,\r\n      &quot;ding&quot;\r\n    ]\r\n  },\r\n  {\r\n    &quot;Id&quot;: &quot;ghi&quot;,\r\n    &quot;Contents&quot;: [\r\n      &quot;bar&quot;,\r\n      &quot;dang&quot;,\r\n      &quot;baz&quot;\r\n    ]\r\n  }\r\n]\r\n```\r\n\r\nI&#39;d like to get the following output:\r\n\r\n```json\r\n{\r\n  &quot;foo&quot;: [\r\n    &quot;abc&quot;,\r\n    &quot;def&quot;\r\n  ],\r\n  &quot;bar&quot;: [\r\n    &quot;abc&quot;,\r\n    &quot;ghi&quot;,\r\n  ],\r\n  &quot;baz&quot;: [\r\n    &quot;def&quot;,\r\n    &quot;ghi&quot;\r\n  ],\r\n  &quot;ding&quot;: [\r\n    &quot;def&quot;\r\n  ],\r\n  &quot;dang&quot;: [\r\n    &quot;ghi&quot;\r\n  ]\r\n}\r\n```\r\n\r\nI&#39;ve tried the following, based on other questions on this site, but I&#39;m stuck trying to avoid clobbering the results when using `reduce`. I know I&#39;m close, I&#39;m just struggling with dealing with the nested data.\r\n\r\n```jq\r\nmap(.Id as $Id\r\n  | .Contents\r\n  | map({key: ., value: [$Id]})\r\n  | from_entries\r\n)\r\n| reduce .[] as $item ({}; . * $item)\r\n```\r\n\r\nThe problem with this code is that, while it does return the data in the structure I want, it&#39;s clobbering the values. This is what it outputs right now:\r\n\r\n```json\r\n{\r\n  &quot;foo&quot;: [\r\n    &quot;def&quot;\r\n  ],\r\n  &quot;bar&quot;: [\r\n    &quot;ghi&quot;\r\n  ],\r\n  &quot;baz&quot;: [\r\n    &quot;ghi&quot;\r\n  ],\r\n  &quot;ding&quot;: [\r\n    &quot;def&quot;\r\n  ],\r\n  &quot;dang&quot;: [\r\n    &quot;ghi&quot;\r\n  ]\r\n}\r\n```\r\n\r\nI&#39;ve tried nesting `reduce` calls but to no avail, I&#39;m just not comfortable with the syntax. I could handle this in other languages, but I&#39;d really like to do it with jq. What am I missing?",
        "link": "https://stackoverflow.com/questions/77026555/swap-key-and-array-value-turning-old-keys-into-new-array-values-using-jq",
        "title": "Swap key and array value, turning old keys into new array values, using jq"
    },
    {
        "tags": [
            "json",
            "key",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1693862420,
                "last_edit_date": 1693862420,
                "creation_date": 1693829797,
                "answer_id": 77037642,
                "question_id": 77037579,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The value of `.id` (a string in this case) has no fields (only objects do), so trying to evaluate `.free` on it will fail.\r\n\r\nYou could catch the failing evaluation with a `try`/`catch` [expression](https://jqlang.github.io/jq/manual/#try-catch). Use `try` on `.free`, and `empty` as the exception handler, as you probably only want it to silently output nothing in that case. With the `empty` [builtin](https://jqlang.github.io/jq/manual/#empty), you simply make it run out of input contexts, thus break out of this iteration step altogether with no further evaluation.\r\n```sh\r\n.[] | select((try .free catch empty) == true).name\r\n```\r\n[Demo](https://jqplay.org/jq?q=.%5B%5D%20%7C%20select%28%28try%20.free%20catch%20empty%29%20%3D%3D%20true%29.name&amp;j=%7B%0A%20%20%22id%22%3A%20%22foo%22%2C%0A%20%20%22node1%22%3A%20%7B%0A%20%20%20%20%22name%22%3A%20%22host001%22%2C%0A%20%20%20%20%22free%22%3A%20true%0A%20%20%7D%2C%0A%20%20%22node2%22%3A%20%7B%0A%20%20%20%20%22name%22%3A%20%22host002%22%2C%0A%20%20%20%20%22free%22%3A%20false%0A%20%20%7D%2C%0A%20%20%22node3%22%3A%20%7B%0A%20%20%20%20%22name%22%3A%20%22host003%22%2C%0A%20%20%20%20%22free%22%3A%20false%0A%20%20%7D%2C%0A%20%20%22node4%22%3A%20%7B%0A%20%20%20%20%22name%22%3A%20%22host004%22%2C%0A%20%20%20%20%22free%22%3A%20true%0A%20%20%7D%0A%7D)\r\n\r\nHowever, `empty` is already the default exception handler, so you can just omit it and only use `try .free`:\r\n```sh\r\n.[] | select((try .free) == true).name\r\n```\r\n[Demo](https://jqplay.org/jq?q=.%5B%5D%20%7C%20select%28%28try%20.free%29%20%3D%3D%20true%29.name&amp;j=%7B%0A%20%20%22id%22%3A%20%22foo%22%2C%0A%20%20%22node1%22%3A%20%7B%0A%20%20%20%20%22name%22%3A%20%22host001%22%2C%0A%20%20%20%20%22free%22%3A%20true%0A%20%20%7D%2C%0A%20%20%22node2%22%3A%20%7B%0A%20%20%20%20%22name%22%3A%20%22host002%22%2C%0A%20%20%20%20%22free%22%3A%20false%0A%20%20%7D%2C%0A%20%20%22node3%22%3A%20%7B%0A%20%20%20%20%22name%22%3A%20%22host003%22%2C%0A%20%20%20%20%22free%22%3A%20false%0A%20%20%7D%2C%0A%20%20%22node4%22%3A%20%7B%0A%20%20%20%20%22name%22%3A%20%22host004%22%2C%0A%20%20%20%20%22free%22%3A%20true%0A%20%20%7D%0A%7D)\r\n\r\nAlternatively, you could also use the [error suppression operator](https://jqlang.github.io/jq/manual/#error-suppression-optional-operator) `?` on `.free` which is a shortcut to `try .free`:\r\n```sh\r\n.[] | select(.free? == true).name\r\n```\r\n[Demo](https://jqplay.org/jq?q=.%5B%5D%20%7C%20select%28.free%3F%20%3D%3D%20true%29.name&amp;j=%7B%0A%20%20%22id%22%3A%20%22foo%22%2C%0A%20%20%22node1%22%3A%20%7B%0A%20%20%20%20%22name%22%3A%20%22host001%22%2C%0A%20%20%20%20%22free%22%3A%20true%0A%20%20%7D%2C%0A%20%20%22node2%22%3A%20%7B%0A%20%20%20%20%22name%22%3A%20%22host002%22%2C%0A%20%20%20%20%22free%22%3A%20false%0A%20%20%7D%2C%0A%20%20%22node3%22%3A%20%7B%0A%20%20%20%20%22name%22%3A%20%22host003%22%2C%0A%20%20%20%20%22free%22%3A%20false%0A%20%20%7D%2C%0A%20%20%22node4%22%3A%20%7B%0A%20%20%20%20%22name%22%3A%20%22host004%22%2C%0A%20%20%20%20%22free%22%3A%20true%0A%20%20%7D%0A%7D)\r\n\r\nLastly, the result of checking if a boolean value is `true` is the same as that boolean value itself, so the shortest way would probably be:\r\n```sh\r\n.[] | select(.free?).name\r\n```\r\n[Demo](https://jqplay.org/jq?q=.%5B%5D%20%7C%20select%28.free%3F%29.name&amp;j=%7B%0A%20%20%22id%22%3A%20%22foo%22%2C%0A%20%20%22node1%22%3A%20%7B%0A%20%20%20%20%22name%22%3A%20%22host001%22%2C%0A%20%20%20%20%22free%22%3A%20true%0A%20%20%7D%2C%0A%20%20%22node2%22%3A%20%7B%0A%20%20%20%20%22name%22%3A%20%22host002%22%2C%0A%20%20%20%20%22free%22%3A%20false%0A%20%20%7D%2C%0A%20%20%22node3%22%3A%20%7B%0A%20%20%20%20%22name%22%3A%20%22host003%22%2C%0A%20%20%20%20%22free%22%3A%20false%0A%20%20%7D%2C%0A%20%20%22node4%22%3A%20%7B%0A%20%20%20%20%22name%22%3A%20%22host004%22%2C%0A%20%20%20%20%22free%22%3A%20true%0A%20%20%7D%0A%7D)\r\n\r\n---\r\n\r\nYour idea of using `has` is good, but it would, again, only work on objects (and `null`), and therefore fail just the same on other types (like the string under `.id`). But you can, instead, directly check the type of the context using the `type` [filter](https://jqlang.github.io/jq/manual/#type):\r\n```sh\r\n.[] | select(type == &quot;object&quot; and .free == true).name\r\n```\r\n[Demo](https://jqplay.org/jq?q=.%5B%5D%20%7C%20select%28type%20%3D%3D%20%22object%22%20and%20.free%20%3D%3D%20true%29.name&amp;j=%7B%0A%20%20%22id%22%3A%20%22foo%22%2C%0A%20%20%22node1%22%3A%20%7B%0A%20%20%20%20%22name%22%3A%20%22host001%22%2C%0A%20%20%20%20%22free%22%3A%20true%0A%20%20%7D%2C%0A%20%20%22node2%22%3A%20%7B%0A%20%20%20%20%22name%22%3A%20%22host002%22%2C%0A%20%20%20%20%22free%22%3A%20false%0A%20%20%7D%2C%0A%20%20%22node3%22%3A%20%7B%0A%20%20%20%20%22name%22%3A%20%22host003%22%2C%0A%20%20%20%20%22free%22%3A%20false%0A%20%20%7D%2C%0A%20%20%22node4%22%3A%20%7B%0A%20%20%20%20%22name%22%3A%20%22host004%22%2C%0A%20%20%20%20%22free%22%3A%20true%0A%20%20%7D%0A%7D)\r\n\r\nOr use the `objects` [shortcut](https://jqlang.github.io/jq/manual/#arrays-objects-iterables-booleans-numbers-normals-finites-strings-nulls-values-scalars) which automatically selects objects only:\r\n```sh\r\n.[] | select(objects.free == true).name\r\n```\r\n[Demo](https://jqplay.org/jq?q=.%5B%5D%20%7C%20select%28objects.free%20%3D%3D%20true%29.name&amp;j=%7B%0A%20%20%22id%22%3A%20%22foo%22%2C%0A%20%20%22node1%22%3A%20%7B%0A%20%20%20%20%22name%22%3A%20%22host001%22%2C%0A%20%20%20%20%22free%22%3A%20true%0A%20%20%7D%2C%0A%20%20%22node2%22%3A%20%7B%0A%20%20%20%20%22name%22%3A%20%22host002%22%2C%0A%20%20%20%20%22free%22%3A%20false%0A%20%20%7D%2C%0A%20%20%22node3%22%3A%20%7B%0A%20%20%20%20%22name%22%3A%20%22host003%22%2C%0A%20%20%20%20%22free%22%3A%20false%0A%20%20%7D%2C%0A%20%20%22node4%22%3A%20%7B%0A%20%20%20%20%22name%22%3A%20%22host004%22%2C%0A%20%20%20%20%22free%22%3A%20true%0A%20%20%7D%0A%7D)\r\n\r\nAnd, here as well, there&#39;s no need for checking a boolean&#39;s equality to `true`:\r\n```sh\r\n.[] | select(objects.free).name\r\n```\r\n[Demo](https://jqplay.org/jq?q=.%5B%5D%20%7C%20select%28objects.free%29.name&amp;j=%7B%0A%20%20%22id%22%3A%20%22foo%22%2C%0A%20%20%22node1%22%3A%20%7B%0A%20%20%20%20%22name%22%3A%20%22host001%22%2C%0A%20%20%20%20%22free%22%3A%20true%0A%20%20%7D%2C%0A%20%20%22node2%22%3A%20%7B%0A%20%20%20%20%22name%22%3A%20%22host002%22%2C%0A%20%20%20%20%22free%22%3A%20false%0A%20%20%7D%2C%0A%20%20%22node3%22%3A%20%7B%0A%20%20%20%20%22name%22%3A%20%22host003%22%2C%0A%20%20%20%20%22free%22%3A%20false%0A%20%20%7D%2C%0A%20%20%22node4%22%3A%20%7B%0A%20%20%20%20%22name%22%3A%20%22host004%22%2C%0A%20%20%20%20%22free%22%3A%20true%0A%20%20%7D%0A%7D)",
                "title": "Select when not all sub-objects have the selector field"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1693862420,
        "creation_date": 1693829396,
        "last_edit_date": 1693842975,
        "question_id": 77037579,
        "body_markdown": "Using this example: \r\n```json\r\n{\r\n  &quot;node1&quot;: {\r\n    &quot;name&quot;: &quot;host001&quot;,\r\n    &quot;free&quot;: true\r\n  },\r\n  &quot;node2&quot;: {\r\n    &quot;name&quot;: &quot;host002&quot;,\r\n    &quot;free&quot;: false\r\n  },\r\n  &quot;node3&quot;: {\r\n    &quot;name&quot;: &quot;host003&quot;,\r\n    &quot;free&quot;: false\r\n  },\r\n  &quot;node4&quot;: {\r\n    &quot;name&quot;: &quot;host004&quot;,\r\n    &quot;free&quot;: true\r\n  }\r\n}\r\n```\r\nI can retrieve the node names where &quot;free&quot; = true with: \r\n```\r\n.[]|select(.free == true).name\r\n```\r\nhttps://jqplay.org/s/vmQFs8KYF2Q\r\n\r\nBut my JSON has some elements without this &quot;free&quot; key: \r\n```json\r\n{\r\n  &quot;id&quot;: &quot;foo&quot;,\r\n  &quot;node1&quot;: {\r\n    &quot;name&quot;: &quot;host001&quot;,\r\n    &quot;free&quot;: true\r\n  },\r\n  &quot;node2&quot;: {\r\n    &quot;name&quot;: &quot;host002&quot;,\r\n    &quot;free&quot;: false\r\n  },\r\n  &quot;node3&quot;: {\r\n    &quot;name&quot;: &quot;host003&quot;,\r\n    &quot;free&quot;: false\r\n  },\r\n  &quot;node4&quot;: {\r\n    &quot;name&quot;: &quot;host004&quot;,\r\n    &quot;free&quot;: true\r\n  }\r\n}\r\n```\r\nThen my commands fails with ```parse error: Invalid numeric literal at line 2, column 4```\r\n\r\nI think the solution lies somehow in &quot;has(free)&quot;, but can&#39;t find the right syntax.",
        "link": "https://stackoverflow.com/questions/77037579/select-when-not-all-sub-objects-have-the-selector-field",
        "title": "Select when not all sub-objects have the selector field"
    },
    {
        "tags": [
            "linux",
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1694029845,
                "post_id": 77054869,
                "comment_id": 135839276,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "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": 1694030212,
                "post_id": 77054869,
                "comment_id": 135839334,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 19121531,
                    "reputation": 23,
                    "user_id": 16246441,
                    "user_type": "registered",
                    "profile_image": "https://lh3.googleusercontent.com/a-/AOh14GiA8UHKtb7zrEitKdQuVJ_9UM3RtLs1AlgEQeHfPw=k-s256",
                    "display_name": "Tahir Khalil",
                    "link": "https://stackoverflow.com/users/16246441/tahir-khalil"
                },
                "reply_to_user": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1694030688,
                "post_id": 77054869,
                "comment_id": 135839415,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1694070755,
                "creation_date": 1694070755,
                "answer_id": 77057338,
                "question_id": 77054869,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Sort by `.Id` and sort all inner `.Media` arrays by `.Order`:\r\n\r\n```\r\n.value |= (sort_by(.Id) | .[].Media |= sort_by(.Order))\r\n```\r\n\r\nOther forms of the same filter are possible too.\r\n\r\nWithout parentheses:\r\n\r\n```\r\n.value |= sort_by(.Id) | .value[].Media |= sort_by(.Order)\r\n```\r\n\r\nWith `map`:\r\n\r\n```\r\n.value |= (sort_by(.Id) | map(.Media |= sort_by(.Order)))\r\n```\r\n\r\n",
                "title": "How to sort a file with `jq` on two columns?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1694527341,
        "creation_date": 1694029658,
        "last_edit_date": 1694527341,
        "question_id": 77054869,
        "body_markdown": "I want to sort my JSON file using `jq` by **Id** &amp; **Order**. How can I do that and generate a new JSON with sorted data? \r\n\r\nI am confused how to put array element and generate complete new sorted file. \r\n\r\nHere is the JSON file I am working with:\r\n\r\n    {\r\n      &quot;@odata.context&quot;: &quot;https://api.myserver.com/v2/$metadata#Property(Id,PhotosChangeTimestamp,ModificationTimestamp,PhotosCount)&quot;,\r\n      &quot;@odata.count&quot;: 2,\r\n      &quot;value&quot;: [\r\n        {\r\n          &quot;Id&quot;: &quot;SOMETHING_9999&quot;,\r\n          &quot;ModificationTimestamp&quot;: &quot;2023-09-01T19:20:19.712Z&quot;,\r\n          &quot;PhotosChangeTimestamp&quot;: &quot;2023-09-01T19:20:19.712Z&quot;,\r\n          &quot;Media&quot;: [\r\n            {\r\n              &quot;MediaKey&quot;: &quot;RAN13042846&quot;,\r\n              &quot;MediaType&quot;: &quot;Image&quot;,\r\n              &quot;Order&quot;: 2,\r\n              &quot;ImageWidth&quot;: 2560,\r\n              &quot;ImageHeight&quot;: 1707,\r\n              &quot;ImageSizeDescription&quot;: &quot;2560x1707&quot;,\r\n              &quot;MediaURL&quot;: &quot;https://myserver.com/images/SOMETHING_9999/4f1900bf-4ad3-4cee-aa06-1374424875b7.jpeg&quot;,\r\n              &quot;MediaModificationTimestamp&quot;: &quot;2023-09-01T19:19:28.792Z&quot;\r\n            },\r\n            {\r\n              &quot;MediaKey&quot;: &quot;RAN13042852&quot;,\r\n              &quot;MediaType&quot;: &quot;Image&quot;,\r\n              &quot;Order&quot;: 1,\r\n              &quot;ImageWidth&quot;: 2560,\r\n              &quot;ImageHeight&quot;: 1707,\r\n              &quot;ImageSizeDescription&quot;: &quot;2560x1707&quot;,\r\n              &quot;MediaURL&quot;: &quot;https://myserver.com/images/SOMETHING_9999/10924c28-3c0b-4967-9080-0216f6b9b3d8.jpeg&quot;,\r\n              &quot;MediaModificationTimestamp&quot;: &quot;2023-09-01T19:19:28.787Z&quot;\r\n            }\r\n          ],\r\n          &quot;PhotosCount&quot;: 2\r\n        },\r\n        {\r\n          &quot;Id&quot;: &quot;SOMETHING_9988&quot;,\r\n          &quot;ModificationTimestamp&quot;: &quot;2023-09-01T19:20:19.712Z&quot;,\r\n          &quot;PhotosChangeTimestamp&quot;: &quot;2023-09-01T19:20:19.712Z&quot;,\r\n          &quot;Media&quot;: [\r\n            {\r\n              &quot;MediaKey&quot;: &quot;RAN13042846&quot;,\r\n              &quot;MediaType&quot;: &quot;Image&quot;,\r\n              &quot;Order&quot;: 2,\r\n              &quot;ImageWidth&quot;: 2560,\r\n              &quot;ImageHeight&quot;: 1707,\r\n              &quot;ImageSizeDescription&quot;: &quot;2560x1707&quot;,\r\n              &quot;MediaURL&quot;: &quot;https://myserver.com/images/SOMETHING_9999/4f1900bf-4ad3-4cee-aa06-1374424875b7.jpeg&quot;,\r\n              &quot;MediaModificationTimestamp&quot;: &quot;2023-09-01T19:19:28.792Z&quot;\r\n            },\r\n            {\r\n              &quot;MediaKey&quot;: &quot;RAN13042844&quot;,\r\n              &quot;MediaType&quot;: &quot;Image&quot;,\r\n              &quot;Order&quot;: 1,\r\n              &quot;ImageWidth&quot;: 2560,\r\n              &quot;ImageHeight&quot;: 1707,\r\n              &quot;ImageSizeDescription&quot;: &quot;2560x1707&quot;,\r\n              &quot;MediaURL&quot;: &quot;https://myserver.com/images/SOMETHING_9999/4f1900bf-4ad3-4cee-aa06-1374424876b9.jpeg&quot;,\r\n              &quot;MediaModificationTimestamp&quot;: &quot;2023-09-01T19:19:28.792Z&quot;\r\n            }\r\n          ],\r\n          &quot;PhotosCount&quot;: 2\r\n        }\r\n      ]\r\n    }\r\n\r\n",
        "link": "https://stackoverflow.com/questions/77054869/how-to-sort-a-file-with-jq-on-two-columns",
        "title": "How to sort a file with `jq` on two columns?"
    },
    {
        "tags": [
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1694080374,
                "post_id": 77058435,
                "comment_id": 135845346,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 5713404,
                    "reputation": 197,
                    "user_id": 4902910,
                    "user_type": "registered",
                    "profile_image": "https://lh3.googleusercontent.com/-3QnTwzmObQk/AAAAAAAAAAI/AAAAAAAAGuE/BEE5Pn0GO9Y/s256-rj/photo.jpg",
                    "display_name": "Roman Dodin",
                    "link": "https://stackoverflow.com/users/4902910/roman-dodin"
                },
                "reply_to_user": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1694080647,
                "post_id": 77058435,
                "comment_id": 135845399,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1694081302,
                "creation_date": 1694081302,
                "answer_id": 77058618,
                "question_id": 77058435,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "By what criteria do you want to match the items?\r\n\r\nIf it is by the same position in their respective parent arrays, you could simply `transpose` the array of arrays, then `add` them up:\r\n```sh\r\n[{interface: map(.interface) | transpose | map(add)}]\r\n```\r\n[Demo](https://jqplay.org/s/oiDqyAfZxtY)\r\n\r\nIf it is by the value of `.name`, you could iterate over the items using `reduce`, and collect the matching fields in an object. Use `map(.)` to re-convert it to an array.\r\n```sh\r\n[{interface: (reduce .[].interface[] as $i ({}; .[$i.name] += $i) | map(.))}]\r\n```\r\n[Demo](https://jqplay.org/s/ij5a4YttlHB)\r\n\r\nNote: If `.interface` is the only key in the top-level array&#39;s items, you could also replace the inner mentions of `.interface` with `.[]`.\r\n\r\nFor the sample data given, both output:\r\n```json\r\n[\r\n  {\r\n    &quot;interface&quot;: [\r\n      {\r\n        &quot;name&quot;: &quot;ethernet-1/1&quot;,\r\n        &quot;ifindex&quot;: 16382,\r\n        &quot;admin-state&quot;: &quot;disable&quot;\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;ethernet-1/2&quot;,\r\n        &quot;ifindex&quot;: 49150,\r\n        &quot;admin-state&quot;: &quot;disable&quot;\r\n      }\r\n    ]\r\n  }\r\n]\r\n```",
                "title": "How to merge with jq json arrays elements where elements are objects with nested arrays?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1694081302,
        "creation_date": 1694079856,
        "question_id": 77058435,
        "body_markdown": "I have the following json document\r\n\r\n```json\r\n[\r\n  {\r\n    &quot;interface&quot;: [\r\n      {\r\n        &quot;name&quot;: &quot;ethernet-1/1&quot;,\r\n        &quot;ifindex&quot;: 16382\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;ethernet-1/2&quot;,\r\n        &quot;ifindex&quot;: 49150\r\n      }\r\n    ]\r\n  },\r\n  {\r\n    &quot;interface&quot;: [\r\n      {\r\n        &quot;name&quot;: &quot;ethernet-1/1&quot;,\r\n        &quot;admin-state&quot;: &quot;disable&quot;\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;ethernet-1/2&quot;,\r\n        &quot;admin-state&quot;: &quot;disable&quot;\r\n      }\r\n    ]\r\n  }\r\n]\r\n```\r\n\r\nand I want to merge the elements of this array so that the following output is desired:\r\n\r\n```json\r\n[\r\n  {\r\n    &quot;interface&quot;: [\r\n      {\r\n        &quot;name&quot;: &quot;ethernet-1/1&quot;,\r\n        &quot;admin-state&quot;: &quot;disable&quot;,\r\n        &quot;ifindex&quot;: 16382\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;ethernet-1/2&quot;,\r\n        &quot;admin-state&quot;: &quot;disable&quot;,\r\n        &quot;ifindex&quot;: 49150\r\n      }\r\n    ]\r\n  }\r\n]\r\n```\r\n\r\nI tried a bunch of solutions with `add` and `group_by` but can&#39;t quite point my finger at where I am missing some jq knowledge.\r\nAppreciate any suggestions/examples.\r\n\r\nThe number of top level array elements is not constrained by two, it is just an example.",
        "link": "https://stackoverflow.com/questions/77058435/how-to-merge-with-jq-json-arrays-elements-where-elements-are-objects-with-nested",
        "title": "How to merge with jq json arrays elements where elements are objects with nested arrays?"
    },
    {
        "tags": [
            "google-bigquery",
            "gis",
            "jq",
            "data-analysis",
            "geojson"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 10502,
                    "reputation": 7802,
                    "user_id": 19880,
                    "user_type": "registered",
                    "accept_rate": 75,
                    "profile_image": "https://www.gravatar.com/avatar/06e716fdfc96ee2ae1a67fec196f847a?s=256&d=identicon&r=PG",
                    "display_name": "Michael Entin",
                    "link": "https://stackoverflow.com/users/19880/michael-entin"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1694128089,
                "post_id": 77062299,
                "comment_id": 135854333,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 4125557,
                    "reputation": 152,
                    "user_id": 3384801,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/KXmy9.jpg?s=256",
                    "display_name": "Markku P.",
                    "link": "https://stackoverflow.com/users/3384801/markku-p"
                },
                "reply_to_user": {
                    "account_id": 10502,
                    "reputation": 7802,
                    "user_id": 19880,
                    "user_type": "registered",
                    "accept_rate": 75,
                    "profile_image": "https://www.gravatar.com/avatar/06e716fdfc96ee2ae1a67fec196f847a?s=256&d=identicon&r=PG",
                    "display_name": "Michael Entin",
                    "link": "https://stackoverflow.com/users/19880/michael-entin"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1694260821,
                "post_id": 77062299,
                "comment_id": 135869922,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1694124876,
                "creation_date": 1694124876,
                "answer_id": 77063142,
                "question_id": 77062299,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "\r\nJust use the `cat` command, single quotes, and avoid using `.geojsonl` extension.  Just use the regular `.json`. \r\n\r\n\r\nBigQuery [docs][1] explain the procedure verbatim:\r\n\r\n```\r\ncat cm.geojson | jq -c &#39;.features[]&#39; &gt; converted.json\r\n```\r\n\r\nIf you convert the geojson exactly this way, it will load:\r\n\r\n```\r\nbq load \\                                                                              \r\n --source_format=NEWLINE_DELIMITED_JSON \\\r\n --json_extension=GEOJSON \\\r\n --autodetect \\\r\n geo-generalize:test.converted  converted.json\r\n\r\nbq query --use_legacy_sql=false &#39;SELECT column_name FROM `geo-generalize.test.INFORMATION_SCHEMA.COLUMNS` WHERE table_name=&quot;converted&quot;;&#39;\r\n\r\n+-------------+\r\n| column_name |\r\n+-------------+\r\n| shape_len   |\r\n| comarea     |\r\n| comarea_id  |\r\n| area_numbe  |\r\n| area_num_1  |\r\n| perimeter   |\r\n| area        |\r\n| geometry    |\r\n| shape_area  |\r\n| community   |\r\n+-------------+\r\n```\r\n\r\n\r\n [1]: https://cloud.google.com/bigquery/docs/geospatial-data#geojson-files",
                "title": "GeoJSON conversion to GeoJSONL BigQuery load error"
            },
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1694183923,
                "creation_date": 1694183923,
                "answer_id": 77067813,
                "question_id": 77062299,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The comment to the question by michael-entin provided the solution.\r\n\r\nSwitching from web console to bq load in the Cloud Shell Terminal did the trick.\r\n\r\n\r\n    bq load  --source_format=NEWLINE_DELIMITED_JSON \\\r\n    --json_extension=GEOJSON --autodetect \\\r\n    my_dataset_name.my_new_table \\\r\n    gs://cloud_storage_bucket/source.geojsonl \\\r\n\r\n",
                "title": "GeoJSON conversion to GeoJSONL BigQuery load error"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1694183923,
        "creation_date": 1694114297,
        "question_id": 77062299,
        "body_markdown": "I am trying to upload to BigQuery the geospatial data of community areas of Chicago. However, I am getting the following errors messages when trying to create a table from newline delimited geoJSON file:\r\n\r\n&gt; Error while reading data, error message: JSON table encountered too many errors, giving up. Rows: 1; errors: 1. Please look into the errors\\[\\] collection for more details.\r\n\r\n&gt; Error while reading data, error message: JSON processing encountered too many errors, giving up. Rows: 1; errors: 1; max bad: 0; error percent: 0\r\n\r\n&gt; Error while reading data, error message: JSON parsing error in row starting at position 0: Nested arrays not allowed.\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\nI obtained the data from [Chicago Data Portal](https://data.cityofchicago.org/Facilities-Geographic-Boundaries/Boundaries-Community-Areas-current-/cauq-8yn6) and [exported it in GeoJSON format](https://www.dropbox.com/scl/fi/lflbja65s0ve11xb2fuq7/cm.geojson?rlkey=8w7mcxm3o4dm8d33gqxz4t2z2&amp;dl=0). I used jq to convert the GeoJSON to [newline delimited GeoJSON](https://www.dropbox.com/scl/fi/eswd7pnomn4kkgmnqafow/cm.gejsonl?rlkey=hmuo10eebok3g0b2csoti6jgf&amp;dl=0) with jq like this:\r\n\r\n```\r\ntype cm.geojson | jq -c &quot;.features[]&quot; &gt; cm.geojsonl\r\n```\r\n\r\n\r\nWhat am I doing wrong &amp; how to fix this issue?\r\n\r\nThank you!",
        "link": "https://stackoverflow.com/questions/77062299/geojson-conversion-to-geojsonl-bigquery-load-error",
        "title": "GeoJSON conversion to GeoJSONL BigQuery load error"
    },
    {
        "tags": [
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1694460585,
                "post_id": 77084321,
                "comment_id": 135891295,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1613587,
                    "reputation": 786618,
                    "user_id": 1491895,
                    "user_type": "registered",
                    "accept_rate": 69,
                    "profile_image": "https://www.gravatar.com/avatar/82f9e178a16364bf561d0ed4da09a35d?s=256&d=identicon&r=PG",
                    "display_name": "Barmar",
                    "link": "https://stackoverflow.com/users/1491895/barmar"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1694460714,
                "post_id": 77084321,
                "comment_id": 135891326,
                "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": 1694462055,
                "post_id": 77084321,
                "comment_id": 135891509,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1694460622,
                "creation_date": 1694460622,
                "answer_id": 77084340,
                "question_id": 77084321,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Bash arrays are not JSON arrays and JSON arrays are not bash arrays. If you none of your values contains new lines, you could use `read` in a loop:\r\n\r\n```\r\nmycli | jq -r &#39;.[]&#39; | while read -r secret; do\r\n  echo &quot;$secret&quot;\r\ndone\r\n```",
                "title": "jq result iteration in bash"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1694811383,
        "creation_date": 1694460413,
        "last_edit_date": 1694811383,
        "question_id": 77084321,
        "body_markdown": "I have this jq output from a CLI command\r\n\r\n    [&quot;test-KEY&quot;,&quot;test-PASSWORD&quot;]\r\n\r\nAssigned that output to a bash variable in this manner\r\n\r\n    secret_list=`mycli | jq`\r\n\r\n\r\nI want to iterate though that output in bash &amp; perform another CLI command on each item.\r\n\r\nSo far I tried this block &amp; is not coming desired command execution:\r\n\r\n    echo &quot;secrets_list: &quot;$secrets_list\r\n    \r\n    length=${#secrets_list[@]}\r\n    echo &quot;Number of secrets $length&quot;\r\n    \r\n    for secret in &quot;${secrets_list[@]}&quot;\r\n    do\r\n          echo &quot;$secret&quot;\r\n    done\r\n\r\nOutput is \r\n\r\n\r\n    secrets_list: [&quot;test-KEY&quot;,&quot;test-PASSWORD&quot;]\r\n    Number of secrets 1\r\n    [&quot;test-KEY&quot;,&quot;test-PASSWORD&quot;]\r\n\r\nMy expectation is to iterate through that array. What am I doing wrong?\r\n",
        "link": "https://stackoverflow.com/questions/77084321/jq-result-iteration-in-bash",
        "title": "jq result iteration in bash"
    },
    {
        "tags": [
            "arrays",
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1694549593,
                "creation_date": 1694549593,
                "answer_id": 77092418,
                "question_id": 77092168,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "While traversing, you could store all parts needed into variables for reference. This includes creating a lookup index using the names under `.volumes` as keys, realized here as object using `INDEX`.\r\n```sh\r\n.items[] | .metadata.name as $meta\r\n| .spec | INDEX(.volumes[]; .name) as $volumes\r\n| .containers[] | .name as $name\r\n| .volumeMounts[] | select($volumes[.name].persistentVolumeClaim.claimName)\r\n| [$meta, $name, .name, .mountPath] | join(&quot;;&quot;)\r\n```\r\n```\r\npod1;container1;mount1;/path1\r\npod1;container2;mount1;/path3\r\n```\r\n[Demo](https://jqplay.org/s/l9buIwBxrMn)",
                "title": "jq: join one array against multiple arrays"
            },
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1694550023,
                "creation_date": 1694550023,
                "answer_id": 77092460,
                "question_id": 77092168,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s a solution which builds an index per item, then transforms the data into structured objects, and finally creates an array to join:\r\n\r\n```\r\n.items[]\r\n| INDEX(.spec.volumes[]; .name) as $index\r\n| { pod: .metadata.name }\r\n+ (\r\n    .spec.containers[]\r\n    | {\r\n        container: .name,\r\n        mount: JOIN($index; .volumeMounts[]; .name; {name: first.name, path: first.mountPath, claim: .[1].persistentVolumeClaim.claimName})\r\n    } | select(.mount.claim)\r\n)\r\n| [ .pod, .container, .mount[] ]\r\n| join(&quot;;&quot;)\r\n```\r\n\r\nOutput:\r\n\r\n```text\r\npod1;container1;mount1;/path1;claim1\r\npod1;container2;mount1;/path3;claim1\r\n```",
                "title": "jq: join one array against multiple arrays"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1694569468,
        "creation_date": 1694547093,
        "last_edit_date": 1694569468,
        "question_id": 77092168,
        "body_markdown": "I&#39;m trying to integrate joining one array with multiple others into my jq command.\r\n\r\nThis is a small example of my json document:\r\n\r\n```yaml\r\n{\r\n    &quot;items&quot;: [\r\n        {\r\n            &quot;metadata&quot;: {\r\n                &quot;name&quot;: &quot;pod1&quot;\r\n            },\r\n            &quot;spec&quot;: {\r\n                &quot;containers&quot;: [\r\n                    {\r\n                        &quot;name&quot;: &quot;container1&quot;,\r\n                        &quot;volumeMounts&quot;: [\r\n                            {\r\n                                &quot;mountPath&quot;: &quot;/path1&quot;,\r\n                                &quot;name&quot;: &quot;mount1&quot;\r\n                            },\r\n                            {\r\n                                &quot;mountPath&quot;: &quot;/path2&quot;,\r\n                                &quot;name&quot;: &quot;mount2&quot;\r\n                            }\r\n                        ]\r\n                    },\r\n                    {\r\n                        &quot;name&quot;: &quot;container2&quot;,\r\n                        &quot;volumeMounts&quot;: [\r\n                            {\r\n                                &quot;mountPath&quot;: &quot;/path3&quot;,\r\n                                &quot;name&quot;: &quot;mount1&quot;\r\n                            }\r\n                        ]\r\n                    }\r\n                ],\r\n                &quot;volumes&quot;: [\r\n                    {\r\n                        &quot;name&quot;: &quot;mount1&quot;,\r\n                        &quot;persistentVolumeClaim&quot;: {\r\n                            &quot;claimName&quot;: &quot;claim1&quot;\r\n                        }\r\n                    },\r\n                    {\r\n                        &quot;name&quot;: &quot;mount2&quot;,\r\n                        &quot;emptyDir&quot;: {}\r\n                    }\r\n                ]\r\n            }\r\n        }\r\n    ]\r\n}\r\n```\r\n\r\nI want to output the name of all pods, its containers, and the containers mount points &amp; names, and in the end only selecting mounts whose volumes have the key `persistentVolumeClaim`, e.g.:\r\n\r\n```plain\r\npod1;container1;mount1;/path1;claim1\r\npod1;container2;mount1;/path3;claim1\r\n```\r\n\r\nSo far I was able to extract the pod-name, container-name and the mount name and path:\r\n\r\n```bash\r\njq -r &#39;.items[]\r\n    | {pod:.metadata.name, c:.spec.containers[]}\r\n    | {pod:.pod, container:.c.name, mount:.c.volumeMounts[]}\r\n    | [.pod, .container, .mount.name, .mount.mountPath]\r\n    | join(&quot;;&quot;)&#39;\r\n```\r\n\r\nThis give the following output:\r\n\r\n```plain\r\npod1;container1;mount1;/path1\r\npod1;container1;mount2;/path2\r\npod1;container2;mount1;/path3\r\n```\r\n\r\nNow I need to join the `volumes` array with each `volumeMounts` array in `containers` and afterwards select for only those with the `persistentVolumeClaim` key. I got it to work to join two arrays, but I wasn&#39;t able to integrate it in the command above to join `volumes` with each `volumesMounts` in the `containers` array in the command above:\r\n\r\n```bash\r\njq -r &#39;.items[]\r\n    | .spec.containers[].volumeMounts+.spec.volumes\r\n    | group_by(.name)\r\n    | map(add)\r\n    | .[]\r\n    | select(.persistentVolumeClaim)&#39;\r\n```\r\n",
        "link": "https://stackoverflow.com/questions/77092168/jq-join-one-array-against-multiple-arrays",
        "title": "jq: join one array against multiple arrays"
    },
    {
        "tags": [
            "json",
            "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": 1694563897,
                "post_id": 77093338,
                "comment_id": 135906948,
                "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": 1694563946,
                "post_id": 77093338,
                "comment_id": 135906954,
                "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": 1694564007,
                "post_id": 77093338,
                "comment_id": 135906965,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1694565659,
                "creation_date": 1694565659,
                "answer_id": 77093425,
                "question_id": 77093338,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "2. `jq -r &#39;.x | with_entries(select(.value | index(&quot;3&quot;))) | keys[]&#39;` seems to do the trick.",
                "title": "jq: Selecting parent keys based on child array contents"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1694571934,
                "creation_date": 1694571934,
                "answer_id": 77093674,
                "question_id": 77093338,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "For the first, getting the unique values of the child arrays:\r\n\r\n```sh\r\n$&#160;jq &#39;[.x | to_entries[] | .value] | flatten | unique&#39; input.json\r\n[\r\n  &quot;1&quot;,\r\n  &quot;2&quot;,\r\n  &quot;3&quot;,\r\n  &quot;4&quot;\r\n]\r\n```\r\n\r\nor if you want the results one element per line instead of as JSON:\r\n\r\n```sh\r\njq -r &#39;[.x | to_entries[] | .value] | flatten | unique[]&#39; input.json\r\n1\r\n2\r\n3\r\n4\r\n```",
                "title": "jq: Selecting parent keys based on child array contents"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1694595494,
                "last_edit_date": 1694595494,
                "creation_date": 1694594311,
                "answer_id": 77095421,
                "question_id": 77093338,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "&gt; 1. I want to obtain a list of all the unique values in the child arrays. What I have is `jq -r &#39;.x[][] file.json | sort | uniq`. Is there a native solution?\r\n\r\nYes, jq has its own `unique` filter  (which also sorts its input automatically). Collect all the items with `[…]` into a single array before using it.\r\n```sh\r\njq -r &#39;[.x[][]] | unique[]&#39; file.json\r\n```\r\n```\r\n1\r\n2\r\n3\r\n4\r\n```\r\n[Demo](https://jqplay.org/s/9-_UwXN2-Un)\r\n\r\n---\r\n&gt; 2. I want to choose keys `&quot;a&quot;` and `&quot;c&quot;` based on the fact that they both have `&quot;3&quot;` in their respective child arrays. How do I go about that? I can get the child arrays with `&quot;3&quot;` in them with `jq -r &#39;.x[] | select(index(&quot;3&quot;) &gt;= 0)&#39; file.json` but I need access to the parent key.\r\n\r\nYou could iterate over the (sorted) `keys` (use `keys_unsorted` instead if you want the original order), and use `IN` (which is just a shortcut to `any` using `==` as comparator) to `select` by containedness.\r\n```sh\r\njq &#39;.x | keys[] as $k | select(IN(.[$k][]; &quot;3&quot;)) | $k&#39; file.json\r\n```\r\n```\r\na\r\nc\r\n```\r\n[Demo](https://jqplay.org/s/FEujiOx_ovF)",
                "title": "jq: Selecting parent keys based on child array contents"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1695085550,
                "last_edit_date": 1695085550,
                "creation_date": 1695084903,
                "answer_id": 77131107,
                "question_id": 77093338,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I want to elaborate on the second question as [there][1] is already a good answer to the first question.\r\n\r\nYou were quite close on the second one. If you use the update operator (`|=`) instead of the filter operator (`|`), you can get the original JSON with objects for the keys you need:\r\n\r\n```\r\nFILTER: .x[] |= select(index(&quot;3&quot;) &gt;= 0)\r\n\r\nRESULT: {&quot;x&quot;:{&quot;a&quot;:[&quot;2&quot;,&quot;3&quot;],&quot;c&quot;:[&quot;3&quot;,&quot;4&quot;]}}\r\n```\r\n\r\nNow, say, you only want the objects `a` and `c`, add the trailing `.[]`\r\n\r\n```\r\nFILTER: .x[] |= select(index(&quot;3&quot;) &gt;= 0) | .[]\r\n\r\nRESULT: {&quot;a&quot;:[&quot;2&quot;,&quot;3&quot;],&quot;c&quot;:[&quot;3&quot;,&quot;4&quot;]}\r\n```\r\n\r\nNow, say, you only want the said keys alone ([demo][2]):\r\n\r\n```\r\nFILTER: .x[] |= select(index(&quot;3&quot;) &gt;= 0) | .[] | keys\r\n\r\nRESULT: [&quot;a&quot;,&quot;c&quot;]\r\n```\r\n\r\n\r\n  [1]: https://stackoverflow.com/a/77095421/84940\r\n  [2]: https://jqplay.org/s/QCLwlpcDb0d",
                "title": "jq: Selecting parent keys based on child array contents"
            }
        ],
        "is_answered": false,
        "answer_count": 4,
        "score": 0,
        "last_activity_date": 1695085550,
        "creation_date": 1694563807,
        "question_id": 77093338,
        "body_markdown": "Consider the following `file.json` where `&quot;x&quot;` is a known string. Two questions:\r\n\r\n1. I want to obtain a list of all the unique values in the child arrays. What I have is `jq -r &#39;.x[][] file.json | sort | uniq`. Is there a native solution?\r\n\r\n2. I want to choose keys `&quot;a&quot;` and `&quot;c&quot;` based on the fact that they both have `&quot;3&quot;` in their respective child arrays. How do I go about that? I can get the child arrays with `&quot;3&quot;` in them with `jq -r &#39;.x[] | select(index(&quot;3&quot;) &gt;= 0)&#39; file.json` but I need access to the parent key.\r\n\r\n```\r\n{\r\n  &quot;x&quot;: {\r\n    &quot;a&quot;: [\r\n      &quot;2&quot;,\r\n      &quot;3&quot;\r\n    ],\r\n    &quot;b&quot;: [\r\n      &quot;1&quot;,\r\n      &quot;2&quot;\r\n    ],\r\n    &quot;c&quot;: [\r\n      &quot;3&quot;,\r\n      &quot;4&quot;\r\n    ]\r\n  }\r\n}\r\n```",
        "link": "https://stackoverflow.com/questions/77093338/jq-selecting-parent-keys-based-on-child-array-contents",
        "title": "jq: Selecting parent keys based on child array contents"
    },
    {
        "tags": [
            "jq",
            "openapi"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1694604061,
                "last_edit_date": 1694604061,
                "creation_date": 1694600704,
                "answer_id": 77096219,
                "question_id": 77096165,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "```\r\n.paths |= with_entries(select(.value.get?.tags[] | contains(&quot;public&quot;)))\r\n```\r\n\r\nWill update the `paths` object to just the result of `select(.value.get?.tags[] | contains(&quot;public&quot;))` which filters out any object where `tags` does not include `public`\r\n\r\nOutput:\r\n```json\r\n{\r\n  &quot;openapi&quot;: &quot;3.0.3&quot;,\r\n  &quot;info&quot;: {\r\n    &quot;title&quot;: &quot;Test OpenAPI specification&quot;,\r\n    &quot;version&quot;: &quot;1.0.0&quot;\r\n  },\r\n  &quot;servers&quot;: [\r\n    {\r\n      &quot;url&quot;: &quot;example.com&quot;\r\n    }\r\n  ],\r\n  &quot;paths&quot;: {\r\n    &quot;/public&quot;: {\r\n      &quot;get&quot;: {\r\n        &quot;operationId&quot;: &quot;publicOperation&quot;,\r\n        &quot;summary&quot;: &quot;Public operation&quot;,\r\n        &quot;description&quot;: &quot;This is a public operation that should appear in the public-facing OpenAPI spec&quot;,\r\n        &quot;tags&quot;: [\r\n          &quot;System&quot;,\r\n          &quot;public&quot;\r\n        ],\r\n        &quot;parameters&quot;: [],\r\n        &quot;security&quot;: [\r\n          {\r\n            &quot;Authorization&quot;: []\r\n          }\r\n        ],\r\n        &quot;responses&quot;: {\r\n          &quot;200&quot;: {\r\n            &quot;description&quot;: &quot;Successful response&quot;,\r\n            &quot;content&quot;: {\r\n              &quot;application/json&quot;: {\r\n                &quot;schema&quot;: {\r\n                  &quot;type&quot;: &quot;string&quot;,\r\n                  &quot;enum&quot;: [\r\n                    &quot;OK&quot;\r\n                  ]\r\n                }\r\n              }\r\n            }\r\n          },\r\n          &quot;default&quot;: {\r\n            &quot;$ref&quot;: &quot;#/components/responses/error&quot;\r\n          }\r\n        }\r\n      }\r\n    }\r\n  },\r\n  &quot;components&quot;: {\r\n    &quot;securitySchemes&quot;: {\r\n      &quot;Authorization&quot;: {\r\n        &quot;type&quot;: &quot;http&quot;,\r\n        &quot;scheme&quot;: &quot;bearer&quot;\r\n      }\r\n    },\r\n    &quot;responses&quot;: {\r\n      &quot;error&quot;: {\r\n        &quot;description&quot;: &quot;Error response&quot;,\r\n        &quot;content&quot;: {\r\n          &quot;application/json&quot;: {\r\n            &quot;schema&quot;: {\r\n              &quot;type&quot;: &quot;object&quot;,\r\n              &quot;properties&quot;: {\r\n                &quot;message&quot;: {\r\n                  &quot;type&quot;: &quot;string&quot;\r\n                },\r\n                &quot;code&quot;: {\r\n                  &quot;type&quot;: &quot;string&quot;\r\n                },\r\n                &quot;issues&quot;: {\r\n                  &quot;type&quot;: &quot;array&quot;,\r\n                  &quot;items&quot;: {\r\n                    &quot;type&quot;: &quot;object&quot;,\r\n                    &quot;properties&quot;: {\r\n                      &quot;message&quot;: {\r\n                        &quot;type&quot;: &quot;string&quot;\r\n                      }\r\n                    },\r\n                    &quot;required&quot;: [\r\n                      &quot;message&quot;\r\n                    ],\r\n                    &quot;additionalProperties&quot;: false\r\n                  }\r\n                }\r\n              },\r\n              &quot;required&quot;: [\r\n                &quot;message&quot;,\r\n                &quot;code&quot;\r\n              ],\r\n              &quot;additionalProperties&quot;: false\r\n            }\r\n          }\r\n        }\r\n      }\r\n    }\r\n  }\r\n}\r\n```\r\n\r\n#### [JqPlay Demo](https://jqplay.org/s/jVumLTvL_p1)\r\n\r\n----------\r\n\r\nTo remove the `public` from the `.get.tags`, use\r\n```\r\n.paths |= with_entries(select(.value.get?.tags[] | contains(&quot;public&quot;)) | .value.get.tags |= map(select(. != &quot;public&quot;)))\r\n```\r\n\r\n#### [JqPlay Demo](https://jqplay.org/s/_O99Oxpa1Fy)",
                "title": "Filtering an OpenAPI spec using jq"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1695357207,
                "last_edit_date": 1695357207,
                "creation_date": 1694841658,
                "answer_id": 77116446,
                "question_id": 77096165,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "## Solution \r\n\r\nHere&#39;s a solution that works regardless of the name of the HTTP verb ([demo][1]):\r\n\r\n```jq\r\n  (.paths[][] |= select( [.tags[] | . == &quot;public&quot;] | any ) ) \r\n| (.paths[]   |= select( (. | length) &gt; 0 )) \r\n| (.paths[][].tags[] |= select( . != &quot;public&quot; )) \r\n```\r\n\r\nYou can leave the last line out if you do not want to remove the &quot;public&quot; tag from the `tags[]` array.\r\n\r\n## Explanation\r\nWe start by noticing that the value of the `.paths` attribute is structured as follows:\r\n\r\n```\r\nendpoints\r\n└── operations \r\n    └── tags\r\n```\r\n\r\nWe can take a three-step approach as follows:\r\n\r\n- STEP-1: Remove every operation that is not public i.e., an operation that does not have at least one tag called &quot;public&quot;.\r\n- STEP-2: Remove every endpoint that does not have at least one public operation.\r\n- STEP-3: Remove the &quot;public&quot; tag from the tags under each endpoint.\r\n\r\n### STEP-1\r\n\r\nHere&#39;s the filter to remove non-public operations:\r\n\r\n```jq\r\n(.paths[][] |= select( [.tags[] | . == &quot;public&quot;] | any ) ) \r\n```\r\n\r\nIt works as follows:\r\n\r\n- `.paths[][]` chooses each operation; the successive `[]` descend one level each.\r\n- `|=` says we are going to modify each operation; so the `select` clause is running on each operation.\r\n- `[.tags[] | . = &quot;public&quot;] | any` is unpacking the tags array for an operation, checking if each element in that array is equal to &quot;public&quot; returning an array that contains true/false elements, and then the `any` clause checks that at least one of the elements is true. \r\n- `select ( &lt;condition&gt; )` only retains those `tag` elements where the condition is true, i.e., only operations that have a tag called &quot;public&quot;.\r\n\r\n### STEP-2\r\n\r\nAt this point, in your example, we would have all the operations under `/private` and `/neither` removed and so the JSON for the paths object would be:\r\n\r\n```jsonc\r\n{ \r\n  &quot;/public&quot; : { get : { /* the operation */ },\r\n  &quot;/private&quot; : {},\r\n  &quot;/neither&quot; : {}\r\n}\r\n```\r\n\r\nNow, we need to remove each endpoint that is an empty object i.e., an endpoint that does not have any public operations.\r\n\r\nHere&#39;s the filter to do that:\r\n\r\n```jq\r\n( .paths[] |= select( (. | length) &gt; 0 )) \r\n```\r\n\r\nIt works as follows:\r\n\r\n- `.paths[]` chooses each endpoint as the `[]` descends one level.\r\n- `|=` says we are going to modify each operation; so the `select` clause is running on each endpoint.\r\n- `(. | length) &gt; 0 )` is checking that each operation (i.e. the selected object) has at least one key. The length operation on an object returns how many keys it has.\r\n- `select ( &lt;condition&gt; )` only retains those endpoints that have some keys, i.e., excludes endpoints without any operations.\r\n\r\n### STEP-3\r\n\r\nNow, our JSON has what we need except the extraneous &quot;public&quot; tag under the `tags[]` array of each operation. We can remove those using this filter:\r\n\r\n```jq\r\n.paths[][].tags[] |= select( . != &quot;public&quot; )\r\n```\r\n\r\nIt works as follows:\r\n\r\n- `.paths[][].tags[]` chooses each tag element\r\n- `|=` is operating on each tag\r\n- `. != &quot;public&quot;` is checking that the value of each tag (represented by `.` here) is not equal to public.\r\n- `select( &lt;condition&gt; )` is therefore retaining only tags that are equal to `public`.\r\n\r\n### Finally...\r\n\r\nThe `|` between the clauses is essentially passing the JSON after being modified from the first filter to the second to the third resulting in:\r\n\r\n```jq\r\n  (.paths[][] |= select( [.tags[] | . == &quot;public&quot;] | any ) ) \r\n| (.paths[]   |= select( (. | length) &gt; 0 )) \r\n| (.paths[][].tags[] |= select( . != &quot;public&quot; )) \r\n```\r\n\r\n  [1]: https://jqplay.org/s/e3X40uBz17a",
                "title": "Filtering an OpenAPI spec using jq"
            }
        ],
        "is_answered": false,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1695357207,
        "creation_date": 1694600316,
        "question_id": 77096165,
        "body_markdown": "I have an OpenAPI spec where some of the endpoints are tagged as `public`.\r\n\r\nI want to filter this with `jq` so that:\r\n\r\n1. Endpoints that are not tagged as public are removed;\r\n2. Other parts of the OpenAPI spec are left as they are;\r\n3. Optionally, the `public` tag is removed.\r\n\r\nI am completely lost with this, and don&#39;t even know where to begin. I&#39;m open to any solution that can run on the command line. It doesn&#39;t have to be `jq`.\r\n\r\nI have tried a lot of different `jq` filters, but none of them get me anywhere close to where I want to be. \r\n\r\nThis is an example input\r\n\r\n\r\n```json\r\n{\r\n  &quot;openapi&quot;: &quot;3.0.3&quot;,\r\n  &quot;info&quot;: {\r\n    &quot;title&quot;: &quot;Test OpenAPI specification&quot;,\r\n    &quot;version&quot;: &quot;1.0.0&quot;\r\n  },\r\n  &quot;servers&quot;: [\r\n    {\r\n      &quot;url&quot;: &quot;example.com&quot;\r\n    }\r\n  ],\r\n  &quot;paths&quot;: {\r\n    &quot;/public&quot;: {\r\n      &quot;get&quot;: {\r\n        &quot;operationId&quot;: &quot;publicOperation&quot;,\r\n        &quot;summary&quot;: &quot;Public operation&quot;,\r\n        &quot;description&quot;: &quot;This is a public operation that should appear in the public-facing OpenAPI spec&quot;,\r\n        &quot;tags&quot;: [\r\n          &quot;System&quot;,\r\n          &quot;public&quot;\r\n        ],\r\n        &quot;parameters&quot;: [],\r\n        &quot;security&quot;: [\r\n          {\r\n            &quot;Authorization&quot;: []\r\n          }\r\n        ],\r\n        &quot;responses&quot;: {\r\n          &quot;200&quot;: {\r\n            &quot;description&quot;: &quot;Successful response&quot;,\r\n            &quot;content&quot;: {\r\n              &quot;application/json&quot;: {\r\n                &quot;schema&quot;: {\r\n                  &quot;type&quot;: &quot;string&quot;,\r\n                  &quot;enum&quot;: [\r\n                    &quot;OK&quot;\r\n                  ]\r\n                }\r\n              }\r\n            }\r\n          },\r\n          &quot;default&quot;: {\r\n            &quot;$ref&quot;: &quot;#/components/responses/error&quot;\r\n          }\r\n        }\r\n      }\r\n    },\r\n    &quot;/private&quot;: {\r\n      &quot;get&quot;: {\r\n        &quot;operationId&quot;: &quot;privateOperation&quot;,\r\n        &quot;summary&quot;: &quot;Private operation&quot;,\r\n        &quot;description&quot;: &quot;This is a private operation that should not appear in the public OpenAPI&quot;,\r\n        &quot;tags&quot;: [\r\n          &quot;System&quot;,\r\n          &quot;private&quot;\r\n        ],\r\n        &quot;parameters&quot;: [],\r\n        &quot;security&quot;: [\r\n          {\r\n            &quot;Authorization&quot;: []\r\n          }\r\n        ],\r\n        &quot;responses&quot;: {\r\n          &quot;200&quot;: {\r\n            &quot;description&quot;: &quot;Successful response&quot;,\r\n            &quot;content&quot;: {\r\n              &quot;application/json&quot;: {\r\n                &quot;schema&quot;: {\r\n                  &quot;type&quot;: &quot;string&quot;,\r\n                  &quot;enum&quot;: [\r\n                    &quot;OK&quot;\r\n                  ]\r\n                }\r\n              }\r\n            }\r\n          },\r\n          &quot;default&quot;: {\r\n            &quot;$ref&quot;: &quot;#/components/responses/error&quot;\r\n          }\r\n        }\r\n      }\r\n    },\r\n    &quot;/neither&quot;: {\r\n      &quot;get&quot;: {\r\n        &quot;operationId&quot;: &quot;neitherPublicNorPrivate&quot;,\r\n        &quot;summary&quot;: &quot;Neither public nor private&quot;,\r\n        &quot;description&quot;: &quot;This operation is not tagged as either public or private and it should not appear in the pulic-facing OpenAPI spec&quot;,\r\n        &quot;tags&quot;: [\r\n          &quot;System&quot;\r\n        ],\r\n        &quot;parameters&quot;: [],\r\n        &quot;security&quot;: [\r\n          {\r\n            &quot;Authorization&quot;: []\r\n          }\r\n        ],\r\n        &quot;responses&quot;: {\r\n          &quot;200&quot;: {\r\n            &quot;description&quot;: &quot;Successful response&quot;,\r\n            &quot;content&quot;: {\r\n              &quot;application/json&quot;: {\r\n                &quot;schema&quot;: {\r\n                  &quot;type&quot;: &quot;string&quot;,\r\n                  &quot;enum&quot;: [\r\n                    &quot;OK&quot;\r\n                  ]\r\n                }\r\n              }\r\n            }\r\n          },\r\n          &quot;default&quot;: {\r\n            &quot;$ref&quot;: &quot;#/components/responses/error&quot;\r\n          }\r\n        }\r\n      }\r\n    }\r\n  },\r\n  &quot;components&quot;: {\r\n    &quot;securitySchemes&quot;: {\r\n      &quot;Authorization&quot;: {\r\n        &quot;type&quot;: &quot;http&quot;,\r\n        &quot;scheme&quot;: &quot;bearer&quot;\r\n      }\r\n    },\r\n    &quot;responses&quot;: {\r\n      &quot;error&quot;: {\r\n        &quot;description&quot;: &quot;Error response&quot;,\r\n        &quot;content&quot;: {\r\n          &quot;application/json&quot;: {\r\n            &quot;schema&quot;: {\r\n              &quot;type&quot;: &quot;object&quot;,\r\n              &quot;properties&quot;: {\r\n                &quot;message&quot;: {\r\n                  &quot;type&quot;: &quot;string&quot;\r\n                },\r\n                &quot;code&quot;: {\r\n                  &quot;type&quot;: &quot;string&quot;\r\n                },\r\n                &quot;issues&quot;: {\r\n                  &quot;type&quot;: &quot;array&quot;,\r\n                  &quot;items&quot;: {\r\n                    &quot;type&quot;: &quot;object&quot;,\r\n                    &quot;properties&quot;: {\r\n                      &quot;message&quot;: {\r\n                        &quot;type&quot;: &quot;string&quot;\r\n                      }\r\n                    },\r\n                    &quot;required&quot;: [\r\n                      &quot;message&quot;\r\n                    ],\r\n                    &quot;additionalProperties&quot;: false\r\n                  }\r\n                }\r\n              },\r\n              &quot;required&quot;: [\r\n                &quot;message&quot;,\r\n                &quot;code&quot;\r\n              ],\r\n              &quot;additionalProperties&quot;: false\r\n            }\r\n          }\r\n        }\r\n      }\r\n    }\r\n  }\r\n}\r\n```\r\n\r\nAnd this is what I&#39;d like to see as my output\r\n\r\n```json\r\n{\r\n  &quot;openapi&quot;: &quot;3.0.3&quot;,\r\n  &quot;info&quot;: {\r\n    &quot;title&quot;: &quot;Test OpenAPI specification&quot;,\r\n    &quot;version&quot;: &quot;1.0.0&quot;\r\n  },\r\n  &quot;servers&quot;: [\r\n    {\r\n      &quot;url&quot;: &quot;example.com&quot;\r\n    }\r\n  ],\r\n  &quot;paths&quot;: {\r\n    &quot;/public&quot;: {\r\n      &quot;get&quot;: {\r\n        &quot;operationId&quot;: &quot;publicOperation&quot;,\r\n        &quot;summary&quot;: &quot;Public operation&quot;,\r\n        &quot;description&quot;: &quot;This is a public operation that should appear in the public-facing OpenAPI spec&quot;,\r\n        &quot;tags&quot;: [\r\n          &quot;System&quot;\r\n        ],\r\n        &quot;parameters&quot;: [],\r\n        &quot;security&quot;: [\r\n          {\r\n            &quot;Authorization&quot;: []\r\n          }\r\n        ],\r\n        &quot;responses&quot;: {\r\n          &quot;200&quot;: {\r\n            &quot;description&quot;: &quot;Successful response&quot;,\r\n            &quot;content&quot;: {\r\n              &quot;application/json&quot;: {\r\n                &quot;schema&quot;: {\r\n                  &quot;type&quot;: &quot;string&quot;,\r\n                  &quot;enum&quot;: [\r\n                    &quot;OK&quot;\r\n                  ]\r\n                }\r\n              }\r\n            }\r\n          },\r\n          &quot;default&quot;: {\r\n            &quot;$ref&quot;: &quot;#/components/responses/error&quot;\r\n          }\r\n        }\r\n      }\r\n    }\r\n  },\r\n  &quot;components&quot;: {\r\n    &quot;securitySchemes&quot;: {\r\n      &quot;Authorization&quot;: {\r\n        &quot;type&quot;: &quot;http&quot;,\r\n        &quot;scheme&quot;: &quot;bearer&quot;\r\n      }\r\n    },\r\n    &quot;responses&quot;: {\r\n      &quot;error&quot;: {\r\n        &quot;description&quot;: &quot;Error response&quot;,\r\n        &quot;content&quot;: {\r\n          &quot;application/json&quot;: {\r\n            &quot;schema&quot;: {\r\n              &quot;type&quot;: &quot;object&quot;,\r\n              &quot;properties&quot;: {\r\n                &quot;message&quot;: {\r\n                  &quot;type&quot;: &quot;string&quot;\r\n                },\r\n                &quot;code&quot;: {\r\n                  &quot;type&quot;: &quot;string&quot;\r\n                },\r\n                &quot;issues&quot;: {\r\n                  &quot;type&quot;: &quot;array&quot;,\r\n                  &quot;items&quot;: {\r\n                    &quot;type&quot;: &quot;object&quot;,\r\n                    &quot;properties&quot;: {\r\n                      &quot;message&quot;: {\r\n                        &quot;type&quot;: &quot;string&quot;\r\n                      }\r\n                    },\r\n                    &quot;required&quot;: [\r\n                      &quot;message&quot;\r\n                    ],\r\n                    &quot;additionalProperties&quot;: false\r\n                  }\r\n                }\r\n              },\r\n              &quot;required&quot;: [\r\n                &quot;message&quot;,\r\n                &quot;code&quot;\r\n              ],\r\n              &quot;additionalProperties&quot;: false\r\n            }\r\n          }\r\n        }\r\n      }\r\n    }\r\n  }\r\n}\r\n```\r\n",
        "link": "https://stackoverflow.com/questions/77096165/filtering-an-openapi-spec-using-jq",
        "title": "Filtering an OpenAPI spec using jq"
    },
    {
        "tags": [
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 20958278,
                    "reputation": 23075,
                    "user_id": 19355181,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/c7943ebd397154185165f876fb128bfd?s=256&d=identicon&r=PG",
                    "display_name": "jqurious",
                    "link": "https://stackoverflow.com/users/19355181/jqurious"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1694636243,
                "post_id": 77100152,
                "comment_id": 135918952,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1694635618,
                "creation_date": 1694635618,
                "answer_id": 77100190,
                "question_id": 77100152,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s one way:\r\n```sh\r\n(.links | map(select(.from == &quot;product1&quot;).to)) as $colors\r\n| .hits | map(select(IN(.id; $colors[])).name)\r\n```\r\n```\r\n[\r\n  &quot;green&quot;,\r\n  &quot;blue&quot;\r\n]\r\n```\r\n[Demo](https://jqplay.org/s/1HDrK-YuurF)\r\n",
                "title": "Using a jq expression, how to return items from a json array using an intermediate mapping array?"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1694635629,
                "creation_date": 1694635629,
                "answer_id": 77100191,
                "question_id": 77100152,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Build an `INDEX` from color ids to names, then select the required products and look up the color by id:\r\n\r\n```\r\n(INDEX(.hits[]; .id) | map_values(.name)) as $colors\r\n| .links\r\n| map(select(.from == &quot;product1&quot;) | $colors[.to])\r\n```\r\n\r\nOr with a single JOIN + INDEX:\r\n\r\n```\r\nJOIN(\r\n  INDEX(.hits[]; .id);\r\n  .links[] | select(.from == &quot;product1&quot;);\r\n  .to;\r\n  last.name)\r\n```",
                "title": "Using a jq expression, how to return items from a json array using an intermediate mapping array?"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1694635642,
                "creation_date": 1694635642,
                "answer_id": 77100192,
                "question_id": 77100152,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Think this does it:\r\n\r\n    [.links[] | select(.from == &quot;product1&quot;) | .to] as $colors | [.hits[] | select(.id | IN($colors[])) | .name]",
                "title": "Using a jq expression, how to return items from a json array using an intermediate mapping array?"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 1,
        "last_activity_date": 1694635642,
        "creation_date": 1694635125,
        "question_id": 77100152,
        "body_markdown": "Given this json:\r\n\r\n    {\r\n      &quot;links&quot;: [\r\n        {\r\n          &quot;from&quot;: &quot;product1&quot;,\r\n          &quot;to&quot;: &quot;color1&quot;\r\n        },\r\n        {\r\n          &quot;from&quot;: &quot;product1&quot;,\r\n          &quot;to&quot;: &quot;color2&quot;\r\n        },\r\n        {\r\n          &quot;from&quot;: &quot;product2&quot;,\r\n          &quot;to&quot;: &quot;color3&quot;\r\n        }\r\n      ],\r\n      &quot;hits&quot;: [\r\n        {\r\n          &quot;id&quot;: &quot;color1&quot;,\r\n          &quot;name&quot;: &quot;green&quot;\r\n        },\r\n        {\r\n          &quot;id&quot;: &quot;color2&quot;,\r\n          &quot;name&quot;: &quot;blue&quot;\r\n        },\r\n        {\r\n          &quot;id&quot;: &quot;color3&quot;,\r\n          &quot;name&quot;: &quot;yellow&quot;\r\n        }\r\n      ]\r\n    }\r\n\r\nHow can I get the color names associated to product1 ([&quot;green&quot;, &quot;blue&quot;]) using a jq expression?\r\n\r\nI managed to come up with:\r\n\r\n    [.links[] | select(.from == &quot;product1&quot;) | .to] as $colors | [.hits[] | select(.id == (&quot;color1&quot;,&quot;color2&quot;)) | .name]\r\n\r\nHowever, I don&#39;t want to hardcode (&quot;color1&quot;,&quot;color2&quot;) but instead refer to $colors.\r\n\r\nIf I use:\r\n\r\n    [.links[] | select(.from == &quot;product1&quot;) | .to] as $colors | [.hits[] | select(.id == ($colors)) | .name]\r\n\r\nI get an empty array back.",
        "link": "https://stackoverflow.com/questions/77100152/using-a-jq-expression-how-to-return-items-from-a-json-array-using-an-intermedia",
        "title": "Using a jq expression, how to return items from a json array using an intermediate mapping array?"
    },
    {
        "tags": [
            "jq",
            "common-expression-language"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 80042,
                    "reputation": 151,
                    "user_id": 226579,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d305dfcc3297c306cf8e9e63cc2caa6a?s=256&d=identicon&r=PG",
                    "display_name": "mohit nagpal",
                    "link": "https://stackoverflow.com/users/226579/mohit-nagpal"
                },
                "reply_to_user": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1694651489,
                "post_id": 77101024,
                "comment_id": 135920724,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1694652454,
                "creation_date": 1694652454,
                "answer_id": 77101183,
                "question_id": 77101024,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "This keeps all those fields under `.payload` that have at least one path `.[].cities[].name` that is resolvable and evaluates to `&quot;city_x&quot;`. Consequently, other fields are removed.\r\n\r\n```sh\r\n.payload |= with_entries(select(IN(.value[].cities?[]?.name; &quot;city_x&quot;)))\r\n```\r\n```json\r\n{\r\n  &quot;payload&quot;: {\r\n    &quot;book2&quot;: {\r\n      &quot;isbn&quot;: &quot;123-456-222&quot;,\r\n      &quot;author&quot;: {\r\n        &quot;lastname&quot;: &quot;Doe&quot;,\r\n        &quot;firstname&quot;: &quot;Jane&quot;\r\n      },\r\n      &quot;editor&quot;: {\r\n        &quot;lastname&quot;: &quot;Smith&quot;,\r\n        &quot;firstname&quot;: &quot;Jane&quot;\r\n      },\r\n      &quot;title&quot;: &quot;C programming guide&quot;,\r\n      &quot;category&quot;: [\r\n        &quot;Programming&quot;,\r\n        &quot;Technology&quot;\r\n      ],\r\n      &quot;sellerid3&quot;: {\r\n        &quot;name&quot;: &quot;sellerid3&quot;,\r\n        &quot;cities&quot;: [\r\n          {\r\n            &quot;name&quot;: &quot;city_a&quot;,\r\n            &quot;sellcount&quot;: 100\r\n          },\r\n          {\r\n            &quot;name&quot;: &quot;city_b&quot;,\r\n            &quot;sellcount&quot;: 200\r\n          }\r\n        ]\r\n      },\r\n      &quot;sellerid4&quot;: {\r\n        &quot;name&quot;: &quot;sellerid4&quot;,\r\n        &quot;cities&quot;: [\r\n          {\r\n            &quot;name&quot;: &quot;city_a&quot;,\r\n            &quot;sellcount&quot;: 10\r\n          },\r\n          {\r\n            &quot;name&quot;: &quot;city_x&quot;,\r\n            &quot;sellcount&quot;: 15\r\n          }\r\n        ]\r\n      }\r\n    }\r\n  }\r\n}\r\n```\r\n[Demo](https://jqplay.org/s/W7PuhesneGs)",
                "title": "Nested json filtering using jq or cel"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1695079586,
                "creation_date": 1695079586,
                "answer_id": 77130885,
                "question_id": 77101024,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "## Solution \r\n\r\nHere&#39;s an approach that will keep only those books that have `cities[].name` somewhere in their descendants that equals `city_x` ([demo][1]):\r\n\r\n```jq\r\n.payload[] |= select( [ .. | if (type == &quot;object&quot; and has(&quot;cities&quot;)) \r\n                             then (.cities[] | .name == &quot;city_x&quot;) \r\n                             else false \r\n                             end ] | any )\r\n                           \r\n```\r\n\r\nA little more modular approach ([demo][2]):\r\n\r\n```\r\ndef criteria($city):\r\n\r\n    [ .. | if (type == &quot;object&quot; and has(&quot;cities&quot;)) \r\n           then (.cities[] | .name == $city) \r\n           else false \r\n           end ] | any;\r\n         \r\n.payload[] |= select( criteria(&quot;city_x&quot;) )\r\n\r\n```\r\n\r\n## Explanation\r\n\r\nThe idea is that for each book produced by `.payload[]`, we only want to let it pass through if it satisfies the criteria: `select( criteria(&quot;city_x&quot;) )`\r\n\r\nThe criteria function produces all possible descendants (`..`) but we are only interested in objects that have a `cities` property. If such an object is encountered, we unwarp the `.cities` property to iterate over each city and check if it&#39;s `name` matches `city_x`. Of course, we are only interested in retaining a book, if there is at least one match.\r\n\r\nAnd so for each descendant, the logic produces `false` if the criteria is not satisfied, and `true` if it is. The final `any` checks that one of these elements is true, which means that the matched book should be included in the final result.\r\n\r\nA caveat: if the same book has two cities named &quot;city_x&quot;, this would produce two `true` elements in the array for the same input object but this is not a problem because we have the final `any`. If it can be assumed that this wouldn&#39;t occur, the logic can be made a little simpler by moving the `any` to the `then` clause ([demo][3]). \r\n\r\n  [1]: https://jqplay.org/s/iYzuO200jYP\r\n  [2]: https://jqplay.org/s/5L1AqapvqRp\r\n  [3]: https://jqplay.org/s/D4YlQ6EgtAJ",
                "title": "Nested json filtering using jq or cel"
            }
        ],
        "is_answered": false,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1695079586,
        "creation_date": 1694647986,
        "last_edit_date": 1694658263,
        "question_id": 77101024,
        "body_markdown": "Need to return payload.* json path where condition payload.*.*.cities.name = city_x matches. Tried looking google cel or jq for this case. did not find way for this so far.\r\n\r\nCase 1 - Sample Json Input\r\n\r\n    {\r\n    \t&quot;payload&quot;: {\r\n    \t\t&quot;book1&quot;: {\r\n    \t\t\t&quot;isbn&quot;: &quot;123-456-2221&quot;,\r\n    \t\t\t&quot;author&quot;: {\r\n    \t\t\t\t&quot;lastname&quot;: &quot;Doe&quot;,\r\n    \t\t\t\t&quot;firstname&quot;: &quot;Jane&quot;\r\n    \t\t\t},\r\n    \t\t\t&quot;editor&quot;: {\r\n    \t\t\t\t&quot;lastname&quot;: &quot;Smith&quot;,\r\n    \t\t\t\t&quot;firstname&quot;: &quot;Jane&quot;\r\n    \t\t\t},\r\n    \t\t\t&quot;title&quot;: &quot;The Ultimate Database Study Guide&quot;,\r\n    \t\t\t&quot;category&quot;: [\r\n    \t\t\t\t&quot;Non-Fiction&quot;,\r\n    \t\t\t\t&quot;Technology&quot;\r\n    \t\t\t],\r\n    \t\t\t&quot;sellerid1&quot;: {\r\n    \t\t\t\t&quot;name&quot;: &quot;sellerid1&quot;,\r\n    \t\t\t\t&quot;cities&quot;: [{\r\n    \t\t\t\t\t\t&quot;name&quot;: &quot;city_a&quot;,\r\n    \t\t\t\t\t\t&quot;sellcount&quot;: 100\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;city_y&quot;,\r\n    \t\t\t\t\t\t&quot;sellcount&quot;: 200\r\n    \t\t\t\t\t}\r\n    \t\t\t\t]\r\n    \t\t\t},\r\n    \t\t\t&quot;sellerid2&quot;: {\r\n    \t\t\t\t&quot;name&quot;: &quot;sellerid2&quot;,\r\n    \t\t\t\t&quot;cities&quot;: [{\r\n    \t\t\t\t\t\t&quot;name&quot;: &quot;city_a&quot;,\r\n    \t\t\t\t\t\t&quot;sellcount&quot;: 10\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;city_b&quot;,\r\n    \t\t\t\t\t\t&quot;sellcount&quot;: 15\r\n    \t\t\t\t\t}\r\n    \t\t\t\t]\r\n    \t\t\t}\r\n    \t\t},\r\n    \t\t&quot;book2&quot;: {\r\n    \t\t\t&quot;isbn&quot;: &quot;123-456-222&quot;,\r\n    \t\t\t&quot;author&quot;: {\r\n    \t\t\t\t&quot;lastname&quot;: &quot;Doe&quot;,\r\n    \t\t\t\t&quot;firstname&quot;: &quot;Jane&quot;\r\n    \t\t\t},\r\n    \t\t\t&quot;editor&quot;: {\r\n    \t\t\t\t&quot;lastname&quot;: &quot;Smith&quot;,\r\n    \t\t\t\t&quot;firstname&quot;: &quot;Jane&quot;\r\n    \t\t\t},\r\n    \t\t\t&quot;title&quot;: &quot;C programming guide&quot;,\r\n    \t\t\t&quot;category&quot;: [\r\n    \t\t\t\t&quot;Programming&quot;,\r\n    \t\t\t\t&quot;Technology&quot;\r\n    \t\t\t],\r\n    \t\t\t&quot;sellerid3&quot;: {\r\n    \t\t\t\t&quot;name&quot;: &quot;sellerid3&quot;,\r\n    \t\t\t\t&quot;cities&quot;: [{\r\n    \t\t\t\t\t\t&quot;name&quot;: &quot;city_a&quot;,\r\n    \t\t\t\t\t\t&quot;sellcount&quot;: 100\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;city_b&quot;,\r\n    \t\t\t\t\t\t&quot;sellcount&quot;: 200\r\n    \t\t\t\t\t}\r\n    \t\t\t\t]\r\n    \t\t\t},\r\n    \t\t\t&quot;sellerid4&quot;: {\r\n    \t\t\t\t&quot;name&quot;: &quot;sellerid4&quot;,\r\n    \t\t\t\t&quot;cities&quot;: [{\r\n    \t\t\t\t\t\t&quot;name&quot;: &quot;city_a&quot;,\r\n    \t\t\t\t\t\t&quot;sellcount&quot;: 10\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;city_x&quot;,\r\n    \t\t\t\t\t\t&quot;sellcount&quot;: 15\r\n    \t\t\t\t\t}\r\n    \t\t\t\t]\r\n    \t\t\t}\r\n    \t\t}\r\n    \t}\r\n    }\r\n\r\n\r\n\r\n\r\n######## Sample json case 2 ###############\r\n\r\n    {\r\n    \t&quot;payload&quot;: {\r\n    \t\t&quot;book1&quot;: {\r\n    \t\t\t&quot;isbn&quot;: &quot;123-456-2221&quot;,\r\n    \t\t\t&quot;author&quot;: {\r\n    \t\t\t\t&quot;lastname&quot;: &quot;Doe&quot;,\r\n    \t\t\t\t&quot;firstname&quot;: &quot;Jane&quot;\r\n    \t\t\t},\r\n    \t\t\t&quot;editor&quot;: {\r\n    \t\t\t\t&quot;lastname&quot;: &quot;Smith&quot;,\r\n    \t\t\t\t&quot;firstname&quot;: &quot;Jane&quot;\r\n    \t\t\t},\r\n    \t\t\t&quot;title&quot;: &quot;The Ultimate Database Study Guide&quot;,\r\n    \t\t\t&quot;category&quot;: [\r\n    \t\t\t\t&quot;Non-Fiction&quot;,\r\n    \t\t\t\t&quot;Technology&quot;\r\n    \t\t\t],\r\n    \t\t\t&quot;sellers&quot;: {\r\n    \t\t\t\t&quot;sellerid1&quot;: {\r\n    \t\t\t\t\t&quot;name&quot;: &quot;sellerid1&quot;,\r\n    \t\t\t\t\t&quot;cities&quot;: [{\r\n    \t\t\t\t\t\t\t&quot;name&quot;: &quot;city_a&quot;,\r\n    \t\t\t\t\t\t\t&quot;sellcount&quot;: 100\r\n    \t\t\t\t\t\t},\r\n    \t\t\t\t\t\t{\r\n    \t\t\t\t\t\t\t&quot;name&quot;: &quot;city_y&quot;,\r\n    \t\t\t\t\t\t\t&quot;sellcount&quot;: 200\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\t&quot;sellerid2&quot;: {\r\n    \t\t\t\t\t&quot;name&quot;: &quot;sellerid2&quot;,\r\n    \t\t\t\t\t&quot;cities&quot;: [{\r\n    \t\t\t\t\t\t\t&quot;name&quot;: &quot;city_a&quot;,\r\n    \t\t\t\t\t\t\t&quot;sellcount&quot;: 10\r\n    \t\t\t\t\t\t},\r\n    \t\t\t\t\t\t{\r\n    \t\t\t\t\t\t\t&quot;name&quot;: &quot;city_b&quot;,\r\n    \t\t\t\t\t\t\t&quot;sellcount&quot;: 15\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    \t\t},\r\n    \t\t&quot;book2&quot;: {\r\n    \t\t\t&quot;isbn&quot;: &quot;123-456-222&quot;,\r\n    \t\t\t&quot;author&quot;: {\r\n    \t\t\t\t&quot;lastname&quot;: &quot;Doe&quot;,\r\n    \t\t\t\t&quot;firstname&quot;: &quot;Jane&quot;\r\n    \t\t\t},\r\n    \t\t\t&quot;editor&quot;: {\r\n    \t\t\t\t&quot;lastname&quot;: &quot;Smith&quot;,\r\n    \t\t\t\t&quot;firstname&quot;: &quot;Jane&quot;\r\n    \t\t\t},\r\n    \t\t\t&quot;title&quot;: &quot;C programming guide&quot;,\r\n    \t\t\t&quot;category&quot;: [\r\n    \t\t\t\t&quot;Programming&quot;,\r\n    \t\t\t\t&quot;Technology&quot;\r\n    \t\t\t],\r\n    \t\t\t&quot;sellers&quot;: {\r\n    \t\t\t\t&quot;sellerid3&quot;: {\r\n    \t\t\t\t\t&quot;name&quot;: &quot;sellerid3&quot;,\r\n    \t\t\t\t\t&quot;cities&quot;: [{\r\n    \t\t\t\t\t\t\t&quot;name&quot;: &quot;city_a&quot;,\r\n    \t\t\t\t\t\t\t&quot;sellcount&quot;: 100\r\n    \t\t\t\t\t\t},\r\n    \t\t\t\t\t\t{\r\n    \t\t\t\t\t\t\t&quot;name&quot;: &quot;city_b&quot;,\r\n    \t\t\t\t\t\t\t&quot;sellcount&quot;: 200\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\t&quot;sellerid4&quot;: {\r\n    \t\t\t\t\t&quot;name&quot;: &quot;sellerid4&quot;,\r\n    \t\t\t\t\t&quot;cities&quot;: [{\r\n    \t\t\t\t\t\t\t&quot;name&quot;: &quot;city_a&quot;,\r\n    \t\t\t\t\t\t\t&quot;sellcount&quot;: 10\r\n    \t\t\t\t\t\t},\r\n    \t\t\t\t\t\t{\r\n    \t\t\t\t\t\t\t&quot;name&quot;: &quot;city_x&quot;,\r\n    \t\t\t\t\t\t\t&quot;sellcount&quot;: 15\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    \t\t},\r\n    \t\t&quot;book3&quot;: {\r\n    \t\t\t&quot;isbn&quot;: &quot;123-456-2221&quot;,\r\n    \t\t\t&quot;author&quot;: {\r\n    \t\t\t\t&quot;lastname&quot;: &quot;Doe&quot;,\r\n    \t\t\t\t&quot;firstname&quot;: &quot;Jane&quot;\r\n    \t\t\t},\r\n    \t\t\t&quot;editor&quot;: {\r\n    \t\t\t\t&quot;lastname&quot;: &quot;Smith&quot;,\r\n    \t\t\t\t&quot;firstname&quot;: &quot;Jane&quot;\r\n    \t\t\t},\r\n    \t\t\t&quot;title&quot;: &quot;The Ultimate Database Study Guide&quot;,\r\n    \t\t\t&quot;category&quot;: [\r\n    \t\t\t\t&quot;Non-Fiction&quot;,\r\n    \t\t\t\t&quot;Technology&quot;\r\n    \t\t\t]\r\n    \t\t},\r\n    \t\t&quot;book4&quot;: {\r\n    \t\t\t&quot;isbn&quot;: &quot;123-456-222&quot;,\r\n    \t\t\t&quot;author&quot;: {\r\n    \t\t\t\t&quot;lastname&quot;: &quot;Doe&quot;,\r\n    \t\t\t\t&quot;firstname&quot;: &quot;Jane&quot;\r\n    \t\t\t},\r\n    \t\t\t&quot;editor&quot;: {\r\n    \t\t\t\t&quot;lastname&quot;: &quot;Smith&quot;,\r\n    \t\t\t\t&quot;firstname&quot;: &quot;Jane&quot;\r\n    \t\t\t},\r\n    \t\t\t&quot;title&quot;: &quot;C programming guide&quot;,\r\n    \t\t\t&quot;category&quot;: [\r\n    \t\t\t\t&quot;Programming&quot;,\r\n    \t\t\t\t&quot;Technology&quot;\r\n    \t\t\t],\r\n    \t\t\t&quot;sellers&quot;: {}\r\n    \t\t}\r\n    \t}\r\n    }\r\n\r\n### required output is same for case1 and case2. ####\r\n\r\n    {\r\n    \t&quot;payload&quot;: {\r\n    \t\t&quot;book2&quot;: {\r\n    \t\t\t&quot;isbn&quot;: &quot;123-456-222&quot;,\r\n    \t\t\t&quot;author&quot;: {\r\n    \t\t\t\t&quot;lastname&quot;: &quot;Doe&quot;,\r\n    \t\t\t\t&quot;firstname&quot;: &quot;Jane&quot;\r\n    \t\t\t},\r\n    \t\t\t&quot;editor&quot;: {\r\n    \t\t\t\t&quot;lastname&quot;: &quot;Smith&quot;,\r\n    \t\t\t\t&quot;firstname&quot;: &quot;Jane&quot;\r\n    \t\t\t},\r\n    \t\t\t&quot;title&quot;: &quot;C programming guide&quot;,\r\n    \t\t\t&quot;category&quot;: [\r\n    \t\t\t\t&quot;Programming&quot;,\r\n    \t\t\t\t&quot;Technology&quot;\r\n    \t\t\t],\r\n    \t\t\t&quot;sellerid3&quot;: {\r\n    \t\t\t\t&quot;name&quot;: &quot;sellerid3&quot;,\r\n    \t\t\t\t&quot;cities&quot;: [{\r\n    \t\t\t\t\t\t&quot;name&quot;: &quot;city_a&quot;,\r\n    \t\t\t\t\t\t&quot;sellcount&quot;: 100\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;city_b&quot;,\r\n    \t\t\t\t\t\t&quot;sellcount&quot;: 200\r\n    \t\t\t\t\t}\r\n    \t\t\t\t]\r\n    \t\t\t},\r\n    \t\t\t&quot;sellerid4&quot;: {\r\n    \t\t\t\t&quot;name&quot;: &quot;sellerid4&quot;,\r\n    \t\t\t\t&quot;cities&quot;: [{\r\n    \t\t\t\t\t\t&quot;name&quot;: &quot;city_a&quot;,\r\n    \t\t\t\t\t\t&quot;sellcount&quot;: 10\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;city_x&quot;,\r\n    \t\t\t\t\t\t&quot;sellcount&quot;: 15\r\n    \t\t\t\t\t}\r\n    \t\t\t\t]\r\n    \t\t\t}\r\n    \t\t}\r\n    \t}\r\n    }\r\n\r\nTried CEL to filter , CEL [playground][1]. Nested filtering this style did not find option in CEL. Looking if any other way using jq. \r\n\r\n\r\n  [1]: https://playcel.undistro.io/?content=H4sIAAAAAAAAA91W30%2FbMBD%2BV255AaQWaFr2gMQDAjYJMYb4ITQRNF2Sa2rNsSPbKUSo%2F%2FvOaSBpt6kVUiW0l9Y5f%2Fd9dxefLy9Big6Dw%2BAlUpGLggIrqTGNgkOYW9gWa%2F1r0LWwTdhYeVMUDMJhf3TwuR%2BGIYN6LQRLN9Fm0Y%2FNEq1TmNPc%2B1RT14n3x8J0AeeoePUKmHX4KRVuJf9NLtzkvQpOONmAbicEd9KJHB3BKZcsRktw48q0gq%2BlSBeyCBJGZdpU3vehK32pVf%2BLSJzQaimoW0omSkudVW0sjx1KS1KSEengj4TbTDqYBe5EOEG2DqbrueTNqOonLrq%2BSSe6VM7jBvv73f3ZAnoV%2B%2FMq9nCJvX14%2FNsLek04XKMo4UaLssGaDA5WlmS%2BeNOtOzZcp2P%2F34Y9gcLozGCeC5VBtn6LXrVu72zR4RqncfhRWzTeUIuO1ijK6IO26MqarN%2Bi%2Fo9%2FZkEvoOfCkLU8Cnj87u3BPTFhTuA0OJ42J2cXcCWxygyrpJ8ixZBFGwgLqEAoRwZ5pkyJOeJjaymPZQWFfiJDKZCaCqNVTsp5bpaV2hB7pn7Nda93nrjt5ro6z7WCs7fo4AJVVmJGsM36O7s%2BkjqaPtwbweOw0qWpQ2szgglLN6A7HpSeGA0h8JZfW25HGGvDwRelA%2F8N0uM1%2FDj%2BdgFsPr%2F5fun3edw2LFeeGbauS7VVZzFFWeI%2FxDFDoayrlVqBhuisyd%2F7JZoPXj2NQY%2BZAfNCkm0Cs4UwWE9qVbuiqsBfrPNS1Wc2ceAPiH8RzV2umg%2Bo3bGQ%2FFq24x40lof4cdffwXB0tHwH70QqmP0GADP1K4oJAAA%3D\r\n",
        "link": "https://stackoverflow.com/questions/77101024/nested-json-filtering-using-jq-or-cel",
        "title": "Nested json filtering using jq or cel"
    },
    {
        "tags": [
            "apache-camel",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1694693568,
                "last_edit_date": 1694693568,
                "creation_date": 1694688410,
                "answer_id": 77104160,
                "question_id": 77102884,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Use the equivalent `select(IN($colors[]; .id))` or `select(any($colors[] == .id; .))` (this is how the filter is defined in [`builtin.jq`](https://github.com/jqlang/jq/blob/7a72f58d2e92254652162ec7ca1b3074e3a22c35/src/builtin.jq#L277))\r\n\r\nOr go with the `INDEX`-based solution that was also proposed under your original question :)",
                "title": "Function IN/1 does not exist in Spring Boot Apache Camel application"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1694693568,
        "creation_date": 1694678741,
        "last_edit_date": 1694687115,
        "question_id": 77102884,
        "body_markdown": "Following the clarification done in:\r\n\r\nhttps://stackoverflow.com/questions/77100152/using-a-jq-expression-how-to-return-items-from-a-json-array-using-an-intermedia/77100192#77100192\r\n\r\nI have tried to implement the solution:\r\n\r\n    [.links[] | select(.from == &quot;product1&quot;) | .to] as $colors | [.hits[] | select(.id | IN($colors[])) | .name]\r\n\r\nHowever my application (Spring Boot Apache Camel) gives me this error: &quot;Function IN/1 does not exist&quot;.\r\n\r\nIf I use &quot;in&quot; instead of &quot;IN&quot; I get: &quot;has() is not applicable to STRING&quot;.\r\n\r\nI am using Apache Camel 4.0.0 (with camel-jq with same version).\r\n\r\nHow to access this function or replace it by one providing the same result?",
        "link": "https://stackoverflow.com/questions/77102884/function-in-1-does-not-exist-in-spring-boot-apache-camel-application",
        "title": "Function IN/1 does not exist in Spring Boot Apache Camel application"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1694695117,
                "creation_date": 1694695117,
                "answer_id": 77104973,
                "question_id": 77104936,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "`feedData` is a JSON object, so you can convert it with `fromjson`:\r\n\r\n```bash\r\n$ jq -r &#39;.getFeedFromMyTeam[] | .recipients[] as $t | [.OpenedAt,$t.receiverId,$t.receiverName,.senderId,(.feedData | fromjson | .keyTwo)] | @csv&#39; file.json\r\n1693321311,&quot;johns&quot;,&quot;John Smith&quot;,&quot;janed&quot;,&quot;my_data_two&quot;\r\n```",
                "title": "Extracting data from nested JSON with escape backslash characters by using jq"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1694695585,
                "last_edit_date": 1694695585,
                "creation_date": 1694695180,
                "answer_id": 77104978,
                "question_id": 77104936,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "[`fromjson`](https://jqlang.github.io/jq/manual/#convert-to-from-json) allows you to parse a JSON-string into the corresponding JSON entity.\r\n\r\ne.g.:\r\n\r\n```\r\n$ jq &#39;fromjson&#39; &lt;&lt;EOF\r\n&quot;{\\&quot;a\\&quot;:1}&quot;\r\nEOF\r\n{\r\n  &quot;a&quot;: 1\r\n}\r\n```\r\n\r\nIntegrating into your filter:\r\n\r\n```\r\njq &lt;my.json -r &#39;.getFeedFromMyTeam[] | .recipients[] as $t\r\n| [.OpenedAt,$t.receiverId,$t.receiverName,.senderId,(.feedData|fromjson.keyTwo)]\r\n| @csv&#39; \r\n```",
                "title": "Extracting data from nested JSON with escape backslash characters by using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1694695585,
        "creation_date": 1694694881,
        "question_id": 77104936,
        "body_markdown": "I have a non-standard format of JSON which is using some nested data with backslash escape characters. \r\n\r\n    {\r\n    &quot;getFeedFromMyTeam&quot;: [\r\n        {\r\n            &quot;OpenedAt&quot;: 1693321311,\r\n            &quot;feedData&quot;: &quot;{\\&quot;keyOne\\&quot;:\\&quot;my_data_one\\&quot;,\\&quot;keyTwo\\&quot;:\\&quot;my_data_two\\&quot;}&quot;,\r\n            &quot;feedId&quot;: &quot;123456789&quot;,\r\n            &quot;recipients&quot;: [\r\n                {\r\n                    &quot;receiverId&quot;: &quot;johns&quot;,\r\n                    &quot;receiverName&quot;: &quot;John Smith&quot;\r\n                }\r\n            ],\r\n            &quot;senderId&quot;: &quot;janed&quot;,\r\n            &quot;senderName&quot;: &quot;Jane Doe&quot;\r\n        }\r\n\r\n    ],\r\n    &quot;hasMore&quot;: true,\r\n    &quot;paginationToken&quot;: &quot;100&quot;  \r\n    }\r\n\r\nI&#39;m trying to convert it to a CSV file with this comand:\r\n\r\n    cat my.json | jq -r &#39;.getFeedFromMyTeam[] | .recipients[] as $t | [.OpenedAt,$t.receiverId,$t.receiverName,.senderId,.feedData] | @csv&#39; \r\n\r\n\r\nAll is good however instead of full &quot;.feedData&quot; which now looks like:\r\n\r\n    &quot;{&quot;&quot;keyOne&quot;&quot;:&quot;&quot;my_data_one&quot;&quot;,&quot;&quot;keyTwo&quot;&quot;:&quot;&quot;my_data_two&quot;&quot;}&quot;\r\n\r\nI would like to get only data from &quot;keyTwo&quot; which is &quot;my_data_two&quot;\r\n\r\nNow it is:\r\n\r\n    1693321311,&quot;johns&quot;,&quot;John Smith&quot;,&quot;janed&quot;,&quot;{&quot;&quot;keyOne&quot;&quot;:&quot;&quot;my_data_one&quot;&quot;,&quot;&quot;keyTwo&quot;&quot;:&quot;&quot;my_data_two&quot;&quot;}&quot;\r\n  \r\nI would like to get:\r\n\r\n    1693321311,&quot;johns&quot;,&quot;John Smith&quot;,&quot;janed&quot;,&quot;my_data_two&quot;\r\n\r\nIdeally I would like to use only jq but if not possible then maybe also awk, sed etc. ",
        "link": "https://stackoverflow.com/questions/77104936/extracting-data-from-nested-json-with-escape-backslash-characters-by-using-jq",
        "title": "Extracting data from nested JSON with escape backslash characters by using jq"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1694703288,
                "creation_date": 1694703288,
                "answer_id": 77106111,
                "question_id": 77106088,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Use `.types` to traverse to that key, then `scan` the string for consecutive digits with a regex. Use the `-r` flag to output raw text:\r\n```sh\r\njq -r &#39;.types | scan(&quot;\\\\d+&quot;)&#39; input.json\r\n```\r\n```json\r\n2\r\n4\r\n5\r\n10\r\n13\r\n```\r\n[Demo](https://jqplay.org/s/-tUnwFiK6fm)\r\n\r\nJust in case this isn&#39;t obvious: the string `{2,4,5,10,13}` is **not** a valid JSON-encoded object or array, so you cannot structurally &quot;iterate&quot; over the numbers. Use string functions (like `scan`) to handle it.",
                "title": "jq - How to get list of values out in a list without keys"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1694703288,
        "creation_date": 1694703166,
        "question_id": 77106088,
        "body_markdown": ".\r\nsorry I am a newbe with jq, maybe I don&#39;t see the &quot;forest because of to much trees&quot;. I have a json which looks simplified like:\r\n\r\n```\r\n{\r\n  &quot;a&quot;: &quot;aaa&quot;,\r\n  &quot;b&quot;: &quot;bbb&quot;,\r\n  &quot;types&quot;: &quot;{2,4,5,10,13}&quot;,\r\n  &quot;c&quot;: &quot;ccc&quot;  \r\n}\r\n```\r\n\r\nThe wanted output from jq should be\r\n\r\n\r\n```\r\n2\r\n4\r\n5\r\n10\r\n13\r\n```\r\n\r\n\r\n\r\nI only get with &quot;jq -r .types&quot; the list out and have to parse it further then manually.\r\nIs there a easy way to do all at once with jq single command?\r\n\r\nThanks in advance, Ralf\r\n",
        "link": "https://stackoverflow.com/questions/77106088/jq-how-to-get-list-of-values-out-in-a-list-without-keys",
        "title": "jq - How to get list of values out in a list without keys"
    },
    {
        "tags": [
            "json",
            "group-by",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1694723663,
                "creation_date": 1694723663,
                "answer_id": 77108216,
                "question_id": 77108105,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Provide `group_by` with two criteria: one is simply the value of `.country`, the other is the containedness of `.level` in a given set of values (here, using `IN` with `H1` and `H2`, which evaluates to a boolean). After the grouping, use a `map` to rectify the shapes of the individual groups as desired.\r\n```sh\r\n.hits |= (\r\n  group_by(.country, IN(.level; &quot;H1&quot;, &quot;H2&quot;)) \r\n  | map((first | {country}) + {entities: map({id, level})})\r\n)\r\n```\r\n```json\r\n{\r\n  &quot;hits&quot;: [\r\n    {\r\n      &quot;country&quot;: &quot;CZ&quot;,\r\n      &quot;entities&quot;: [\r\n        {\r\n          &quot;id&quot;: &quot;id3&quot;,\r\n          &quot;level&quot;: &quot;H2&quot;\r\n        }\r\n      ]\r\n    },\r\n    {\r\n      &quot;country&quot;: &quot;IT&quot;,\r\n      &quot;entities&quot;: [\r\n        {\r\n          &quot;id&quot;: &quot;id4&quot;,\r\n          &quot;level&quot;: &quot;H2&quot;\r\n        }\r\n      ]\r\n    },\r\n    {\r\n      &quot;country&quot;: &quot;PT&quot;,\r\n      &quot;entities&quot;: [\r\n        {\r\n          &quot;id&quot;: &quot;id5&quot;,\r\n          &quot;level&quot;: &quot;H3&quot;\r\n        },\r\n        {\r\n          &quot;id&quot;: &quot;id6&quot;,\r\n          &quot;level&quot;: &quot;H3&quot;\r\n        },\r\n        {\r\n          &quot;id&quot;: &quot;id7&quot;,\r\n          &quot;level&quot;: &quot;H4&quot;\r\n        }\r\n      ]\r\n    },\r\n    {\r\n      &quot;country&quot;: &quot;PT&quot;,\r\n      &quot;entities&quot;: [\r\n        {\r\n          &quot;id&quot;: &quot;id1&quot;,\r\n          &quot;level&quot;: &quot;H2&quot;\r\n        },\r\n        {\r\n          &quot;id&quot;: &quot;id2&quot;,\r\n          &quot;level&quot;: &quot;H1&quot;\r\n        }\r\n      ]\r\n    }\r\n  ]\r\n}\r\n```\r\n[Demo](https://jqplay.org/s/A1tvPLh3wNa)",
                "title": "How to group array entries by key and by key value in jq?"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1694723695,
                "creation_date": 1694723695,
                "answer_id": 77108217,
                "question_id": 77108105,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here is one possible solution which uses of the `,` filter which generates multiple outputs for a single input. It also uses the fact that iterating inside an object &quot;multiplies&quot; this object (generating multiple objects, one for each iterated value)\r\n\r\n```\r\n.hits\r\n| group_by(.country)\r\n| map({\r\n    country: first.country,\r\n    entities: map({id,level})\r\n    | (map(select(IN(&quot;H1&quot;,&quot;H2&quot;;.level))), map(select(IN(&quot;H3&quot;,&quot;H4&quot;;.level))))\r\n    | select(length&gt;0)\r\n})\r\n| { hits: . }\r\n```",
                "title": "How to group array entries by key and by key value in jq?"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1694740822,
                "creation_date": 1694740822,
                "answer_id": 77109130,
                "question_id": 77108105,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s a straightforward solution using the generic stream-oriented function `aggregate_by/2`:\r\n```\r\ndef aggregate_by(s; f):\r\n  reduce s as $x  (null; .[$x|f] += [$x]);\r\n\r\naggregate_by(.hits[]; .level)\r\n| [aggregate_by( (.H1 + .H2)[]; .country)] +\r\n  [aggregate_by( (.H3 + .H4)[]; .country)]\r\n| map( to_entries[]\r\n       | {country: .key, entities: (.value | map(del(.country))) } )\r\n| {hits: [ . ]}\r\n\r\n```\r\n\r\nUsing `aggregate_by` here not only makes the solution quite straightforward \r\nonce one understands what it does, but also makes the program relatively efficient in comparison to `group_by/1` in that the latter relies on sorting.\r\n",
                "title": "How to group array entries by key and by key value in jq?"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1694763593,
                "creation_date": 1694763593,
                "answer_id": 77110500,
                "question_id": 77108105,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "In case it is helpful to someone: if we start with something very similar to the [selected answer][1], but with minor changes for readability ([demo][2]): \r\n\r\n```jq\r\n.hits |= [\r\n\r\n  group_by(.country, (.level == &quot;H1&quot; or .level == &quot;H2&quot;)) []\r\n  | { country : first.country, entities: [.[] | { level, id }] }\r\n\r\n]\r\n```\r\n\r\nwe can accommodate an arbitrary complex grouping criteria as follows ([demo][3]):\r\n\r\n```jq\r\ndef transform:\r\n  if    . == &quot;H1&quot; then 1\r\n  elif  . == &quot;H2&quot; then 1\r\n  elif  . == &quot;H3&quot; then 2\r\n  elif  . == &quot;H4&quot; then 2\r\n  else  3\r\n  end;\r\n\r\n.hits |= [\r\n group_by(.country, (.level | transform)) []\r\n | { country : first.country, entities: [.[] | del(.country) ] }\r\n]\r\n```\r\n\r\nIt also keeps all properties except `.country` instead of having to provide a whitelist of values.\r\n\r\n\r\n  [1]: https://stackoverflow.com/a/77108216/84940\r\n  [2]: https://jqplay.org/s/Uxa_YJC8yl6\r\n  [3]: https://jqplay.org/s/e3jDkn5yM6G",
                "title": "How to group array entries by key and by key value in jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 4,
        "score": 0,
        "last_activity_date": 1694763593,
        "creation_date": 1694722435,
        "last_edit_date": 1694740861,
        "question_id": 77108105,
        "body_markdown": "Given this json:\r\n\r\n    {\r\n      &quot;hits&quot;: [\r\n        {\r\n          &quot;country&quot;: &quot;PT&quot;,\r\n          &quot;level&quot;: &quot;H2&quot;,\r\n          &quot;id&quot;: &quot;id1&quot;\r\n        },\r\n        {\r\n          &quot;country&quot;: &quot;PT&quot;,\r\n          &quot;level&quot;: &quot;H1&quot;,\r\n          &quot;id&quot;: &quot;id2&quot;\r\n        },\r\n        {\r\n          &quot;country&quot;: &quot;CZ&quot;,\r\n          &quot;level&quot;: &quot;H2&quot;,\r\n          &quot;id&quot;: &quot;id3&quot;\r\n        },\r\n        {\r\n          &quot;country&quot;: &quot;IT&quot;,\r\n          &quot;level&quot;: &quot;H2&quot;,\r\n          &quot;id&quot;: &quot;id4&quot;\r\n        },\r\n        {\r\n          &quot;country&quot;: &quot;PT&quot;,\r\n          &quot;level&quot;: &quot;H3&quot;,\r\n          &quot;id&quot;: &quot;id5&quot;\r\n        },\r\n        {\r\n          &quot;country&quot;: &quot;PT&quot;,\r\n          &quot;level&quot;: &quot;H3&quot;,\r\n          &quot;id&quot;: &quot;id6&quot;\r\n        },\r\n        {\r\n          &quot;country&quot;: &quot;PT&quot;,\r\n          &quot;level&quot;: &quot;H4”,\r\n          &quot;id&quot;: &quot;id7&quot;\r\n        }\r\n      ]\r\n    }\r\n\r\nI would like to group this by country and in two levels, one having the H1 and H2 entries, and the other having the H3 and H4 entries. Furthermore, I would like that ids and levels to be encapsulated in an object called &quot;entities&quot; like follows:\r\n\r\n    {\r\n      &quot;hits&quot;: [\r\n        {\r\n          &quot;country&quot;: &quot;PT&quot;,\r\n          &quot;entities&quot;: [\r\n            {\r\n              &quot;id&quot;: &quot;id2&quot;,\r\n              &quot;level&quot;: &quot;H1&quot;\r\n            },\r\n            {\r\n              &quot;id&quot;: &quot;id1&quot;,\r\n              &quot;level&quot;: &quot;H2&quot;\r\n            }\r\n          ]\r\n        },\r\n        {\r\n          &quot;country&quot;: &quot;CZ&quot;,\r\n          &quot;entities&quot;: [\r\n            {\r\n              &quot;id&quot;: &quot;id3&quot;,\r\n              &quot;level&quot;: &quot;H2&quot;\r\n            }\r\n          ]\r\n        },\r\n        {\r\n          &quot;country&quot;: &quot;IT&quot;,\r\n          &quot;entities&quot;: [\r\n            {\r\n              &quot;id&quot;: &quot;id4&quot;,\r\n              &quot;level&quot;: &quot;H2&quot;\r\n            }\r\n          ]\r\n        },\r\n        {\r\n          &quot;country&quot;: &quot;PT&quot;,\r\n          &quot;entities&quot;: [\r\n            {\r\n              &quot;id&quot;: &quot;id5&quot;,\r\n              &quot;level&quot;: &quot;H3&quot;\r\n            },\r\n            {\r\n              &quot;id&quot;: &quot;id6&quot;,\r\n              &quot;level&quot;: &quot;H3&quot;\r\n            },\r\n            {\r\n              &quot;id&quot;: &quot;id7&quot;,\r\n              &quot;level&quot;: &quot;H4&quot;\r\n            },\r\n          ]\r\n        }\r\n      ]\r\n    }\r\n\r\nI am quite new to jq. Could anyone help me doing this in jq?",
        "link": "https://stackoverflow.com/questions/77108105/how-to-group-array-entries-by-key-and-by-key-value-in-jq",
        "title": "How to group array entries by key and by key value in jq?"
    },
    {
        "tags": [
            "powershell",
            "variables",
            "curl",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 3804027,
                    "reputation": 10300,
                    "user_id": 3156906,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/a5d8efdd5ae8f58ab54d6c046d09f066?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "mclayton",
                    "link": "https://stackoverflow.com/users/3156906/mclayton"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1694806205,
                "post_id": 77114292,
                "comment_id": 135944533,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 19375,
                    "reputation": 447959,
                    "user_id": 45375,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/39f6e2dc52425b1e08027c01bb880be0?s=256&d=identicon&r=PG",
                    "display_name": "mklement0",
                    "link": "https://stackoverflow.com/users/45375/mklement0"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1694807156,
                "post_id": 77114292,
                "comment_id": 135944700,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 19375,
                    "reputation": 447959,
                    "user_id": 45375,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/39f6e2dc52425b1e08027c01bb880be0?s=256&d=identicon&r=PG",
                    "display_name": "mklement0",
                    "link": "https://stackoverflow.com/users/45375/mklement0"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1694827952,
                "post_id": 77114292,
                "comment_id": 135946684,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 29454676,
                    "reputation": 31,
                    "user_id": 22570810,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/76f10e22681e7cc2189e7379c32ae182?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Michel Mouchon",
                    "link": "https://stackoverflow.com/users/22570810/michel-mouchon"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1695132548,
                "post_id": 77114292,
                "comment_id": 135981243,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "is_answered": false,
        "answer_count": 0,
        "score": 0,
        "last_activity_date": 1694798531,
        "creation_date": 1694798531,
        "question_id": 77114292,
        "body_markdown": "I have Curl + jq sentence that works well in command line : \r\n**C:\\WINDOWS\\system32&gt;curl -k -u user:password -Ss http://10.0.0.2:5252/xxx | jq -r &quot;.list|.items&quot; | jq &quot;.[]|select(.text==\\&quot;RL/for_01.01.00\\&quot;)&quot;| jq -r &quot;.number&quot;\r\n01.01.00**\r\nit return this 01.01.00 value \r\nI need to have it into a Variable to reuse it late into my pipeline. but impossible to make it.\r\n\r\n\r\n\r\n\r\n\r\nI tried this with no success : \r\n\r\n- task: PowerShell@2\r\n  inputs:\r\n    targetType: &#39;inline&#39;\r\n    script: |\r\n      Write-Host &quot;Retrieve the Version# from Branch name&quot;\r\n        $version=$(echo $(curl -k -u user:password -Ss http://10.0.0.2:5252/xxx | jq -r &#39;.list|.items&#39;| jq &quot;.[]|select(.text==\\&quot;$(Build.SourceBranchName)\\&quot;)&quot; | jq -r &#39;.number&#39;))\r\n        Write-Host &quot;##vso[task.setvariable variable=version]$version&quot;\r\n\r\nit alway return this \r\nAt E:\\azureDevOpsAgents\\_work\\_temp\\a0a21d4a-f6e6-4526-8711-d42b8a06a5f1.ps1:4 char:34\r\n+   $version=$(echo $(curl -k -u ***:*** -Ss http://10 ...\r\n+                             ~~\r\n    + CategoryInfo          : InvalidArgument: (:) [Invoke-WebRequest], ParentContainsErrorRecordException\r\n    + FullyQualifiedErrorId : AmbiguousParameter,Microsoft.PowerShell.Commands.InvokeWebRequestCommand\r\n \r\nIt seem to do not acces at all this syntaxe\r\nHa some one an Idea of the wau to put my cURL + JQ filtering result into a variable ?",
        "link": "https://stackoverflow.com/questions/77114292/store-result-of-curl-jq-into-a-variable-usable-in-powershell-used-in-azure-pi",
        "title": "store Result of curl + jq into a Variable usable in powershell (used in AZURE Pipeline script)"
    },
    {
        "tags": [
            "bash",
            "curl",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1694805782,
                "post_id": 77114902,
                "comment_id": 135944463,
                "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": 1694805798,
                "post_id": 77114902,
                "comment_id": 135944464,
                "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": 1694805864,
                "post_id": 77114902,
                "comment_id": 135944474,
                "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": 1694805977,
                "post_id": 77114902,
                "comment_id": 135944492,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "reply_to_user": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1694806024,
                "post_id": 77114902,
                "comment_id": 135944500,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 11698906,
                    "reputation": 3549,
                    "user_id": 8564731,
                    "user_type": "registered",
                    "profile_image": "https://lh4.googleusercontent.com/-YS7UCJcQ0-Q/AAAAAAAAAAI/AAAAAAAAACg/55XwHWieOlI/s256-rj/photo.jpg",
                    "display_name": "Jeremy Fiel",
                    "link": "https://stackoverflow.com/users/8564731/jeremy-fiel"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1694807799,
                "post_id": 77114902,
                "comment_id": 135944806,
                "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": 1694809216,
                "post_id": 77114902,
                "comment_id": 135945001,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "is_answered": false,
        "answer_count": 0,
        "score": 0,
        "last_activity_date": 1694805651,
        "creation_date": 1694805651,
        "question_id": 77114902,
        "body_markdown": "```\r\n#!/bin/bash\r\n\r\nDATA=$(curl -X GET https://$BASEURL/rest/api/latest/repos \\\r\n   -H &quot;accept: application/json&quot; \\\r\n   -H &quot;authorization: Bearer $APIKEY&quot; \\\r\n   | jq -c &#39;[ .values[] | {project: .slug, repo: .project.key}] &#39;)\r\n\r\necho $DATA\r\nfor repo in &quot;${DATA[@]}&quot;\r\n\r\ndo \r\nPROJ=$(jq -r &#39;.[] | .project&#39; &lt;&lt;&lt; $repo)\r\nREPO=$(jq -r &#39;.[] | .repo&#39; &lt;&lt;&lt; $repo)\r\n\r\necho $PROJ\r\necho $REPO\r\ndone;\r\n```\r\n\r\nexpected `$DATA` to be an array of objects with two properties `project, repo`\r\n\r\nthen I want to loop through each object in the `$DATA` array and extract the value for each property and store it in a variable.\r\n\r\nthen print the variables to stdout. \r\n\r\nI can&#39;t figure out why `$repo` is another array. My understanding is using the syntax `&quot;${array[@]}&quot;` allows the variable `$repo` to reach into each index of the `DATA` array. \r\n\r\nThis brings me to why I&#39;m tryin to parse that with jq in a subshell.  I thought I would be able to do something like `$repo[&quot;project&quot;]` to extract the value but it&#39;s not working.\r\n\r\nthe output shows\r\n\r\n```bash\r\n# from echo $DATA, this seems to be correct.\r\n[{&quot;project&quot;: &quot;some_proj_name&quot;, &quot;repo&quot;: &quot;repo_name&quot; }, {...} ...]\r\n\r\n# from for loop subshells \r\n# echo $PROJ \r\nsome_proj_namepy\r\n# echo $REPO\r\nrepo_nameaflsdkd\r\n```\r\nI have no idea where those extra characters are coming from\r\n",
        "link": "https://stackoverflow.com/questions/77114902/bash-for-loop-printing-additional-characters-from-jq-output",
        "title": "Bash for loop printing additional characters from jq output"
    },
    {
        "tags": [
            "bash",
            "ansible",
            "jq",
            "fish"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1694821680,
                "creation_date": 1694821680,
                "answer_id": 77115829,
                "question_id": 77115828,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "One way to do this is to use the `ansible-inventory` command and then use the `json` `ANSIBLE_STDOUT_CALLBACK` but first `ANSIBLE_LOAD_CALLBACK_PLUGINS` [needs to be enabled][1] and pipe the output to `jq` for processing just the IPS. Here is a the command, adjust the `--limit` pattern (or remove for all) and the `--inventory` path: \r\n\r\nFish: Create test file\r\n```fish\r\necho &quot;all:\r\n  children:\r\n    resolvers:\r\n      hosts:\r\n        host1:\r\n          ansible_host: 8.8.8.8\r\n        host2:\r\n          ansible_host: 8.8.4.4\r\n        host3:\r\n          ansible_host: 1.1.1.1\r\n  hosts:\r\n    otherhost:\r\n      ansible_host: 192.168.1.1&quot; &gt; /tmp/inventory.yml\r\n```\r\n\r\nBash: Create test file\r\n```bash\r\ncat &gt; /tmp/inventory.yml &lt;&lt;EOF\r\nall:\r\n  children:\r\n    resolvers:\r\n      hosts:\r\n        host1:\r\n          ansible_host: 8.8.8.8\r\n        host2:\r\n          ansible_host: 8.8.4.4\r\n        host3:\r\n          ansible_host: 1.1.1.1\r\n  hosts:\r\n    otherhost:\r\n      ansible_host: 192.168.1.1\r\nEOF\r\n\r\n```\r\n\r\nThen, output just the IPS:\r\n\r\n```shell\r\nANSIBLE_LOAD_CALLBACK_PLUGINS=yes \\\r\nANSIBLE_STDOUT_CALLBACK=json \\\r\nansible-inventory \\\r\n    --inventory /tmp/inventory.yml \\\r\n    --list \\\r\n        | jq --raw-output &#39;\r\n            ._meta[] \r\n            | to_entries[] \r\n            | .value.ansible_host\r\n          &#39;\r\n```\r\n\r\nOutput:\r\n```log\r\n8.8.8.8\r\n8.8.4.4\r\n1.1.1.1\r\n192.168.1.1\r\n```\r\n\r\nOr output specific IPS with `--limit` filter, use * for wildcard:\r\n```shell\r\nANSIBLE_LOAD_CALLBACK_PLUGINS=yes \\\r\nANSIBLE_STDOUT_CALLBACK=json \\\r\nansible-inventory \\\r\n    --inventory /tmp/inventory.yml \\\r\n    --limit &quot;resolv*&quot; \\\r\n    --list \\\r\n        | jq --raw-output &#39;\r\n            ._meta[] \r\n            | to_entries[] \r\n            | .value.ansible_host\r\n          &#39;\r\n```\r\n\r\nOutput:\r\n```log\r\n8.8.8.8\r\n8.8.4.4\r\n1.1.1.1\r\n```\r\n\r\n  [1]: https://github.com/ansible/ansible/issues/16194#issuecomment-311340681",
                "title": "How to get a list of IPs from Ansible yml inventory for use in a shell script?"
            },
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1694843721,
                "creation_date": 1694843721,
                "answer_id": 77116543,
                "question_id": 77115828,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The query can be simplified\r\n\r\n```bash\r\nshell&gt; ansible-inventory -i inventory.yml --list | jq -r &#39;._meta[][].ansible_host&#39;\r\n8.8.8.8\r\n8.8.4.4\r\n1.1.1.1\r\n192.168.1.1\r\n```\r\n",
                "title": "How to get a list of IPs from Ansible yml inventory for use in a shell script?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1694843721,
        "creation_date": 1694821680,
        "last_edit_date": 1694822024,
        "question_id": 77115828,
        "body_markdown": "How to get a list of all the IPs in an Ansible inventory for a pattern, for use in a script outside of Ansible? ",
        "link": "https://stackoverflow.com/questions/77115828/how-to-get-a-list-of-ips-from-ansible-yml-inventory-for-use-in-a-shell-script",
        "title": "How to get a list of IPs from Ansible yml inventory for use in a shell script?"
    },
    {
        "tags": [
            "json",
            "batch-file",
            "cmd",
            "jq",
            "instana"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1694912507,
                "post_id": 77120085,
                "comment_id": 135953685,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 6606826,
                    "reputation": 47,
                    "user_id": 5103413,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/e01be29a5ca876782d9c570e13505dce?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Beavis",
                    "link": "https://stackoverflow.com/users/5103413/beavis"
                },
                "reply_to_user": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1694913569,
                "post_id": 77120085,
                "comment_id": 135953744,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1694914285,
                "post_id": 77120085,
                "comment_id": 135953786,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1694914127,
                "creation_date": 1694914127,
                "answer_id": 77120180,
                "question_id": 77120085,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "For multiple input files, you can create another array around all of them using the `--slurp` (or `-s` option), then use `map` on that:\r\n```sh\r\njq -s &#39;map(.items[] | {…})&#39; *.json\r\n```\r\n[Demo](https://jqplay.org/s/VBhllDZcLVt)\r\n\r\nOr programmatically iterate (e.g.using `reduce`) over each input (using `inputs` in combination with the `--null-input` (or `-n`) flag):\r\n```sh\r\njq -n &#39;reduce inputs as {$items} ([]; . + [$items[] | {…}])&#39; *.json\r\n```\r\n[Demo](https://jqplay.org/s/6TmFbubF6cI)",
                "title": "Merging Instana EUM JSONs with JQ in CMD"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1694963329,
                "last_edit_date": 1694963329,
                "creation_date": 1694934754,
                "answer_id": 77120833,
                "question_id": 77120085,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I&#39;m sorry. I&#39;m afraid I don&#39;t know Instana nor JQ enough in order to exactly understand what you need... You have _not_ show your desired final output file either... However, I _do_ know Batch files enough!\r\n\r\nThe pure Batch file below process all `*.json` files and extract your &quot;needed data elements&quot; as you show above. This is a first step to get the right solution, because this Batch file could be modified in any way you need.\r\n\r\n    @echo off\r\n    setlocal\r\n    \r\n    for %%f in (*.json) do (\r\n       set &quot;url=&quot;\r\n       for /F &quot;tokens=2,3 delims=[:,] &quot; %%a in (&#39;findstr &quot;name uniqueSessions&quot; &quot;%%f&quot;&#39;) do (\r\n          if not defined url (\r\n             echo &quot;url&quot;: %%a\r\n             set &quot;url=%%a&quot;\r\n          ) else (\r\n             echo &quot;date&quot;: %%a\r\n             echo &quot;load&quot;: %%~Nb\r\n             set &quot;url=&quot;\r\n          )\r\n       )\r\n    )\r\n\r\nOutput example:\r\n\r\n    &quot;url&quot;: &quot;page1.htm&quot;\r\n    &quot;date&quot;: 1675292400000\r\n    &quot;load&quot;: 4\r\n    &quot;url&quot;: &quot;page2.htm&quot;\r\n    &quot;date&quot;: 1675292400000\r\n    &quot;load&quot;: 1\r\n    &quot;url&quot;: &quot;page3.htm&quot;\r\n    &quot;date&quot;: 1675292400000\r\n    &quot;load&quot;: 7\r\n    &quot;url&quot;: &quot;page4.htm&quot;\r\n    &quot;date&quot;: 1675292400000\r\n    &quot;load&quot;: 3\r\n    &quot;url&quot;: &quot;page5.htm&quot;\r\n    &quot;date&quot;: 1675292400000\r\n    &quot;load&quot;: 6\r\n    &quot;url&quot;: &quot;page6.htm&quot;\r\n    &quot;date&quot;: 1675292400000\r\n    &quot;load&quot;: 2\r\n\r\nPerhaps if you show us the desired output file, I could complete the solution\r\n\r\n\r\n",
                "title": "Merging Instana EUM JSONs with JQ in CMD"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1695083352,
                "last_edit_date": 1695083352,
                "creation_date": 1695082085,
                "answer_id": 77130989,
                "question_id": 77120085,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Adding `|jq -s` to what you already have should work: \r\n\r\n```bash\r\ntype *.json | \r\njq &quot;.items[] | {url: .name, date: .metrics[][0][0], load: .metrics[][0][1]}&quot; |\r\njq -s \r\n```\r\n\r\nA trailing `jq -s` can do the array wrapping for you if you have a list of json objects like so:\r\n\r\n```\r\n&#167; cat input-malformed.json \r\n{ &quot;a&quot; : 1,\r\n  &quot;b&quot; : 2 }\r\n{ &quot;a&quot; : 11,\r\n  &quot;b&quot; : 22 }\r\n\r\n&#167; cat input-malformed.json | jq -s\r\n[\r\n  {\r\n    &quot;a&quot;: 1,\r\n    &quot;b&quot;: 2\r\n  },\r\n  {\r\n    &quot;a&quot;: 11,\r\n    &quot;b&quot;: 22\r\n  }\r\n]\r\n```\r\n\r\nI don&#39;t have a Windows machine handy, but the bash equivalent on jq version 1.6 works (where a.json and b.json are copies of your input JSON documents):\r\n\r\n```bash\r\ncat a.json b.json | \r\njq &quot;.items[] | {url: .name, date: .metrics[][0][0], load: .metrics[][0][1]}&quot; |\r\njq -s \r\n``` ",
                "title": "Merging Instana EUM JSONs with JQ in CMD"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 1,
        "last_activity_date": 1695083352,
        "creation_date": 1694910947,
        "question_id": 77120085,
        "body_markdown": "I&#39;m using Instana to deliver view stats on my site, each daily file looks like this:\r\n\r\n```\r\n{\r\n  &quot;items&quot; : [ {\r\n    &quot;name&quot; : &quot;page1.htm&quot;,\r\n    &quot;earliestTimestamp&quot; : 1675222177839,\r\n    &quot;cursor&quot; : {\r\n      &quot;@class&quot; : &quot;.IngestionOffsetCursor&quot;,\r\n      &quot;ingestionTime&quot; : 1675292168217,\r\n      &quot;offset&quot; : 1\r\n    },\r\n    &quot;metrics&quot; : {\r\n      &quot;uniqueSessions.distinct_count&quot; : [ [ 1675292400000, 4.0 ] ]\r\n    }\r\n  }, {\r\n    &quot;name&quot; : &quot;page2.htm&quot;,\r\n    &quot;earliestTimestamp&quot; : 1675260035165,\r\n    &quot;cursor&quot; : {\r\n      &quot;@class&quot; : &quot;.IngestionOffsetCursor&quot;,\r\n      &quot;ingestionTime&quot; : 1675292168217,\r\n      &quot;offset&quot; : 2\r\n    },\r\n    &quot;metrics&quot; : {\r\n      &quot;uniqueSessions.distinct_count&quot; : [ [ 1675292400000, 1.0 ] ]\r\n    }\r\n  }, {\r\n    &quot;name&quot; : &quot;page3.htm&quot;,\r\n    &quot;earliestTimestamp&quot; : 1675228447118,\r\n    &quot;cursor&quot; : {\r\n      &quot;@class&quot; : &quot;.IngestionOffsetCursor&quot;,\r\n      &quot;ingestionTime&quot; : 1675292168217,\r\n      &quot;offset&quot; : 3\r\n    },\r\n    &quot;metrics&quot; : {\r\n      &quot;uniqueSessions.distinct_count&quot; : [ [ 1675292400000, 7.0 ] ]\r\n    }\r\n  } ],\r\n  &quot;canLoadMore&quot; : false,\r\n  &quot;totalHits&quot; : 12,\r\n  &quot;totalRepresentedItemCount&quot; : 12,\r\n  &quot;totalRetainedItemCount&quot; : 12,\r\n  &quot;adjustedTimeframe&quot; : {\r\n    &quot;windowSize&quot; : 86400000,\r\n    &quot;to&quot; : 1675292400000\r\n  }\r\n}\r\n```\r\n\r\nThese daily files should be merged into one json after filtering for the necessary info:\r\n\r\n- url (from name)\r\n\r\n- date (first value in &quot;uniqueSessions.distinct_count&quot;)\r\n\r\n- number of page visits: (second value in &quot;uniqueSessions.distinct_count&quot;)  \r\n  It is important, that it has to be done in CMD, since I have to use a batch file as the target user is not allowed to run PowerShell scripts, nor have access to any other CL tool.\r\n\r\nSo far, I managed to boil down the files to the needed data elements as separate JSON objects using:  `type *.json | jq &quot;.items[] | {url: .name, date: .metrics[][0][0], load: .metrics[][0][1]}&quot;`\r\n\r\nthe result looks like:\r\n\r\n```\r\n{\r\n  &quot;url&quot;: &quot;page1.htm&quot;,\r\n  &quot;date&quot;: 1675292400000,\r\n  &quot;load&quot;: 4\r\n}\r\n{\r\n  &quot;url&quot;: &quot;page1.htm&quot;,\r\n  &quot;date&quot;: 1675292400000,\r\n  &quot;load&quot;: 1\r\n}\r\n{\r\n  &quot;url&quot;: &quot;page1.htm&quot;,\r\n  &quot;date&quot;: 1675292400000,\r\n  &quot;load&quot;: 7\r\n}\r\n```\r\n\r\nhowever, if I try to wrap it in square brackets (as tutorials suggest) to get a valid JSON,  I get one file with a bunch of arrays starting and ending where they did in the original files.  \r\nI did the homework, and  am aware of this: &lt;https://stackoverflow.com/questions/70573060/combining-multiple-json-files-into-a-single-json-file-with-jq-filters&gt; actually, I played around with this for a while now before asking. I was thinking if I could add again curly brackets and a root node, it would help, but I haven&#39;t found a way where JQ wouldn&#39;t fail to do noting, that most probably the error comes from windows cmd&#39;s quotation mark usage.\r\n\r\nHow can I make this into one JSON instead of as many arrays as many source files?  Thanks!",
        "link": "https://stackoverflow.com/questions/77120085/merging-instana-eum-jsons-with-jq-in-cmd",
        "title": "Merging Instana EUM JSONs with JQ in CMD"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1695059410,
                "creation_date": 1695059410,
                "answer_id": 77129388,
                "question_id": 77129356,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You have to concatenate the literal part with the variable, and make it a key identifier:\r\n```sh\r\n# using string interpolation\r\njq --arg BAR &quot;$BAR&quot; &#39;del(.packages.&quot;foo/\\($BAR)&quot;.version)&#39;\r\n\r\n# using string addition\r\njq --arg BAR &quot;$BAR&quot; &#39;del(.packages[&quot;foo/&quot; + $BAR].version)&#39;\r\n```\r\n",
                "title": "How to expand a variable to a key with a slash/special character and use it as an argument in jq"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1695080933,
                "creation_date": 1695080933,
                "answer_id": 77130943,
                "question_id": 77129356,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Using the approach from [this answer][1] is more robust, but if you already exported the environment variable `$BAR`, you could just rely on bash to do the substitution:\r\n\r\n```\r\n&#167; echo &#39;{ &quot;packages&quot; : { &quot;foo/bar&quot; : { &quot;name&quot;: &quot;P1&quot;, &quot;version&quot; : 1 } } }&#39; | \r\n  jq &#39;del(.packages.&quot;foo/&#39;$BAR&#39;&quot;.version)&#39;\r\n```\r\n\r\n```\r\n{\r\n  &quot;packages&quot;: {\r\n    &quot;foo/bar&quot;: {\r\n      &quot;name&quot;: &quot;P1&quot;\r\n    }\r\n  }\r\n}\r\n```\r\n\r\nIf you did not export the variable, you could supply it inline too:\r\n\r\n```\r\n&#167; echo &#39;{ &quot;packages&quot; : { &quot;foo/bar&quot; : { &quot;name&quot;: &quot;P1&quot;, &quot;version&quot; : 1 } } }&#39; | \r\n  BAR=bar jq &#39;del(.packages.&quot;foo/&#39;$BAR&#39;&quot;.version)&#39;\r\n```\r\n\r\n  [1]: https://stackoverflow.com/a/77129388/84940",
                "title": "How to expand a variable to a key with a slash/special character and use it as an argument in jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1695080933,
        "creation_date": 1695059195,
        "question_id": 77129356,
        "body_markdown": "With `jq` I&#39;m trying to delete a node of which its path is a variable that expands to a string with a slash (special character).\r\n\r\nSo, this works (a path with a special character needs to be quoted):\r\n```\r\ncat package-lock.json | jq &#39;del(.packages.&quot;foo/bar&quot;)&#39; &gt; package-lock-new.json\r\n```\r\nAnd this works (adding an argument from the environment variables):\r\n```\r\nexport ROOT=packages\r\ncat package-lock.json | jq --arg ROOT &quot;$ROOT&quot; &#39;del(.$ROOT.&quot;foo/bar&quot;)&#39; &gt; package-lock-new.json\r\n```\r\nHowever, combined - expanding the environment variable in a quoted path - does not work:\r\n```\r\nexport BAR=bar\r\ncat package-lock.json | jq --arg BAR &quot;$BAR&quot; &#39;del(.packages.&quot;foo/$BAR&quot;.version)&#39; &gt; package-lock-new.json\r\n```\r\n\r\nWhat would be the right escaping for `jq`?",
        "link": "https://stackoverflow.com/questions/77129356/how-to-expand-a-variable-to-a-key-with-a-slash-special-character-and-use-it-as-a",
        "title": "How to expand a variable to a key with a slash/special character and use it as an argument in jq"
    },
    {
        "tags": [
            "json",
            "path",
            "jq",
            "keypaths"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1695122303,
                "creation_date": 1695122303,
                "answer_id": 77134076,
                "question_id": 77133925,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "With `paths` function, filtering out array indices of object keys and collecting unique paths:\r\n\r\n    jq &#39;[paths(.) | map(select(type != &quot;number&quot;)) | join(&quot;.&quot;)] | unique[]&#39; test.json \r\n\r\n\r\n----------\r\n\r\n    &quot;results&quot;\r\n    &quot;results.branches&quot;\r\n    &quot;results.branches.city&quot;\r\n    &quot;results.branches.customers&quot;\r\n    &quot;results.branches.customers.id&quot;\r\n    &quot;results.branches.customers.name&quot;\r\n    &quot;results.branches.id&quot;\r\n    &quot;results.id&quot;\r\n    &quot;results.name&quot;\r\n\r\n",
                "title": "How to produce a list of all unique key path from a given JSON"
            },
            {
                "up_vote_count": 4,
                "is_accepted": false,
                "score": 4,
                "last_activity_date": 1695124699,
                "last_edit_date": 1695124699,
                "creation_date": 1695123616,
                "answer_id": 77134233,
                "question_id": 77133925,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You could `map` the `paths` to only contain `strings`, then drop the duplicates using `unique`, and `join` the items by providing a delimiter:\r\n```sh\r\njq -r &#39;[paths | map(strings)] | unique[] | join(&quot;.&quot;)&#39;\r\n```\r\n```json\r\nresults\r\nresults.branches\r\nresults.branches.city\r\nresults.branches.customers\r\nresults.branches.customers.id\r\nresults.branches.customers.name\r\nresults.branches.id\r\nresults.id\r\nresults.name\r\n```\r\n[Demo](https://jqplay.org/s/WX5qwPD-n76)\r\n\r\nTo retain the document order (`unique` also sorts the array), you could deduplicate the list by using the joined paths as (unique-by-definition) object fields instead:\r\n```sh\r\njq -r &#39;[paths | map(strings) | join(&quot;.&quot;) | {(.):.}] | add[]&#39;\r\n```\r\n```json\r\nresults\r\nresults.id\r\nresults.name\r\nresults.branches\r\nresults.branches.id\r\nresults.branches.city\r\nresults.branches.customers\r\nresults.branches.customers.id\r\nresults.branches.customers.name\r\n```\r\n[Demo](https://jqplay.org/s/mZxtOZ1hpeW)",
                "title": "How to produce a list of all unique key path from a given JSON"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1697593122,
                "last_edit_date": 1697593122,
                "creation_date": 1695203346,
                "answer_id": 77141240,
                "question_id": 77133925,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s a solution that outputs the following to make it clear where the arrays are as well:\r\n\r\n```\r\nresults[]\r\nresults[].branches[]\r\nresults[].branches[].city\r\nresults[].branches[].customers[]\r\nresults[].branches[].customers[].id\r\nresults[].branches[].customers[].name\r\nresults[].branches[].id\r\nresults[].id\r\nresults[].name\r\n```\r\nThis is quite handy to see the &quot;shape&quot; of the JSON quickly before manipulating it. \r\n\r\nIf you have this code in a script called `show-shape.jq` ([demo][1]):\r\n\r\n```jq\r\n#! /usr/local/bin/jq -r -f \r\n\r\ndef extract:\r\n    [ paths \r\n    | [ .[] | if type == &quot;number&quot; then &quot;[]&quot; else . end ] \r\n    | join (&quot;.&quot;) ] ;\r\n\r\ndef longest:\r\n    . | sort_by(length) | reverse| .[0] ; \r\n\r\ndef clean:\r\n    [ .[] | gsub(&quot;[.][[]]&quot;; &quot;[]&quot;) ]  \r\n    | group_by(. | rtrimstr(&quot;[]&quot;)) \r\n    | [ .[] | longest ];\r\n\r\ndef show:\r\n    extract | sort | unique | clean | .[];\r\n    \r\nshow\r\n```\r\n\r\nYou can use it as follows:\r\n\r\n```\r\ncat some.json | show-shape.jq\r\n```\r\n\r\nExample:\r\n\r\n```\r\n&#167; echo &#39;{&quot;x&quot;:{&quot;a&quot;:1,&quot;b&quot;:[{&quot;c&quot;:1},{&quot;c&quot;:2}],&quot;d&quot;:{&quot;e&quot;:1}}}&#39; | show-shape.jq \r\n\r\nx\r\nx.a\r\nx.b[]\r\nx.b[].c\r\nx.d\r\nx.d.e\r\n```\r\n\r\nNotice the distinction between how `x.b[].c` and `x.d.e` are displayed.\r\n\r\nOne shortcoming of the script, thuogh, is that it does not show a trailing `[]` for an empty array:\r\n\r\n```\r\n&#167; echo &#39;{ &quot;a&quot; : [1] }&#39; | show-json-shape.jq \r\na[]\r\n&#167; echo &#39;{ &quot;a&quot; : [] }&#39; | show-json-shape.jq \r\na\r\n```\r\n  [1]: https://jqplay.org/s/i5sVvOhxA3h",
                "title": "How to produce a list of all unique key path from a given JSON"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 2,
        "last_activity_date": 1697593122,
        "creation_date": 1695120854,
        "last_edit_date": 1695181310,
        "question_id": 77133925,
        "body_markdown": "I would like to produce a list of all unique key path from a given JSON, each one in a line.\r\n\r\nFor example, from this input JSON:\r\n\r\n    {\r\n       &quot;results&quot;:[\r\n          {\r\n             &quot;id&quot;:306,\r\n             &quot;name&quot;:&quot;First Company&quot;,\r\n             &quot;branches&quot;:[\r\n                {\r\n                   &quot;id&quot;:4191,\r\n                   &quot;city&quot;:&quot;San Francisco&quot;,\r\n                   &quot;customers&quot;:[\r\n                      {\r\n                         &quot;id&quot;:446,\r\n                         &quot;name&quot;:&quot;Big Tech 1&quot;\r\n                      },\r\n                      {\r\n                         &quot;id&quot;:447,\r\n                         &quot;name&quot;:&quot;Big Tech 2&quot;\r\n                      }\r\n                   ]\r\n                },\r\n                {\r\n                   &quot;id&quot;:4192,\r\n                   &quot;city&quot;:&quot;Miami&quot;,\r\n                   &quot;customers&quot;:[\r\n                      {\r\n                         &quot;id&quot;:448,\r\n                         &quot;name&quot;:&quot;Insurance Tech 1&quot;\r\n                      },\r\n                      {\r\n                         &quot;id&quot;:449,\r\n                         &quot;name&quot;:&quot;Health Tech 2&quot;\r\n                      }\r\n                   ]\r\n                }\r\n             ]\r\n          }\r\n       ]\r\n    }\r\n\r\nI would like to produce this output:\r\n\r\n      results\r\n      results.id\r\n      results.name\r\n      results.branches\r\n      results.branches.id\r\n      results.branches.city\r\n      results.branches.customers\r\n      results.branches.customers.id\r\n      results.branches.customers.name\r\n\r\nI am struggling with the command line below but it is not working.\r\n\r\n    jq &#39;\r\n    def path(k):\r\n      if k | type == &quot;object&quot;:\r\n        reduce(.keys[] | path(.), k)\r\n      else:\r\n        [k]\r\n    ;\r\n    \r\n    .[] | path(&quot;.&quot;) | flatten | sort&#39; example.json\r\n\r\nAny help, please?\r\n",
        "link": "https://stackoverflow.com/questions/77133925/how-to-produce-a-list-of-all-unique-key-path-from-a-given-json",
        "title": "How to produce a list of all unique key path from a given JSON"
    },
    {
        "tags": [
            "json",
            "jq",
            "flatten",
            "json-flattener"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1695126017,
                "last_edit_date": 1695126017,
                "creation_date": 1695125435,
                "answer_id": 77134445,
                "question_id": 77134418,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Iterate and nest:\r\n```sh\r\njq -r &#39;\r\n  .results[] | [.id, .name] + (\r\n    .branches[] | [.id, .city] + (\r\n      .customers[] | [.id, .name]\r\n    )\r\n  ) | @tsv\r\n&#39;\r\n```\r\n```csv\r\n306\tFirst Company\t4191\tSeattle\t446\tBig Tech 1\r\n306\tFirst Company\t4191\tSeattle\t447\tBig Tech 2\r\n306\tFirst Company\t4192\tOakland\t448\tHealth Tech 1\r\n306\tFirst Company\t4192\tOakland\t449\tHealth Tech 2\r\n```\r\n[Demo](https://jqplay.org/s/kGqGKrRrxAG)\r\n\r\nTo keep the values JSON-encoded (quotes around strings), you could re-convert them using `@json`\r\n```sh\r\njq -r &#39;\r\n  .results[] | [.id, .name] + (\r\n    .branches[] | [.id, .city] + (\r\n      .customers[] | [.id, .name]\r\n    )\r\n  ) | map(@json) | @tsv\r\n&#39;\r\n```\r\n```csv\r\n306\t&quot;First Company&quot;\t4191\t&quot;Seattle&quot;\t446\t&quot;Big Tech 1&quot;\r\n306\t&quot;First Company&quot;\t4191\t&quot;Seattle&quot;\t447\t&quot;Big Tech 2&quot;\r\n306\t&quot;First Company&quot;\t4192\t&quot;Oakland&quot;\t448\t&quot;Health Tech 1&quot;\r\n306\t&quot;First Company&quot;\t4192\t&quot;Oakland&quot;\t449\t&quot;Health Tech 2&quot;\r\n```\r\n[Demo](https://jqplay.org/s/H6OLyJ4F7vw)\r\n\r\nAlternatively (to the JSON encoding), you could use the `@csv` builtin, which also escapes strings but also separates the items with a comma:\r\n```sh\r\njq -r &#39;\r\n  .results[] | [.id, .name] + (\r\n    .branches[] | [.id, .city] + (\r\n      .customers[] | [.id, .name]\r\n    )\r\n  ) | @csv\r\n&#39;\r\n```\r\n```csv\r\n306,&quot;First Company&quot;,4191,&quot;Seattle&quot;,446,&quot;Big Tech 1&quot;\r\n306,&quot;First Company&quot;,4191,&quot;Seattle&quot;,447,&quot;Big Tech 2&quot;\r\n306,&quot;First Company&quot;,4192,&quot;Oakland&quot;,448,&quot;Health Tech 1&quot;\r\n306,&quot;First Company&quot;,4192,&quot;Oakland&quot;,449,&quot;Health Tech 2&quot;\r\n```\r\n[Demo](https://jqplay.org/s/YdkLeG6yPOC)",
                "title": "How to produce a flat list of all values from a given JSON"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1695157528,
                "last_edit_date": 1695157528,
                "creation_date": 1695147301,
                "answer_id": 77137016,
                "question_id": 77134418,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The following makes various assumptions but only hardcodes &quot;results&quot;, &quot;branches&quot; and &quot;customers&quot;,\r\nand does *not* assume that the ordering of the keys within the customer objects is uniform.\r\nUsing `scalar_keys` in the obvious way, the solution can also be readily extended to allow for greater depth, and\r\nindeed could be generalized to compute the array-valued keys.\r\n```\r\ndef scalar_keys:\r\n  [ keys_unsorted[] as $k\r\n    | .[$k]\r\n    | scalars\r\n    | $k ];\r\n    \r\n.results[]\r\n| [.[scalar_keys[]] ] as $top\r\n| .branches[]\r\n| [.[scalar_keys[]] ] as $intermediate\r\n| .customers\r\n| (first | keys_unsorted) as $keys\r\n| .[]\r\n| $top + $intermediate + [.[$keys[]]]\r\n```\r\n\r\nThis produces arrays, so you will want to tack on a call to `@tsv` or `@csv` or similar.",
                "title": "How to produce a flat list of all values from a given JSON"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1697953162,
                "last_edit_date": 1697953162,
                "creation_date": 1695444322,
                "answer_id": 77161685,
                "question_id": 77134418,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s a simple solution that does not depend on the structure of the JSON ([demo][1], [another demo][2]):\r\n\r\n```jq\r\ndef unroll:\r\n    if type == &quot;object&quot; \r\n    then [.[] | scalars] + ((.[] | iterables | unroll) // [] ) \r\n    elif type == &quot;array&quot; \r\n    then (.[] | unroll)\r\n    else [.] \r\n    end;\r\n    \r\nunroll | @tsv\r\n```\r\n\r\nIt recursively descends through the object graph, but when it encounters an object, it extracts all the scalars so that on the way up (in the recursion), the scalars in the path become one array. When an array is encountered though, it just acts as a pass-through and unrolls the array.\r\n\r\n[1]: https://jqplay.org/s/PJ0FxaegKX4\r\n[2]: https://jqplay.org/s/QYagHsDTxBY",
                "title": "How to produce a flat list of all values from a given JSON"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 1,
        "last_activity_date": 1697953162,
        "creation_date": 1695125227,
        "last_edit_date": 1695151381,
        "question_id": 77134418,
        "body_markdown": "I would like to produce a list of all values from any given JSON. The special requirement is that for values in nested attributes, all the values of parent&#39;s attributes must be repeated in the line. No keys must be printed.\r\n\r\nFor example, from this input JSON:\r\n\r\n    {\r\n       &quot;results&quot;:[\r\n          {\r\n             &quot;id&quot;:306,\r\n             &quot;name&quot;:&quot;First Company&quot;,\r\n             &quot;branches&quot;:[\r\n                {\r\n                   &quot;id&quot;:4191,\r\n                   &quot;city&quot;:&quot;Seattle&quot;,\r\n                   &quot;customers&quot;:[\r\n                      {\r\n                         &quot;id&quot;:446,\r\n                         &quot;name&quot;:&quot;Big Tech 1&quot;\r\n                      },\r\n                      {\r\n                         &quot;id&quot;:447,\r\n                         &quot;name&quot;:&quot;Big Tech 2&quot;\r\n                      }\r\n                   ]\r\n                },\r\n                {\r\n                   &quot;id&quot;:4192,\r\n                   &quot;city&quot;:&quot;Oakland&quot;,\r\n                   &quot;customers&quot;:[\r\n                      {\r\n                         &quot;id&quot;:448,\r\n                         &quot;name&quot;:&quot;Health Tech 1&quot;\r\n                      },\r\n                      {\r\n                         &quot;id&quot;:449,\r\n                         &quot;name&quot;:&quot;Health Tech 2&quot;\r\n                      }\r\n                   ]\r\n                }\r\n             ]\r\n          }\r\n       ]\r\n    }\r\n\r\nI would like to produce this output (please notice the repeated values are highlighted in red, but the output should be with no colors; no keys should be printed):\r\n\r\n[![enter image description here][1]][1]\r\n\r\n\r\n\r\n\r\n  [1]: https://i.sstatic.net/dHx7j.png\r\n\r\nThe JSON above is just an example and generic JSON with arbitrary depth of nesting of JSON objects must be assumed, which suggests that the processing must be recursive. If *null* appears they must be printed as well.\r\n",
        "link": "https://stackoverflow.com/questions/77134418/how-to-produce-a-flat-list-of-all-values-from-a-given-json",
        "title": "How to produce a flat list of all values from a given JSON"
    }
]