[
    {
        "tags": [
            "json",
            "jq",
            "flatten",
            "recursive-datastructures"
        ],
        "answers": [
            {
                "up_vote_count": 5,
                "is_accepted": true,
                "score": 5,
                "last_activity_date": 1617042966,
                "creation_date": 1617042966,
                "answer_id": 66859735,
                "question_id": 66859568,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "`..` is your friend:\r\n\r\n```\r\n.. | objects | select( .id and .text) | {id, category: .text}\r\n```",
                "title": "How do I use jq to flatten a complex json structure?"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1617042968,
                "creation_date": 1617042968,
                "answer_id": 66859736,
                "question_id": 66859568,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If your actual input is that simple, recursively extracting *id* and *text* from each object under *value* should work.\r\n```\r\n[ .value | recurse | objects | {id, category: .text} ]\r\n```\r\n&lt;sup&gt;[Online demo](https://jqplay.org/s/x1_oyREeQW)&lt;/sup&gt;",
                "title": "How do I use jq to flatten a complex json structure?"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1617070227,
                "creation_date": 1617070227,
                "answer_id": 66863886,
                "question_id": 66859568,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "&gt;  I was totally going in the wrong direction \r\n\r\nNot really.  Going in that direction, you would have something like:\r\n\r\n    .value[] \r\n    | recurse(.children[]?) \r\n    | {id, category: .text}",
                "title": "How do I use jq to flatten a complex json structure?"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 2,
        "last_activity_date": 1617079461,
        "creation_date": 1617042190,
        "last_edit_date": 1617079461,
        "question_id": 66859568,
        "body_markdown": "I have the following simplified json structure: Notice an array of values, which have children, whose children could have children.\r\n```\r\n{\r\n  &quot;value&quot;: [\r\n    {\r\n      &quot;id&quot;: &quot;12&quot;,\r\n      &quot;text&quot;: &quot;Beverages&quot;,\r\n      &quot;state&quot;: &quot;closed&quot;,\r\n      &quot;attributes&quot;: null,\r\n      &quot;iconCls&quot;: null\r\n    },\r\n    {\r\n      &quot;id&quot;: &quot;10&quot;,\r\n      &quot;text&quot;: &quot;Foods&quot;,\r\n      &quot;state&quot;: &quot;closed&quot;,\r\n      &quot;attributes&quot;: null,\r\n      &quot;iconCls&quot;: null,\r\n      &quot;children&quot;: [\r\n        {\r\n          &quot;id&quot;: &quot;33&quot;,\r\n          &quot;text&quot;: &quot;Mexican&quot;,\r\n          &quot;state&quot;: &quot;closed&quot;,\r\n          &quot;attributes&quot;: null,\r\n          &quot;iconCls&quot;: null,\r\n          &quot;children&quot;: [\r\n            {\r\n              &quot;id&quot;: &quot;6100&quot;,\r\n              &quot;text&quot;: &quot;Taco&quot;,\r\n              &quot;count&quot;: &quot;3&quot;,\r\n              &quot;attributes&quot;: null,\r\n              &quot;iconCls&quot;: &quot;&quot;\r\n            }\r\n          ]\r\n        }\r\n      ]\r\n    }\r\n  ]\r\n}\r\n```\r\n\r\nHow do I flatten a json structure using jq? I would like to print each element just once, but in a flat structure. An example output:\r\n\r\n```\r\n{\r\n  &quot;id&quot;: &quot;12&quot;,\r\n  &quot;category&quot;: &quot;Beverages&quot;\r\n},\r\n{\r\n  &quot;id&quot;: &quot;10&quot;,\r\n  &quot;category&quot;: &quot;Foods&quot;\r\n},\r\n{\r\n  &quot;id&quot;: &quot;33&quot;,\r\n  &quot;category&quot;: &quot;Mexican&quot;\r\n},\r\n{\r\n  &quot;id&quot;: &quot;6100&quot;,\r\n  &quot;category&quot;: &quot;Tacos&quot;\r\n}\r\n```\r\n\r\nMy attempt doesn&#39;t seem to work at all:\r\n\r\n```\r\ncat simple.json - | jq &#39;.value[] | {id: .id, category: .text} + {id: .children[]?.id, category: .children[]?.text}&#39;\r\n```",
        "link": "https://stackoverflow.com/questions/66859568/how-do-i-use-jq-to-flatten-a-complex-json-structure",
        "title": "How do I use jq to flatten a complex json structure?"
    },
    {
        "tags": [
            "json",
            "csv",
            "export-to-csv",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1617145621,
                "last_edit_date": 1617145621,
                "creation_date": 1617125813,
                "answer_id": 66875818,
                "question_id": 66872649,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "```\r\njq -r &#39;\r\n  [&quot;Size&quot;,&quot;Colour&quot;,&quot;Shape&quot;,&quot;Weight&quot;] as $Keys\r\n  | ([&quot;id&quot;, &quot;vol&quot;] + ($Keys|map(ascii_downcase))),\r\n    ( .[]\r\n     | (.Tags|from_entries) as $dict\r\n     | [.InstanceId, .Vol, $dict[$Keys[]]] )\r\n  | @csv\r\n&#39;\r\n```\r\n\r\nThis will produce valid CSV, with the columns in the desired order, irrespective of the ordering of the items in the .Tags array.\r\n\r\nIf you don&#39;t want the strings in the rows to be quoted, then (at the risk of not having valid CSV) one option to consider would be replacing `@csv` above by `join(&quot;,&quot;)`.  Alternatively, you might wish to consider using `@tsv` and then replacing the tabs by commas (e.g. using `sed` or `tr`or even `jq` :-). \r\n",
                "title": "Export json via jq to csv"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1617154636,
        "creation_date": 1617113588,
        "last_edit_date": 1617154636,
        "question_id": 66872649,
        "body_markdown": "I have this output as test.json ( Its an AWS extract, but I have changed the names )\r\n\r\n    [\r\n        {\r\n            &quot;InstanceId&quot;: &quot;I-1234&quot;,\r\n            &quot;Vol&quot;: &quot;vol-5678&quot;,\r\n            &quot;Delete&quot;: false,\r\n            &quot;State&quot;: &quot;in-use&quot;,\r\n            &quot;Tags&quot;: [\r\n                {\r\n                    &quot;Key&quot;: &quot;Size&quot;,\r\n                    &quot;Value&quot;: &quot;large&quot;\r\n                },\r\n                {\r\n                    &quot;Key&quot;: &quot;Colour&quot;,\r\n                    &quot;Value&quot;: &quot;red&quot;\r\n                },\r\n                {\r\n                    &quot;Key&quot;: &quot;Shape&quot;,\r\n                    &quot;Value&quot;: &quot;square&quot;\r\n                },\r\n                {\r\n                    &quot;Key&quot;: &quot;Weight&quot;,\r\n                    &quot;Value&quot;: &quot;light&quot;\r\n                }\r\n            ]\r\n        }\r\n    ]\r\n\r\nI want to export specific fields, including all tags to a csv, so it looks like this:\r\n\r\n    id,vol,state,size,colour,shape,weight\r\n    value,value,value,value,value,value,value\r\n\r\nI have run this:\r\n\r\ncat test.json | jq -c &#39; {  id: .[].InstanceId, vol: .[].Vol, tags: .[].Tags | map  ( [ .Key, .Value] | join (&quot;:&quot;)) | @csv } &#39; &gt;&gt; test.csv\r\n\r\nAnd it looks like this:\r\n\r\n    cat test.csv\r\n    {&quot;id&quot;:&quot;I-1234&quot;,&quot;vol&quot;:&quot;vol-5678&quot;,&quot;tags&quot;:&quot;\\&quot;Size:large\\&quot;,\\&quot;Colour:red\\&quot;,\\&quot;Shape:square\\&quot;,\\&quot;Weight:25kg\\&quot;&quot;}\r\n\r\nif I open in Excel, looks like:\r\n\r\n    {&quot;id&quot;:&quot;I-1234&quot;\tvol:&quot;vol-5678&quot;\ttags:&quot;\\&quot;Size:large\\&quot;\t\\&quot;Colour:red\\&quot;\t\\&quot;Shape:square\\&quot;\t\\&quot;Weight:25kg\\&quot;&quot;}\r\n\r\nI will be looping this over many aws resources, and would like to keep appending to csv.\r\n\r\n    I want to remove \r\n    { } at beginning and end.\r\n\r\n    the key description I would like at top as a header, rather than to the left of the value..\r\n    \r\n        so for: &quot;id&quot;:&quot;I-1234&quot;\tvol:&quot;vol-5678&quot;\r\n        I would like\r\n        id, vol\r\n        I-1234, vol-5678\r\n    \r\n    and the same with the Tags\r\n    remove the Array Name: &quot;tags:&quot; ( think its the array name, I&#39;m not a developer, infrastructure dude! ) and just leave\r\n    Size,Colour,Shape,Weight, ...\r\n    large,red,square,25kg, ...\r\n    \r\n    Can anyone help, point me in the right direction ..\r\n    thanks .. :)\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/66872649/export-json-via-jq-to-csv",
        "title": "Export json via jq to csv"
    },
    {
        "tags": [
            "powershell",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1617120595,
                "post_id": 66873163,
                "comment_id": 118212157,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 945128,
                    "reputation": 75,
                    "user_id": 972506,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/1ef21533e360590527655e429ac5a269?s=256&d=identicon&r=PG",
                    "display_name": "user972506",
                    "link": "https://stackoverflow.com/users/972506/user972506"
                },
                "reply_to_user": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1617702278,
                "post_id": 66873163,
                "comment_id": 118371379,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "is_answered": false,
        "answer_count": 0,
        "score": 0,
        "last_activity_date": 1617115292,
        "creation_date": 1617115292,
        "question_id": 66873163,
        "body_markdown": "I&#39;ve got a command. lets call it &quot;gc listen&quot;.\r\nThat command send on powershell (windows) a stream that regulary send me a json string with some information. example :\r\n`gc listen | jq -c &#39;.eventBody.group.queueId&#39;`\r\n\r\nAnd, as you can imagine, it is not working as expected :D \r\n1. the command `gc listen` is working correctly, i have every second a json like that\r\n\r\n&gt; {\r\n  &quot;topicName&quot;: &quot;v2.analytics.queues.fzef-9208-4078-b012-fzegzeg.observations&quot;,\r\n  &quot;version&quot;: &quot;2&quot;,\r\n  &quot;eventBody&quot;: {\r\n    &quot;group&quot;: {\r\n      &quot;queueId&quot;: &quot;fzef-9208-4078-b012-fzegzeg&quot;,\r\n      &quot;mediaType&quot;: &quot;voice&quot;\r\n    },\r\n    &quot;data&quot;: [\r\n      {\r\n        &quot;interval&quot;: &quot;2021-03-30T09:00:00.000Z/2021-03-30T09:30:00.000Z&quot;,\r\n        &quot;metrics&quot;: [\r\n          {\r\n            &quot;metric&quot;: &quot;nConnected&quot;,\r\n            &quot;stats&quot;: {\r\n              &quot;count&quot;: 1.0\r\n            }\r\n          },\r\n          {\r\n            &quot;metric&quot;: &quot;tAbandon&quot;,\r\n            &quot;stats&quot;: {\r\n              &quot;count&quot;: 3.0,\r\n              &quot;sum&quot;: 184416.0,\r\n              &quot;min&quot;: 41981.0,\r\n              &quot;max&quot;: 89420.0\r\n            }\r\n          },\r\n          {\r\n            &quot;metric&quot;: &quot;tHeldComplete&quot;,\r\n            &quot;stats&quot;: {\r\n              &quot;count&quot;: 12.0,\r\n              &quot;sum&quot;: 958886.0,\r\n              &quot;min&quot;: 9126.0,\r\n              &quot;max&quot;: 161639.0\r\n            }\r\n          },\r\n          {\r\n            &quot;metric&quot;: &quot;nOffered&quot;,\r\n            &quot;stats&quot;: {\r\n              &quot;count&quot;: 59.0\r\n            }\r\n          }\r\n          }\r\n        ]\r\n      }\r\n    ]\r\n  },\r\n  &quot;metadata&quot;: {\r\n    &quot;CorrelationId&quot;: &quot;7f3ef949-d85d-4cea-b92b-6d96b2915568&quot;\r\n  }\r\n}\r\n\r\n 2. if i save that on a file, and do : `type test.txt | jq -c &#39;.eventBody.group.queueId&#39;` i can get the queueId. And if i save multiple output of the first command, i got multiple id. no problem.\r\n\r\n 3. BUT when i try both on the same time, i don&#39;t have anything :\r\n\r\n `gc listen | jq -c &#39;.eventBody.group.queueId&#39;`\r\nwith that command i, don&#39;t have anything. \r\n\r\n4. it seems that in linux that command is orking correctly...\r\n\r\nDo you have any idea ?",
        "link": "https://stackoverflow.com/questions/66873163/filter-an-notification-output-live-with-jq",
        "title": "Filter an notification output live with JQ"
    },
    {
        "tags": [
            "json",
            "select",
            "jq",
            "edit"
        ],
        "answers": [
            {
                "up_vote_count": 5,
                "is_accepted": true,
                "score": 5,
                "last_activity_date": 1617120913,
                "creation_date": 1617120913,
                "answer_id": 66874656,
                "question_id": 66874366,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "`|=` is your friend, e.g.\r\n\r\n    .techniques |= map(select(.tactic == &quot;impact&quot;))",
                "title": "jq select, but preserve parent objects"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 3,
        "last_activity_date": 1617169643,
        "creation_date": 1617119811,
        "last_edit_date": 1617169643,
        "question_id": 66874366,
        "body_markdown": "This works to search for tactics that equal &quot;impact&quot;. However, it will only pull the objects themselves.\r\n```jq &#39;.techniques[] | select(.tactic == &quot;impact&quot;)&#39;```\r\n\r\nIs there no way to use select while walking through json with something like ```jq &#39;. | select(.techniques[].tactic == &quot;impact&quot;)&#39;```? I&#39;m guessing the issue is that something like that, even if it works, still does not explicitly say to leave the previous items as well.\r\n\r\nIt is not viable to manually rebuild the parent.\r\n\r\ninput\r\n```\r\n{\r\n  &quot;viewMode&quot;: 0,\r\n  &quot;hideDisabled&quot;: false,\r\n  &quot;techniques&quot;: [\r\n    {\r\n      &quot;name&quot;: &quot;john&quot;,\r\n      &quot;tactic&quot;: &quot;reconnaissance&quot;\r\n    },\r\n    {\r\n      &quot;name&quot;: &quot;jane&quot;,\r\n      &quot;tactic&quot;: &quot;impact&quot;\r\n    },\r\n    {\r\n      &quot;name&quot;: &quot;jill&quot;,\r\n      &quot;tactic&quot;: &quot;execution&quot;\r\n    }\r\n  ],\r\n  &quot;karma&quot;: &quot;yes&quot;\r\n}\r\n```\r\ndesired output\r\n```\r\n{\r\n  &quot;viewMode&quot;: 0,\r\n  &quot;hideDisabled&quot;: false,\r\n  &quot;techniques&quot;: [\r\n    {\r\n      &quot;name&quot;: &quot;jane&quot;,\r\n      &quot;tactic&quot;: &quot;impact&quot;\r\n    }\r\n  ],\r\n  &quot;karma&quot;: &quot;yes&quot;\r\n}\r\n```\r\n\r\nIf this is so remedial that it warrants no response, I&#39;ll figure it out and update. It seems like the most basic thing. I&#39;ll also be doing a !=, which also works fine normally, but doesn&#39;t capture the entire body.\r\n\r\nI have tried using variables to do it, which get me close;\r\n```\r\njq  &#39;{techniques: [.techniques[] | select(.tactic == &quot;impact&quot;)]} as $a| $a&#39;  test.json\r\n```\r\nHowever, trying to add a key &quot;techniques&quot; to that array ruins my ability to use it;\r\n\r\n```\r\njq  &#39;{techniques: [.techniques[] | select(.tactic == &quot;impact&quot;)]} as $a| $a + [.]&#39;  test.json\r\njq: error (at test.json:19): object ({&quot;technique...) and array ([{&quot;viewMode...) cannot be added\r\n```",
        "link": "https://stackoverflow.com/questions/66874366/jq-select-but-preserve-parent-objects",
        "title": "jq select, but preserve parent objects"
    },
    {
        "tags": [
            "arrays",
            "json",
            "object",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1617208020,
                "last_edit_date": 1617208020,
                "creation_date": 1617207121,
                "answer_id": 66891434,
                "question_id": 66890517,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "```\r\n.stats[]\r\n| {devid,key} + (.value[] | to_entries[] | {nodeId: .key|tonumber, value})\r\n```\r\n\r\nYou might wish to replace `tonumber` by `(tonumber? // .)` for robustness.",
                "title": "Parse dynamic array of objects with JQ"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1617208288,
        "creation_date": 1617203500,
        "last_edit_date": 1617208288,
        "question_id": 66890517,
        "body_markdown": "I am trying to flatten and re-transform a JSON payload via JQ, but have been unsuccessful thus far. I have the following payload that has a dynamic number of values depending for each object underneath the `stats` field:\r\n\r\n```\r\n{\r\n  &quot;stats&quot;: [\r\n    {\r\n      &quot;devid&quot;: 3,\r\n      &quot;key&quot;: &quot;diskall&quot;,\r\n      &quot;value&quot;: [\r\n        {\r\n          &quot;0&quot;: 0.0001,\r\n          &quot;1&quot;: 0.0001,\r\n          &quot;2&quot;: 0.0012,\r\n          &quot;3&quot;: 0.0005,\r\n          &quot;4&quot;: 0.0007,\r\n          &quot;5&quot;: 0.0013,\r\n          &quot;6&quot;: 0.0006000000000000001,\r\n          &quot;7&quot;: 0.0006000000000000001,\r\n          &quot;8&quot;: 0.0006000000000000001,\r\n          &quot;9&quot;: 0.0006000000000000001,\r\n          &quot;10&quot;: 0.0005,\r\n          &quot;11&quot;: 0.0005,\r\n          &quot;12&quot;: 0.0005\r\n        }\r\n      ]\r\n    },\r\n    {\r\n      &quot;devid&quot;: 7,\r\n      &quot;key&quot;: &quot;diskall&quot;,\r\n      &quot;value&quot;: [\r\n        {\r\n          &quot;0&quot;: 0.0003,\r\n          &quot;1&quot;: 0.0004,\r\n          &quot;2&quot;: 0.0012,\r\n          &quot;3&quot;: 0.0005,\r\n          &quot;4&quot;: 0.0007,\r\n          &quot;5&quot;: 0.0013,\r\n          &quot;6&quot;: 0.00060001\r\n        }\r\n      ]\r\n    }\r\n  ]\r\n}\r\n```\r\n\r\nI want to flatten and transform the value array object keys/values to a result like below (for each value within each stat object). Basically take the key in values and place that in a field called `nodeId` and take the value and place that in a field called `value`\r\n\r\n```\r\n{\r\n&quot;devid&quot;: 3\r\n&quot;key&quot;: &quot;diskall&quot;\r\n&quot;nodeId&quot;: 0\r\n&quot;value&quot;: 0.0001\r\n},\r\n{\r\n&quot;devid&quot;: 3\r\n&quot;key&quot;: &quot;diskall&quot;\r\n&quot;nodeId&quot;: 1\r\n&quot;value&quot;: 0.0001\r\n},\r\n{\r\n&quot;devid&quot;: 3\r\n&quot;key&quot;: &quot;diskall&quot;\r\n&quot;nodeId&quot;: 2\r\n&quot;value&quot;: 0.0012\r\n},\r\n{\r\n&quot;devid&quot;: 7\r\n&quot;key&quot;: &quot;diskall&quot;\r\n&quot;nodeId&quot;: 0\r\n&quot;value&quot;: 0.0003\r\n}\r\n```\r\n\r\nI was able to flatten with jq like this: `.stats | map(del(.value) + .value[])`, but I&#39;m not sure how to approach transforming the values into their own objects as well as rename the keys/values a bit.",
        "link": "https://stackoverflow.com/questions/66890517/parse-dynamic-array-of-objects-with-jq",
        "title": "Parse dynamic array of objects with JQ"
    },
    {
        "tags": [
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1617209021,
                "post_id": 66891879,
                "comment_id": 118242566,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 4805530,
                    "reputation": 1060,
                    "user_id": 3880736,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/0775394df03b923047f187d3e49d5989?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "xbalaji",
                    "link": "https://stackoverflow.com/users/3880736/xbalaji"
                },
                "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": 1617209332,
                "post_id": 66891879,
                "comment_id": 118242696,
                "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": 1617209640,
                "post_id": 66891879,
                "comment_id": 118242836,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 7,
                "is_accepted": false,
                "score": 7,
                "last_activity_date": 1617218634,
                "last_edit_date": 1617218634,
                "creation_date": 1617209252,
                "answer_id": 66891962,
                "question_id": 66891879,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "```\r\njq -r &#39;\r\n  to_entries[] |                  # replace items with {&quot;key&quot;: ..., &quot;value&quot;: ...}\r\n    .key as $username |           # store top-level key in $username\r\n    .value |                      # later code operates only on value\r\n    to_entries[] |                # break top-level value into key/value pairs\r\n    ([$username, .key, .value] |  # create list w/ desired output fields\r\n     map(tojson) |                # encode those fields as literal JSON\r\n     join(&quot; &quot;))                   # ...and separate those JSON fields with spaces\r\n&#39;\r\n```\r\n\r\nConcatenated onto a single line, this looks like:\r\n\r\n```\r\njq -r &#39;to_entries[] | .key as $username | .value | to_entries[] | ([$username, .key, .value] | map(tojson) | join(&quot; &quot;))&#39;\r\n```\r\n\r\n---\r\n\r\n[@peak](https://stackoverflow.com/users/997358/peak) also kindly pointed out a terser alternative that avoids the need for `$username`:\r\n\r\n```\r\njq -r &#39;\r\n  to_entries[] |      # Replace items with {&quot;key&quot;:..., &quot;value&quot;: ...}\r\n    [.key]+(          # Prepend key to results of next group:\r\n      .value |        #   ...creating that group by starting with the value\r\n      to_entries[] |  #   ...then splitting it further into key/value pairs\r\n      [.key, .value]  #   ...then putting key and value into a list\r\n    ) |\r\n    map(tojson) |     # encode the results of the above as JSON strings\r\n    join(&quot; &quot;)         # ...and then separate those strings with spaces.\r\n&#39;",
                "title": "Traversing with jq/yq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1617218634,
        "creation_date": 1617208936,
        "last_edit_date": 1617218119,
        "question_id": 66891879,
        "body_markdown": "I have a data file similar to the one as below\r\n\r\n```\r\n{\r\n  &quot;user01&quot;: {\r\n    &quot;name&quot;: &quot;User01 Name&quot;,\r\n    &quot;age&quot;: &quot;20&quot;,\r\n    &quot;sex&quot;: &quot;male&quot;,\r\n    &quot;state&quot;: &quot;CA&quot;,\r\n    &quot;zip&quot;: &quot;92012&quot;\r\n  },\r\n  &quot;user02&quot;: {\r\n    &quot;name&quot;: &quot;User02 Name&quot;,\r\n    &quot;age&quot;: &quot;22&quot;,\r\n    &quot;sex&quot;: &quot;female&quot;\r\n  },\r\n  &quot;user03&quot;: {\r\n    &quot;age&quot;: &quot;24&quot;,\r\n    &quot;sex&quot;: &quot;male&quot;,\r\n    &quot;zip&quot;: &quot;92412&quot;\r\n  },\r\n  &quot;user04&quot;: {\r\n    &quot;name&quot;: &quot;User05 Name&quot;,\r\n    &quot;age&quot;: &quot;30&quot;,\r\n    &quot;sex&quot;: &quot;female&quot;,\r\n    &quot;state&quot;: &quot;UT&quot;,\r\n    &quot;zip&quot;: &quot;96232&quot;\r\n  }\r\n}\r\n```\r\nI would like to get output like this\r\n\r\n```\r\n&quot;user01&quot; &quot;name&quot; &quot;User01 Name&quot;\r\n&quot;user01&quot; &quot;age&quot; &quot;20&quot;\r\n&quot;user01&quot; &quot;sex&quot; &quot;male&quot;\r\n&quot;user01&quot; &quot;state&quot; &quot;CA&quot;\r\n&quot;user01&quot; &quot;zip&quot; &quot;92012&quot;\r\n&quot;user02&quot; &quot;name&quot; &quot;User02 Name&quot;\r\n&quot;user02&quot; &quot;age&quot; &quot;22&quot;\r\n&quot;user02&quot; &quot;sex&quot; &quot;female&quot;\r\n&quot;user03&quot; &quot;age&quot; &quot;24&quot;\r\n&quot;user03&quot; &quot;sex&quot; &quot;male&quot;\r\n&quot;user03&quot; &quot;zip&quot; &quot;92412&quot;\r\n&quot;user04&quot; &quot;name&quot; &quot;User05 Name&quot;\r\n&quot;user04&quot; &quot;age&quot; &quot;30&quot;\r\n&quot;user04&quot; &quot;sex&quot; &quot;female&quot;\r\n&quot;user04&quot; &quot;state&quot; &quot;UT&quot;\r\n&quot;user04&quot; &quot;zip&quot; &quot;96232&quot;\r\n```\r\nI&#39;m not able to figure out how to keep the top level key, print the key value pair as each of them is processed. Thanks for your help.\r\n\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/66891879/traversing-with-jq-yq",
        "title": "Traversing with jq/yq"
    },
    {
        "tags": [
            "bash",
            "less",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 11,
                "is_accepted": true,
                "score": 11,
                "last_activity_date": 1617222132,
                "creation_date": 1617222132,
                "answer_id": 66894836,
                "question_id": 66894559,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "&quot;Works for me&quot;™:\r\n* in one terminal window:\r\n\r\n    ```bash\r\n    while true; do echo &quot;{\\&quot;date\\&quot;:\\&quot;$(date)\\&quot;}&quot; &gt;&gt; logfile; sleep 1; done\r\n    ```\r\n* in another:\r\n\r\n    ```bash\r\n    tail -f logfile | jq .\r\n    ```\r\n\r\n",
                "title": "How do I run jq on each log line and tail it?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 7,
        "last_activity_date": 1617222132,
        "creation_date": 1617220781,
        "question_id": 66894559,
        "body_markdown": "I have a log file with each line being a json object. I want to view the log lines as pretty json while being able to tail the logs, with maybe `tail` or `less`.\r\nI have tried the following and they either return immediately i.e. don&#39;t tail the logs, or appear to tail (by not returning) but don&#39;t update with new logs\r\n\r\n```\r\nless jsonlines.log | jq &quot;.&quot; \r\ntail -f jsonlines.log | jq &quot;.&quot;\r\n```\r\n",
        "link": "https://stackoverflow.com/questions/66894559/how-do-i-run-jq-on-each-log-line-and-tail-it",
        "title": "How do I run jq on each log line and tail it?"
    },
    {
        "tags": [
            "json",
            "bash",
            "yaml",
            "jq",
            "key-value"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 9589062,
                    "reputation": 2764,
                    "user_id": 7120667,
                    "user_type": "registered",
                    "accept_rate": 92,
                    "profile_image": "https://i.sstatic.net/0UC4R.jpg?s=256",
                    "display_name": "Rushabh Patel",
                    "link": "https://stackoverflow.com/users/7120667/rushabh-patel"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1617223225,
                "post_id": 66894756,
                "comment_id": 118248164,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1617228591,
                "last_edit_date": 1617228591,
                "creation_date": 1617223075,
                "answer_id": 66895017,
                "question_id": 66894756,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You are only missing the additional flag `--raw-output` for jq.\r\nThe command should look like\r\n\r\n```\r\njq --raw-output &#39;.[] | [.name, .value] | join(&quot;:&quot;)&#39; file.json\r\n```\r\n\r\nThe `--raw-output` argument makes jq print the output directly instead of printing it as a JSON string, i.e., escaping it in a string.\r\n\r\nIn your expected output you have no space after the colon, but you have it in your jq command.",
                "title": "YAML format from JSON in Linux"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1617229382,
        "creation_date": 1617221640,
        "last_edit_date": 1617229382,
        "question_id": 66894756,
        "body_markdown": "I am looking easy ways to clean my `json` in linux. \r\n\r\n**Sample Input:**\r\n\r\n    [{&quot;name&quot;:&quot;Student1&quot;,&quot;value&quot;:&quot;John&quot;},{&quot;name&quot;:&quot;Student2&quot;,&quot;value&quot;:&quot;Jack&quot;},{&quot;name&quot;:&quot;Student3&quot;,&quot;value&quot;:&quot;Nick&quot;},{&quot;name&quot;:&quot;Student4&quot;,&quot;value&quot;:&quot;Karen&quot;},{&quot;name&quot;:&quot;Student5&quot;,&quot;value&quot;:&quot;Jonas&quot;}]\r\n\r\n**Expected Output:**\r\nI want to save below expected output in `txt/yaml` file in linux.\r\n\r\n    Student1:John\r\n    Student2:Jack\r\n    Student3:Nick\r\n    Student4:Karen\r\n    Student5:Jonas\r\n\r\n\r\n**My Attempt:**\r\n\r\n    jq &#39;. | map([.name, .value] | join(&quot;: &quot;)) | join(&quot;\\n&quot;)&#39; file.json &gt;&gt; all_param.yml;",
        "link": "https://stackoverflow.com/questions/66894756/yaml-format-from-json-in-linux",
        "title": "YAML format from JSON in Linux"
    },
    {
        "tags": [
            "arrays",
            "jq",
            "prepend"
        ],
        "answers": [
            {
                "up_vote_count": 14,
                "is_accepted": true,
                "score": 14,
                "last_activity_date": 1617233726,
                "creation_date": 1617233726,
                "answer_id": 66896605,
                "question_id": 66896566,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can concatenate arrays with `+` so you can add your new object inside an array and concat the rest:\r\n\r\n```\r\n.examples |= [{example: &quot;1&quot;}] + .\r\n```\r\n\r\nhttps://jqplay.org/s/XIsoZ4GvOa",
                "title": "Using jq to add/prepend an element to the top of an array"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 4,
        "last_activity_date": 1617249601,
        "creation_date": 1617233382,
        "last_edit_date": 1617249601,
        "question_id": 66896566,
        "body_markdown": "I have the following json file (example.json):\r\n\r\n```\r\n{\r\n  &quot;examples&quot;: [\r\n    {\r\n      &quot;example&quot;: &quot;2&quot;\r\n    },\r\n    {\r\n      &quot;example&quot;: &quot;3&quot;\r\n    }\r\n  ]\r\n}\r\n```\r\nI&#39;d like to use jq to add a new element to the top of this array (rather than the bottom). All the solutions I&#39;ve come up with simply add it to the bottom (code I&#39;m using below):\r\n\r\n```\r\njq &#39;.examples +=\r\n[{&quot;example&quot;: &quot;1&quot;,\r\n}]&#39; example.json\r\n```\r\nThe desired output (in case it&#39;s not immediately obvious) would be:\r\n\r\n```\r\n{\r\n  &quot;examples&quot;: [\r\n    {\r\n      &quot;example&quot;: &quot;1&quot;\r\n    },\r\n    {\r\n      &quot;example&quot;: &quot;2&quot;\r\n    },\r\n    {\r\n      &quot;example&quot;: &quot;3&quot;\r\n    }\r\n  ]\r\n}\r\n```",
        "link": "https://stackoverflow.com/questions/66896566/using-jq-to-add-prepend-an-element-to-the-top-of-an-array",
        "title": "Using jq to add/prepend an element to the top of an array"
    },
    {
        "tags": [
            "linux",
            "iteration",
            "export-to-csv",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 6313442,
                    "reputation": 45115,
                    "user_id": 5625547,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/oqCND.jpg?s=256",
                    "display_name": "0stone0",
                    "link": "https://stackoverflow.com/users/5625547/0stone0"
                },
                "edited": false,
                "score": 3,
                "creation_date": 1617289132,
                "post_id": 66906867,
                "comment_id": 118268274,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1617340681,
                "last_edit_date": 1617340681,
                "creation_date": 1617317459,
                "answer_id": 66912484,
                "question_id": 66906867,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Assuming the input is structured as shown, the following is guaranteed to produce valid CSV (including the header), in accordance with the headers in the question:\r\n```\r\n[&quot;iccid&quot;,&quot;timeStamp&quot;] as $h1\r\n| [&quot;dataUsage&quot;,&quot;dataUsageUnit&quot;,&quot;voiceMTUsage&quot;,&quot;voiceMTUsageUnit&quot;,&quot;voiceMOUsage&quot;,&quot;voiceMOUsageUnit&quot;,&quot;smsmtusage&quot;,&quot;smsmousage&quot;] as $h2\r\n| ($h1+$h2),\r\n  ([.[$h1[]]] + (.deviceCycleUsageInZones[][] | [.[$h2[]]] ))\r\n| @csv\r\n```\r\n\r\nIf you really don&#39;t want the strings to be quoted, then change `@csv` to `join(&quot;,&quot;)`, and hope for the best.\r\n\r\n## Discussion\r\nThe above solution does not depend on the ordering of keys within the JSON objects.  This is achieved using the idiom:\r\n\r\n    .[ $index[] ]\r\n\r\nwhere `$index` is an array of key names.  This tiny bit of cleverness is possible because, given a jq expression, s, producing a stream of JSON values s1, s2, ..., the jq expression `$x[s]` evaluates to the stream: $x[s1], $x[s2], ..., assuming all the latter jq expressions are valid.",
                "title": "How to iterate through .json and get .csv?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -2,
        "last_activity_date": 1617340681,
        "creation_date": 1617289057,
        "last_edit_date": 1617340577,
        "question_id": 66906867,
        "body_markdown": "I have the following json contents:\r\n```\r\n{\r\n&quot;iccid&quot;: &quot;1961021111937667&quot;,\r\n&quot;timeStamp&quot;: &quot;2021-03-25T09:42:30.681Z&quot;,\r\n&quot;cycleStartDate&quot;: &quot;2021-02-28T16:00:00.000Z&quot;,\r\n&quot;cycleEndDate&quot;: &quot;2021-03-31T14:59:59.000Z&quot;,\r\n&quot;deviceCycleUsageInZones&quot;: {\r\n&quot;TEST-25GB, 1&quot;: [\r\n{\r\n&quot;ratePlan&quot;: &quot;TEST-25GB&quot;,\r\n&quot;ratePlanVersion&quot;: &quot;1&quot;,\r\n&quot;zone&quot;: &quot;default zone&quot;,\r\n&quot;dataUsage&quot;: 15155147646,\r\n&quot;dataUsageUnit&quot;: &quot;bytes&quot;,\r\n&quot;voiceMTUsage&quot;: null,\r\n&quot;voiceMTUsageUnit&quot;: null,\r\n&quot;voiceMOUsage&quot;: null,\r\n&quot;voiceMOUsageUnit&quot;: null,\r\n&quot;smsmtusage&quot;: null,\r\n&quot;smsmousage&quot;: 3\r\n}\r\n],\r\n&quot;TEST-29GB, 1&quot;: [\r\n{\r\n&quot;ratePlan&quot;: &quot;TEST - 29602&quot;,\r\n&quot;ratePlanVersion&quot;: &quot;1&quot;,\r\n&quot;zone&quot;: &quot;default zone&quot;,\r\n&quot;dataUsage&quot;: null,\r\n&quot;dataUsageUnit&quot;: null,\r\n&quot;voiceMTUsage&quot;: 1080,\r\n&quot;voiceMTUsageUnit&quot;: &quot;seconds&quot;,\r\n&quot;voiceMOUsage&quot;: 960,\r\n&quot;voiceMOUsageUnit&quot;: &quot;seconds&quot;,\r\n&quot;smsmtusage&quot;: null,\r\n&quot;smsmousage&quot;: null\r\n}\r\n]\r\n}\r\n}\r\n```\r\n\r\nHow to go through the contents of .json file to get the following .csv output?\r\n```\r\n1961021111937667, 2021-03-25T09:42:30.681Z,15155147646,bytes,null,null,null,null,null,3\r\n1961021111937667, 2021-03-25T09:42:30.681Z,null,null,1080,seconds,960,seconds,null,null\r\n```\r\nIn other words, I want the following headers included:\r\n```\r\niccid,timeStamp,dataUsage,dataUsageUnit,voiceMTUsage,voiceMTUsageUnit,voiceMOUsage,voiceMOUsageUnit,smsmtusage,smsmousage\r\n```",
        "link": "https://stackoverflow.com/questions/66906867/how-to-iterate-through-json-and-get-csv",
        "title": "How to iterate through .json and get .csv?"
    },
    {
        "tags": [
            "json",
            "object",
            "merge",
            "jq",
            "array-merge"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1617296296,
                "creation_date": 1617296296,
                "answer_id": 66908704,
                "question_id": 66907565,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "It looks like you will have to define your own &quot;merge&quot; filter.\r\n\r\nGiven your sample inputs, the following does produce the result you ask for, but it should probably be taken as a starting point as you refine your specification:\r\n```\r\ndef merge($a; $b): \r\n   if ($a|type) == &quot;object&quot; and ($b|type) == &quot;object&quot; \r\n       then reduce (($a + $b)|keys_unsorted[]) as $k ({}; \r\n         .[$k] = merge($a[$k]; $b[$k]))\r\n   elif ($a|type) ==&quot;array&quot; and ($b|type) == &quot;array&quot; then  $a + $b | add\r\n   elif $b == null then $a\r\n   else $b\r\n   end;\r\n\r\n```\r\nFor efficiency, you might wish to consider invoking this as `merge(input;input)`, using the -n command-line option instead of -s.\r\n",
                "title": "How to deep merge 2 files with jq for arrays"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1617296380,
        "creation_date": 1617291472,
        "last_edit_date": 1617296380,
        "question_id": 66907565,
        "body_markdown": "\r\nI am trying to merge the following two json files; but I only seem to be able to partially merge; as soon as an element is within an array the reduce fails.\r\n\r\n\r\n    {\r\n        &quot;value1&quot;: 200,\r\n        &quot;timestamp&quot;: 1382461861,\r\n        &quot;deployment&quot;: [\r\n            {\r\n                &quot;component&quot;: &quot;whatever&quot;,\r\n                &quot;containers&quot;: &quot;key value&quot;\r\n            }\r\n        ]\r\n    }\r\n\r\nand \r\n\r\n    {\r\n        &quot;status&quot;: 200,\r\n        &quot;timestamp&quot;: 1382461861,\r\n        &quot;deployment&quot;: [\r\n            {\r\n                &quot;autoscaling&quot;: {\r\n                    &quot;maxReplicas&quot;: 1,\r\n                    &quot;minReplicas&quot;: 1,\r\n                    &quot;targetCPUUtilizationPercentage&quot;: 40\r\n                }\r\n            }\r\n        ]\r\n    }\r\n\r\n\r\nUsing `jq -s &#39;reduce .[] as $item({}; . * $item)&#39; x.json x2.json` does not work if the input is an array; instead I get a partial merge but not a deep merge\r\n\r\n    {\r\n      &quot;value1&quot;: 200,\r\n      &quot;timestamp&quot;: 1382461861,\r\n      &quot;deployment&quot;: [\r\n        {\r\n          &quot;autoscaling&quot;: {\r\n            &quot;maxReplicas&quot;: 1,\r\n            &quot;minReplicas&quot;: 1,\r\n            &quot;targetCPUUtilizationPercentage&quot;: 40\r\n          }\r\n        }\r\n      ],\r\n      &quot;status&quot;: 200\r\n    }\r\n  \r\nThe expected output would be\r\n\r\n```\r\n{\r\n    &quot;value1&quot;: 200,\r\n    &quot;timestamp&quot;: 1382461861,\r\n    &quot;deployment&quot;: [\r\n        {\r\n            &quot;component&quot;: &quot;whatever&quot;,\r\n            &quot;containers&quot;: &quot;key value&quot;,\r\n\r\n            &quot;autoscaling&quot;: {\r\n                &quot;maxReplicas&quot;: 1,\r\n                &quot;minReplicas&quot;: 1,\r\n                &quot;targetCPUUtilizationPercentage&quot;: 40\r\n            }\r\n        }\r\n    ],\r\n    &quot;status&quot;: 200,\r\n}\r\n```\r\n\r\n\r\nCan i anyone suggest where I may be going wrong",
        "link": "https://stackoverflow.com/questions/66907565/how-to-deep-merge-2-files-with-jq-for-arrays",
        "title": "How to deep merge 2 files with jq for arrays"
    },
    {
        "tags": [
            "json",
            "timestamp",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 10015983,
                    "reputation": 144648,
                    "user_id": 9072753,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/EPmGy.jpg?s=256",
                    "display_name": "KamilCuk",
                    "link": "https://stackoverflow.com/users/9072753/kamilcuk"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1617295813,
                "post_id": 66908468,
                "comment_id": 118271168,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2035639,
                    "reputation": 1166,
                    "user_id": 1818059,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/r4K6q.png?s=256",
                    "display_name": "MyICQ",
                    "link": "https://stackoverflow.com/users/1818059/myicq"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1617296477,
                "post_id": 66908468,
                "comment_id": 118271493,
                "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": 1617297785,
                "post_id": 66908468,
                "comment_id": 118272020,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 12611586,
                    "reputation": 97,
                    "user_id": 9170497,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/c4fbecf1aadfb619290e7976fbb22071?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Arda Savran",
                    "link": "https://stackoverflow.com/users/9170497/arda-savran"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1617302260,
                "post_id": 66908468,
                "comment_id": 118273717,
                "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": 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": 0,
                "creation_date": 1617372660,
                "post_id": 66908468,
                "comment_id": 118291948,
                "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": 0,
                "creation_date": 1617492353,
                "post_id": 66908468,
                "comment_id": 118320285,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1617492325,
                "creation_date": 1617492325,
                "answer_id": 66936743,
                "question_id": 66908468,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You&#39;re right about the time functions only working with integral seconds. This answer uses a string function to parse out the fraction.\r\n\r\nIf this is `file.json` contains an array of objects\r\n```json\r\n[\r\n    {\r\n        &quot;type&quot;: &quot;Point&quot;,\r\n        &quot;time&quot;: &quot;2021-04-01T01:19:21.243866342Z&quot;\r\n    },\r\n    {\r\n        &quot;type&quot;: &quot;Circle&quot;,\r\n        &quot;time&quot;: &quot;2020-01-01T00:00:00.01Z&quot;\r\n    },\r\n    {\r\n        &quot;type&quot;: &quot;Line&quot;,\r\n        &quot;time&quot;: &quot;1970-01-01T01:00:00Z&quot;\r\n    }\r\n]\r\n```\r\nThen\r\n```bash\r\njq &#39;\r\n    def datestamp2epoch:\r\n        . | scan(&quot;(.+?)([.][0-9]+)?Z$&quot;)\r\n          | [(.[0] + &quot;Z&quot; | fromdateiso8601), (.[1] // 0 | tonumber)]\r\n          | add;\r\n    map(.time |= datestamp2epoch)\r\n&#39; file.json\r\n```\r\n```json\r\n[\r\n  {\r\n    &quot;type&quot;: &quot;Point&quot;,\r\n    &quot;time&quot;: 1617243561.2438664\r\n  },\r\n  {\r\n    &quot;type&quot;: &quot;Circle&quot;,\r\n    &quot;time&quot;: 1577836800.01\r\n  },\r\n  {\r\n    &quot;type&quot;: &quot;Line&quot;,\r\n    &quot;time&quot;: 3600\r\n  }\r\n]\r\n```",
                "title": "How to convert an ISO timestamp field in JSON to epoch using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1617492325,
        "creation_date": 1617295312,
        "last_edit_date": 1617343969,
        "question_id": 66908468,
        "body_markdown": "I have an array of JSON messages like this:\r\n\r\n    {\r\n      &quot;type&quot;: &quot;Point&quot;,\r\n      &quot;time&quot;: &quot;2021-04-01T01:19:21.243866342Z&quot;,\r\n      &quot;value&quot;: 1,\r\n      &quot;metric&quot;: &quot;iterations&quot;,\r\n      &quot;method&quot;: &quot;&quot;,\r\n      &quot;name&quot;: &quot;&quot;,\r\n      &quot;proto&quot;: &quot;&quot;,\r\n      &quot;status&quot;: &quot;&quot;,\r\n      &quot;tls_version&quot;: &quot;&quot;,\r\n      &quot;url&quot;: &quot;&quot;,\r\n      &quot;expected_response&quot;: &quot;&quot;,\r\n      &quot;group&quot;: &quot;&quot;,\r\n      &quot;scenario&quot;: &quot;default&quot;,\r\n      &quot;agent_hostname&quot;: &quot;ip-13-3-3-33.ap-southeast-2.compute.internal&quot;,\r\n      &quot;agent_ipaddress&quot;: &quot;33.3.3.3&quot;,\r\n      &quot;agent_casetype&quot;: &quot;simplerequest&quot;,\r\n      &quot;agent_casename&quot;: &quot;test_case&quot;\r\n    }\r\n\r\nThis is a message that is generated by an app and stored in a folder. I would like to convert the time fields from the ISO to epoch-microseconds.\r\n\r\nI could use this: .time_field | .[0:-9] | strptime(&quot;%Y-%m-%dT%H:%M:%S&quot;) | mktime\r\n\r\nBut this remove the entire decimal part and gives me only second granularity. This is trending data and a few events may happen within the same second.\r\n\r\nHow can I achieve that using jq?\r\n\r\nThanks",
        "link": "https://stackoverflow.com/questions/66908468/how-to-convert-an-iso-timestamp-field-in-json-to-epoch-using-jq",
        "title": "How to convert an ISO timestamp field in JSON to epoch using jq"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1617377442,
                "last_edit_date": 1617377442,
                "creation_date": 1617377032,
                "answer_id": 66921556,
                "question_id": 66921373,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "### Warning: *highly inefficient*\r\n\r\n1) Get all `.state` where value **is not** `foo`\r\n2) Check if `length == 0`\r\n\r\n```\r\njq &#39;map(select(.state != &quot;foo&quot;)) | length == 0&#39;\r\n```\r\n\r\n### [Jq▷Play |~|  TRUE][1]\r\n\r\n### [Jq▷Play |~| FALSE][2]\r\n\r\n\r\n  [1]: https://jqplay.org/s/spnzpUAf4B\r\n  [2]: https://jqplay.org/s/-N302xfGOB",
                "title": "how to check if all elements are equal with jq"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1617379277,
                "last_edit_date": 1617379277,
                "creation_date": 1617377140,
                "answer_id": 66921580,
                "question_id": 66921373,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "It would be easy to come up with an inefficient solution, e.g. using `map` or `unique`, but it&#39;s also quite easy to use `all/2` to devise an efficient, generic solution. \r\n\r\nConsider the following stream-oriented function:\r\n\r\n```\r\n# Return `true` if s is the empty stream\r\ndef allEquals(s):\r\n  (first(s) // null) as $x | all(s; .==$x);\r\n```\r\n\r\nUsing this, we can efficiently test for the equality of all the .state values in an array of objects as in the sample data, while ignoring other keys:\r\n\r\n    allEquals(.[].state)\r\n\r\n## Footnote\r\n\r\nOf course, if the objects in the array have only one key, as in the sample shown in the Q, one could simply write:\r\n\r\n    .[0] as $x | all(.[]; . == $x)\r\n\r\nThanks to jq&#39;s neat handling of edge cases, this works even if the input array is empty.",
                "title": "how to check if all elements are equal with jq"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": -1,
                "last_activity_date": 1617385154,
                "creation_date": 1617385154,
                "answer_id": 66923146,
                "question_id": 66921373,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "this code `[.[].state == (&quot;foo&quot;) ] | all` works as expected",
                "title": "how to check if all elements are equal with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 2,
        "last_activity_date": 1617385154,
        "creation_date": 1617376291,
        "last_edit_date": 1617377087,
        "question_id": 66921373,
        "body_markdown": "I have json data from curl like this:\r\n\r\n    [\r\n       {\r\n         &quot;state&quot;: &quot;foo&quot;,\r\n       },\r\n       {\r\n         &quot;state&quot;: &quot;foo&quot;,\r\n       },\r\n       {\r\n         &quot;state&quot;: &quot;foo&quot;,\r\n       }\r\n    ]\r\n\r\noutput of `curl uri | jq .[].state` would be\r\n\r\n    &quot;foo&quot;\r\n    &quot;foo&quot;\r\n    &quot;foo&quot;\r\n\r\nHow can I check with **jq** if all the &quot;state&quot; values are equal and use this **true** or **false** status next in my condition? in this example I would get **true** value.\r\n\r\nbut here\r\n\r\n    &quot;foo&quot;\r\n    &quot;foo&quot;\r\n    &quot;bar&quot;\r\n\r\nshould be **false**",
        "link": "https://stackoverflow.com/questions/66921373/how-to-check-if-all-elements-are-equal-with-jq",
        "title": "how to check if all elements are equal with jq"
    },
    {
        "tags": [
            "json",
            "bash",
            "loops",
            "key",
            "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": 1617385579,
                "post_id": 66923126,
                "comment_id": 118296909,
                "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": 1617386233,
                "post_id": 66923126,
                "comment_id": 118297142,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1617387479,
                "last_edit_date": 1617387479,
                "creation_date": 1617386101,
                "answer_id": 66923324,
                "question_id": 66923126,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Easily done.\r\n\r\nFirst, let&#39;s focus on the jq code alone:\r\n\r\n```jq\r\nto_entries[]                # split items into keys and values\r\n| .key as $site             # store first key in $site\r\n| .value                    # code below deals with the value\r\n| to_entries[]              # split that value into keys and values\r\n| .key as $user             # store the key in $user\r\n| .value                    # code below deals with the value\r\n| to_entries[]              # split that value into keys and values\r\n| .key as $repository_name  # store the key in $repository_name\r\n| .value as $version        # store the value in $version\r\n| if $site == &quot;https://github.com&quot; then\r\n    &quot;\\($site)/\\($user)/\\($repository_name)/archive/refs/heads/\\($version).tar.gz&quot;\r\n  else\r\n    &quot;\\($site)/\\($user)/\\($repository_name)/-/archive/\\($version)/\\($repository_name)-\\($version).tar.gz&quot;\r\n  end\r\n```\r\n\r\nThat generates a list of lines. Reading lines into a bash array looks like `readarray -t arrayname &lt; ...datasource...`\r\n\r\nThus, using a [process substitution](https://wiki.bash-hackers.org/syntax/expansion/proc_subst) to redirect jq&#39;s stdout as if it were a file:\r\n\r\n```bash\r\nreadarray -t uris &lt; &lt;(jq -r &#39;\r\n  to_entries[]\r\n  | .key as $site\r\n  | .value\r\n  | to_entries[]\r\n  | .key as $user\r\n  | .value\r\n  | to_entries[]\r\n  | .key as $repository_name\r\n  | .value as $version\r\n  | if $site == &quot;https://github.com&quot; then\r\n      &quot;\\($site)/\\($user)/\\($repository_name)/archive/refs/heads/\\($version).tar.gz&quot;\r\n    else\r\n      &quot;\\($site)/\\($user)/\\($repository_name)/-/archive/\\($version)/\\($repository_name)-\\($version).tar.gz&quot;\r\n    end\r\n  &#39; &lt;config.json\r\n)\r\n```",
                "title": "jq json object concatenation to bash string array"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1617414110,
                "last_edit_date": 1617414110,
                "creation_date": 1617392376,
                "answer_id": 66924409,
                "question_id": 66923126,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The basic task of generating the strings can be done efficiently and generically (i.e., without any limits on the depths of the basenames) using the jq filter:\r\n\r\n    paths(strings) as $p | $p + [getpath($p)] | join(&quot;/&quot;)\r\n\r\nThere are several ways to populate a bash array accordingly, but if you merely wish to iterate through the values, you could use a bash `while` loop, like so:\r\n```\r\n&lt; input.json jq -r &#39;\r\n  paths(strings) as $p | $p + [getpath($p)] | join(&quot;/&quot;)&#39; | \r\n  while read -r line ; do\r\n    echo &quot;$line&quot;\r\n  done\r\n```\r\n\r\nYou might also wish to consider using jq&#39;s @sh or @uri filter.  For a jq urlencode function, see e.g. \r\nhttps://rosettacode.org/wiki/URL_encoding#jq\r\n\r\n(If the strings contain newlines or tabs, then the above would need to be tweaked accordingly.)\r\n\r\n\r\n",
                "title": "jq json object concatenation to bash string array"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 2,
        "last_activity_date": 1617618875,
        "creation_date": 1617385077,
        "last_edit_date": 1617618875,
        "question_id": 66923126,
        "body_markdown": "I want to use [jq](https://stedolan.github.io/jq/) (or anything else when it&#39;s the wrong tool) to concatenate a json object like this:\r\n\r\n```\r\n{\r\n  &quot;https://github.com&quot;: {\r\n    &quot;user-one&quot;: {\r\n      &quot;repository-one&quot;: &quot;version-one&quot;,\r\n      &quot;repository-two&quot;: &quot;version-two&quot;\r\n    },\r\n    &quot;user-two&quot;: {\r\n      &quot;repository-three&quot;: &quot;version-three&quot;,\r\n      &quot;repository-four&quot;: &quot;version-four&quot;\r\n    }\r\n  },\r\n  &quot;https://gitlab.com&quot;: {\r\n    &quot;user-three&quot;: {\r\n      &quot;repository-five&quot;: &quot;version-five&quot;,\r\n      &quot;repository-six&quot;: &quot;version-six&quot;\r\n    },\r\n    &quot;user-four&quot;: {\r\n      &quot;repository-seven&quot;: &quot;version-seven&quot;,\r\n      &quot;repository-eight&quot;: &quot;version-eight&quot;\r\n    }\r\n  }\r\n}\r\n```\r\n\r\nrecursively to a bash string array like this:\r\n\r\n```\r\n(\r\n    &quot;https://github.com/user-one/repository-one/archive/refs/heads/version-one.tar.gz&quot;\r\n    &quot;https://github.com/user-one/repository-two/archive/refs/heads/version-two.tar.gz&quot;\r\n    &quot;https://github.com/user-two/repository-three/archive/refs/heads/version-three.tar.gz&quot;\r\n    &quot;https://github.com/user-two/repository-four/archive/refs/heads/version-four.tar.gz&quot;\r\n    &quot;https://gitlab.com/user-three/repository-five/-/archive/version-five/repository-five-version-five.tar.gz&quot;\r\n    &quot;https://gitlab.com/user-three/repository-six/-/archive/version-six/repository-six-version-six.tar.gz&quot;\r\n    &quot;https://gitlab.com/user-four/repository-seven/-/archive/version-seven/repository-seven-version-seven.tar.gz&quot;\r\n    &quot;https://gitlab.com/user-four/repository-eight/-/archive/version-eight/repository-eight-version-eight.tar.gz&quot;\r\n)\r\n```\r\n\r\nfor subsequent use in a loop.\r\n\r\n```\r\nfor i in &quot;${arr[@]}&quot;\r\ndo\r\n   echo &quot;$i&quot;\r\ndone\r\n```\r\n\r\nHave no idea how to do that.\r\nAs you can see, the values must be handled differently depending on the object name.\r\n\r\n```\r\n&quot;https://github.com&quot; + &quot;/&quot; + $user_name + &quot;/&quot; + $repository_name + &quot;/archive/refs/heads/&quot; + $version + &quot;.tar.gz&quot;\r\n\r\n&quot;https://gitlab.com&quot; + &quot;/&quot; + $user_name + &quot;/&quot; + $repository_name + &quot;/-/archive/&quot; + $version + &quot;/&quot; + $repository_name + &quot;-&quot; + $version + &quot;.tar.gz&quot;\r\n```\r\n\r\nCould anyone help?",
        "link": "https://stackoverflow.com/questions/66923126/jq-json-object-concatenation-to-bash-string-array",
        "title": "jq json object concatenation to bash string array"
    },
    {
        "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": 1,
                "creation_date": 1617463377,
                "post_id": 66932509,
                "comment_id": 118313057,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1617581527,
                "creation_date": 1617581527,
                "answer_id": 66946943,
                "question_id": 66932509,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Issue was there were quotes around $docker_image in your jq expression and also the argument needed to be defined like so: \r\n\r\n`--arg &lt;variable_name&gt; &lt;variable_value&gt;`\r\n\r\nThe same as above with actual values: \r\n\r\n`--arg docker_image &quot;b6fa739cedf5&quot;`\r\n\r\n&lt;br&gt;\r\n\r\n\r\n**With this knowledge, you can then do the following:**\r\n```\r\njq -r --arg docker_image &quot;b6fa739cedf5&quot; &#39;.taskDefinition.containerDefinitions[0].image = $docker_image&#39; &lt;&lt;&lt; $task_definition &gt; task-definition.json\r\n```\r\n\r\n\r\nI had to fix the extra comma after  `&quot;image&quot;: &quot;$docker_image&quot;`\r\n\r\nSteps I took to reproduce:\r\n\r\n```\r\n$ export task_definition=&#39;{\r\n&gt;   &quot;taskDefinition&quot;: {\r\n&gt;     &quot;taskDefinitionArn&quot;: &quot;arn:aws:ecs:us-east-1:123454566788:task-definition/nodejs-webapp:21&quot;,\r\n&gt;     &quot;containerDefinitions&quot;: [\r\n&gt;       {\r\n&gt;         &quot;name&quot;: &quot;webapp&quot;,\r\n&gt;         &quot;image&quot;: &quot;$docker_image&quot;\r\n&gt;       }\r\n&gt;     ]\r\n&gt;   }\r\n&gt; }&#39;\r\n\r\n$ jq -r --arg docker_image &quot;b6fa739cedf5&quot; &#39;.taskDefinition.containerDefinitions[0].image = $docker_image&#39; &lt;&lt;&lt; $task_definition &gt; task-definition.json\r\n\r\n$ cat task-definition.json\r\ncat task-definition.json\r\n{\r\n  &quot;taskDefinition&quot;: {\r\n    &quot;taskDefinitionArn&quot;: &quot;arn:aws:ecs:us-east-1:123454566788:task-definition/nodejs-webapp:21&quot;,\r\n    &quot;containerDefinitions&quot;: [\r\n      {\r\n        &quot;name&quot;: &quot;webapp&quot;,\r\n        &quot;image&quot;: &quot;b6fa739cedf5&quot;\r\n      }\r\n    ]\r\n  }\r\n}\r\n```\r\n\r\n\r\n",
                "title": "In jq update json when passing value as a variable"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1617581527,
        "creation_date": 1617461648,
        "question_id": 66932509,
        "body_markdown": "The variable `$task_definition` contains json content. I need to update a specific value in that json. The variable `$docker_image` contains value of the image name. When the below script gets executed it puts the variable name and not the value of the variable `$docker_image`.  How do I make it put the value of the variable.\r\n\r\n    jq &#39;.taskDefinition.containerDefinitions[0].image = &quot;$docker_image&quot;&#39; &lt;&lt;&lt; &quot;$task_definition&quot; &gt; task-definition.json\r\n\r\noutput:\r\n\r\n    {\r\n      &quot;taskDefinition&quot;: {\r\n        &quot;taskDefinitionArn&quot;: &quot;arn:aws:ecs:us-east-1:123454566788:task-definition/nodejs-webapp:21&quot;,\r\n        &quot;containerDefinitions&quot;: [\r\n          {\r\n            &quot;name&quot;: &quot;webapp&quot;,\r\n            &quot;image&quot;: &quot;$docker_image&quot;,\r\n          }\r\n    \t]\r\n      }\r\n    }\r\n\r\n",
        "link": "https://stackoverflow.com/questions/66932509/in-jq-update-json-when-passing-value-as-a-variable",
        "title": "In jq update json when passing value as a variable"
    },
    {
        "tags": [
            "function",
            "arguments",
            "jq",
            "semantics"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1617620709,
                "last_edit_date": 1617620709,
                "creation_date": 1617500760,
                "answer_id": 66937347,
                "question_id": 66936632,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You&#39;re right about `def _assign(paths; vv): vv as $value ...` \r\n\r\nIn essence, a formal parameter, $x, is equivalent to having `x` in the formal parameter list, followed by `x as $x` shortly thereafter. \r\n\r\nThis is briefly mentioned in the [jq manual][1]:\r\n\r\n```\r\nOr use the short-hand:\r\n\r\ndef addvalue($f): ...;\r\n```\r\n\r\nWhat is not mentioned is that, using this example, `f` can also be used in the body of `addvalue`, though doing so might easily be the source of confusion. For example, what result would you expect the following to produce?\r\n\r\n    echo 1 2 3 | jq -n &#39;def f($x): x+x; f(input)&#39;\r\n\r\n  [1]: https://stedolan.github.io/jq/manual/v1.6/",
                "title": "meaning of $value in function formal parameters"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1617620709,
        "creation_date": 1617491307,
        "last_edit_date": 1617502580,
        "question_id": 66936632,
        "body_markdown": "I&#39;m looking at the JQ &quot;builtin.jq&quot; file, and find\r\n```\r\ndef _assign(paths; $value): reduce path(paths) as $p (.; setpath($p; $value));\r\n```\r\nand am trying to figure out the semantics of &quot;$value&quot; as a formal parameter.  It could mean that the parameter is expected to provide only one value, not a list of them.  Or it could be the same as \r\n```\r\ndef _assign(paths; vv): vv as $value | reduce path(paths) as $p (.; setpath($p; $value));\r\n```\r\nor maybe it&#39;s something else?\r\n\r\nI can&#39;t find anything in the documentation about this kind of function formal-parameter.",
        "link": "https://stackoverflow.com/questions/66936632/meaning-of-value-in-function-formal-parameters",
        "title": "meaning of $value in function formal parameters"
    },
    {
        "tags": [
            "regex",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1617641457,
                "post_id": 66955804,
                "comment_id": 118354116,
                "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": 1617641572,
                "post_id": 66955804,
                "comment_id": 118354160,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 3005506,
                    "reputation": 8405,
                    "user_id": 2550114,
                    "user_type": "registered",
                    "accept_rate": 91,
                    "profile_image": "https://i.sstatic.net/R8VYt.png?s=256",
                    "display_name": "James Owers",
                    "link": "https://stackoverflow.com/users/2550114/james-owers"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1718273660,
                "post_id": 66955804,
                "comment_id": 138603364,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1617640452,
                "creation_date": 1617640452,
                "answer_id": 66956361,
                "question_id": 66955804,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Ok I found how to do it!\r\n```\r\njq -r &#39;.tags[] | select(test(&quot;^[0-9].*linux&quot;))&#39;\r\n```",
                "title": "Regex search in JQ"
            },
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1617648831,
                "creation_date": 1617648831,
                "answer_id": 66958239,
                "question_id": 66955804,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The arguments to regex functions must be JSON strings, so any regex backslash must be escaped.  Thus, instead of `match(&quot;\\d.*linux&quot;)`\r\nyou&#39;d write: \r\n\r\n`match(&quot;\\\\d.*linux&quot;)`\r\n\r\n",
                "title": "Regex search in JQ"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1617648831,
        "creation_date": 1617638104,
        "question_id": 66955804,
        "body_markdown": "I am looking for a regular expression in my `jq` query (using. It&#39;s a pretty simple one, I want to match entries starting with a number `\\d` (or `[0-9]`) and ending in `linux`. What I&#39;ve tried so far:\r\n```\r\nversions=`echo $allversions| jq &#39;.tags[] | select(startswith(&quot;\\d&quot;)) | select(endswith(&quot;linux&quot;))&#39;`\r\n```\r\nbut I don&#39;t think `startwith` doesn&#39;t support regular expression. I&#39;m reading that `match` supports regular expression, but I cannot find proper documentation or examples about it. A simple `&#39;jq &#39;.tags[]| match(&quot;\\d.*linux&quot;)&#39;` doesn&#39;t work and gives a syntax error message:\r\n```\r\nsyntax error near unexpected token `&quot;\\d*linux&quot;&#39;\r\n```\r\nHow can I accomplish this? Or should I combine `jq` with `sed` instead?\r\n\r\nFYI:\r\n```\r\n$ jq --version\r\njq-1.6\r\n```",
        "link": "https://stackoverflow.com/questions/66955804/regex-search-in-jq",
        "title": "Regex search in JQ"
    },
    {
        "tags": [
            "arrays",
            "json",
            "object",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1617715476,
                "creation_date": 1617715476,
                "answer_id": 66969556,
                "question_id": 66969364,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Check this,\r\n\r\nhttps://jqplay.org/s/xF9DyVbhXD\r\n\r\n    { foo : [ { id : .foo[] } ] }",
                "title": "Changing array of numbers into array of objects jq"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1617715729,
                "creation_date": 1617715729,
                "answer_id": 66969621,
                "question_id": 66969364,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "There are a few ways to go about it.\r\n\r\nFirst you want to create a new object for each item in foo:\r\n\r\n```\r\n$ jq -c &#39;{ id: .foo[] }&#39;\r\n{&quot;id&quot;:1519739200}\r\n{&quot;id&quot;:1519739600}\r\n{&quot;id&quot;:1519740000}\r\n```\r\n\r\nYou can then rebuild the &quot;shape&quot; you had - first with `[ ... ]`\r\n\r\n```\r\n$ jq -c &#39;[ { id: .foo[] } ]&#39; \r\n[{&quot;id&quot;:1519739200},{&quot;id&quot;:1519739600},{&quot;id&quot;:1519740000}]\r\n```\r\n\r\nThen the `{ foo: }`\r\n\r\n```\r\n$ jq -c &#39;{ foo: [ { id: .foo[] } ] }&#39; \r\n{&quot;foo&quot;:[{&quot;id&quot;:1519739200},{&quot;id&quot;:1519739600},{&quot;id&quot;:1519740000}]}\r\n```\r\n\r\nAnother option is to use `|=` to modify/update `.foo` directly.\r\n\r\n```\r\n$ jq -c &#39;.foo |= [{id: .[]}]&#39; \r\n{&quot;foo&quot;:[{&quot;id&quot;:1519739200},{&quot;id&quot;:1519739600},{&quot;id&quot;:1519740000}]}\r\n```",
                "title": "Changing array of numbers into array of objects jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 2,
        "last_activity_date": 1617746304,
        "creation_date": 1617714813,
        "last_edit_date": 1617746304,
        "question_id": 66969364,
        "body_markdown": "I&#39;m totally brand new to JSON and jq so this might seem like a simple question.\r\nI&#39;d like to change an array of numbers into an array of objects with a key for each value (number). \r\n\r\nLet&#39;s say I have a JSON file like this:\r\n\r\n    {\r\n    &quot;foo&quot;: [1519739200, 1519739600, 1519740000]\r\n    }\r\n\r\nThen my desired output would be:\r\n\r\n    {\r\n    &quot;foo&quot;: [\r\n        {\r\n           &quot;id&quot;: 1519739200\r\n        },\r\n        {\r\n           &quot;id&quot;: 1519739600\r\n        },\r\n        {\r\n           &quot;id&quot;: 1519740000\r\n        },\r\n      ]\r\n    }\r\n\r\nSo far everything I&#39;ve seen was connected with adding new keys with values to existing object or merging two arrays into few objects. I know that I can add more keys into already existing object but how can I add keys to an array? I assume I have to change array elements into objects first but how do I do it?\r\nThank you for answer.",
        "link": "https://stackoverflow.com/questions/66969364/changing-array-of-numbers-into-array-of-objects-jq",
        "title": "Changing array of numbers into array of objects jq"
    },
    {
        "tags": [
            "arrays",
            "json",
            "jq",
            "edit"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1617779107,
                "last_edit_date": 1617779107,
                "creation_date": 1617727012,
                "answer_id": 66972828,
                "question_id": 66972699,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The simplest solution is:\r\n\r\n```jq\r\n.testResults[].assertionResults[].failureMessages[] |= .[0:100]\r\n```\r\n\r\nCheck it [online](https://jqplay.org/s/jnoORMZLa3)!\r\n\r\nThe online example keeps only the first 10 characters of the failure messages to show the effect on the sample JSON you posted in the question (it contains short error messages).\r\n\r\nRead about [array/string slice (`.[a:b]`)](https://stedolan.github.io/jq/manual/#Array/StringSlice:.[10:15]) and [update assignment (`|=`)](https://stedolan.github.io/jq/manual/#Update-assignment:|=) in the JQ documentation.",
                "title": "Replace array values if they exist with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1617779107,
        "creation_date": 1617726593,
        "last_edit_date": 1617736126,
        "question_id": 66972699,
        "body_markdown": "While I use `jq` a lot, I do so mostly for simpler tasks. This one has tied my brain into a knot.\r\n\r\nI have some JSON output from unit tests which I need to modify. Specifically, I need to remove (or replace) an error value because the test framework generates output that is hundreds of lines long.\r\n\r\nThe JSON looks like this:\r\n\r\n```json\r\n{\r\n  &quot;numFailedTestSuites&quot;: 1,\r\n  &quot;numFailedTests&quot;: 1,\r\n  &quot;numPassedTestSuites&quot;: 1,\r\n  &quot;numPassedTests&quot;: 1,\r\n  ...\r\n  &quot;testResults&quot;: [\r\n    {\r\n      &quot;assertionResults&quot;: [\r\n        {\r\n          &quot;failureMessages&quot;: [\r\n            &quot;Error: error message here&quot;\r\n          ],\r\n          &quot;status&quot;: &quot;failed&quot;,\r\n          &quot;title&quot;: &quot;matches snapshot&quot;\r\n        },\r\n        {\r\n          &quot;failureMessages&quot;: [\r\n            &quot;Error: another error message here&quot;,\r\n            &quot;Error: yet another error message here&quot;\r\n          ],\r\n          &quot;status&quot;: &quot;failed&quot;,\r\n          &quot;title&quot;: &quot;matches another snapshot&quot;\r\n        }\r\n      ],\r\n      &quot;endTime&quot;: 1617720396223,\r\n      &quot;startTime&quot;: 1617720393320,\r\n      &quot;status&quot;: &quot;failed&quot;,\r\n      &quot;summary&quot;: &quot;&quot;\r\n    },\r\n    {\r\n      &quot;assertionResults&quot;: [\r\n        {\r\n          &quot;failureMessages&quot;: [],\r\n          &quot;status&quot;: &quot;passed&quot;,\r\n        },\r\n        {\r\n          &quot;failureMessages&quot;: [],\r\n          &quot;status&quot;: &quot;passed&quot;,\r\n        }\r\n      ]\r\n    }\r\n  ]\r\n}\r\n```\r\n\r\nI want to replace each element in `failureMessages` with either a generic `failed` message or with a truncated version (let&#39;s say 100 characters) of itself.\r\n\r\nThe tricky part (for me) is that `failureMessages` is an array and can have 0-n values and I would need to modify all of them. \r\n\r\nI know I can find non-empty arrays with `select(.. | .failureMessages | length &gt; 0)` but that&#39;s as far as I got, because I don&#39;t need to actually `select` items, I need to replace them and get the full JSON back.",
        "link": "https://stackoverflow.com/questions/66972699/replace-array-values-if-they-exist-with-jq",
        "title": "Replace array values if they exist with jq"
    },
    {
        "tags": [
            "json",
            "select",
            "jq",
            "flatten"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1617745947,
                "creation_date": 1617745947,
                "answer_id": 66976958,
                "question_id": 66976506,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The following produces your first alternative:\r\n```\r\n.subFields[]\r\n| select(.id?)\r\n| { id, title, description, type} +\r\n    (.subFields[] \r\n     | select(.type?) \r\n     | [.type,.label,.value] | join(&quot;,&quot;)\r\n     |  { questions: .} )\r\n```\r\nNotice the two `select()` filters.\r\n\r\nThe key names are specified explicitly here to ensure the ordering you specified is honored.\r\n\r\n",
                "title": "Flatten a JSON document using jq by filtering an array by keys"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1617746252,
        "creation_date": 1617743468,
        "last_edit_date": 1617746252,
        "question_id": 66976506,
        "body_markdown": "I have a JSON in the following format:\r\n\r\n        {\r\n      &quot;subFields&quot;: [\r\n        {\r\n          &quot;id&quot;: &quot;question_1&quot;,\r\n          &quot;type&quot;: &quot;radioGroup&quot;,\r\n          &quot;description&quot;: &quot;Description1&quot;,\r\n          &quot;title&quot;: &quot;title1&quot;,\r\n          &quot;subFields&quot;: [\r\n            {\r\n              &quot;type&quot;: &quot;radio&quot;,\r\n              &quot;label&quot;: &quot;Yes&quot;,\r\n              &quot;value&quot;: 1\r\n            },\r\n            {\r\n              &quot;type&quot;: &quot;radio&quot;,\r\n              &quot;label&quot;: &quot;No&quot;,\r\n              &quot;value&quot;: 0\r\n            },\r\n            {\r\n              &quot;uiComponent&quot;: &quot;SmallContent&quot;,\r\n              &quot;componentProps&quot;: {\r\n                &quot;text&quot;: &quot;* If the answer to the above question is “Yes”, please contact the Support immediately.&quot;\r\n              }\r\n            }\r\n          ]\r\n        },\r\n        {\r\n          &quot;uiComponent&quot;: &quot;Spacer&quot;\r\n        },\r\n        {\r\n          &quot;id&quot;: &quot;question_2&quot;,\r\n          &quot;type&quot;: &quot;radioGroup&quot;,\r\n          &quot;description&quot;: &quot;Description2&quot;,\r\n          &quot;title&quot;: &quot;Title2&quot;,\r\n          &quot;subFields&quot;: [\r\n            {\r\n              &quot;type&quot;: &quot;radio&quot;,\r\n              &quot;label&quot;: &quot;Label - Value 1&quot;,\r\n              &quot;value&quot;: 1\r\n            },\r\n            {\r\n              &quot;type&quot;: &quot;radio&quot;,\r\n              &quot;label&quot;: &quot;Label - Value 2&quot;,\r\n              &quot;value&quot;: 2\r\n            },\r\n            {\r\n              &quot;type&quot;: &quot;radio&quot;,\r\n              &quot;label&quot;: &quot;Label - Value 3&quot;,\r\n              &quot;value&quot;: 3\r\n            },\r\n            {\r\n              &quot;type&quot;: &quot;radio&quot;,\r\n              &quot;label&quot;: &quot;Other&quot;,\r\n              &quot;value&quot;: 13,\r\n              &quot;subFields&quot;: [\r\n                {\r\n                  &quot;id&quot;: &quot;question_2a&quot;,\r\n                  &quot;type&quot;: &quot;string&quot;,\r\n                  &quot;condition&quot;: {\r\n                    &quot;type&quot;: &quot;BinaryExpression&quot;,\r\n                    &quot;operator&quot;: &quot;==&quot;,\r\n                    &quot;left&quot;: {\r\n                      &quot;type&quot;: &quot;Identifier&quot;,\r\n                      &quot;name&quot;: &quot;question_2&quot;\r\n                    },\r\n                    &quot;right&quot;: {\r\n                      &quot;type&quot;: &quot;Literal&quot;,\r\n                      &quot;value&quot;: 13\r\n                    }\r\n                  }\r\n                }\r\n              ]\r\n            }\r\n          ]\r\n        },\r\n        {\r\n          &quot;id&quot;: &quot;question_2_b&quot;,\r\n          &quot;style&quot;: {\r\n            &quot;marginTop&quot;: &quot;30px&quot;\r\n          },\r\n          &quot;type&quot;: &quot;radioGroup&quot;,\r\n          &quot;description&quot;: &quot;Description3&quot;,\r\n          &quot;title&quot;: &quot;&quot;,\r\n          &quot;subFields&quot;: [\r\n            {\r\n              &quot;type&quot;: &quot;radio&quot;,\r\n              &quot;label&quot;: &quot;Label - Radio 1&quot;,\r\n              &quot;value&quot;: 1\r\n            },\r\n            {\r\n              &quot;type&quot;: &quot;radio&quot;,\r\n              &quot;label&quot;: &quot;Label - Radio 2&quot;,\r\n              &quot;value&quot;: 2\r\n            },\r\n            {\r\n              &quot;type&quot;: &quot;radio&quot;,\r\n              &quot;label&quot;: &quot;Label - Radio 3&quot;,\r\n              &quot;value&quot;: 3\r\n            }\r\n          ]\r\n        },\r\n        {\r\n          &quot;uiComponent&quot;: &quot;Spacer&quot;\r\n        },\r\n        {\r\n          &quot;id&quot;: &quot;question_3&quot;,\r\n          &quot;type&quot;: &quot;radioGroup&quot;,\r\n          &quot;description&quot;: &quot;Description3&quot;,\r\n          &quot;title&quot;: &quot;Title3&quot;,\r\n          &quot;subFields&quot;: [\r\n            {\r\n              &quot;type&quot;: &quot;radio&quot;,\r\n              &quot;label&quot;: &quot;Yes&quot;,\r\n              &quot;value&quot;: 1\r\n            },\r\n            {\r\n              &quot;type&quot;: &quot;radio&quot;,\r\n              &quot;label&quot;: &quot;No&quot;,\r\n              &quot;value&quot;: 0\r\n            }\r\n          ]\r\n        },\r\n        {\r\n          &quot;uiComponent&quot;: &quot;Spacer&quot;\r\n        },\r\n        {\r\n          &quot;condition&quot;: {\r\n            &quot;type&quot;: &quot;BinaryExpression&quot;,\r\n            &quot;operator&quot;: &quot;==&quot;,\r\n            &quot;left&quot;: {\r\n              &quot;type&quot;: &quot;Identifier&quot;,\r\n              &quot;name&quot;: &quot;signer_type&quot;\r\n            },\r\n            &quot;right&quot;: {\r\n              &quot;type&quot;: &quot;Literal&quot;,\r\n              &quot;value&quot;: &quot;entity&quot;\r\n            }\r\n          },\r\n          &quot;subFields&quot;: [\r\n            {\r\n              &quot;uiComponent&quot;: &quot;Spacer&quot;\r\n            },\r\n            {\r\n              &quot;id&quot;: &quot;question_4&quot;,\r\n              &quot;type&quot;: &quot;radioGroup&quot;,\r\n              &quot;description&quot;: &quot;Description_4&quot;,\r\n              &quot;title&quot;: &quot;Title_4&quot;,\r\n              &quot;subFields&quot;: [\r\n                {\r\n                  &quot;type&quot;: &quot;radio&quot;,\r\n                  &quot;label&quot;: &quot;Yes&quot;,\r\n                  &quot;value&quot;: 1\r\n                },\r\n                {\r\n                  &quot;type&quot;: &quot;radio&quot;,\r\n                  &quot;label&quot;: &quot;No&quot;,\r\n                  &quot;value&quot;: 0\r\n                }\r\n              ]\r\n            },\r\n            {\r\n              &quot;uiComponent&quot;: &quot;Spacer&quot;\r\n            }\r\n          ],\r\n          &quot;uiComponent&quot;: &quot;Block&quot;\r\n        },\r\n        {\r\n          &quot;uiComponent&quot;: &quot;Spacer&quot;\r\n        }\r\n      ],\r\n      &quot;uiComponent&quot;: &quot;Container&quot;\r\n    }\r\n\r\nand I would like to generate the following output:\r\n\r\n    [\r\n    \t{\r\n    \t\t&quot;id&quot;: &quot;question_1&quot;,\r\n    \t\t&quot;title&quot;: &quot;title1&quot;,\r\n    \t\t&quot;description&quot;: &quot;Description1&quot;,\r\n    \t\t&quot;type&quot;: &quot;radioGroup&quot;,\r\n    \t\t&quot;questions&quot;: &quot;radio,Yes,1&quot;\r\n    \t},\r\n    \t{\r\n    \t\t&quot;id&quot;: &quot;question_1&quot;,\r\n    \t\t&quot;title&quot;: &quot;title1&quot;,\r\n    \t\t&quot;description&quot;: &quot;Description1&quot;,\r\n    \t\t&quot;type&quot;: &quot;radioGroup&quot;,\r\n    \t\t&quot;questions&quot;: &quot;radio,No,0&quot;\r\n    \t},\r\n    \t{\r\n    \t\t&quot;id&quot;: &quot;question_2&quot;,\r\n    \t\t&quot;title&quot;: &quot;Title2&quot;,\r\n    \t\t&quot;description&quot;: &quot;Description2&quot;,\r\n    \t\t&quot;type&quot;: &quot;radioGroup&quot;,\r\n    \t\t&quot;questions&quot;: &quot;radio,Label - Value 1,1&quot;\r\n    \t},\r\n    \t{\r\n    \t\t&quot;id&quot;: &quot;question_2&quot;,\r\n    \t\t&quot;title&quot;: &quot;Title2&quot;,\r\n    \t\t&quot;description&quot;: &quot;Description2&quot;,\r\n    \t\t&quot;type&quot;: &quot;radioGroup&quot;,\r\n    \t\t&quot;questions&quot;: &quot;radio,Label - Value 2,2&quot;\r\n    \t},\r\n    \t{\r\n    \t\t&quot;id&quot;: &quot;question_2&quot;,\r\n    \t\t&quot;title&quot;: &quot;Title2&quot;,\r\n    \t\t&quot;description&quot;: &quot;Description2&quot;,\r\n    \t\t&quot;type&quot;: &quot;radioGroup&quot;,\r\n    \t\t&quot;questions&quot;: &quot;radio,Label - Value 3,3&quot;\r\n    \t},\r\n    \t{\r\n    \t\t&quot;id&quot;: &quot;question_2_b&quot;,\r\n    \t\t&quot;title&quot;: &quot;&quot;,\r\n    \t\t&quot;description&quot;: &quot;Description3&quot;,\r\n    \t\t&quot;type&quot;: &quot;radioGroup&quot;,\r\n    \t\t&quot;questions&quot;: &quot;radio,Label - Value 1,1&quot;\r\n    \t},\r\n    \t{\r\n    \t\t&quot;id&quot;: &quot;question_2_b&quot;,\r\n    \t\t&quot;title&quot;: &quot;&quot;,\r\n    \t\t&quot;description&quot;: &quot;Description3&quot;,\r\n    \t\t&quot;type&quot;: &quot;radioGroup&quot;,\r\n    \t\t&quot;questions&quot;: &quot;radio,Label - Value 2,2&quot;\r\n    \t},\r\n    \t{\r\n    \t\t&quot;id&quot;: &quot;question_2_b&quot;,\r\n    \t\t&quot;title&quot;: &quot;&quot;,\r\n    \t\t&quot;description&quot;: &quot;Description3&quot;,\r\n    \t\t&quot;type&quot;: &quot;radioGroup&quot;,\r\n    \t\t&quot;questions&quot;: &quot;radio,Label - Value 3,3&quot;\r\n    \t},\r\n    \t{\r\n    \t\t&quot;id&quot;: &quot;question_3&quot;,\r\n    \t\t&quot;title&quot;: &quot;Title3&quot;,\r\n    \t\t&quot;description&quot;: &quot;Description3&quot;,\r\n    \t\t&quot;type&quot;: &quot;radioGroup&quot;,\r\n    \t\t&quot;questions&quot;: &quot;radio,Yes,1&quot;\r\n    \t},\r\n    \t{\r\n    \t\t&quot;id&quot;: &quot;question_3&quot;,\r\n    \t\t&quot;title&quot;: &quot;Title3&quot;,\r\n    \t\t&quot;description&quot;: &quot;Description3&quot;,\r\n    \t\t&quot;type&quot;: &quot;radioGroup&quot;,\r\n    \t\t&quot;questions&quot;: &quot;radio,No,0&quot;\r\n    \t}\r\n    ]\r\n\r\nor in alternative a reduced version:\r\n\r\n    [\r\n      &quot;question_1&quot;,\r\n      &quot;title1&quot;,\r\n      &quot;Description1&quot;,\r\n      &quot;radioGroup&quot;,\r\n      &quot;radio,Yes,1&quot;,\r\n      &quot;radio,No,0&quot;\r\n    ],\r\n    [\r\n      &quot;question_2&quot;,\r\n      &quot;title2&quot;,\r\n      &quot;Description2&quot;,\r\n      &quot;radioGroup&quot;,\r\n      &quot;radio,Label - Value 1,1&quot;,\r\n      &quot;radio,Label - Value 2,2&quot;,\r\n      &quot;radio,Label - Value 3,3&quot;,\r\n    ],\r\n    [\r\n      &quot;question_2_b&quot;,\r\n      &quot;Description3&quot;,\r\n      &quot;radioGroup&quot;,\r\n      &quot;radio,Label - Value 1,1&quot;,\r\n      &quot;radio,Label - Value 2,2&quot;,\r\n      &quot;radio,Label - Value 3,3&quot;,\r\n    ],\r\n    [\r\n      &quot;question_3&quot;,\r\n      &quot;Title3&quot;,\r\n      &quot;Description3&quot;,\r\n      &quot;radioGroup&quot;,\r\n      &quot;radio,Yes,1&quot;,\r\n      &quot;radio,No,0&quot;\r\n    ]\r\n\r\nThe objective is to get only the objects that contain the id (to remove the **{&quot;uiComponent&quot;: &quot;Spacer&quot;}** objects) and get only the **subFields** with these tags inside the array:\r\n\r\n      &quot;subFields&quot;: [\r\n        {\r\n          &quot;type&quot;: &quot;xxxx&quot;,\r\n          &quot;label&quot;: &quot;xxxx&quot;,\r\n          &quot;value&quot;: xxxx\r\n        },\r\n\r\nI was able to flatten the JSON array by using the following JQ pattern:\r\n\r\n[jq play 1][1]\r\n\r\n    .subFields[] | select(has(&quot;id&quot;) and .id != null)| {id: .id, type: .type, description: .description, anwers: .subFields}\r\n\r\nand generated this result:\r\n\r\n    {\r\n      &quot;id&quot;: &quot;question_1&quot;,\r\n      &quot;type&quot;: &quot;radioGroup&quot;,\r\n      &quot;description&quot;: &quot;Description1&quot;,\r\n      &quot;anwers&quot;: [\r\n        {\r\n          &quot;type&quot;: &quot;radio&quot;,\r\n          &quot;label&quot;: &quot;Yes&quot;,\r\n          &quot;value&quot;: 1\r\n        },\r\n        {\r\n          &quot;type&quot;: &quot;radio&quot;,\r\n          &quot;label&quot;: &quot;No&quot;,\r\n          &quot;value&quot;: 0\r\n        },\r\n        {\r\n          &quot;uiComponent&quot;: &quot;SmallContent&quot;,\r\n          &quot;componentProps&quot;: {\r\n            &quot;text&quot;: &quot;* If the answer to the above question is “Yes”, please contact the Support immediately.&quot;\r\n          }\r\n        }\r\n      ]\r\n    }\r\n    {\r\n      &quot;id&quot;: &quot;question_2&quot;,\r\n      &quot;type&quot;: &quot;radioGroup&quot;,\r\n      &quot;description&quot;: &quot;Description2&quot;,\r\n      &quot;anwers&quot;: [\r\n        {\r\n          &quot;type&quot;: &quot;radio&quot;,\r\n          &quot;label&quot;: &quot;Label - Value 1&quot;,\r\n          &quot;value&quot;: 1\r\n        },\r\n        {\r\n          &quot;type&quot;: &quot;radio&quot;,\r\n          &quot;label&quot;: &quot;Label - Value 2&quot;,\r\n          &quot;value&quot;: 2\r\n        },\r\n        {\r\n          &quot;type&quot;: &quot;radio&quot;,\r\n          &quot;label&quot;: &quot;Label - Value 3&quot;,\r\n          &quot;value&quot;: 3\r\n        },\r\n        {\r\n          &quot;type&quot;: &quot;radio&quot;,\r\n          &quot;label&quot;: &quot;Other&quot;,\r\n          &quot;value&quot;: 13,\r\n          &quot;subFields&quot;: [\r\n            {\r\n              &quot;id&quot;: &quot;question_2a&quot;,\r\n              &quot;type&quot;: &quot;string&quot;,\r\n              &quot;condition&quot;: {\r\n                &quot;type&quot;: &quot;BinaryExpression&quot;,\r\n                &quot;operator&quot;: &quot;==&quot;,\r\n                &quot;left&quot;: {\r\n                  &quot;type&quot;: &quot;Identifier&quot;,\r\n                  &quot;name&quot;: &quot;question_2&quot;\r\n                },\r\n                &quot;right&quot;: {\r\n                  &quot;type&quot;: &quot;Literal&quot;,\r\n                  &quot;value&quot;: 13\r\n                }\r\n              }\r\n            }\r\n          ]\r\n        }\r\n      ]\r\n    }\r\n    {\r\n      &quot;id&quot;: &quot;question_2_b&quot;,\r\n      &quot;type&quot;: &quot;radioGroup&quot;,\r\n      &quot;description&quot;: &quot;Description3&quot;,\r\n      &quot;anwers&quot;: [\r\n        {\r\n          &quot;type&quot;: &quot;radio&quot;,\r\n          &quot;label&quot;: &quot;Label - Radio 1&quot;,\r\n          &quot;value&quot;: 1\r\n        },\r\n        {\r\n          &quot;type&quot;: &quot;radio&quot;,\r\n          &quot;label&quot;: &quot;Label - Radio 2&quot;,\r\n          &quot;value&quot;: 2\r\n        },\r\n        {\r\n          &quot;type&quot;: &quot;radio&quot;,\r\n          &quot;label&quot;: &quot;Label - Radio 3&quot;,\r\n          &quot;value&quot;: 3\r\n        }\r\n      ]\r\n    }\r\n    {\r\n      &quot;id&quot;: &quot;question_3&quot;,\r\n      &quot;type&quot;: &quot;radioGroup&quot;,\r\n      &quot;description&quot;: &quot;Description3&quot;,\r\n      &quot;anwers&quot;: [\r\n        {\r\n          &quot;type&quot;: &quot;radio&quot;,\r\n          &quot;label&quot;: &quot;Yes&quot;,\r\n          &quot;value&quot;: 1\r\n        },\r\n        {\r\n          &quot;type&quot;: &quot;radio&quot;,\r\n          &quot;label&quot;: &quot;No&quot;,\r\n          &quot;value&quot;: 0\r\n        }\r\n      ]\r\n    }\r\n\r\nMy problem is that I don&#39;t know how to remove these sections:\r\n\r\n    {\r\n      &quot;uiComponent&quot;: &quot;SmallContent&quot;,\r\n      &quot;componentProps&quot;: {\r\n        &quot;text&quot;: &quot;* If the answer to the above question is “Yes”, please contact the Support immediately.&quot;\r\n      }\r\n    }\r\n\t\r\nand\r\n\r\n      &quot;subFields&quot;: [\r\n        {\r\n          &quot;id&quot;: &quot;question_2a&quot;,\r\n          &quot;type&quot;: &quot;string&quot;,\r\n          &quot;condition&quot;: {\r\n            &quot;type&quot;: &quot;BinaryExpression&quot;,\r\n            &quot;operator&quot;: &quot;==&quot;,\r\n            &quot;left&quot;: {\r\n              &quot;type&quot;: &quot;Identifier&quot;,\r\n              &quot;name&quot;: &quot;question_2&quot;\r\n            },\r\n            &quot;right&quot;: {\r\n              &quot;type&quot;: &quot;Literal&quot;,\r\n              &quot;value&quot;: 13\r\n            }\r\n          }\r\n        }\r\n      ]\r\n\r\nI played a little bit arround with this jq for the question_3 only:\r\n\r\n[jq play 2][2]\r\n\r\n    .subFields[] |  {id: .id, title: .title, description: .description, type: .type, subFields: .subFields} | select(has(&quot;id&quot;) and .id != null) | select(.id==&quot;question_3&quot;) |  {id: .id, title: .title, description: .description, type: .type, questions: (.subFields[]|join(&quot;,&quot;))}\r\n\r\nand produced this result:\r\n\r\n    {\r\n      &quot;id&quot;: &quot;question_3&quot;,\r\n      &quot;title&quot;: &quot;Title3&quot;,\r\n      &quot;description&quot;: &quot;Description3&quot;,\r\n      &quot;type&quot;: &quot;radioGroup&quot;,\r\n      &quot;questions&quot;: &quot;radio,Yes,1&quot;\r\n    }\r\n    {\r\n      &quot;id&quot;: &quot;question_3&quot;,\r\n      &quot;title&quot;: &quot;Title3&quot;,\r\n      &quot;description&quot;: &quot;Description3&quot;,\r\n      &quot;type&quot;: &quot;radioGroup&quot;,\r\n      &quot;questions&quot;: &quot;radio,No,0&quot;\r\n    }\r\n\r\nand also\r\n\r\n[jq play 3][3]\r\n\r\n    .subFields[] |  {id: .id, title: .title, description: .description, type: .type, subFields: .subFields} | select(has(&quot;id&quot;) and .id != null) | select(.id==&quot;question_3&quot;) |  [.id, .title, .description, .type, (.subFields[]|join(&quot;,&quot;))]\r\n\r\nresulting on this:\r\n\r\n    [\r\n      &quot;question_3&quot;,\r\n      &quot;Title3&quot;,\r\n      &quot;Description3&quot;,\r\n      &quot;radioGroup&quot;,\r\n      &quot;radio,Yes,1&quot;,\r\n      &quot;radio,No,0&quot;\r\n    ]\r\n\r\nCan you help me improve those JQ pattern I created to get the intended results?\r\n\r\nThanks in advance!\r\n\r\n  [1]: https://jqplay.org/s/KVSA7S_ES5\r\n  [2]: https://jqplay.org/s/a-UWCazubc\r\n  [3]: https://jqplay.org/s/bJEKjPlTfE",
        "link": "https://stackoverflow.com/questions/66976506/flatten-a-json-document-using-jq-by-filtering-an-array-by-keys",
        "title": "Flatten a JSON document using jq by filtering an array by keys"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 8423,
                    "reputation": 757671,
                    "user_id": 15168,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/WtEI9.png?s=256",
                    "display_name": "Jonathan Leffler",
                    "link": "https://stackoverflow.com/users/15168/jonathan-leffler"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1617756180,
                "post_id": 66978161,
                "comment_id": 118392987,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1617937321,
                "creation_date": 1617937321,
                "answer_id": 67014504,
                "question_id": 66978161,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "```jq\r\n.[] | select( .username == $username ) | .username + &quot; : &quot; + .password\r\n```\r\n\r\nUsed as\r\n\r\n```sh\r\njq --arg username solr -r &#39;.[] | select( .username == $username ) | .username + &quot; : &quot; + .password&#39;\r\n```\r\n\r\n[jqplay](https://jqplay.org/s/fEkcRmZt9v)\r\n",
                "title": "How to get selected values from JSON output"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1617937321,
        "creation_date": 1617755699,
        "last_edit_date": 1617756101,
        "question_id": 66978161,
        "body_markdown": "From the output shown, I was looking for `solr : xcfrtgyhujikolpu` in a shell script:\r\n\r\n    [{&quot;username&quot;:&quot;zookeeper&quot;,&quot;password&quot;:&quot;sdfrtghuioklhq&quot;}, \r\n     {&quot;username&quot;:&quot;solr&quot;,&quot;password&quot;:&quot;xcfrtgyhujikolpu&quot;}]\r\n\r\n\r\nI tried:\r\n\r\n    |  jq -r .[].password",
        "link": "https://stackoverflow.com/questions/66978161/how-to-get-selected-values-from-json-output",
        "title": "How to get selected values from JSON output"
    },
    {
        "tags": [
            "shell",
            "sed",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 21176095,
                    "reputation": 1,
                    "user_id": 15571375,
                    "user_type": "registered",
                    "profile_image": "https://lh4.googleusercontent.com/-04TLlA6EWpw/AAAAAAAAAAI/AAAAAAAAAAA/AMZuucnMQp2w_OLsKy877HkQycc3rwhtew/s96-c/s256-rj/photo.jpg",
                    "display_name": "sanketh Ranebennur",
                    "link": "https://stackoverflow.com/users/15571375/sanketh-ranebennur"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1617783104,
                "post_id": 66981336,
                "comment_id": 118399426,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 468289,
                    "reputation": 190915,
                    "user_id": 874188,
                    "user_type": "registered",
                    "accept_rate": 62,
                    "profile_image": "https://www.gravatar.com/avatar/091f411d57db5be8298e057a32e5ad72?s=256&d=identicon&r=PG",
                    "display_name": "tripleee",
                    "link": "https://stackoverflow.com/users/874188/tripleee"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1617783579,
                "post_id": 66981336,
                "comment_id": 118399627,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1617858809,
                "post_id": 66981336,
                "comment_id": 118426494,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1617783478,
                "creation_date": 1617783478,
                "answer_id": 66982110,
                "question_id": 66981336,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Your JSON doesn&#39;t look 100% valid but with valid JSON, use jq e.g.:\r\n\r\n    jq &#39;.start-date=&quot;2013-06-27T10:00:00&quot; | .end-date=&quot;2013-06-27T10:00:00&quot; | .proposed-date=&quot;2013-06-27T10:00:00&quot;&#39; dummy-file.json",
                "title": "using sed i need to replace value"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1617863610,
                "last_edit_date": 1617863610,
                "creation_date": 1617818869,
                "answer_id": 66991777,
                "question_id": 66981336,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "tripleee told why your command behaved as you observed. Now to rectify it, you have to change the _greedy_ `.*` to some expression which doesn&#39;t match more than wanted; this can be an expression of fixed length as `....-..-..T..:..:..` or an expression of variable length which doesn&#39;t extend to unwanted characters as `[^\\]*` (the `[` `]` denote a [Bracket Expression][1] _that shall match a specific set of single characters_, the `^` at the start denotes a _non-matching list_, and the _list_ consists of only the char `\\`, i. e. the `[^\\]*` matches any number (`*`) of characters which are not `\\`, so the match only reaches till the end of the start timestamp and stops at the following `\\`).\r\n\r\n\r\n  [1]: https://pubs.opengroup.org/onlinepubs/9699919799/basedefs/V1_chap09.html#tag_09_03_05",
                "title": "using sed i need to replace value"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1617944605,
                "last_edit_date": 1617944605,
                "creation_date": 1617895725,
                "answer_id": 67007216,
                "question_id": 66981336,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "A jq-only solution can easily be built-up using `sub` beginning like so:\r\n```\r\n.&quot;test.yaml&quot; |= sub(&quot;(?&lt;key&gt;start-date: )(?&lt;date&gt;[-0-9:T]+)&quot;; &quot;\\(.key)2013-06-27T10:00:00&quot;)\r\n```\r\n\r\nYou would add additional `sub` filters (like the one shown) to the RHS for each key of interest, using the pattern:\r\n\r\n    .&quot;test-yaml&quot; |= (sub(...) | sub(...) ...)\r\n\r\nThis approach would be particularly advantageous if the replacement string must be computed based on the string being replaced.",
                "title": "using sed i need to replace value"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 0,
        "last_activity_date": 1630152725,
        "creation_date": 1617780133,
        "last_edit_date": 1630152725,
        "question_id": 66981336,
        "body_markdown": "    {\r\n    \t&quot;test.yaml&quot;: &quot;# Copyright (c) 2019-2020 .\\n# All Rights Reserved.\\n#\\n#\\n\\trace1:\\n  - trace-id:\\n      - \\&quot;immm-0555555555\\&quot;\\n      - \\&quot;mncid-6666666666\\&quot;\\n    test-service:\\n      - \\&quot;test-data\\&quot;\\n    proposed-date: 2019-06-26T16:32:52\\n    start-date: 2019-06-27T10:00:00\\n    end-date: 2050-06-27T10:30:00\\n    test-type: \\&quot;HIGH\\&quot;&quot;\r\n    }\r\n\r\nabove is the json content basically i need to update startdate enddate proposeddate i have used sed command to update \r\n\r\n    sed -i -e &#39;s/start-date: .*\\\\n/start-date: 2013-06-27T10:00:00\\\\n/&#39; /dummyfile.json\r\n\r\nafter this command execution\r\n\r\n    {\r\n    \t&quot;test.yaml&quot;: &quot;# Copyright (c) 2019-2020 .\\n# All Rights Reserved.\\n#\\n#\\n\\trace1:\\n  - trace-id:\\n      - \\&quot;immm-0555555555\\&quot;\\n      - \\&quot;mncid-6666666666\\&quot;\\n    test-service:\\n      - \\&quot;test-data\\&quot;\\n    proposed-date: 2019-06-26T16:32:52\\n    start-date: 2013-06-27T10:00:00\\n       test-type: \\&quot;HIGH\\&quot;&quot;\r\n    }\r\n\r\nbut this updating like this end-date is also deleted \r\n\r\n",
        "link": "https://stackoverflow.com/questions/66981336/using-sed-i-need-to-replace-value",
        "title": "using sed i need to replace value"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 1270084,
                    "reputation": 5516,
                    "user_id": 1226605,
                    "user_type": "registered",
                    "accept_rate": 86,
                    "profile_image": "https://www.gravatar.com/avatar/ad052087f658c0667ac37deca1ee61fb?s=256&d=identicon&r=PG",
                    "display_name": "devang",
                    "link": "https://stackoverflow.com/users/1226605/devang"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1617811303,
                "post_id": 66989639,
                "comment_id": 118413123,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 332115,
                    "reputation": 3018,
                    "user_id": 657215,
                    "user_type": "registered",
                    "accept_rate": 86,
                    "profile_image": "https://www.gravatar.com/avatar/5152934729b9d249b4dab2beb731f439?s=256&d=identicon&r=PG",
                    "display_name": "Graddy",
                    "link": "https://stackoverflow.com/users/657215/graddy"
                },
                "reply_to_user": {
                    "account_id": 1270084,
                    "reputation": 5516,
                    "user_id": 1226605,
                    "user_type": "registered",
                    "accept_rate": 86,
                    "profile_image": "https://www.gravatar.com/avatar/ad052087f658c0667ac37deca1ee61fb?s=256&d=identicon&r=PG",
                    "display_name": "devang",
                    "link": "https://stackoverflow.com/users/1226605/devang"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1617812325,
                "post_id": 66989639,
                "comment_id": 118413551,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1617811302,
                "last_edit_date": 1617811302,
                "creation_date": 1617810980,
                "answer_id": 66989733,
                "question_id": 66989639,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Use `map_values`:\r\n\r\n    jq &#39;map_values([.[]])&#39; file.json",
                "title": "jq: create object from another nested object"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1617828995,
                "last_edit_date": 1617828995,
                "creation_date": 1617811484,
                "answer_id": 66989857,
                "question_id": 66989639,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Based on my understanding, here&#39;s the `jq`\r\n\r\n```\r\nto_entries | map({ &quot;\\(.key)&quot;: .value | to_entries | map(.value) }) | add\r\n```\r\n\r\nwith output -\r\n\r\n```\r\n[\r\n  {\r\n    &quot;iter_1&quot;: [\r\n      &quot;rv_0&quot;,\r\n      &quot;rv_1&quot;,\r\n      &quot;rv_2&quot;,\r\n      &quot;rv_3&quot;,\r\n      &quot;rv_4&quot;,\r\n      &quot;rv_5&quot;,\r\n      &quot;rv_6&quot;,\r\n      &quot;rv_7&quot;,\r\n      &quot;rv_8&quot;,\r\n      &quot;rv_9&quot;,\r\n      &quot;rv_10&quot;,\r\n      &quot;rv_11&quot;,\r\n      &quot;rv_12&quot;,\r\n      &quot;rv_13&quot;,\r\n      &quot;rv_14&quot;,\r\n      &quot;rv_15&quot;\r\n    ]\r\n  },\r\n  {\r\n    &quot;iter_2&quot;: [\r\n      &quot;rv_0&quot;,\r\n      &quot;rv_1&quot;,\r\n      &quot;rv_2&quot;,\r\n      &quot;rv_3&quot;,\r\n      &quot;rv_4&quot;,\r\n      &quot;rv_5&quot;,\r\n      &quot;rv_6&quot;,\r\n      &quot;rv_7&quot;\r\n    ]\r\n  },\r\n  {\r\n    &quot;iter_4&quot;: [\r\n      &quot;rv_0&quot;,\r\n      &quot;rv_1&quot;,\r\n      &quot;rv_2&quot;,\r\n      &quot;rv_3&quot;\r\n    ]\r\n  },\r\n  {\r\n    &quot;iter_8&quot;: [\r\n      &quot;rv_0&quot;,\r\n      &quot;rv_1&quot;\r\n    ]\r\n  },\r\n  {\r\n    &quot;iter_16&quot;: [\r\n      &quot;rv_0&quot;\r\n    ]\r\n  }\r\n]```",
                "title": "jq: create object from another nested object"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1617811648,
                "creation_date": 1617811648,
                "answer_id": 66989905,
                "question_id": 66989639,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "    map_values([.[]])\r\n\r\nYour question about jq variables is not so clear to me, but is apparently irrelevant here. Note, though, that `keys` sorts the key names.",
                "title": "jq: create object from another nested object"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 0,
        "last_activity_date": 1617828995,
        "creation_date": 1617810584,
        "question_id": 66989639,
        "body_markdown": "I have the following json file\r\n```\r\n{\r\n  &quot;iter_1&quot;: {\r\n    &quot;rv_0&quot;: &quot;rv_0&quot;,\r\n    &quot;rv_1&quot;: &quot;rv_1&quot;,\r\n    &quot;rv_2&quot;: &quot;rv_2&quot;,\r\n    &quot;rv_3&quot;: &quot;rv_3&quot;,\r\n    &quot;rv_4&quot;: &quot;rv_4&quot;,\r\n    &quot;rv_5&quot;: &quot;rv_5&quot;,\r\n    &quot;rv_6&quot;: &quot;rv_6&quot;,\r\n    &quot;rv_7&quot;: &quot;rv_7&quot;,\r\n    &quot;rv_8&quot;: &quot;rv_8&quot;,\r\n    &quot;rv_9&quot;: &quot;rv_9&quot;,\r\n    &quot;rv_10&quot;: &quot;rv_10&quot;,\r\n    &quot;rv_11&quot;: &quot;rv_11&quot;,\r\n    &quot;rv_12&quot;: &quot;rv_12&quot;,\r\n    &quot;rv_13&quot;: &quot;rv_13&quot;,\r\n    &quot;rv_14&quot;: &quot;rv_14&quot;,\r\n    &quot;rv_15&quot;: &quot;rv_15&quot;\r\n  },\r\n  &quot;iter_2&quot;: {\r\n    &quot;rv_0&quot;: &quot;rv_1&quot;,\r\n    &quot;rv_1&quot;: &quot;rv_2&quot;,\r\n    &quot;rv_2&quot;: &quot;rv_4&quot;,\r\n    &quot;rv_3&quot;: &quot;rv_6&quot;,\r\n    &quot;rv_4&quot;: &quot;rv_8&quot;,\r\n    &quot;rv_5&quot;: &quot;rv_11&quot;,\r\n    &quot;rv_6&quot;: &quot;rv_13&quot;,\r\n    &quot;rv_7&quot;: &quot;rv_14&quot;\r\n  },\r\n  &quot;iter_4&quot;: {\r\n    &quot;rv_0&quot;: &quot;rv_1&quot;,\r\n    &quot;rv_1&quot;: &quot;rv_6&quot;,\r\n    &quot;rv_2&quot;: &quot;rv_8&quot;,\r\n    &quot;rv_3&quot;: &quot;rv_14&quot;\r\n  },\r\n  &quot;iter_8&quot;: {\r\n    &quot;rv_0&quot;: &quot;rv_1&quot;,\r\n    &quot;rv_1&quot;: &quot;rv_14&quot;\r\n  },\r\n  &quot;iter_16&quot;: {\r\n    &quot;rv_0&quot;: &quot;rv_1&quot;\r\n  }\r\n}\r\n```\r\n\r\nand I want to create a new object where the keys are top level keys (iter_n) and the value of each key is an array of the nested values. In other words, they value for `iter_2` is an array containing `[rv_1, rv_2...,rv_14]`. Is it possible to do this in jq ?\r\n\r\nHere&#39;s what I tried so far :\r\n\r\n```\r\n jq -c &#39;{(. | keys[] as $k | $k) : (. | .iter_1)}&#39;\r\n```\r\nIdeally, I&#39;d like to use `$k` in the value part of object construction. From what I understand, the scoping rules of jq doesn&#39;t allow this. Is this true ? Are there other ways (in jq) to create the object I want ?",
        "link": "https://stackoverflow.com/questions/66989639/jq-create-object-from-another-nested-object",
        "title": "jq: create object from another nested object"
    },
    {
        "tags": [
            "amazon-web-services",
            "shell",
            "command-line-interface",
            "aws-cloudformation",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1617815026,
                "creation_date": 1617815026,
                "answer_id": 66990793,
                "question_id": 66990112,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "We can easily do with native --query \r\n\r\n&gt; aws cloudformation list-exports --query\r\n&gt; &quot;Exports[?Name==&#39;ThisIsNameOfExport&#39;].Value&quot;  --output text",
                "title": "Filter exported data cloudFormation using aws cli"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1617822041,
                "creation_date": 1617822041,
                "answer_id": 66992544,
                "question_id": 66990112,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Using jq:\r\n\r\n\r\n    .Exports[] | select(.Name == &quot;My-RSC-NAME&quot;).Value",
                "title": "Filter exported data cloudFormation using aws cli"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1617822128,
        "creation_date": 1617812490,
        "last_edit_date": 1617822128,
        "question_id": 66990112,
        "body_markdown": "I want to filter the exported output values of this command `aws cloudformation list-exports` using **jq** or **query**.\r\n\r\nExample of Data:\r\n```\r\n     {\r\n        &quot;Exports&quot;: [\r\n            {\r\n                &quot;ExportingStackId&quot;: &quot;arn:aws...&quot;,\r\n                &quot;Name&quot;: &quot;RSC-NAME-2&quot;,\r\n                &quot;Value&quot;: &quot;RSC-VALUE-2&quot;\r\n            },\r\n            {\r\n                &quot;ExportingStackId&quot;: &quot;arn:aws...&quot;,\r\n                &quot;Name&quot;: &quot;My-RSC-NAME&quot;,\r\n                &quot;Value&quot;: &quot;My-RSC-VALUE&quot;\r\n            }\r\n        ]\r\n    } \r\n```\r\nI&#39;m looking for a command that can return the **Value** and filter by **Name**\r\n\r\nExample: if i search by **Name** equal to `My-RSC-NAME` the result will be `My-RSC-VALUE`\r\n\r\n",
        "link": "https://stackoverflow.com/questions/66990112/filter-exported-data-cloudformation-using-aws-cli",
        "title": "Filter exported data cloudFormation using aws cli"
    },
    {
        "tags": [
            "json",
            "if-statement",
            "select",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 295859,
                    "reputation": 14087,
                    "user_id": 600486,
                    "user_type": "registered",
                    "accept_rate": 80,
                    "profile_image": "https://i.sstatic.net/akN6H.png?s=256",
                    "display_name": "blurfus",
                    "link": "https://stackoverflow.com/users/600486/blurfus"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1617820414,
                "post_id": 66992079,
                "comment_id": 118416960,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1570898,
                    "reputation": 2784,
                    "user_id": 1458605,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/dRqvI.jpg?s=256",
                    "display_name": "fgiraldeau",
                    "link": "https://stackoverflow.com/users/1458605/fgiraldeau"
                },
                "reply_to_user": {
                    "account_id": 295859,
                    "reputation": 14087,
                    "user_id": 600486,
                    "user_type": "registered",
                    "accept_rate": 80,
                    "profile_image": "https://i.sstatic.net/akN6H.png?s=256",
                    "display_name": "blurfus",
                    "link": "https://stackoverflow.com/users/600486/blurfus"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1617824074,
                "post_id": 66992079,
                "comment_id": 118418481,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1617821488,
                "last_edit_date": 1617821488,
                "creation_date": 1617820923,
                "answer_id": 66992288,
                "question_id": 66992079,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Don&#39;t use `select`:\r\n\r\n    . | if .foo.bar == &quot;one&quot; then .foo.bar |= &quot;ok&quot; else . end\r\n\r\n`select` is useful for filtering, but it doesn&#39;t return a false value if there&#39;s nothing to select, it doesn&#39;t return anything.",
                "title": "jq ignores else clause"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 3,
        "last_activity_date": 1617836401,
        "creation_date": 1617820135,
        "last_edit_date": 1617836401,
        "question_id": 66992079,
        "body_markdown": "I would like to search and replace a specific value in a json line-based data using jq and keep the object unmodified if the match is false.\r\n\r\nConsidering the following `input.json`:\r\n\r\n```json\r\n{&quot;foo&quot;:{&quot;bar&quot;:&quot;one&quot;}}\r\n{&quot;foo&quot;:{&quot;bar&quot;:&quot;two&quot;}}\r\n```\r\n\r\nI tried the following statement, but the else clause is ignored, and therefore lines that don&#39;t match are lost:\r\n\r\n```sh\r\njq -c &#39;. | if (select(.foo.bar == &quot;one&quot;)) then .foo.bar |= &quot;ok&quot; else . end&#39; input.json\r\n```\r\n\r\nproduces result:\r\n\r\n```json\r\n{&quot;foo&quot;:{&quot;bar&quot;:&quot;ok&quot;}}\r\n```\r\n\r\nThe following command produces the right output:\r\n\r\n```sh\r\njq -c &#39;(. | select(.foo.bar == &quot;one&quot;)).foo.bar = &quot;ok&quot;&#39; input.json\r\n```\r\n\r\ndesired output:\r\n```json\r\n{&quot;foo&quot;:{&quot;bar&quot;:&quot;ok&quot;}}\r\n{&quot;foo&quot;:{&quot;bar&quot;:&quot;two&quot;}}\r\n```\r\n\r\nWhy the first command fails to output the object `.` in the else clause?",
        "link": "https://stackoverflow.com/questions/66992079/jq-ignores-else-clause",
        "title": "jq ignores else clause"
    },
    {
        "tags": [
            "json",
            "nested",
            "key",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1617950421,
                "last_edit_date": 1617950421,
                "creation_date": 1617949446,
                "answer_id": 67016077,
                "question_id": 67015851,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You could use `walk`:\r\n```\r\nwalk(if type==&quot;object&quot; and .suffix_name \r\n     then .suffix_name |= sub(&quot;[.]fifo$&quot;;&quot;&quot;) else . end)\r\n```\r\n\r\nAlternatively, just use `|=`:\r\n```\r\n (.. | select(type == &quot;object&quot; and .suffix_name) | .suffix_name) \r\n  |=  sub(&quot;[.]fifo$&quot;;&quot;&quot;) \r\n```",
                "title": "How to access key at any level?"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1617950258,
                "creation_date": 1617950258,
                "answer_id": 67016206,
                "question_id": 67015851,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "An alternate to `walk` using the `path` functions - `getpath` and `setpath`\r\n\r\n```jq\r\nreduce ( paths | select(.[-1] | endswith(&quot;suffix_name&quot;)? ) ) as $p \r\n  ( .; setpath($p; getpath($p) | sub(&quot;[.]fifo$&quot;;&quot;&quot;) ) )\r\n```\r\n\r\nIdentify paths from the root to `suffix_name` and iterate it over using `reduce`. For each of the paths, reconstruct the value by having the suffix removed.",
                "title": "How to access key at any level?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1617950690,
        "creation_date": 1617948121,
        "last_edit_date": 1617950690,
        "question_id": 67015851,
        "body_markdown": "I have this input file\r\n\r\n```json\r\n{\r\n\t&quot;description&quot;: &quot;this is a fake description&quot;,\r\n\t&quot;owner&quot;: &quot;john&quot;,\r\n\t&quot;region&quot;: &quot;us-east-1&quot;,\r\n\t&quot;topics&quot;: {\r\n\t\t&quot;For collecting responses for prod1&quot;: {\r\n\t\t\t&quot;suffix_name&quot;: &quot;response-to-hogwarts.fifo&quot;,\r\n\t\t\t&quot;tags&quot;: {}\r\n\t\t}\r\n\t},\r\n\t&quot;queues&quot;: {\r\n\t\t&quot;For collecting responses and requests from test1&quot;: {\r\n\t\t\t&quot;suffix_name&quot;: &quot;rr_sf_name.fifo&quot;,\r\n\t\t\t&quot;tags&quot;: {}\r\n\t\t},\r\n\t\t&quot;For collecting responses for test2&quot;: {\r\n\t\t\t&quot;suffix_name&quot;: &quot;response-to-hogwarts.fifo&quot;,\r\n\t\t\t&quot;tags&quot;: {}\r\n\t\t}\r\n\t},\r\n\t&quot;subscriptions&quot;: {\r\n\t\t&quot;For receiving harry_potter requests&quot;: {\r\n\t\t\t&quot;topic&quot;: {\r\n\t\t\t\t&quot;suffix_name&quot;: &quot;harry_potter.fifo&quot;,\r\n\t\t\t\t&quot;tag&quot;: &quot;staging&quot;\r\n\t\t\t},\r\n\t\t\t&quot;queue&quot;: {\r\n\t\t\t\t&quot;suffix_name&quot;: &quot;rr_sf_name.fifo&quot;\r\n\t\t\t}\r\n\t\t},\r\n\t\t&quot;For receiving harry_potter requests from test3&quot;: {\r\n\t\t\t&quot;topic&quot;: {\r\n\t\t\t\t&quot;suffix_name&quot;: &quot;harry_potter.fifo&quot;,\r\n\t\t\t\t&quot;tag&quot;: &quot;harry_potter_hogwarts&quot;\r\n\t\t\t},\r\n\t\t\t&quot;queue&quot;: {\r\n\t\t\t\t&quot;suffix_name&quot;: &quot;rr_sf_name.fifo&quot;\r\n\t\t\t}\r\n\t\t},\r\n\t\t&quot;For receiving demo requests&quot;: {\r\n\t\t\t&quot;topic&quot;: {\r\n\t\t\t\t&quot;suffix_name&quot;: &quot;demo.fifo&quot;,\r\n\t\t\t\t&quot;tag&quot;: &quot;staging&quot;\r\n\t\t\t},\r\n\t\t\t&quot;queue&quot;: {\r\n\t\t\t\t&quot;suffix_name&quot;: &quot;rr_sf_name.fifo&quot;\r\n\t\t\t}\r\n\t\t},\r\n\t\t&quot;For receiving demo requests from test4 through connector&quot;: {\r\n\t\t\t&quot;topic&quot;: {\r\n\t\t\t\t&quot;suffix_name&quot;: &quot;demo.fifo&quot;,\r\n\t\t\t\t&quot;tag&quot;: &quot;harry_potter_hogwarts&quot;\r\n\t\t\t},\r\n\t\t\t&quot;queue&quot;: {\r\n\t\t\t\t&quot;suffix_name&quot;: &quot;rr_sf_name.fifo&quot;\r\n\t\t\t}\r\n\t\t},\r\n\t\t&quot;For receiving testing responses for hogwarts&quot;: {\r\n\t\t\t&quot;topic&quot;: {\r\n\t\t\t\t&quot;suffix_name&quot;: &quot;response-to-hogwarts.fifo&quot;\r\n\t\t\t},\r\n\t\t\t&quot;queue&quot;: {\r\n\t\t\t\t&quot;suffix_name&quot;: &quot;response-to-hogwarts.fifo&quot;\r\n\t\t\t}\r\n\t\t}\r\n\t}\r\n}\r\n```\r\n\r\nNow I want to remove the &quot;.fifo&quot; suffix from the value of **ALL** the `suffix_name` fields, at any level\r\n\r\nExample output (truncated for brevity)\r\n```json\r\n    &quot;topics&quot;: {\r\n        &quot;For collecting responses for prod1&quot;: {\r\n            &quot;suffix_name&quot;: &quot;response-to-hogwarts&quot;,\r\n            &quot;tags&quot;: {}\r\n        }\r\n    },\r\n```\r\n\r\nNow I came up with this, which **is working** for me.\r\n```\r\n.queues |= with_entries(.value.suffix_name |= sub(&quot;.fifo&quot;;&quot;&quot;))\r\n| .topics |= with_entries(.value.suffix_name |= sub(&quot;.fifo&quot;;&quot;&quot;))\r\n| .subscriptions |= with_entries(.value |= with_entries(.value |= with_entries(.value |= rtrimstr(&quot;.fifo&quot;))))\r\n```\r\n\r\nI want to know, if there is a better way, using recurse or something, to parse through all keys and if the key is `suffix_name`, trim the &quot;.fifo&quot; from the value.",
        "link": "https://stackoverflow.com/questions/67015851/how-to-access-key-at-any-level",
        "title": "How to access key at any level?"
    },
    {
        "tags": [
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 10015983,
                    "reputation": 144648,
                    "user_id": 9072753,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/EPmGy.jpg?s=256",
                    "display_name": "KamilCuk",
                    "link": "https://stackoverflow.com/users/9072753/kamilcuk"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1617980895,
                "post_id": 67023548,
                "comment_id": 118471559,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 10015983,
                    "reputation": 144648,
                    "user_id": 9072753,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/EPmGy.jpg?s=256",
                    "display_name": "KamilCuk",
                    "link": "https://stackoverflow.com/users/9072753/kamilcuk"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1617981069,
                "post_id": 67023548,
                "comment_id": 118471641,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1617982063,
                "last_edit_date": 1617982063,
                "creation_date": 1617981322,
                "answer_id": 67023785,
                "question_id": 67023548,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "\r\nWith the following input files:\r\n\r\n    $ cat /tmp/1.jq\r\n    {\r\n      &quot;DB&quot;: &quot;jaap_35290&quot;,\r\n      &quot;DBUSER&quot;: &quot;jaap_35290&quot;,\r\n      &quot;HOST&quot;: &quot;localhost&quot;,\r\n      &quot;TYPE&quot;: &quot;mysql&quot;,\r\n      &quot;CHARSET&quot;: &quot;UTF8&quot;\r\n    }\r\n    $ cat /tmp/2.jq\r\n    {\r\n      &quot;DB&quot;: &quot;db_2&quot;,\r\n      &quot;DBUSER&quot;: &quot;jaap_35290&quot;,\r\n      &quot;HOST&quot;: &quot;localhost&quot;,\r\n      &quot;TYPE&quot;: &quot;mysql&quot;,\r\n      &quot;CHARSET&quot;: &quot;UTF8&quot;\r\n    }\r\n\r\nWith the help of https://blog.differentpla.net/blog/2019/01/11/jq-reduce/ and https://stedolan.github.io/jq/manual/ I was able to output the expected output with these input files:\r\n\r\n    $ jq -s &#39;reduce .[] as $line ({}; . + {($line | .DB): $line} )&#39; /tmp/1.jq /tmp/2.jq\r\n    {\r\n      &quot;jaap_35290&quot;: {\r\n        &quot;DB&quot;: &quot;jaap_35290&quot;,\r\n        &quot;DBUSER&quot;: &quot;jaap_35290&quot;,\r\n        &quot;HOST&quot;: &quot;localhost&quot;,\r\n        &quot;TYPE&quot;: &quot;mysql&quot;,\r\n        &quot;CHARSET&quot;: &quot;UTF8&quot;\r\n      },\r\n      &quot;db_2&quot;: {\r\n        &quot;DB&quot;: &quot;db_2&quot;,\r\n        &quot;DBUSER&quot;: &quot;jaap_35290&quot;,\r\n        &quot;HOST&quot;: &quot;localhost&quot;,\r\n        &quot;TYPE&quot;: &quot;mysql&quot;,\r\n        &quot;CHARSET&quot;: &quot;UTF8&quot;\r\n      }\r\n    }\r\n",
                "title": "jq merge 2 files as associative &quot;json&quot; file"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1617997060,
                "last_edit_date": 1617997060,
                "creation_date": 1617982669,
                "answer_id": 67024132,
                "question_id": 67023548,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "A simple and efficient solution:\r\n\r\n    jq -n &#39;INDEX(inputs; .DB)&#39;  ...\r\n\r\nwhere ... specifies the relevant file names.\r\n\r\nOf course, if you&#39;re generating the JSON objects using jq, then you should be able to combine everything into one invocation of jq, using `INDEX/2`.\r\n\r\n\r\n",
                "title": "jq merge 2 files as associative &quot;json&quot; file"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1617997060,
        "creation_date": 1617980533,
        "question_id": 67023548,
        "body_markdown": "Have multiple json files (Generated with JQ) that have the following format. \r\n\r\n    {\r\n        &quot;DB&quot;: &quot;jaap_35290&quot;,\r\n        &quot;DBUSER&quot;: &quot;jaap_35290&quot;,\r\n        &quot;HOST&quot;: &quot;localhost&quot;,\r\n        &quot;TYPE&quot;: &quot;mysql&quot;,\r\n        &quot;CHARSET&quot;: &quot;UTF8&quot;,\r\n    }\r\n\r\nI need merged them via jq to have the following format associative array in php (For other systems that need this format that I can&#39;t control.)\r\n\r\n     {\r\n         &quot;jaap_35290&quot;: {\r\n            &quot;DB&quot;: &quot;jaap_35290&quot;,\r\n            &quot;DBUSER&quot;: &quot;jaap_35290&quot;,\r\n            &quot;HOST&quot;: &quot;localhost&quot;,\r\n            &quot;TYPE&quot;: &quot;mysql&quot;,\r\n            &quot;CHARSET&quot;: &quot;UTF8&quot;,\r\n        },\r\n        &quot;db_2&quot;: {\r\n            &quot;DB&quot;: &quot;db_2&quot;,\r\n            &quot;DBUSER&quot;: &quot;jaap_35290&quot;,\r\n            &quot;HOST&quot;: &quot;localhost&quot;,\r\n            &quot;TYPE&quot;: &quot;mysql&quot;,\r\n            &quot;CHARSET&quot;: &quot;UTF8&quot;,\r\n        },\r\n    }\r\n    \r\nWith jq i am able to merge the json &quot;files&quot; to an normal array but it sadly doesn&#39;t work in the other systems...\r\n\r\n    jq -s &lt;&lt;&lt; $(while read str; do\r\n        parse_object_kv_list_json_non_eval &quot;$str&quot; \r\n        # output of the first example json file\r\n    done &lt; &lt;(cat $USER_DATA/db.conf))\r\n\r\nThe output will be when phrased by normal array and \r\n\r\n     {\r\n         {\r\n            &quot;DB&quot;: &quot;jaap_35290&quot;,\r\n            &quot;DBUSER&quot;: &quot;jaap_35290&quot;,\r\n            &quot;HOST&quot;: &quot;localhost&quot;,\r\n            &quot;TYPE&quot;: &quot;mysql&quot;,\r\n            &quot;CHARSET&quot;: &quot;UTF8&quot;,\r\n        },\r\n        {\r\n            &quot;DB&quot;: &quot;db_2&quot;,\r\n            &quot;DBUSER&quot;: &quot;jaap_35290&quot;,\r\n            &quot;HOST&quot;: &quot;localhost&quot;,\r\n            &quot;TYPE&quot;: &quot;mysql&quot;,\r\n            &quot;CHARSET&quot;: &quot;UTF8&quot;,\r\n        },\r\n    }\r\n\r\nAlso tried:\r\n\r\n    jq -s &lt;&lt;&lt; $(while read str; do\r\n        json=$(parse_object_kv_list_json_non_eval &quot;$str&quot;)\r\n        key=$(echo $json | jq -r &#39;.DB&#39;);\r\n        echo &quot;{\\&quot;$key\\&quot;:$json}&quot;      \r\n    done &lt; &lt;(cat $USER_DATA/db.conf))\r\n\r\nBut then the output is\r\n\r\n    [\r\n        {\r\n            &quot;jaap_35290&quot;: {\r\n                &quot;DB&quot;: &quot;jaap_35290&quot;,\r\n                &quot;DBUSER&quot;: &quot;jaap_35290&quot;,\r\n                &quot;HOST&quot;: &quot;localhost&quot;,\r\n                &quot;TYPE&quot;: &quot;mysql&quot;,\r\n                &quot;CHARSET&quot;: &quot;UTF8&quot;,\r\n            }\r\n        },\r\n        {\r\n            &quot;db_2&quot;: {\r\n                &quot;DB&quot;: &quot;db_2&quot;,\r\n                &quot;DBUSER&quot;: &quot;jaap_35290&quot;,\r\n                &quot;HOST&quot;: &quot;localhost&quot;,\r\n                &quot;TYPE&quot;: &quot;mysql&quot;,\r\n                &quot;CHARSET&quot;: &quot;UTF8&quot;,\r\n            },\r\n        }\r\n    ]\r\n\r\nAny way how I can solve it?",
        "link": "https://stackoverflow.com/questions/67023548/jq-merge-2-files-as-associative-json-file",
        "title": "jq merge 2 files as associative &quot;json&quot; file"
    },
    {
        "tags": [
            "linux",
            "bash",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1617998209,
                "creation_date": 1617998209,
                "answer_id": 67027536,
                "question_id": 67027391,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Use the `-R` argument (aka `--raw-input`) to tell `jq` that it&#39;s receiving input as strings rather than JSON, and use `input` to read only a single item at a time. Thus:\r\n\r\n```\r\njq -Rn input &lt;yourfile\r\n```\r\n\r\n...will output:\r\n\r\n```json\r\n&quot;5584157003&quot;\r\n```\r\n\r\n---\r\n\r\nIf you want to convert it to a number, that&#39;s what `tonumber` is for:\r\n\r\n```\r\njq -Rn &#39;input | tonumber&#39; &lt;yourfile\r\n```\r\n\r\n...which will output:\r\n\r\n```json\r\n5584157003\r\n```",
                "title": "read the first line of a text file with JQ"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1618005951,
                "last_edit_date": 1618005951,
                "creation_date": 1617998276,
                "answer_id": 67027553,
                "question_id": 67027391,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "&gt; what I am ultimately trying to do is fetch each line number from this file one by one and make an api call using bash.\r\n\r\nFor a straightforward task like that, you could simply use bash&#39;s read, along the lines of\r\n\r\n    while IFS= read -r line ; do ... done &lt; newfile.txt\r\n\r\nIf any kind of transformation of the input lines needs to be done, however, jq might be appropriate, e.g. if the lines must be URL-encoded.  This could be done using `inputs` in conjunction with jq&#39;s -n and -R command-line options, along the lines of:\r\n\r\n    while IFS= read -r line ; do \r\n    ... \r\n    done &lt; &lt;(jq -Rrn &#39;inputs|@uri&#39; newfile.txt)\r\n\r\n",
                "title": "read the first line of a text file with JQ"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1618006918,
                "last_edit_date": 1618006918,
                "creation_date": 1618006605,
                "answer_id": 67028912,
                "question_id": 67027391,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "&gt; is there a way to specifically retrieve a line number? for example line 3? \r\n\r\nIf no transformation need be done, then using `sed` would probably be the simplest, efficient approach; if a simple transformation is required, then besides `sed`, `awk` might be worth considering, but jq might also be worth considering under certain circumstances. \r\n\r\nIn particular, if efficiency is a consideration, then it would make sense to use jq&#39;s `nth` filter, along the lines of:\r\n\r\n    jq --argjson n 3 -nR &#39;nth($n - 1; inputs)&#39; newfile.txt \r\n\r\nThis approach will avoid reading lines beyond the specified one.\r\n\r\n(`nth` counts from 0.)\r\n\r\nYou might also want to use jq&#39;s -r option.\r\n",
                "title": "read the first line of a text file with JQ"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 0,
        "last_activity_date": 1618006918,
        "creation_date": 1617997584,
        "question_id": 67027391,
        "body_markdown": "Trying to see how I can read the first line of a text file using `jq` \r\n\r\nI have a text file with a bunch of ids (newfile.txt )\r\n\r\n    5584157003\r\n    5584158003\r\n    5584159003\r\n    5584160003\r\n\r\nid like to be able to just read the first line with jq.  \r\n\r\nI tried doing this \r\n\r\n    cat newfile.txt | jq &#39;.[0]&#39;\r\n\r\nBut getting an error of \r\n\r\n    jq: error (at &lt;stdin&gt;:482): Cannot index number with number\r\n\r\nI&#39;d like to be able to read line by line so that I can eventually run a look with that ID and be able to do stuff with it.  Any ideas?",
        "link": "https://stackoverflow.com/questions/67027391/read-the-first-line-of-a-text-file-with-jq",
        "title": "read the first line of a text file with JQ"
    },
    {
        "tags": [
            "python",
            "ruby",
            "pip",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 166270,
                    "reputation": 135171,
                    "user_id": 390278,
                    "user_type": "registered",
                    "accept_rate": 86,
                    "profile_image": "https://www.gravatar.com/avatar/84715fec547362389d02f5be0ed12814?s=256&d=identicon&r=PG",
                    "display_name": "Jeff Mercado",
                    "link": "https://stackoverflow.com/users/390278/jeff-mercado"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1618009146,
                "post_id": 67027634,
                "comment_id": 118481571,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 3686921,
                    "reputation": 1065,
                    "user_id": 3780985,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/m6NNs.png?s=256",
                    "display_name": "hrmncd",
                    "link": "https://stackoverflow.com/users/3780985/hrmncd"
                },
                "reply_to_user": {
                    "account_id": 166270,
                    "reputation": 135171,
                    "user_id": 390278,
                    "user_type": "registered",
                    "accept_rate": 86,
                    "profile_image": "https://www.gravatar.com/avatar/84715fec547362389d02f5be0ed12814?s=256&d=identicon&r=PG",
                    "display_name": "Jeff Mercado",
                    "link": "https://stackoverflow.com/users/390278/jeff-mercado"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1618012853,
                "post_id": 67027634,
                "comment_id": 118482290,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 3686921,
                    "reputation": 1065,
                    "user_id": 3780985,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/m6NNs.png?s=256",
                    "display_name": "hrmncd",
                    "link": "https://stackoverflow.com/users/3780985/hrmncd"
                },
                "reply_to_user": {
                    "account_id": 166270,
                    "reputation": 135171,
                    "user_id": 390278,
                    "user_type": "registered",
                    "accept_rate": 86,
                    "profile_image": "https://www.gravatar.com/avatar/84715fec547362389d02f5be0ed12814?s=256&d=identicon&r=PG",
                    "display_name": "Jeff Mercado",
                    "link": "https://stackoverflow.com/users/390278/jeff-mercado"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1618014243,
                "post_id": 67027634,
                "comment_id": 118482512,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 289134,
                    "reputation": 389369,
                    "user_id": 589924,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/b2cf53d5a3d25f95c0db4e025aed4153?s=256&d=identicon&r=PG",
                    "display_name": "ikegami",
                    "link": "https://stackoverflow.com/users/589924/ikegami"
                },
                "reply_to_user": {
                    "account_id": 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": 1618088176,
                "post_id": 67027634,
                "comment_id": 118497958,
                "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"
                },
                "reply_to_user": {
                    "account_id": 289134,
                    "reputation": 389369,
                    "user_id": 589924,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/b2cf53d5a3d25f95c0db4e025aed4153?s=256&d=identicon&r=PG",
                    "display_name": "ikegami",
                    "link": "https://stackoverflow.com/users/589924/ikegami"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1618088631,
                "post_id": 67027634,
                "comment_id": 118498057,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 289134,
                    "reputation": 389369,
                    "user_id": 589924,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/b2cf53d5a3d25f95c0db4e025aed4153?s=256&d=identicon&r=PG",
                    "display_name": "ikegami",
                    "link": "https://stackoverflow.com/users/589924/ikegami"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1618088709,
                "post_id": 67027634,
                "comment_id": 118498071,
                "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"
                },
                "reply_to_user": {
                    "account_id": 289134,
                    "reputation": 389369,
                    "user_id": 589924,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/b2cf53d5a3d25f95c0db4e025aed4153?s=256&d=identicon&r=PG",
                    "display_name": "ikegami",
                    "link": "https://stackoverflow.com/users/589924/ikegami"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1618089575,
                "post_id": 67027634,
                "comment_id": 118498231,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 289134,
                    "reputation": 389369,
                    "user_id": 589924,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/b2cf53d5a3d25f95c0db4e025aed4153?s=256&d=identicon&r=PG",
                    "display_name": "ikegami",
                    "link": "https://stackoverflow.com/users/589924/ikegami"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1618113330,
                "post_id": 67027634,
                "comment_id": 118501660,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1618015596,
                "creation_date": 1618015596,
                "answer_id": 67029833,
                "question_id": 67027634,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I did not expect this, but this issue has been resolved after I updated `pip3` with this command:\r\n\r\n    pip3 install --upgrade pip\r\n\r\nThen I used the same command to install the requirements, and this time, `jq` was installed successfully:\r\n\r\n    pip3 install -r requirements.txt",
                "title": "pip3 can&#39;t install jq on macOS due to ruby dependencies"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1618088474,
                "creation_date": 1618088474,
                "answer_id": 67039212,
                "question_id": 67027634,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "&gt; But I don&#39;t know how to use this configure parameter when I am installing jq via pip3.\r\n\r\n```sh\r\nwget https://github.com/stedolan/jq/releases/download/jq-1.6/jq-1.6.tar.gz\r\ntar xvzf jq-1.6.tar.gz\r\ncd jq-1.6\r\n./configure --disable-docs\r\nmake -j8\r\nmake check\r\n```",
                "title": "pip3 can&#39;t install jq on macOS due to ruby dependencies"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1618088474,
        "creation_date": 1617998715,
        "last_edit_date": 1618000545,
        "question_id": 67027634,
        "body_markdown": "I am trying to install a specific `jq` version in my virtual pyenv environment with the command below: \r\n\r\n    pip3 install -r requirements.txt\r\n\r\nrequirements.txt has this line among others: `jq==1.0.2`\r\n\r\nThe error message:\r\n\r\n    Downloaded https://github.com/stedolan/jq/releases/download/jq-1.6/jq-1.6.tar.gz\r\n        Executing: autoreconf -i\r\n        glibtoolize: putting auxiliary files in &#39;.&#39;.\r\n        glibtoolize: copying file &#39;./ltmain.sh&#39;\r\n        glibtoolize: putting macros in AC_CONFIG_MACRO_DIRS, &#39;m4&#39;.\r\n        glibtoolize: copying file &#39;m4/libtool.m4&#39;\r\n        glibtoolize: copying file &#39;m4/ltoptions.m4&#39;\r\n        glibtoolize: copying file &#39;m4/ltsugar.m4&#39;\r\n        glibtoolize: copying file &#39;m4/ltversion.m4&#39;\r\n        glibtoolize: copying file &#39;m4/lt~obsolete.m4&#39;\r\n        configure.ac:7: warning: The macro `AC_CONFIG_HEADER&#39; is obsolete.\r\n        configure.ac:7: You should run autoupdate.\r\n        ./lib/autoconf/status.m4:719: AC_CONFIG_HEADER is expanded from...\r\n        configure.ac:7: the top level\r\n        configure.ac:36: warning: The macro `AM_PROG_LIBTOOL&#39; is obsolete.\r\n        configure.ac:36: You should run autoupdate.\r\n        m4/libtool.m4:100: AM_PROG_LIBTOOL is expanded from...\r\n        configure.ac:36: the top level\r\n        configure.ac:46: warning: The macro `AC_HEADER_STDC&#39; is obsolete.\r\n        configure.ac:46: You should run autoupdate.\r\n        ./lib/autoconf/headers.m4:704: AC_HEADER_STDC is expanded from...\r\n        configure.ac:46: the top level\r\n        configure.ac:54: warning: The macro `AC_HEADER_TIME&#39; is obsolete.\r\n        configure.ac:54: You should run autoupdate.\r\n        ./lib/autoconf/headers.m4:743: AC_HEADER_TIME is expanded from...\r\n        configure.ac:54: the top level\r\n        configure.ac:60: warning: The macro `AC_TRY_COMPILE&#39; is obsolete.\r\n        configure.ac:60: You should run autoupdate.\r\n        ./lib/autoconf/general.m4:2847: AC_TRY_COMPILE is expanded from...\r\n        lib/m4sugar/m4sh.m4:692: _AS_IF_ELSE is expanded from...\r\n        lib/m4sugar/m4sh.m4:699: AS_IF is expanded from...\r\n        ./lib/autoconf/general.m4:2249: AC_CACHE_VAL is expanded from...\r\n        ./lib/autoconf/general.m4:2270: AC_CACHE_CHECK is expanded from...\r\n        configure.ac:60: the top level\r\n        configure.ac:68: warning: The macro `AC_TRY_COMPILE&#39; is obsolete.\r\n        configure.ac:68: You should run autoupdate.\r\n        ./lib/autoconf/general.m4:2847: AC_TRY_COMPILE is expanded from...\r\n        lib/m4sugar/m4sh.m4:692: _AS_IF_ELSE is expanded from...\r\n        lib/m4sugar/m4sh.m4:699: AS_IF is expanded from...\r\n        ./lib/autoconf/general.m4:2249: AC_CACHE_VAL is expanded from...\r\n        ./lib/autoconf/general.m4:2270: AC_CACHE_CHECK is expanded from...\r\n        configure.ac:68: the top level\r\n        configure.ac:87: warning: AC_OUTPUT should be used without arguments.\r\n        configure.ac:87: You should run autoupdate.\r\n        configure.ac:17: warning: The macro `AC_PROG_CC_STDC&#39; is obsolete.\r\n        configure.ac:17: You should run autoupdate.\r\n        ./lib/autoconf/c.m4:1666: AC_PROG_CC_STDC is expanded from...\r\n        configure.ac:17: the top level\r\n        configure.ac:59: warning: The macro `AC_HELP_STRING&#39; is obsolete.\r\n        configure.ac:59: You should run autoupdate.\r\n        ./lib/autoconf/general.m4:204: AC_HELP_STRING is expanded from...\r\n        configure.ac:59: the top level\r\n        configure.ac:64: warning: The macro `AC_HELP_STRING&#39; is obsolete.\r\n        configure.ac:64: You should run autoupdate.\r\n        ./lib/autoconf/general.m4:204: AC_HELP_STRING is expanded from...\r\n        configure.ac:64: the top level\r\n        configure.ac:68: warning: The macro `AC_HELP_STRING&#39; is obsolete.\r\n        configure.ac:68: You should run autoupdate.\r\n        ./lib/autoconf/general.m4:204: AC_HELP_STRING is expanded from...\r\n        configure.ac:68: the top level\r\n        configure.ac:72: warning: The macro `AC_HELP_STRING&#39; is obsolete.\r\n        configure.ac:72: You should run autoupdate.\r\n        ./lib/autoconf/general.m4:204: AC_HELP_STRING is expanded from...\r\n        configure.ac:72: the top level\r\n        configure.ac:76: warning: The macro `AC_HELP_STRING&#39; is obsolete.\r\n        configure.ac:76: You should run autoupdate.\r\n        ./lib/autoconf/general.m4:204: AC_HELP_STRING is expanded from...\r\n        configure.ac:76: the top level\r\n        configure.ac:80: warning: The macro `AC_HELP_STRING&#39; is obsolete.\r\n        configure.ac:80: You should run autoupdate.\r\n        ./lib/autoconf/general.m4:204: AC_HELP_STRING is expanded from...\r\n        configure.ac:80: the top level\r\n        configure.ac:84: warning: The macro `AC_HELP_STRING&#39; is obsolete.\r\n        configure.ac:84: You should run autoupdate.\r\n        ./lib/autoconf/general.m4:204: AC_HELP_STRING is expanded from...\r\n        configure.ac:84: the top level\r\n        configure.ac:135: warning: The macro `AC_HELP_STRING&#39; is obsolete.\r\n        configure.ac:135: You should run autoupdate.\r\n        ./lib/autoconf/general.m4:204: AC_HELP_STRING is expanded from...\r\n        ./lib/autoconf/general.m4:1534: AC_ARG_ENABLE is expanded from...\r\n        configure.ac:135: the top level\r\n        Executing: ./configure CFLAGS=-fPIC --disable-maintainer-mode --with-oniguruma=/private/var/folders/fb/bh6d9vgn3lndrfb8k3gxmb5r0000gn/T/pip-install-77pax3w4/jq/_deps/onig-install-6.9.4\r\n        checking for a BSD-compatible install... /usr/bin/install -c\r\n        checking whether build environment is sane... yes\r\n        checking for a race-free mkdir -p... ./config/install-sh -c -d\r\n        checking for gawk... no\r\n        checking for mawk... no\r\n        checking for nawk... no\r\n        checking for awk... awk\r\n        checking whether make sets $(MAKE)... yes\r\n        checking whether make supports nested variables... yes\r\n        checking whether make supports nested variables... (cached) yes\r\n        checking whether make supports the include directive... yes (GNU style)\r\n        checking for gcc... gcc\r\n        checking whether the C compiler works... yes\r\n        checking for C compiler default output file name... a.out\r\n        checking for suffix of executables...\r\n        checking whether we are cross compiling... no\r\n        checking for suffix of object files... o\r\n        checking whether the compiler supports GNU C... yes\r\n        checking whether gcc accepts -g... yes\r\n        checking for gcc option to enable C11 features... none needed\r\n        checking whether gcc understands -c and -o together... yes\r\n        checking dependency style of gcc... gcc3\r\n        checking for ar... ar\r\n        checking the archiver (ar) interface... ar\r\n        checking whether to enable maintainer-specific portions of Makefiles... no\r\n        checking for gcc... (cached) gcc\r\n        checking whether the compiler supports GNU C... (cached) yes\r\n        checking whether gcc accepts -g... (cached) yes\r\n        checking for gcc option to enable C11 features... (cached) none needed\r\n        checking whether gcc understands -c and -o together... (cached) yes\r\n        checking dependency style of gcc... (cached) gcc3\r\n        checking how to run the C preprocessor... gcc -E\r\n        checking for bison... bison -y\r\n        checking build system type... x86_64-apple-darwin20.3.0\r\n        checking host system type... x86_64-apple-darwin20.3.0\r\n        checking how to print strings... printf\r\n        checking for a sed that does not truncate output... /usr/bin/sed\r\n        checking for grep that handles long lines and -e... /usr/bin/grep\r\n        checking for egrep... /usr/bin/grep -E\r\n        checking for fgrep... /usr/bin/grep -F\r\n        checking for ld used by gcc... /Library/Developer/CommandLineTools/usr/bin/ld\r\n        checking if the linker (/Library/Developer/CommandLineTools/usr/bin/ld) is GNU ld... no\r\n        checking for BSD- or MS-compatible name lister (nm)... /usr/bin/nm -B\r\n        checking the name lister (/usr/bin/nm -B) interface... BSD nm\r\n        checking whether ln -s works... yes\r\n        checking the maximum length of command line arguments... 786432\r\n        checking how to convert x86_64-apple-darwin20.3.0 file names to x86_64-apple-darwin20.3.0 format... func_convert_file_noop\r\n        checking how to convert x86_64-apple-darwin20.3.0 file names to toolchain format... func_convert_file_noop\r\n        checking for /Library/Developer/CommandLineTools/usr/bin/ld option to reload object files... -r\r\n        checking for objdump... objdump\r\n        checking how to recognize dependent libraries... pass_all\r\n        checking for dlltool... no\r\n        checking how to associate runtime and link libraries... printf %s\\n\r\n        checking for archiver @FILE support... no\r\n        checking for strip... strip\r\n        checking for ranlib... ranlib\r\n        checking command to parse /usr/bin/nm -B output from gcc object... ok\r\n        checking for sysroot... no\r\n        checking for a working dd... /bin/dd\r\n        checking how to truncate binary pipes... /bin/dd bs=4096 count=1\r\n        checking for mt... no\r\n        checking if : is a manifest tool... no\r\n        checking for dsymutil... dsymutil\r\n        checking for nmedit... nmedit\r\n        checking for lipo... lipo\r\n        checking for otool... otool\r\n        checking for otool64... no\r\n        checking for -single_module linker flag... yes\r\n        checking for -exported_symbols_list linker flag... yes\r\n        checking for -force_load linker flag... yes\r\n        checking for stdio.h... yes\r\n        checking for stdlib.h... yes\r\n        checking for string.h... yes\r\n        checking for inttypes.h... yes\r\n        checking for stdint.h... yes\r\n        checking for strings.h... yes\r\n        checking for sys/stat.h... yes\r\n        checking for sys/types.h... yes\r\n        checking for unistd.h... yes\r\n        checking for dlfcn.h... yes\r\n        checking for objdir... .libs\r\n        checking if gcc supports -fno-rtti -fno-exceptions... yes\r\n        checking for gcc option to produce PIC... -fno-common -DPIC\r\n        checking if gcc PIC flag -fno-common -DPIC works... yes\r\n        checking if gcc static flag -static works... no\r\n        checking if gcc supports -c -o file.o... yes\r\n        checking if gcc supports -c -o file.o... (cached) yes\r\n        checking whether the gcc linker (/Library/Developer/CommandLineTools/usr/bin/ld) supports shared libraries... yes\r\n        checking dynamic linker characteristics... darwin20.3.0 dyld\r\n        checking how to hardcode library paths into programs... immediate\r\n        checking whether stripping libraries is possible... yes\r\n        checking if libtool supports shared libraries... yes\r\n        checking whether to build shared libraries... yes\r\n        checking whether to build static libraries... yes\r\n        checking for valgrind... no\r\n        configure: WARNING: valgrind is required to test jq.\r\n        checking for memmem... yes\r\n        checking for mkstemp... yes\r\n        checking for shlwapi.h... no\r\n        checking for bundle... bundle\r\n        checking for Ruby dependencies... configure: WARNING: The following gems are missing\r\n         * rake (10.4.2)\r\n         * i18n (0.7.0)\r\n         * json (1.8.3)\r\n         * minitest (5.8.0)\r\n         * thread_safe (0.3.5)\r\n         * tzinfo (1.2.2)\r\n         * activesupport (4.2.3)\r\n         * addressable (2.3.8)\r\n         * builder (3.2.2)\r\n         * launchy (2.4.3)\r\n         * liquid (3.0.6)\r\n         * maruku (0.7.2)\r\n         * rack (1.6.4)\r\n         * sass (3.4.16)\r\n         * rack-protection (1.5.3)\r\n         * tilt (2.0.1)\r\n         * sinatra (1.4.6)\r\n         * watch (0.1.0)\r\n         * yui-compressor (0.12.0)\r\n         * bonsai (1.4.9)\r\n         * hpricot (0.8.6)\r\n         * mustache (0.99.8)\r\n         * rdiscount (2.1.8)\r\n         * ronn (0.7.3)\r\n        Install missing gems with `bundle install`\r\n        *****************************************************************\r\n        *  Ruby dependencies for building jq documentation not found.   *\r\n        *  You can still build, install and hack on jq, but the manpage *\r\n        *  will not be rebuilt and some of the tests will not run.      *\r\n        *  See docs/README.md for how to install the docs dependencies. *\r\n        *****************************************************************\r\n        no\r\n\r\nIt looks like this error is due to missing Ruby dependencies. I read on [jq documentation][1] that \r\n\r\n&gt; (2) If you get error messages involving pipenv and if you do not need\r\n&gt; the documentation to be &quot;built&quot;, then add the --disable-docs flag to\r\n&gt; ./configure, e.g.\r\n&gt; \r\n&gt; ./configure --disable-docs\r\n\r\nBut I don&#39;t know how to use this configure parameter when I am installing jq via pip3.\r\n\r\nThe [documentation][1] also shows how to install dependencies for docs:\r\n\r\n    Install Dependencies (RVM, for docs)\r\n    \r\n    Note that as of February 26, 2019, ruby is no longer a dependency for building jq from &quot;master&quot;; python is used instead. If make fails because of python, run configure with the --disable-docs command-line option.\r\n    \r\n    Note also that curl | bash is a best practice...\r\n    \r\n    cd ~/jq/docs\r\n    curl -L https://get.rvm.io | bash -s stable --ruby=1.9.3\r\n    cd docs\r\n    bundle install\r\n\r\nHowever, I am not sure how I am supposed to follow these steps while I am doing the jq install via pip3 in a virtual environment.\r\n\r\nThe [README.md][2] file in the jq documentation (of the current version) explains how to build the documentation, but again, I am not sure how to follow those steps while using pip3 in a virtual environment.\r\n\r\nThe jq documentation is not critical for me. I just want to properly install jq. \r\n\r\nAny suggestions, please?\r\n\r\n\r\n  [1]: https://github.com/stedolan/jq/wiki/Installation#macos\r\n  [2]: https://github.com/stedolan/jq/blob/master/docs/README.md",
        "link": "https://stackoverflow.com/questions/67027634/pip3-cant-install-jq-on-macos-due-to-ruby-dependencies",
        "title": "pip3 can&#39;t install jq on macOS due to ruby dependencies"
    },
    {
        "tags": [
            "bash",
            "environment-variables",
            "export",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1618198153,
                "post_id": 67030229,
                "comment_id": 118520455,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 5,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1618023366,
                "creation_date": 1618023366,
                "answer_id": 67030406,
                "question_id": 67030229,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You could store the original JSON in a variable (instead of a file), and then extract the key and cert from that:\r\n\r\n    apiResult=$(API call)\r\n    cert=$(jq -r &#39;.certificate&#39; &lt;&lt;&lt;&quot;$apiResult&quot;)\r\n    key=$(jq -r &#39;.key&#39; &lt;&lt;&lt;&quot;$apiResult&quot;)\r\n\r\nNotes: I recommend using lower- or mixed-case variables, to avoid accidental conflicts with the many all-caps names with special meanings. Also, `&lt;&lt;&lt;` is a bashism, and won&#39;t work in all other shells; if you need this be portable to e.g. dash, use something like `key=$(printf &#39;%s\\n&#39; &quot;$apiResult&quot; | jq -r &#39;.key&#39;)`.",
                "title": "Is there a way to output jq into multiple variables for bash script?"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1618024986,
                "creation_date": 1618024986,
                "answer_id": 67030513,
                "question_id": 67030229,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If neither of the values contain a newline, you can easily use `read`:\r\n\r\n    $ read cert key &lt; &lt;( echo &#39;{&quot;certificate&quot;: &quot;foo&quot;, &quot;key&quot;: &quot;bar&quot;}&#39; | jq -r .certificate,.key | tr \\\\n &#39; &#39;)\r\n    $ echo $cert\r\n    foo\r\n    $ echo $key\r\n    bar\r\n\r\nor:\r\n\r\n    $ { read cert; read key; } &lt;&lt; EOF\r\n    &gt; $( echo &#39;{&quot;certificate&quot;: &quot;foo&quot;, &quot;key&quot;: &quot;bar&quot;}&#39; | jq -r .certificate,.key )\r\n    &gt; EOF\r\n    $ echo $cert:$key\r\n    foo:bar\r\n\r\nThe certificate almost certainly will contain newlines, so you many want to serialize that data (eg, base64 encode it). But you&#39;re probably better off using Gordon Davisson&#39;s approach.\r\n",
                "title": "Is there a way to output jq into multiple variables for bash script?"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1618201730,
                "last_edit_date": 1618201730,
                "creation_date": 1618198214,
                "answer_id": 67052332,
                "question_id": 67030229,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Unless there are NUL characters in the strings, there should be no need to call jq more than once, or to serialize the data.\r\n\r\nIn the simplest case, you could proceed along the following lines:\r\n```\r\n{ IFS= read -r certificate\r\n  IFS= read -r key\r\n  echo &quot;certificate=$certificate&quot;\r\n  echo &quot;key=$key&quot;\r\n} &lt; &lt;(API call | jq -r &#39;.certificate, .key&#39;)\r\n```\r\n\r\nIf the values do not contain NUL but might contain newline characters,\r\nthen you could use NUL as the delimiter.  For the sake of variety,\r\nwe could also use a `while` loop:\r\n```\r\nwhile IFS= read -r -d $&#39;\\0&#39; certificate\r\ndo\r\n  IFS= read -r -d $&#39;\\0&#39; key\r\n  echo &quot;certificate=$certificate&quot;\r\n  echo &quot;key=$key&quot;\r\ndone &lt; &lt;(API call | jq -rj &#39;[.certificate, .key] | join(&quot;\\u0000&quot;)&#39;)\r\n```\r\n\r\n### Conversely ...\r\nIf the values of interest might contain literal NUL values (&quot;\\u0000&quot;), then the question seems to be problematic, as bash variables in effect cannot contain literal NULs.\r\n\r\nIf any of the values of interest might contain literal NUL values, then here are two strategies for extracting the &quot;raw&quot; string equivalents into separate files:\r\n\r\n1) Save the JSON output in a (temporary) file, and invoke `jq -r` once per value of interest in the obvious way.\r\n\r\n2) Set up a bash pipeline starting with:\r\n \r\n    **API call** | jq -r &#39;.certificate, .key | @base64`\r\n\r\n    and continuing with a loop in which each line is decoded, e.g. using `base64 --decode` or jq&#39;s `@base64d`.  \r\n\r\nThe second strategy might make sense if the API call produces a very large JSON document.",
                "title": "Is there a way to output jq into multiple variables for bash script?"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1618297375,
                "last_edit_date": 1618297375,
                "creation_date": 1618296147,
                "answer_id": 67069916,
                "question_id": 67030229,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Say you created a program that output shell commands.\r\n\r\n\r\n```lang-none\r\n$ data_source | jq -r &#39;@sh &quot;certificate=\\( .certificate )\\nkey=\\( .key )&quot;&#39;\r\ncertificate=&#39;the certificate&#39;\r\nkey=&#39;the key&#39;\r\n```\r\n\r\nThen, all you would need to do is evaluate them.\r\n\r\n```sh\r\neval &quot;$( data_source | jq -r &#39;@sh &quot;certificate=\\( .certificate )\\nkey=\\( .key )&quot;&#39; )&quot;\r\n```\r\n\r\n---\r\n\r\nIf you were dealing with many variables, you could use the following:\r\n\r\n```sh\r\neval &quot;$(\r\n   data_source |\r\n   jq -r &#39;\r\n      { &quot;certificate&quot;: &quot;certificate&quot;, &quot;key&quot;: &quot;key&quot; } as $map | \r\n      ( $map | keys_unsorted[] ) as $shell_var |\r\n      $shell_var + @sh &quot;=\\( .[$map[$shell_var]] )&quot;\r\n   &#39;\r\n)&quot;\r\n```\r\n\r\nYou could even use paths.\r\n\r\n```sh\r\neval &quot;$(\r\n   data_source |\r\n   jq -r &#39;\r\n      { &quot;certificate&quot;: [ &quot;certificate&quot; ], &quot;key&quot;: [ &quot;key&quot; ] } as $map | \r\n      ( $map | keys_unsorted[] ) as $shell_var |\r\n      $shell_var + @sh &quot;=\\( getpath($map[$shell_var]) )&quot;\r\n   &#39;\r\n)&quot;\r\n```\r\n",
                "title": "Is there a way to output jq into multiple variables for bash script?"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1688138431,
                "creation_date": 1688138431,
                "answer_id": 76590264,
                "question_id": 67030229,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can output text like\r\n\r\n```\r\nVAR1=something\r\nVAR2=somethingElse\r\n```\r\n\r\nand eval it. This way you&#39;ll have 2 new variables:\r\n\r\n```\r\neval `API_CALL | jq -r &#39;&quot;VAR1=&quot;+.var1,&quot;VAR2=&quot;+.var2&#39;\r\n```",
                "title": "Is there a way to output jq into multiple variables for bash script?"
            }
        ],
        "is_answered": true,
        "answer_count": 5,
        "score": 6,
        "last_activity_date": 1688138431,
        "creation_date": 1618021019,
        "last_edit_date": 1618294736,
        "question_id": 67030229,
        "body_markdown": "Basically I have a bash script that at one point makes an API call and a cert and key are generated and returned in json. I pipe it to jq and can select either the cert or the key and store it in a variable.\r\n\r\nSomething like this:\r\n\r\n    CERT=$(API call | jq -r &#39;.certificate&#39;)\r\n    or\r\n    KEY=$(API call | jq -r &#39;.key&#39;)\r\n\r\nI want to store each in its own variable but I can&#39;t make the call twice because it will generate a new cert/key.\r\n\r\nI know that I can just store both in a file and then manipulate after to accomplish my task but I am curious if jq offers a direct way to selectively store each value in its own variable?",
        "link": "https://stackoverflow.com/questions/67030229/is-there-a-way-to-output-jq-into-multiple-variables-for-bash-script",
        "title": "Is there a way to output jq into multiple variables for bash script?"
    },
    {
        "tags": [
            "json",
            "jq",
            "tabular"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1618385372,
                "last_edit_date": 1618385372,
                "creation_date": 1618304234,
                "answer_id": 67071727,
                "question_id": 67070932,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "A jq-only solution is certainly possible, but it would almost certainly be much easier to use jq’s `@tsv` in conjunction with  `column -t` or perhaps `pr -e`; see e.g. https://stackoverflow.com/questions/66050075/replace-tab-with-variable-amount-of-spaces-maintaining-the-alignment",
                "title": "tabulated output with carriage return with jq"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1618385372,
        "creation_date": 1618301050,
        "last_edit_date": 1618305185,
        "question_id": 67070932,
        "body_markdown": "I&#39;m tryng to get a tabulated output with jq, but I can&#39;t get the alignement perfect. See:\r\n\r\n    $ ./Error_CLIENT.sh | /home/USER/jq -rj &#39;.[] | .job.Name, &quot;\\t\\t&quot; ,.Atrributes.userData, &quot;\\n&quot;&#39;\r\n    HOME22          pte\r\n    HOME23          pte\r\n    HOUSEABI                pdt all\r\n    HOUSEAB2                pdt all\r\n    ....\r\n\r\nI would like to get:\r\n\r\n    HOME22                  pte\r\n    HOME23                  pte\r\n    HOUSEABI                pdt all\r\n    HOUSEAB2                pdt all\r\n    .......\r\n\r\n\r\nDo you know if it&#39;s possible? Thanks",
        "link": "https://stackoverflow.com/questions/67070932/tabulated-output-with-carriage-return-with-jq",
        "title": "tabulated output with carriage return with jq"
    },
    {
        "tags": [
            "json",
            "jq",
            "global",
            "edit",
            "removeall"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 1831510,
                    "reputation": 560,
                    "user_id": 1662815,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/eVAmV.jpg?s=256",
                    "display_name": "m4ngl3r",
                    "link": "https://stackoverflow.com/users/1662815/m4ngl3r"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1618384913,
                "post_id": 67071152,
                "comment_id": 118582067,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1618322577,
                "last_edit_date": 1618322577,
                "creation_date": 1618303892,
                "answer_id": 67071635,
                "question_id": 67071152,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "    walk(if type==&quot;object&quot; and .name == &quot;exception&quot;\r\n         then empty else . end)\r\n\r\nEquivalently:\r\n\r\n    walk(select(type==&quot;object&quot; and .name == &quot;exception&quot; | not))",
                "title": "Removing entire object from JSON file based on key value pair"
            },
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1618322383,
                "creation_date": 1618322383,
                "answer_id": 67076360,
                "question_id": 67071152,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "    del(..|select(type==&quot;object&quot; and .name==&quot;exception&quot;))\r\n\r\nTry it at https://jqplay.org/s/il12Ribpdb",
                "title": "Removing entire object from JSON file based on key value pair"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1618322577,
        "creation_date": 1618302019,
        "last_edit_date": 1618321439,
        "question_id": 67071152,
        "body_markdown": "I been struggling removing set-off objects from Json file. I tried with jq json parser method but nothing has worked out. Could someone please help on this. \r\n\r\nWhat am looking for is – Wherever the below key and value pair are present in a file, the entire object should be removed.\r\n\r\n```json\r\n{&quot;name&quot;: &quot;exception&quot;}\r\n```\r\n\r\n**Input:** \r\n\r\n```json\r\n{\r\n  &quot;results&quot;: [\r\n    {\r\n      &quot;id&quot;: &quot;a21f5193-881e-11eb-a0c1-3726f4a71fa9&quot;,\r\n      &quot;retailerId&quot;: &quot;1&quot;,\r\n      &quot;category&quot;: &quot;exception&quot;,\r\n      &quot;context&quot;: {\r\n        &quot;sourceEvents&quot;: [\r\n          &quot;902bd449-881e-11eb-b603-29eb6c297e7d&quot;\r\n        ],\r\n        &quot;entityType&quot;: &quot;ORDER&quot;\r\n      },\r\n      &quot;eventStatus&quot;: &quot;FAILED&quot;,\r\n      &quot;attributes&quot;: [\r\n        {\r\n          &quot;name&quot;: &quot;exception&quot;,\r\n          &quot;value&quot;: {\r\n            &quot;code&quot;: 400,\r\n            &quot;message&quot;: &quot;Failed to execute http call&quot;,\r\n            &quot;stackTrace&quot;: [\r\n              {\r\n                &quot;fileName&quot;: &quot;ReadOnlyFluentApiClient.java&quot;,\r\n                &quot;className&quot;: &quot;com.fluentretail.api.v2.client.ReadOnlyFluentApiClient&quot;\r\n              }\r\n            ],\r\n            &quot;suppressed&quot;: [],\r\n            &quot;suppressedExceptions&quot;: []\r\n          },\r\n          &quot;type&quot;: &quot;OBJECT&quot;\r\n        },\r\n        {\r\n          &quot;name&quot;: &quot;lastRule&quot;,\r\n          &quot;value&quot;: &quot;ETOSUAT.base.ProposedFulfilmentWithoutInventory&quot;,\r\n          &quot;type&quot;: &quot;String&quot;\r\n        },\r\n        {\r\n          &quot;name&quot;: &quot;lastRuleSet&quot;,\r\n          &quot;value&quot;: &quot;FindAndCreateDigitalFulfilment&quot;,\r\n          &quot;type&quot;: &quot;String&quot;\r\n        },\r\n        {\r\n          &quot;name&quot;: &quot;message&quot;,\r\n          &quot;value&quot;: &quot;Failed to execute http call&quot;,\r\n          &quot;type&quot;: &quot;String&quot;\r\n        }\r\n      ],\r\n      &quot;source&quot;: null,\r\n      &quot;generatedBy&quot;: &quot;Rubix User&quot;,\r\n      &quot;generatedOn&quot;: &quot;2021-03-18T19:17:51.517+0000&quot;\r\n    },\r\n    {\r\n      &quot;id&quot;: &quot;a21f5193-881e-11eb-a0c1-3726f4a71fa9&quot;,\r\n      &quot;retailerId&quot;: &quot;1&quot;,\r\n      &quot;category&quot;: &quot;exception&quot;,\r\n      &quot;context&quot;: {\r\n        &quot;sourceEvents&quot;: [\r\n          &quot;902bd449-881e-11eb-b603-29eb6c297e7d&quot;\r\n        ],\r\n        &quot;entityType&quot;: &quot;ORDER&quot;\r\n      },\r\n      &quot;eventStatus&quot;: &quot;FAILED&quot;,\r\n      &quot;attributes&quot;: [\r\n        {\r\n          &quot;name&quot;: &quot;exception&quot;,\r\n          &quot;value&quot;: {\r\n            &quot;code&quot;: 400,\r\n            &quot;message&quot;: &quot;Failed to execute http call&quot;,\r\n            &quot;stackTrace&quot;: [\r\n              {\r\n                &quot;fileName&quot;: &quot;ReadOnlyFluentApiClient.java&quot;,\r\n                &quot;className&quot;: &quot;com.fluentretail.api.v2.client.ReadOnlyFluentApiClient&quot;\r\n              }\r\n            ],\r\n            &quot;suppressed&quot;: [],\r\n            &quot;suppressedExceptions&quot;: []\r\n          },\r\n          &quot;type&quot;: &quot;OBJECT&quot;\r\n        },\r\n        {\r\n          &quot;name&quot;: &quot;lastRule&quot;,\r\n          &quot;value&quot;: &quot;ETOSUAT.base.ProposedFulfilmentWithoutInventory&quot;,\r\n          &quot;type&quot;: &quot;String&quot;\r\n        },\r\n        {\r\n          &quot;name&quot;: &quot;lastRuleSet&quot;,\r\n          &quot;value&quot;: &quot;FindAndCreateDigitalFulfilment&quot;,\r\n          &quot;type&quot;: &quot;String&quot;\r\n        },\r\n        {\r\n          &quot;name&quot;: &quot;message&quot;,\r\n          &quot;value&quot;: &quot;Failed to execute http call&quot;,\r\n          &quot;type&quot;: &quot;String&quot;\r\n        }\r\n      ],\r\n      &quot;source&quot;: null,\r\n      &quot;generatedBy&quot;: &quot;Rubix User&quot;,\r\n      &quot;generatedOn&quot;: &quot;2021-03-18T19:17:51.517+0000&quot;\r\n    }\r\n  ]\r\n}\r\n```\r\n\r\n\r\n**Expected output is -** \r\n\r\n```json\r\n{\r\n  &quot;results&quot;: [\r\n    {\r\n      &quot;id&quot;: &quot;a21f5193-881e-11eb-a0c1-3726f4a71fa9&quot;,\r\n      &quot;retailerId&quot;: &quot;1&quot;,\r\n      &quot;category&quot;: &quot;exception&quot;,\r\n      &quot;context&quot;: {\r\n        &quot;sourceEvents&quot;: [\r\n          &quot;902bd449-881e-11eb-b603-29eb6c297e7d&quot;\r\n        ],\r\n        &quot;entityType&quot;: &quot;ORDER&quot;\r\n      },\r\n      &quot;eventStatus&quot;: &quot;FAILED&quot;,\r\n      &quot;attributes&quot;: [\r\n        {\r\n          &quot;name&quot;: &quot;lastRule&quot;,\r\n          &quot;value&quot;: &quot;ETOSUAT.base.ProposedFulfilmentWithoutInventory&quot;,\r\n          &quot;type&quot;: &quot;String&quot;\r\n        },\r\n        {\r\n          &quot;name&quot;: &quot;lastRuleSet&quot;,\r\n          &quot;value&quot;: &quot;FindAndCreateDigitalFulfilment&quot;,\r\n          &quot;type&quot;: &quot;String&quot;\r\n        },\r\n        {\r\n          &quot;name&quot;: &quot;message&quot;,\r\n          &quot;value&quot;: &quot;Failed to execute http call&quot;,\r\n          &quot;type&quot;: &quot;String&quot;\r\n        }\r\n      ],\r\n      &quot;source&quot;: null,\r\n      &quot;generatedBy&quot;: &quot;Rubix User&quot;,\r\n      &quot;generatedOn&quot;: &quot;2021-03-18T19:17:51.517+0000&quot;\r\n    },\r\n    {\r\n      &quot;id&quot;: &quot;a21f5193-881e-11eb-a0c1-3726f4a71fa9&quot;,\r\n      &quot;retailerId&quot;: &quot;1&quot;,\r\n      &quot;category&quot;: &quot;exception&quot;,\r\n      &quot;context&quot;: {\r\n        &quot;sourceEvents&quot;: [\r\n          &quot;902bd449-881e-11eb-b603-29eb6c297e7d&quot;\r\n        ],\r\n        &quot;entityType&quot;: &quot;ORDER&quot;\r\n      },\r\n      &quot;eventStatus&quot;: &quot;FAILED&quot;,\r\n      &quot;attributes&quot;: [\r\n        {\r\n          &quot;name&quot;: &quot;lastRule&quot;,\r\n          &quot;value&quot;: &quot;ETOSUAT.base.ProposedFulfilmentWithoutInventory&quot;,\r\n          &quot;type&quot;: &quot;String&quot;\r\n        },\r\n        {\r\n          &quot;name&quot;: &quot;lastRuleSet&quot;,\r\n          &quot;value&quot;: &quot;FindAndCreateDigitalFulfilment&quot;,\r\n          &quot;type&quot;: &quot;String&quot;\r\n        },\r\n        {\r\n          &quot;name&quot;: &quot;message&quot;,\r\n          &quot;value&quot;: &quot;Failed to execute http call&quot;,\r\n          &quot;type&quot;: &quot;String&quot;\r\n        }\r\n      ],\r\n      &quot;source&quot;: null,\r\n      &quot;generatedBy&quot;: &quot;Rubix User&quot;,\r\n      &quot;generatedOn&quot;: &quot;2021-03-18T19:17:51.517+0000&quot;\r\n    }\r\n  ]\r\n}\r\n```\r\n",
        "link": "https://stackoverflow.com/questions/67071152/removing-entire-object-from-json-file-based-on-key-value-pair",
        "title": "Removing entire object from JSON file based on key value pair"
    },
    {
        "tags": [
            "node.js",
            "jq",
            "json2csv"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1618321799,
                "post_id": 67073322,
                "comment_id": 118562737,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1618326318,
                "creation_date": 1618326318,
                "answer_id": 67077485,
                "question_id": 67073322,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Try\r\n\r\n    jq -r &#39;.data.ticker | to_entries[] | [.key, (.value | (.vol|tonumber), (.low|tonumber))] | @csv&#39;\r\n\r\nExplanation: `.data.ticker` - path to your data, `to_entries[]` - since ticker name is key, we need to convert this object to `.key` and `.value`, `()` - parenthesis helps, so you don&#39;t need to write full path every time, `tonumber` - convert string to number (remove double quotes)\r\n\r\nAdd all your fields",
                "title": "Cant convert JSON to csv by jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -1,
        "last_activity_date": 1618326318,
        "creation_date": 1618310542,
        "question_id": 67073322,
        "body_markdown": "I am new to jq,  I have a JSON file from (call: all.2):\r\n\r\n    {&quot;code&quot;:0, &quot;data&quot;: {&quot;date&quot;: 1617978312600,&quot;ticker&quot;: {&quot;KAVAUSDT&quot;: {&quot;vol&quot;: &quot;15022.96236047&quot;,&quot;low&quot;: &quot;7.0419&quot;,&quot;open&quot;:&quot;7.8990&quot;,&quot;high&quot;: &quot;8.1997&quot;,&quot;last&quot;: &quot;7.1516&quot;,&quot;buy&quot;: &quot;7.1516&quot;,&quot;buy_amount&quot;:&quot;11.02402741&quot;,&quot;sell&quot;:&quot;7.1699&quot;,&quot;sell_amount&quot;: &quot;37.46319593&quot;},&quot;CFXUSDT&quot;: {&quot;vol&quot;: &quot;108550.36674746&quot;,&quot;low&quot;: &quot;1.226636&quot;,&quot;open&quot;: &quot;1.267724&quot;,&quot;high&quot;: &quot;1.378400&quot;,&quot;last&quot;: &quot;1.273187&quot;,&quot;buy&quot;: &quot;1.272200&quot;,&quot;buy_amount&quot;: &quot;14.65071234&quot;,&quot;sell&quot;: &quot;1.294900&quot;,&quot;sell_amount&quot;: &quot;84.88000789&quot;},&quot;SUSHIBTC&quot;: {&quot;vol&quot;: &quot;5644.10352324&quot;,&quot;low&quot;: &quot;0.00024680&quot;,&quot;open&quot;: &quot;0.00024857&quot;,&quot;high&quot;: &quot;0.00026493&quot;,&quot;last&quot;: &quot;0.00025704&quot;,&quot;buy&quot;: &quot;0.00025563&quot;,&quot;buy_amount&quot;: &quot;104.74291100&quot;,&quot;sell&quot;: &quot;0.00025730&quot;,&quot;sell_amount&quot;: &quot;94.16400000&quot;},&quot;SUNUSDT&quot;: {&quot;vol&quot;: &quot;7058.81491709&quot;,&quot;low&quot;:&quot;37.3431&quot;,&quot;open&quot;:&quot;37.9590&quot;,&quot;high&quot;: &quot;44.0446&quot;,&quot;last&quot;: &quot;40.6945&quot;,&quot;buy&quot;: &quot;40.1001&quot;,&quot;buy_amount&quot;: &quot;25.40000000&quot;,&quot;sell&quot;:&quot;41.0771&quot;,&quot;sell_amount&quot;: &quot;3.40000000&quot;}}}, &quot;message&quot;: &quot;OK&quot;}\r\n\r\nI want to convert the data to csv ( space separated) similar to the following: \r\n[As Shown in the ATTACHED IMAGE][1]\r\n\r\n\r\n  [1]: https://i.sstatic.net/NC2Xi.png\r\n\r\nI tried  the following, but it didnt work: \r\n\r\n    mlr --j2c cat all.2&gt;allq1.csv\r\n\r\n    jq -r &#39;.[]|[ .ticker,.ticker.vol,.ticker.low,.ticker.open,.ticker.high,.ticker.last,.ticker.buy,.ticker.buy_amount,.ticker.sell,.ticker.sell_amount ]|@csv&#39; all.2 &gt; all.csv\r\n",
        "link": "https://stackoverflow.com/questions/67073322/cant-convert-json-to-csv-by-jq",
        "title": "Cant convert JSON to csv by jq"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1618367562,
                "post_id": 67084209,
                "comment_id": 118578050,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 21021985,
                    "reputation": 143,
                    "user_id": 15448086,
                    "user_type": "registered",
                    "profile_image": "https://lh6.googleusercontent.com/-hUtlhKetR8g/AAAAAAAAAAI/AAAAAAAAAAA/AMZuucnl2frteAxklNKR9bhqpqhQdTdfdw/s96-c/s256-rj/photo.jpg",
                    "display_name": "Shak",
                    "link": "https://stackoverflow.com/users/15448086/shak"
                },
                "reply_to_user": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1618376382,
                "post_id": 67084209,
                "comment_id": 118579632,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1618433985,
                "creation_date": 1618433985,
                "answer_id": 67099048,
                "question_id": 67084209,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here is a simple solution:\r\n```\r\n&lt; input.txt jq -nR &#39;\r\n  reduce (inputs | split(&quot;,&quot;)) as $line ({};\r\n    getpath($line[0:2]) as $v\r\n    | setpath($line[0:2]; $v + [{value1: $line[2], value2: $line[3]} ] ) )\r\n&#39;\r\n```\r\n\r\n\r\n",
                "title": "How do I create JSON file structure and then populate through jq with bash output"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1618433985,
        "creation_date": 1618362265,
        "question_id": 67084209,
        "body_markdown": "Trying to create the following JSON structure through bash. There will be a max of 4 environments that I want to be shown even if there are no content within them, and example output can be found below the structure. \r\n\r\nExample General Structure:\r\n```\r\n{\r\n    &quot;ENV&quot;:{\r\n        &quot;ENV1&quot;:{\r\n            &quot;Middleware&quot;: [\r\n                {\r\n                &quot;value1&quot;: &quot;&quot;,\r\n                &quot;value2&quot;: &quot;&quot;\r\n                \r\n            }\r\n        ],\r\n            &quot;System&quot;: [\r\n                {\r\n                &quot;value1&quot;: &quot;&quot;,\r\n                &quot;value2&quot;: &quot;&quot;,\r\n                &quot;value3&quot;: &quot;&quot;\r\n            }\r\n        ],\r\n            &quot;Application&quot;: [\r\n                {\r\n                &quot;value1&quot;: &quot;&quot;,\r\n                &quot;value2&quot;: &quot;&quot;\r\n            }\r\n        ], \r\n            &quot;Utility&quot;:[\r\n                {\r\n                &quot;value1&quot;: &quot;&quot;,\r\n                &quot;value2&quot;: &quot;&quot;,\r\n                &quot;value3&quot;: &quot;&quot;\r\n            }\r\n        ] \r\n        },\r\n        &quot;ENV2&quot;:{\r\n            &quot;Middleware&quot;: [\r\n                {\r\n                &quot;value1&quot;: &quot;&quot;,\r\n                &quot;value2&quot;: &quot;&quot;\r\n                \r\n            }\r\n        ],\r\n            &quot;System&quot;: [\r\n                {\r\n                &quot;value1&quot;: &quot;&quot;,\r\n                &quot;value2&quot;: &quot;&quot;,\r\n                &quot;value3&quot;: &quot;&quot;\r\n            }\r\n        ],\r\n            &quot;Application&quot;: [\r\n                {\r\n                &quot;value1&quot;: &quot;&quot;,\r\n                &quot;value2&quot;: &quot;&quot;\r\n            }\r\n        ], \r\n            &quot;Utility&quot;:[\r\n                {\r\n                &quot;value1&quot;: &quot;&quot;,\r\n                &quot;value2&quot;: &quot;&quot;,\r\n                &quot;value3&quot;: &quot;&quot;\r\n            }\r\n        ]\r\n        },\r\n        &quot;ENV3&quot;:{\r\n            &quot;Middleware&quot;: [\r\n                {\r\n                &quot;value1&quot;: &quot;&quot;,\r\n                &quot;value2&quot;: &quot;&quot;\r\n                \r\n            }\r\n        ],\r\n            &quot;System&quot;: [\r\n                {\r\n                &quot;value1&quot;: &quot;&quot;,\r\n                &quot;value2&quot;: &quot;&quot;,\r\n                &quot;value3&quot;: &quot;&quot;\r\n            }\r\n        ],\r\n            &quot;Application&quot;: [\r\n                {\r\n                &quot;value1&quot;: &quot;&quot;,\r\n                &quot;value2&quot;: &quot;&quot;\r\n            }\r\n        ], \r\n            &quot;Utility&quot;:[\r\n                {\r\n                &quot;value1&quot;: &quot;&quot;,\r\n                &quot;value2&quot;: &quot;&quot;,\r\n                &quot;value3&quot;: &quot;&quot;\r\n            }\r\n        ]\r\n        },\r\n        &quot;ENV4&quot;:{\r\n            &quot;Middleware&quot;: [\r\n                {\r\n                &quot;value1&quot;: &quot;&quot;,\r\n                &quot;value2&quot;: &quot;&quot;\r\n                \r\n            }\r\n        ],\r\n            &quot;System&quot;: [\r\n                {\r\n                &quot;value1&quot;: &quot;&quot;,\r\n                &quot;value2&quot;: &quot;&quot;,\r\n                &quot;value3&quot;: &quot;&quot;\r\n            }\r\n        ],\r\n            &quot;Application&quot;: [\r\n                {\r\n                &quot;value1&quot;: &quot;&quot;,\r\n                &quot;value2&quot;: &quot;&quot;\r\n            }\r\n        ], \r\n            &quot;Utility&quot;:[\r\n                {\r\n                &quot;value1&quot;: &quot;&quot;,\r\n                &quot;value2&quot;: &quot;&quot;,\r\n                &quot;value3&quot;: &quot;&quot;\r\n            }\r\n        ]\r\n        }\r\n    }\r\n}\r\n```\r\nExample json output (output.json):\r\n```\r\n{\r\n    &quot;ENV&quot;: {\r\n        &quot;ENV1&quot;: {\r\n            &quot;Middleware&quot;: [\r\n                {\r\n                    &quot;value1&quot;: &quot;Mqwerty&quot;,\r\n                    &quot;value2&quot;: &quot;Mqwerty&quot;\r\n                },\r\n                {\r\n                    &quot;value1&quot;: &quot;Mqwerty&quot;,\r\n                    &quot;value2&quot;: &quot;Mqwerty&quot;\r\n                },\r\n                {\r\n                    &quot;value1&quot;: &quot;Mqwerty&quot;,\r\n                    &quot;value2&quot;: &quot;Mqwerty&quot;\r\n                }\r\n            ],\r\n            &quot;System&quot;: [\r\n                {\r\n                    &quot;value1&quot;: &quot;Sqwerty&quot;,\r\n                    &quot;value2&quot;: &quot;Sqwerty&quot;,\r\n                    &quot;value3&quot;: &quot;Sqwerty&quot;\r\n                }\r\n            ],\r\n            &quot;Application&quot;: [\r\n                {\r\n                    &quot;value1&quot;: &quot;Aqwerty&quot;,\r\n                    &quot;value2&quot;: &quot;Aqwerty&quot;\r\n                },\r\n                {\r\n                    &quot;value1&quot;: &quot;Aqwerty&quot;,\r\n                    &quot;value2&quot;: &quot;Aqwerty&quot;\r\n                }\r\n            ],\r\n            &quot;Utility&quot;: [\r\n                {\r\n                    &quot;value1&quot;: &quot;Uqwerty&quot;,\r\n                    &quot;value2&quot;: &quot;Uqwerty&quot;,\r\n                    &quot;value3&quot;: &quot;Uqwerty&quot;\r\n                }\r\n            ]\r\n        },\r\n        &quot;ENV2&quot;: {\r\n            &quot;Middleware&quot;: [],\r\n            &quot;System&quot;: [],\r\n            &quot;Application&quot;: [],\r\n            &quot;Utility&quot;: []\r\n        },\r\n        &quot;ENV3&quot;: {\r\n            &quot;Middleware&quot;: [\r\n                {\r\n                    &quot;value1&quot;: &quot;Mqwerty&quot;,\r\n                    &quot;value2&quot;: &quot;Mqwerty&quot;\r\n                },\r\n                {\r\n                    &quot;value1&quot;: &quot;Mqwerty&quot;,\r\n                    &quot;value2&quot;: &quot;Mqwerty&quot;\r\n                }\r\n            ],\r\n            &quot;System&quot;: [],\r\n            &quot;Application&quot;: [],\r\n            &quot;Utility&quot;: []\r\n        },\r\n        &quot;ENV4&quot;: {\r\n            &quot;Middleware&quot;: [],\r\n            &quot;System&quot;: [],\r\n            &quot;Application&quot;: [],\r\n            &quot;Utility&quot;: []\r\n        }\r\n    }\r\n}\r\n```\r\nMy input file will look something like this (input.txt):\r\n```\r\nENV1,Middleware,Mqwerty,Mqwerty\r\nENV1,Middleware,Mqwerty,Mqwerty\r\nENV1,Middleware,Mqwerty,Mqwerty\r\nENV1,System,Sqwerty,Sqwerty,Sqwerty\r\nENV1,Application,Aqwerty,Aqwerty\r\nENV1,Application,Aqwerty,Aqwerty\r\nENV1,Utility,Uqwerty,Uqwerty,Uqwerty\r\nENV3,Middleware,Mqwerty,Mqwerty\r\nENV3,Middleware,Mqwerty,Mqwerty\r\n```\r\nI would like to use jq to create the aforementioned structure and then populate the json file with the values in the input file. Also, a secondary question is that after the json file is produced, can you edit or partially update certain components of the file? E.g. Changing ENV.ENV1.Middleware[0].value1 from Mqwerty to Cqwerty without recreating the whole file.",
        "link": "https://stackoverflow.com/questions/67084209/how-do-i-create-json-file-structure-and-then-populate-through-jq-with-bash-outpu",
        "title": "How do I create JSON file structure and then populate through jq with bash output"
    },
    {
        "tags": [
            "jq",
            "aws-cli"
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1618396738,
                "last_edit_date": 1618396738,
                "creation_date": 1618396349,
                "answer_id": 67090011,
                "question_id": 67089955,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Replace `.[].VpcId.S` with `map(.VpcId.S)`. The `.[]` syntax takes the elements out of the array.\r\n\r\n---\r\n\r\nYou can combine your different `jq` filters together in this way:\r\n\r\n```\r\n.Items | map(select(.VpcId.S != &quot;None&quot;) | .VpcId.S)\r\n```",
                "title": "convert the output from jq to array"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1618396738,
        "creation_date": 1618396068,
        "last_edit_date": 1618396374,
        "question_id": 67089955,
        "body_markdown": "I have dynamodb table present in the aws account, I want to filter it based on the certain conditioning and get the result as an array\r\n\r\nbelow is the aws cli query with jq\r\n```\r\naws dynamodb scan  --table-name sample-table  | jq .Items | jq &#39;map(select(.VpcId.S != &quot;None&quot;)) &#39; | jq  .[].VpcId.S\r\n```\r\n\r\nhere is the output which I am getting:\r\n```\r\n\r\n&quot;vpc-yyyyyyyyyyyyyyyyy&quot;\r\n&quot;vpc-zzzzzzzzzzzzzzzzz&quot;\r\n&quot;vpc-XXXXXXXXXxxxxxxxx&quot;\r\n\r\n```\r\n\r\nI want the output as \r\n```\r\n[\r\n&quot;vpc-yyyyyyyyyyyyyyyyy&quot;,\r\n&quot;vpc-zzzzzzzzzzzzzzzzz&quot;,\r\n&quot;vpc-XXXXXXXXXxxxxxxxx&quot;\r\n]\r\n```\r\n\r\nso that I can pass it to the terraform.\r\n\r\nbelow is the output of the actual command\r\n```\r\naws dynamodb scan  --table-name sample-table\r\n\r\n{\r\n&quot;Items&quot;: [\r\n  {\r\n   \r\n    &quot;VpcId&quot;: {\r\n      &quot;S&quot;: &quot;vpc-yyyyyyyyyyyyyyyyy&quot;\r\n    }\r\n  },\r\n    {\r\n   \r\n    &quot;VpcId&quot;: {\r\n      &quot;S&quot;: &quot;None&quot;\r\n    }\r\n  },\r\n  {\r\n   \r\n    &quot;VpcId&quot;: {\r\n      &quot;S&quot;: &quot;vpc-xxxxxxxxxxxxxxxxx&quot;\r\n    }\r\n  },\r\n  }\r\n]\r\n}\r\n```",
        "link": "https://stackoverflow.com/questions/67089955/convert-the-output-from-jq-to-array",
        "title": "convert the output from jq to array"
    },
    {
        "tags": [
            "curl",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 3264599,
                    "reputation": 83,
                    "user_id": 2749318,
                    "user_type": "registered",
                    "accept_rate": 88,
                    "profile_image": "https://i.sstatic.net/5Gu5p.jpg?s=256",
                    "display_name": "DaveyLions",
                    "link": "https://stackoverflow.com/users/2749318/daveylions"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1618420565,
                "post_id": 67096008,
                "comment_id": 118598332,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1618435001,
                "post_id": 67096008,
                "comment_id": 118603793,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 3264599,
                    "reputation": 83,
                    "user_id": 2749318,
                    "user_type": "registered",
                    "accept_rate": 88,
                    "profile_image": "https://i.sstatic.net/5Gu5p.jpg?s=256",
                    "display_name": "DaveyLions",
                    "link": "https://stackoverflow.com/users/2749318/daveylions"
                },
                "reply_to_user": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1618502100,
                "post_id": 67096008,
                "comment_id": 118626031,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1618438620,
                "creation_date": 1618438620,
                "answer_id": 67099784,
                "question_id": 67096008,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Given your sample input (without the extra comma that makes it technically invalid as JSON), the following produces the output shown below:\r\n```\r\ndef prior($yymmdd): sub(&quot;-(?&lt;d&gt;\\\\d)-&quot;; &quot;-0\\(.d)-&quot;) &lt;= ($yymmdd);\r\n\r\n(now|strflocaltime(&quot;%Y-%m-%d&quot;)) as $now\r\n| .Passwords[]\r\n| {username,\r\n   storage,\r\n   custom_fields : .custom_fields | map(select(.key == &quot;expiry-event&quot; and (.value|prior($now)))) }\r\n   \r\n```\r\n\r\nYou can easily remove any unwanted fields, e.g. using `del/1`, or by specifying the keys you do want.\r\n### Output\r\n\r\n```\r\n{\r\n  &quot;username&quot;: &quot;testusername&quot;,\r\n  &quot;storage&quot;: &quot;Normal&quot;,\r\n  &quot;custom_fields&quot;: [\r\n    {\r\n      &quot;notes&quot;: null,\r\n      &quot;key&quot;: &quot;expiry-event&quot;,\r\n      &quot;value&quot;: &quot;2021-4-13&quot;\r\n    }\r\n  ]\r\n}\r\n```",
                "title": "JQ Filter for parent IDs and child IDs with date evaluation"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1618502034,
        "creation_date": 1618419526,
        "last_edit_date": 1618502034,
        "question_id": 67096008,
        "body_markdown": "I am on a tight deadline and working on a work around for a product that is not exposing a SQL view but does expose some elements via API. Looking to do this processing in the PIPE after the curl query.\r\n\r\nReproduction: \r\n\r\n    curl -x GET -u {credentials} {endpoint fqdn} | jq\r\n\r\n        {\r\n      &quot;total_count&quot;: 34,\r\n      &quot;Passwords&quot;: [\r\n        {\r\n          &quot;username&quot;: &quot;testusername&quot;,\r\n          &quot;category&quot;: null,\r\n          &quot;device_ids&quot;: [],\r\n          &quot;view_users&quot;: &quot;&quot;,\r\n          &quot;view_groups&quot;: &quot;&quot;,\r\n          &quot;last_pw_change&quot;: &quot;2021-04-13T13:30:03Z&quot;,\r\n          &quot;notes&quot;: &quot;&quot;,\r\n          &quot;storage&quot;: &quot;Normal&quot;,\r\n          &quot;use_only_users&quot;: &quot;&quot;,\r\n          &quot;label&quot;: &quot;EXPIRED&quot;,\r\n          &quot;view_edit_groups&quot;: &quot;&quot;,\r\n          &quot;first_added&quot;: &quot;2021-04-13T13:30:03.790Z&quot;,\r\n          &quot;use_only_groups&quot;: &quot;&quot;,\r\n          &quot;storage_id&quot;: 1,\r\n          &quot;view_edit_users&quot;: &quot;admin&quot;,\r\n          &quot;password&quot;: &quot;&quot;,\r\n          &quot;id&quot;: 36,\r\n          &quot;custom_fields&quot;: [\r\n            {\r\n              &quot;notes&quot;: null,\r\n              &quot;key&quot;: &quot;expiry-event&quot;,\r\n              &quot;value&quot;: &quot;2021-4-13&quot;\r\n            }\r\n          ]\r\n        }\r\n      ],\r\n    }\r\n\r\nAbove is an example of what is returned via curl. I&#39;d like to be able to grab the USERNAME, STORAGE_ID, and then the CUSTOM_FIELDS &gt; KEY and CUSTOM_FIELDS &gt; VALUE \r\n\r\nWHEN the Key = expiry-event\r\nand the VALUE for that key is prior to today&#39;s date. \r\n\r\nIs this possible with JQ filtering? I am not sure that the date option is a function in JQ. But any help getting as close as possible would be appreciated. \r\n\r\nI&#39;ve tried filtering into separate arrays but I get a FAILED TO BUILD BODY error. Thanks!",
        "link": "https://stackoverflow.com/questions/67096008/jq-filter-for-parent-ids-and-child-ids-with-date-evaluation",
        "title": "JQ Filter for parent IDs and child IDs with date evaluation"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 21021985,
                    "reputation": 143,
                    "user_id": 15448086,
                    "user_type": "registered",
                    "profile_image": "https://lh6.googleusercontent.com/-hUtlhKetR8g/AAAAAAAAAAI/AAAAAAAAAAA/AMZuucnl2frteAxklNKR9bhqpqhQdTdfdw/s96-c/s256-rj/photo.jpg",
                    "display_name": "Shak",
                    "link": "https://stackoverflow.com/users/15448086/shak"
                },
                "reply_to_user": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1618470749,
                "post_id": 67102884,
                "comment_id": 118611848,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1618525859,
                "last_edit_date": 1618525859,
                "creation_date": 1618469506,
                "answer_id": 67103575,
                "question_id": 67102884,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s one way to build up a solution from easily understood pieces. In this case, jq would be invoked with `-nR`.\r\n```\r\ndef initial:\r\n  null\r\n  | .[&quot;DEV&quot;, &quot;SIT&quot;, &quot;UAT&quot;, &quot;PROD&quot;][&quot;Middleware&quot;, &quot;System&quot;, &quot;Application&quot;, &quot;Utility&quot;] = [];\r\n\r\ndef objectify($keys):\r\n  . as $in\r\n  | reduce range(0; $keys|length) as $i ({}; .[$keys[$i]] = ($in[$i]) );\r\n\r\ndef object:\r\n  .[0] as $top\r\n  | .[1:] \r\n  | if   $top == &quot;Middleware&quot;  then objectify([&quot;name&quot;, &quot;release&quot;])\r\n    elif $top == &quot;System&quot;      then objectify([&quot;domain&quot;, &quot;tag&quot;])\r\n    elif $top == &quot;Application&quot; then objectify([&quot;domain&quot;, &quot;host&quot;, &quot;user&quot;])\r\n    elif $top == &quot;Utility&quot;     then objectify([&quot;domain&quot;, &quot;health&quot;, &quot;version&quot;])\r\n    else objectify( map(tostring) )  # or raise an error, or ...\r\n    end;\r\n\r\nreduce (inputs | split(&quot;,&quot;)) as $line (initial;\r\n  getpath($line[0:2]) as $v\r\n  | setpath($line[0:2]; $v + [$line[1:] | object] ))\r\n| {ENV: .}\r\n```",
                "title": "Defining custom keys for object types through JQ when converting text file into JSON format"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1618541831,
                "last_edit_date": 1618541831,
                "creation_date": 1618525744,
                "answer_id": 67116746,
                "question_id": 67102884,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s a DRYer and more declarative version of my other solution on this page.  It also handles the anomalous case slightly differently.\r\n\r\n```\r\n&lt; input.txt jq -nR &#39;\r\n\r\n  def categories:\r\n      { &quot;Middleware&quot;:  [&quot;name&quot;, &quot;release&quot;],\r\n        &quot;System&quot;:      [&quot;domain&quot;, &quot;tag&quot;],\r\n        &quot;Application&quot;: [&quot;domain&quot;, &quot;host&quot;, &quot;user&quot;],\r\n        &quot;Utility&quot;:    [&quot;domain&quot;, &quot;health&quot;, &quot;version&quot;] };\r\n\r\n  def initial:\r\n    null\r\n    | .[&quot;DEV&quot;, &quot;SIT&quot;, &quot;UAT&quot;, &quot;PROD&quot;][ categories | keys[]] = [];\r\n\r\n  def objectify($keys):\r\n    . as $in\r\n    | reduce range(0; $keys|length) as $i ({}; .[$keys[$i]] = ($in[$i]) );\r\n\r\n  def object:\r\n    categories[.[0]] as $keys\r\n    | .[1:] \r\n    | objectify($keys // [range(0;length) | tostring]);\r\n\r\nreduce (inputs | split(&quot;,&quot;)) as $line (initial;\r\n  getpath($line[0:2]) as $v\r\n  | setpath($line[0:2]; $v + [$line[1:] | object] ))\r\n| {ENV: .}\r\n```",
                "title": "Defining custom keys for object types through JQ when converting text file into JSON format"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1618541831,
        "creation_date": 1618465597,
        "last_edit_date": 1618470762,
        "question_id": 67102884,
        "body_markdown": "Trying to create the following JSON structure through bash. There will be a max of 4 environments that I want to be shown even if there are no content within them, and example output can be found below the structure.\r\n\r\nInput Text File:\r\n\r\n    DEV,Middleware,Mqwerty,Mqwerty\r\n    DEV,Middleware,Mqwerty,Mqwerty\r\n    DEV,Middleware,Mqwerty,Mqwerty\r\n    DEV,System,Sqwerty,Sqwerty\r\n    DEV,Application,Aqwerty,Aqwerty,Aqwerty\r\n    UAT,Application,Aqwerty,Aqwerty,Aqwerty\r\n    DEV,Utility,Uqwerty,Uqwerty,Uqwerty\r\n    PROD,Middleware,Mqwerty,Mqwerty\r\n    DEV,Middleware,Mqwerty,Mqwerty\r\n\r\nDesired JSON Structure:\r\n\r\n        {\r\n        &quot;ENV&quot;: {\r\n            &quot;DEV&quot;: {\r\n                &quot;Middleware&quot;: [\r\n                    {\r\n                        &quot;name&quot;: &quot;Mqwerty&quot;,\r\n                        &quot;release&quot;: &quot;Mqwerty&quot;\r\n                    },\r\n                    {\r\n                        &quot;name&quot;: &quot;Mqwerty&quot;,\r\n                        &quot;release&quot;: &quot;Mqwerty&quot;\r\n                    },\r\n                    {\r\n                        &quot;name&quot;: &quot;Mqwerty&quot;,\r\n                        &quot;release&quot;: &quot;Mqwerty&quot;\r\n                    }\r\n                ],\r\n                &quot;System&quot;: [\r\n                    {\r\n                        &quot;name&quot;: &quot;Sqwerty&quot;,\r\n                        &quot;tag&quot;: &quot;Sqwerty&quot;\r\n                    }\r\n                ],\r\n                &quot;Application&quot;: [\r\n                    {\r\n                        &quot;domain&quot;: &quot;Aqwerty&quot;,\r\n                        &quot;host&quot;: &quot;Aqwerty&quot;,\r\n                        &quot;user&quot;: &quot;Aqwerty&quot;\r\n                    },\r\n                    {\r\n                        &quot;domain&quot;: &quot;Aqwerty&quot;,\r\n                        &quot;host&quot;: &quot;Aqwerty&quot;,\r\n                        &quot;user&quot;: &quot;Aqwerty&quot;\r\n                    }\r\n                ],\r\n                &quot;Utility&quot;: [\r\n                    {\r\n                        &quot;domain&quot;: &quot;Uqwerty&quot;,\r\n                        &quot;health&quot;: &quot;Uqwerty&quot;,\r\n                        &quot;version&quot;: &quot;Uqwerty&quot;\r\n                    }\r\n                ]\r\n            },\r\n            &quot;SIT&quot;: {\r\n                &quot;Middleware&quot;: [],\r\n                &quot;System&quot;: [],\r\n                &quot;Application&quot;: [],\r\n                &quot;Utility&quot;: []\r\n            },\r\n            &quot;UAT&quot;: {\r\n                &quot;Middleware&quot;: [\r\n                    {\r\n                        &quot;name&quot;: &quot;Mqwerty&quot;,\r\n                        &quot;release&quot;: &quot;Mqwerty&quot;\r\n                    },\r\n                    {\r\n                        &quot;name&quot;: &quot;Mqwerty&quot;,\r\n                        &quot;release&quot;: &quot;Mqwerty&quot;\r\n                    }\r\n                ],\r\n                &quot;System&quot;: [],\r\n                &quot;Application&quot;: [],\r\n                &quot;Utility&quot;: []\r\n            },\r\n            &quot;PROD&quot;: {\r\n                &quot;Middleware&quot;: [],\r\n                &quot;System&quot;: [],\r\n                &quot;Application&quot;: [],\r\n                &quot;Utility&quot;: []\r\n            }\r\n        }\r\n    }\r\n\r\nSome key notes, even in environments that don&#39;t have information, the &#39;template&#39; of middleware, system, application and utility (lets call these categories) is still there. The categories also have a predefined key:value structure that follows:\r\n\r\nApplication (keys): domain, host, user\r\n\r\nUtility: domain, health, version\r\n\r\nMiddleware: name, release\r\n\r\nSystem: name, tag\r\n\r\nThis is the code I&#39;ve been able to get so far, however its unable to add a particular set of keys for each category (Application, Utility, Middleware and System) and also isn&#39;t able to add all the values as well.\r\n\r\n   \r\n\r\n    #!/usr/bin/jq -Rnf\r\n    reduce inputs as $line\r\n      ( .ENV\r\n        [&quot;DEV&quot;, &quot;SIT&quot;, &quot;UAT&quot;, &quot;PROD&quot;]\r\n        [&quot;Middleware&quot;, &quot;System&quot;, &quot;Application&quot;, &quot;Utility&quot;] = []\r\n    \r\n      ; ($line | split(&quot;,&quot;)) as $elements\r\n      | .ENV [$elements[0]] [$elements[1]] +=\r\n        [ $elements[2:]\r\n        | with_entries(.key |= &quot;value\\(.+1)&quot;)\r\n        ]\r\n      )\r\n\r\nI really do appreciate any help and thank you for taking you time reading this questions, apologies for being a long one. Also any good resources regarding jq would be appreciated. ",
        "link": "https://stackoverflow.com/questions/67102884/defining-custom-keys-for-object-types-through-jq-when-converting-text-file-into",
        "title": "Defining custom keys for object types through JQ when converting text file into JSON format"
    },
    {
        "tags": [
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1618522351,
                "post_id": 67104115,
                "comment_id": 118634126,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 5899608,
                    "reputation": 24394,
                    "user_id": 4643584,
                    "user_type": "registered",
                    "accept_rate": 64,
                    "profile_image": "https://www.gravatar.com/avatar/7e9ba0de356f3346f0b798a29cca10ed?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Shakiba Moshiri",
                    "link": "https://stackoverflow.com/users/4643584/shakiba-moshiri"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1618843472,
                "post_id": 67104115,
                "comment_id": 118718811,
                "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": 1662111412,
                "post_id": 67104115,
                "comment_id": 129935325,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "is_answered": false,
        "answer_count": 0,
        "score": 0,
        "last_activity_date": 1662111314,
        "creation_date": 1618471887,
        "last_edit_date": 1662111314,
        "question_id": 67104115,
        "body_markdown": "I have a command on printers status, that i want to get in json format\r\nhere is a command and output:\r\n\r\n    qchk -AW  \r\n\r\n    Queue                Dev            Status       Job Files              User         PP   %  Blks  Cp Rnk\r\n    -------------------- -------------- --------- ------ ------------------ ---------- ---- --- ----- --- ---\r\n    PRTS0910  hp@PRTS0910    DOWN     \r\n                             QUEUED     10872 test.ksh           root                    1   1   1\r\n                             QUEUED     10873 test.ksh           root                    1   1   2\r\n    PRTS09102 hp@PRTS09102   READY    \r\n    PRTS0913  hp@PRTS0913    READY    \r\n    PRTC1401  hp@PRTC1401    READY    \r\n    PRTS1018  hp@PRTS1018    READY    \r\n    PRTS0TESTQ PRTS0TEST      DOWN     \r\n                             QUEUED     10871 print.ksh          root                    1   1   1\r\n\r\nI have got a script on  kshell with jq using:\r\n\r\n    #!/usr/bin/ksh\r\n    qchk -AW | tr -s &#39; &#39; |  jq -sR   &#39;split(&quot;\\n&quot;) |\r\n          .[2:-1] |\r\n            map(split(&quot; &quot;)) |\r\n          map({&quot;Printer&quot;: .[0],\r\n               &quot;device&quot;: .[1],\r\n               &quot;state&quot;: .[2],\r\n               &quot;job&quot;: .[3],\r\n               &quot;something&quot;: .[4],\r\n               &quot;somth2&quot;: .[5]})&#39;\r\n\r\nThe problem is, that i think, I do not understand jq working principles, and can not understand how jq could process delails( jobs)  rows - under printer rows, so this script gives me all json like structure in one row like :\r\n\r\n    {\r\n        &quot;Printer&quot;: &quot;PRTS0910&quot;,\r\n        &quot;device&quot;: &quot;hp@PRTS0910&quot;,\r\n        &quot;state&quot;: &quot;DOWN&quot;,\r\n        &quot;job&quot;: &quot;&quot;,\r\n        &quot;something&quot;: null,\r\n        &quot;somth2&quot;: null\r\n      },\r\n      {\r\n        &quot;Printer&quot;: &quot;&quot;,\r\n        &quot;device&quot;: &quot;QUEUED&quot;,\r\n        &quot;state&quot;: &quot;10872&quot;,\r\n        &quot;job&quot;: &quot;test.ksh&quot;,\r\n        &quot;something&quot;: &quot;root&quot;,\r\n        &quot;somth2&quot;: &quot;1&quot;\r\n      },\r\n      {\r\n        &quot;Printer&quot;: &quot;&quot;,\r\n        &quot;device&quot;: &quot;QUEUED&quot;,\r\n        &quot;state&quot;: &quot;10873&quot;,\r\n        &quot;job&quot;: &quot;test.ksh&quot;,\r\n        &quot;something&quot;: &quot;root&quot;,\r\n        &quot;somth2&quot;: &quot;1&quot;\r\n      },\r\n      {\r\n        &quot;Printer&quot;: &quot;PRTS09102&quot;,\r\n        &quot;device&quot;: &quot;hp@PRTS09102&quot;,\r\n        &quot;state&quot;: &quot;READY&quot;,\r\n        &quot;job&quot;: &quot;&quot;,\r\n        &quot;something&quot;: null,\r\n        &quot;somth2&quot;: null\r\n      },\r\n\r\nbut i need add somwhere in my code lines to filter job lines under printers with something like this (to process lines -&quot;QUEUED     10871 print.ksh          root                    1   1   1&quot;) :\r\n\r\n    map(split(&quot; &quot;)) |\r\n          map({&quot;Staus&quot;: .[0],\r\n               &quot;Job number&quot;: .[1],\r\n               &quot;file&quot;: .[2],\r\n               &quot;user&quot;: .[3],\r\n               &quot;something3&quot;: .[4],\r\n               &quot;somth4&quot;: .[5]})&#39;\r\n\r\nto get master detail json object\r\n\r\n\r\nAny help \r\n\r\nHere is a sample output from qchk, sorry am not very expierenced in SO editing:\r\n\r\n    # qchk -AW\r\nQueue                Dev            Status       Job Files              User         PP   %  Blks  Cp Rnk\r\n&lt;pre&gt;\r\nPRTS0408             hp@PRTS0408    READY    \r\nPRTS0416             hp@PRTS0416    READY    \r\nPRTS0417             hp@PRTS0417    READY    \r\nPRTS0702             hp@PRTS0702    RUNNING   110816 /alliance/PRINT/PR root          0 100   140   1   1\r\n                                    QUEUED    110848 /alliance/PRINT/PR root                  141   1   2\r\n                                    QUEUED    110849 /alliance/PRINT/PR root                  141   1   3\r\n                                    QUEUED    110850 /alliance/PRINT/PR root                  141   1   4\r\n                                    QUEUED    110856 /alliance/PRINT/PR root                  141   1   5\r\n                                    QUEUED    110857 /alliance/PRINT/PR root                  141   1   6\r\n                                    QUEUED    110858 /alliance/PRINT/PR root                  141   1   7\r\n                                    QUEUED    110859 /alliance/PRINT/PR root                  141   1   8\r\n                                    QUEUED    110860 /alliance/PRINT/PR root                  141   1   9\r\n                                    QUEUED    110861 /alliance/PRINT/PR root                  140   1  10\r\n                                    QUEUED    110862 /alliance/PRINT/PR root                  140   1  11\r\n                                    QUEUED    110884 /alliance/PRINT/PR root                  141   1  12\r\n                                    QUEUED    110885 /alliance/PRINT/PR root                  141   1  13\r\n                                    QUEUED    110886 /alliance/PRINT/PR root                  141   1  14\r\nPRTS0714             hp@PRTS0714    RUNNING   110984 /alliance/PRINT/PR root          0 100    11   1   1\r\nPRTS0723             hp@PRTS0723    READY    \r\nPRTS0901             hp@PRTS0901    READY    \r\nPRTS0906             hp@PRTS0906    READY    \r\nPRTS0907             hp@PRTS0907    READY    \r\nPRTS0909             hp@PRTS0909    READY    \r\nPRTS0910             hp@PRTS0910    READY    \r\nPRTS09102            hp@PRTS09102   RUNNING   111017 /alliance/PRINT/PR root          0 100   141   1   1\r\n                                    QUEUED    111018 /alliance/PRINT/PR root                  140   1   2\r\n                                    QUEUED    111019 /alliance/PRINT/PR root                  140   1   3\r\n\r\n&lt;/pre&gt;\r\n\r\nIn two words row is the printers, and they are owners of their print jobs, and I need to somehow get this relation in json.\r\n\r\n\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/67104115/getting-output-from-shell-command-in-json-format",
        "title": "Getting output from shell command in json format"
    },
    {
        "tags": [
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 6196394,
                    "reputation": 86601,
                    "user_id": 5291015,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/4tAvO.jpg?s=256",
                    "display_name": "Inian",
                    "link": "https://stackoverflow.com/users/5291015/inian"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1618475715,
                "post_id": 67104920,
                "comment_id": 118613900,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 5203734,
                    "reputation": 37594,
                    "user_id": 4162356,
                    "user_type": "registered",
                    "accept_rate": 92,
                    "profile_image": "https://i.sstatic.net/dGhuV.png?s=256",
                    "display_name": "James Brown",
                    "link": "https://stackoverflow.com/users/4162356/james-brown"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1618475864,
                "post_id": 67104920,
                "comment_id": 118613976,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1618475810,
                "creation_date": 1618475810,
                "answer_id": 67105016,
                "question_id": 67104920,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "One way would be to start your pipeline with:\r\n\r\n    range(0;length) as $i | .[$i] \r\n\r\nYou then can use $i in the remainder of the program.",
                "title": "how to add secuential number getting output with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1618475810,
        "creation_date": 1618475434,
        "question_id": 67104920,
        "body_markdown": "I&#39;m getting some values with jq command like these:\r\n\r\n    curl xxxxxx | jq -r  &#39;.[] | [&quot;\\(.job.Name), \\(.atrib.data)&quot;]&#39; | @tsv&#39; | column -t -s &quot;,&quot;\r\n\r\nIt gives me:\r\n\r\n    AAAA     PENDING\r\n    ZZZ      FAILED BAD\r\n\r\nWhat I want is that I get is a first field with a secuencial number (1 ....) like these:\r\n\r\n    1     AAA        PENDING\r\n    2     ZZZ        FAILED BAD\r\n    ......\r\n\r\nDo you know if it&#39;s possible? Thanks!\r\n\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/67104920/how-to-add-secuential-number-getting-output-with-jq",
        "title": "how to add secuential number getting output with jq"
    },
    {
        "tags": [
            "json",
            "bash",
            "environment-variables",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1618493329,
                "post_id": 67109361,
                "comment_id": 118621575,
                "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": 1618493375,
                "post_id": 67109361,
                "comment_id": 118621597,
                "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": 1618493442,
                "post_id": 67109361,
                "comment_id": 118621629,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 21267733,
                    "reputation": 13,
                    "user_id": 15647720,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/2257e80907b10eeef8197f96bf39fc94?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "eliminyro",
                    "link": "https://stackoverflow.com/users/15647720/eliminyro"
                },
                "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": 1618494193,
                "post_id": 67109361,
                "comment_id": 118622011,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 21267733,
                    "reputation": 13,
                    "user_id": 15647720,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/2257e80907b10eeef8197f96bf39fc94?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "eliminyro",
                    "link": "https://stackoverflow.com/users/15647720/eliminyro"
                },
                "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": 1,
                "creation_date": 1618494439,
                "post_id": 67109361,
                "comment_id": 118622154,
                "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": 1618498791,
                "post_id": 67109361,
                "comment_id": 118624362,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1618498463,
                "creation_date": 1618498463,
                "answer_id": 67110807,
                "question_id": 67109361,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "NUL-delimiting output from jq lets you read it into bash variables even if it contains newlines or other delimiters (which we could possibly see -- consider `&quot;message&quot;: &quot;first line\\nsecond line&quot;`).\r\n\r\nYou can do this with `jq -j` (like `-r` but without the automatic newlines), then adding explicit NULs with `&quot;\\u0000&quot;`. On the bash side, the practices needed for reading are given in [BashFAQ #001](https://mywiki.wooledge.org/BashFAQ/001) -- search for `NUL` therein.\r\n\r\nComing together, this looks like:\r\n\r\n```\r\n#!/usr/bin/env bash\r\nwhile IFS= read -r -d &#39;&#39; code &amp;&amp; IFS= read -r -d &#39;&#39; message; do\r\n  echo &quot;Got code: &lt;$code&gt; and message: &lt;$message&gt;&quot;\r\ndone &lt; &lt;(jq -j &#39;.[] | (.status.code, &quot;\\u0000&quot;, .message, &quot;\\u0000&quot;)&#39; &lt;input.json)\r\n```",
                "title": "How to select two keys from JSON that are located in two different layers (array and a string) using jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1618515644,
        "creation_date": 1618493192,
        "last_edit_date": 1618515644,
        "question_id": 67109361,
        "body_markdown": "I have a bash script where I need to parse certain data in order to make it react properly based on the retrieved data.\r\nThe data can be exported as JSON, so that is what I am doing.\r\n\r\nI was wondering if I could parse this JSON with JQ to get the data I need in one go.\r\n\r\nHere is the structure:\r\n\r\n```json\r\n[{&quot;long_message&quot;:\r\n  {\r\n   &quot;just&quot;:&quot;a&quot;,\r\n   &quot;bunch&quot;:&quot;of&quot;,\r\n   &quot;unrelated&quot;:&quot;data&quot;,\r\n   &quot;can be&quot;:&quot;omitted&quot;\r\n  },\r\n  &quot;status&quot;: {\r\n     &quot;message&quot;:&quot;CRITICAL&quot;,\r\n     &quot;code&quot;:1\r\n  },\r\n  &quot;service&quot;:&quot;SERVICE_NAME&quot;,\r\n  &quot;message&quot;:&quot;you messed up&quot;\r\n}]\r\n```\r\n\r\nI need to get the values of &#39;code&#39; and second &#39;message&#39;. Is it possible?\r\nI couldn&#39;t figure it out based on jq&#39;s documentation, so perhaps someone who understands it better than me can help.\r\n\r\nMy current code is:\r\n\r\n```sh\r\njq -r &#39;.[].status.code &amp;&amp; .[].message&#39;\r\n```\r\n\r\n...and it fails with:\r\n\r\n```none\r\njq: error: syntax error, unexpected INVALID_CHARACTER, expecting $end (Unix shell quoting issues?) at &lt;top-level&gt;, line 1: \r\n```\r\n\r\nThanks in advance.\r\n\r\nP.S.: Is there a way to put that data into shell variables?",
        "link": "https://stackoverflow.com/questions/67109361/how-to-select-two-keys-from-json-that-are-located-in-two-different-layers-array",
        "title": "How to select two keys from JSON that are located in two different layers (array and a string) using jq?"
    },
    {
        "tags": [
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1618596720,
                "post_id": 67122766,
                "comment_id": 118659067,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1618610945,
                "post_id": 67122766,
                "comment_id": 118663678,
                "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": 1662407677,
                "post_id": 67122766,
                "comment_id": 129994452,
                "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": 1662408447,
                "post_id": 67122766,
                "comment_id": 129994633,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1663855479,
                "last_edit_date": 1663855479,
                "creation_date": 1662409297,
                "answer_id": 73614339,
                "question_id": 67122766,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Once the missing closing braces and brackets (`}}]}`) are added to your script, it is possible to start fixing it. You are trying to iterate over a nested `.Summary[]` array, even though you are already iterating over the top level one. Comparing this to a common programming language, this would be similar to using the same loop inside of itself. Since there is no `.Summary[].Summary` property, this will fail.\r\n\r\nSo instead of doing `.Summary[] | .SummaryId` in the inner levels, access `.SummaryId` directly, because you are already in the context of a single list item. (or `.summaryId`? unclear from your example, you mix both cases. Might even be called `RecommendationId` from the second element in the input. [Please provide proper MWE. minimal. workable.](https://stackoverflow.com/help/minimal-reproducible-example))\r\n\r\n```json\r\n{\r\n    version: &quot;2.1.0&quot;,\r\n    &quot;$schema&quot;: &quot;http://json.schemastore.org/sarif-2.1.0-rtm.4&quot;,\r\n    runs: [\r\n        {\r\n            tool: {\r\n                driver: {\r\n                    name: &quot;Tool Name&quot;,\r\n                    informationUri: &quot;google.com&quot;,\r\n                    rules: .Summary\r\n                        | map(select(.FilePath != &quot;.&quot;))\r\n                        | map({\r\n                            id: .SummaryId,\r\n                            help: {\r\n                                text: .Description,\r\n                                markdown: .Description\r\n                            },\r\n                            properties: {\r\n                                tags: [\r\n                                    if (.SummaryId//.summaryId) | contains(&quot;prod&quot;)? then &quot;prod&quot;\r\n                                    else &quot;test&quot; end\r\n                                ]\r\n                            },\r\n                            results: [\r\n                                {\r\n                                    ruleId: (.SummaryId//.summaryId),\r\n                                    level: &quot;warning&quot;,\r\n                                    locations: [\r\n                                        {\r\n                                            physicalLocation: {\r\n                                                artifactLocation: {\r\n                                                    uri: .FilePath\r\n                                                },\r\n                                                region: {\r\n                                                    startLine: .StartLine,\r\n                                                    endLine: .EndLine\r\n                                                }\r\n                                            }\r\n                                        }\r\n                                    ],\r\n                                    message: {\r\n                                        text: .Description | split(&quot;.&quot;) | first\r\n                                    }\r\n                                }\r\n                            ]\r\n                        })\r\n                }\r\n            }\r\n        }\r\n    ]\r\n}\r\n```",
                "title": "JQ query: Unexpected $end, expecting &#39;}&#39;"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1663855479,
        "creation_date": 1618565743,
        "question_id": 67122766,
        "body_markdown": "I&#39;m constructing a JQ query to parse below JSON object:\r\n\r\n    {\r\n        &quot;Summary&quot;: [\r\n        {\r\n            &quot;FilePath&quot;: &quot;src/main/java/com/mycompany/app/App.java&quot;,\r\n            &quot;summaryId&quot;: &quot;prod-123&quot;,\r\n            &quot;StartLine&quot;: 26,\r\n            &quot;EndLine&quot;: 26,\r\n            &quot;Description&quot;: &quot;Okay&quot;\r\n        },\r\n        {\r\n            &quot;FilePath&quot;: &quot;src/main/java/com/mycompany/app/App.java&quot;,\r\n            &quot;RecommendationId&quot;: &quot;test-321&quot;,\r\n            &quot;StartLine&quot;: 26,\r\n            &quot;EndLine&quot;: 26,\r\n            &quot;Description&quot;: &quot;Bad&quot;\r\n        }]\r\n    }\r\n\r\n\r\nI&#39;m expecting the output of the JQ query to be in a [SARIF](https://docs.oasis-open.org/sarif/sarif/v2.1.0/sarif-v2.1.0.html) format as below:\r\n\r\n    {\r\n        &quot;version&quot;: &quot;2.1.0&quot;,\r\n        &quot;$schema&quot;: &quot;http://json.schemastore.org/sarif-2.1.0-rtm.4&quot;,\r\n        &quot;runs&quot;: [\r\n            {\r\n                &quot;tool&quot;:\r\n                {\r\n                    &quot;driver&quot;:\r\n                    {\r\n                        &quot;name&quot;: &quot;Tool Name&quot;,\r\n                        &quot;informationUri&quot;: &quot;google.com&quot;,\r\n                        &quot;rules&quot;: [\r\n                            {\r\n                                &quot;id&quot;: &quot;prod-123&quot;,\r\n                                &quot;help&quot;:\r\n                                {\r\n                                    &quot;text&quot;: &quot;Okay&quot;,\r\n                                    &quot;markdown&quot;: &quot;Okay&quot;\r\n                                },\r\n                                &quot;properties&quot;: {\r\n                                  &quot;tags&quot;: [ &quot;prod&quot;]\r\n                                }\r\n                            },\r\n                            {\r\n                                &quot;id&quot;: &quot;test-321&quot;,\r\n                                &quot;help&quot;:\r\n                                {\r\n                                    &quot;text&quot;: &quot;Bad&quot;,\r\n                                    &quot;markdown&quot;: &quot;Bad&quot;\r\n                                },\r\n                                &quot;properties&quot;: {\r\n                                  &quot;tags&quot;: [ &quot;test&quot;]\r\n                                }\r\n                            }\r\n                        }\r\n                    ]\r\n                }\r\n            },\r\n            &quot;results&quot;: [\r\n            {\r\n                &quot;ruleId&quot;: &quot;prod-123&quot;,\r\n                &quot;level&quot;: &quot;warning&quot;,\r\n                &quot;locations&quot;: [\r\n                {\r\n                    &quot;physicalLocation&quot;:\r\n                    {\r\n                        &quot;artifactLocation&quot;:\r\n                        {\r\n                            &quot;uri&quot;: &quot;src/main/java/com/mycompany/app/App.java\r\n                        },\r\n                        &quot;region&quot;:\r\n                        {\r\n                            &quot;startLine&quot;: 25,\r\n                            &quot;endLine&quot;: 25\r\n                        }\r\n                    }\r\n                }],\r\n                &quot;message&quot;:\r\n                {\r\n                    &quot;text&quot;: &quot;Okay&quot;\r\n                }\r\n            },\r\n            {\r\n                &quot;ruleId&quot;: &quot;test-321&quot;,\r\n                &quot;level&quot;: &quot;warning&quot;,\r\n                &quot;locations&quot;: [\r\n                {\r\n                    &quot;physicalLocation&quot;:\r\n                    {\r\n                        &quot;artifactLocation&quot;:\r\n                        {\r\n                            &quot;uri&quot;: &quot;src/main/java/com/mycompany/app/App.java&quot;\r\n                        },\r\n                        &quot;region&quot;:\r\n                        {\r\n                            &quot;startLine&quot;: 19,\r\n                            &quot;endLine&quot;: 19\r\n                        }\r\n                    }\r\n                }],\r\n                &quot;message&quot;:\r\n                {\r\n                    &quot;text&quot;: &quot;Bad&quot;\r\n                }\r\n            }]\r\n        }\r\n    ]\r\n    }\r\n\r\n\r\nI&#39;ve so far tried to built below JQ query, however I&#39;m stuck with the error (see at the bottom):\r\n\t\r\n\r\n    {\r\n    \t    version: &quot;2.1.0&quot;,\r\n    \t    &quot;$schema&quot;: &quot;http://json.schemastore.org/sarif-2.1.0-rtm.4&quot;,\r\n    \t    runs: [\r\n    \t            {\r\n    \t                tool:\r\n    \t                {\r\n    \t                    driver:\r\n    \t                    {\r\n    \t                        name: &quot;Tool Name&quot;,\r\n    \t                        informationUri: &quot;google.com&quot;,\r\n    \t                        rules: [ .Summary[] | select(.FilePath != &quot;.&quot;) |\r\n    \t                        {\r\n    \t                            id: .SummaryId,\r\n    \t                            help:\r\n    \t                            {\r\n    \t                                text: .Description,\r\n    \t                                markdown: .Description\r\n    \t                            },\r\n    \t                            properties:\r\n    \t                            {\r\n    \t                                tags: [.Summary[] | (\r\n    \t                                    if.SummaryId | contains(&quot;prod&quot;) then &quot;prod&quot;\r\n    \t                                    else &quot;test&quot;\r\n    \t                                    end)]\r\n    \t                            },\r\n    \t                            results: [.Summary[] | select(.FilePath != &quot;.&quot;) |\r\n    \t                            {\r\n    \t                                ruleId: .SummaryId,\r\n    \t                                level: &quot;warning&quot;,\r\n    \t                                locations: [\r\n    \t                                {\r\n    \t                                    physicalLocation:\r\n    \t                                    {\r\n    \t                                        artifactLocation:\r\n    \t                                        {\r\n    \t                                            uri: .FilePath\r\n    \t                                        },\r\n    \t                                        region:\r\n    \t                                        {\r\n    \t                                            startLine: .StartLine,\r\n    \t                                            endLine: .EndLine\r\n    \t                                        }\r\n    \t                                    }\r\n    \t                                }],\r\n    \t                                message:\r\n    \t                                {\r\n    \t                                    text: .Description | split(&quot;.&quot;)[0]\r\n    \t                                }\r\n    \t                            }]\r\n    \t                        }]\r\n    \t                    }\r\n\r\n\r\n**jq: error: syntax error, unexpected $end, expecting &#39;}&#39; (Unix shell quoting issues?) at &lt;top-level&gt;, line 1:\r\njq: 1 compile error\r\nexit status 3**\r\n\r\nAny help appreciated. Thanks.",
        "link": "https://stackoverflow.com/questions/67122766/jq-query-unexpected-end-expecting",
        "title": "JQ query: Unexpected $end, expecting &#39;}&#39;"
    },
    {
        "tags": [
            "json",
            "jq",
            "kubectl",
            "redis-sentinel"
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1618600786,
                "creation_date": 1618600786,
                "answer_id": 67131032,
                "question_id": 67124379,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Using `map` with .items is probably a better way to go, along the lines of:\r\n\r\n```\r\n.items\r\n| {\r\n    label: &quot;my-label&quot;,\r\n    sentinels: map(\r\n      { host: (.metadata.name + &quot;.&quot;\r\n\t      + .metadata.namespace + &quot;.&quot;\r\n\t      + &quot;svc&quot; + &quot;.&quot;\r\n\t      + &quot;cluster&quot; + &quot;.&quot;\r\n\t      + &quot;local&quot;),\r\n        port: .spec.ports[0].port\r\n      } ),\r\n    sentinelName: &quot;mymaster&quot;,\r\n    dbIndex: 0\r\n  }\r\n| {connections: [.] }\r\n\r\n```",
                "title": "format json output jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1618600786,
        "creation_date": 1618572461,
        "question_id": 67124379,
        "body_markdown": "I&#39;m deploying redis-commander in Kubernetes. I&#39;m creating a configuration connection file for [Redis-Commander][1]. I have a command in my bash script to get the required parameters for the connection file as per the link. Managed to connect locally between redis-commander and 1 redis server via sentinel just fine but have many more in non-prod so I need to configure the command below to get desired json output. \r\n\r\nThis command\r\n```\r\nkubectl get svc --selector=&#39;app.kubernetes.io/component=sentinel&#39; --all-namespaces -o json |\r\njq -r &#39;\r\n.items[]\r\n   | {label:&quot;my-label&quot;,\r\n   sentinels: [{host: (.metadata.name + &quot;.&quot;\r\n   + .metadata.namespace + &quot;.&quot;\r\n   + &quot;svc&quot; + &quot;.&quot;\r\n   + &quot;cluster&quot; + &quot;.&quot;\r\n   + &quot;local&quot;),port: .spec.ports[0].port}],\r\n   sentinelName:&quot;mymaster&quot;,\r\n   dbIndex: 0\r\n   }\r\n| {connections: [.]}&#39;\r\n```\r\n\r\nhas an output similar to this (I&#39;ve changed the name part):\r\n\r\n```\r\n{\r\n  &quot;connections&quot;: [\r\n    {\r\n      &quot;label&quot;: &quot;my-label&quot;,\r\n      &quot;sentinels&quot;: [\r\n        {\r\n          &quot;host&quot;: &quot;name1.development.svc.cluster.local&quot;,\r\n          &quot;port&quot;: 26379\r\n        }\r\n      ],\r\n      &quot;sentinelName&quot;: &quot;mymaster&quot;,\r\n      &quot;dbIndex&quot;: 0\r\n    }\r\n  ]\r\n}\r\n{\r\n  &quot;connections&quot;: [\r\n    {\r\n      &quot;label&quot;: &quot;my-label&quot;,\r\n      &quot;sentinels&quot;: [\r\n        {\r\n          &quot;host&quot;: &quot;name2.development.svc.cluster.local&quot;,\r\n          &quot;port&quot;: 26379\r\n        }\r\n      ],\r\n      &quot;sentinelName&quot;: &quot;mymaster&quot;,\r\n      &quot;dbIndex&quot;: 0\r\n    }\r\n  ]\r\n}\r\n{\r\n  &quot;connections&quot;: [\r\n    {\r\n      &quot;label&quot;: &quot;my-label&quot;,\r\n      &quot;sentinels&quot;: [\r\n        {\r\n          &quot;host&quot;: &quot;name3.staging.svc.cluster.local&quot;,\r\n          &quot;port&quot;: 26379\r\n        }\r\n      ],\r\n      &quot;sentinelName&quot;: &quot;mymaster&quot;,\r\n      &quot;dbIndex&quot;: 0\r\n    }\r\n  ]\r\n}\r\n```\r\n\r\nThe output I&#39;m trying to achieve is this:\r\n\r\n```\r\n{\r\n  &quot;connections&quot;: [\r\n    {\r\n      &quot;label&quot;: &quot;my-label&quot;,\r\n      &quot;sentinels&quot;: [\r\n        {\r\n          &quot;host&quot;: &quot;name1.development.svc.cluster.local&quot;,\r\n          &quot;port&quot;: 26379\r\n        },\r\n        {\r\n          &quot;host&quot;: &quot;name2.development.svc.cluster.local&quot;,\r\n          &quot;port&quot;: 26379\r\n        },\r\n        {\r\n          &quot;host&quot;: &quot;name3.staging.svc.cluster.local&quot;,\r\n          &quot;port&quot;: 26379\r\n        }\r\n      ],\r\n      &quot;sentinelName&quot;: &quot;mymaster&quot;,\r\n      &quot;dbIndex&quot;: 0\r\n    }\r\n  ]\r\n}\r\n```\r\n\r\nNot used jq many times so any pointers would be greatly appreciated.\r\n\r\n  [1]: https://github.com/joeferner/redis-commander/blob/master/docs/connections.md#connect-to-redis-server-via-redis-sentinel",
        "link": "https://stackoverflow.com/questions/67124379/format-json-output-jq",
        "title": "format json output jq"
    },
    {
        "tags": [
            "json",
            "shell",
            "export-to-csv",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1618663309,
                "last_edit_date": 1618663309,
                "creation_date": 1618655975,
                "answer_id": 67137221,
                "question_id": 67135550,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Pipe into:\r\n\r\n    jq -r &#39;keys[] as $k | select(.[$k]|type==&quot;array&quot;) |[$k]+.[$k][]|@csv&#39;\r\n\r\nOr use `keys_unsorted`.\r\n\r\nThis solution is not robust. You might like to consider this alternative:\r\n\r\n    keys[] as $k |[$k]+.[$k][]? | @csv\r\nSee it in action at https://jqplay.org/s/8zMbHxlfoz",
                "title": "How to export csv from JSON data with using JQ"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1618663309,
        "creation_date": 1618642687,
        "last_edit_date": 1618656579,
        "question_id": 67135550,
        "body_markdown": "This is what I tried\r\n\r\n    curl -s &#39;https://api.hoge.com/api/?symbol=TEST&#39; \\ | jq -r &#39;.[] | select(.bids ) | to_entries| map(.value) | @csv &#39; &gt; OrderBook.csv;\r\n\r\nThen I got this error back\r\n\r\n    jq: error (at &lt;stdin&gt;:0): Cannot index number with string &quot;bids&quot;\r\n\r\nThe JSON data that I can retrieve from the url above is this\r\n\r\n    {&quot;lastUpdateId&quot;:18891938,\r\n\t&quot;bids&quot;:[\r\n\t\t[&quot;3.23600000&quot;,&quot;101.76600000&quot;],\r\n\t\t[&quot;3.23500000&quot;,&quot;2161.63600000&quot;],\r\n\t\t[&quot;3.23100000&quot;,&quot;30.95000000&quot;],\r\n\t\t[&quot;3.23000000&quot;,&quot;3.12600000&quot;],\r\n\t\t[&quot;3.22900000&quot;,&quot;303.95100000&quot;]\r\n\t],\r\n\t&quot;asks&quot;:[\r\n\t\t[&quot;3.24100000&quot;,&quot;15.90200000&quot;],\r\n\t\t[&quot;3.24200000&quot;,&quot;1679.00000000&quot;],\r\n\t\t[&quot;3.24500000&quot;,&quot;953.98800000&quot;],\r\n\t\t[&quot;3.24800000&quot;,&quot;7.57700000&quot;],\r\n\t\t[&quot;3.25400000&quot;,&quot;37.26700000&quot;]\r\n\t]}\r\n\r\n\r\n\r\nHow can I export it as csv file something like this below\r\n\r\n    &quot;bids&quot;,&quot;3.23600000&quot;,&quot;101.76600000&quot;\r\n    &quot;bids&quot;,&quot;3.23500000&quot;,&quot;2161.63600000&quot;\r\n    &quot;bids&quot;,&quot;3.23100000&quot;,&quot;30.95000000&quot;\r\n    &quot;bids&quot;,&quot;3.23000000&quot;,&quot;3.12600000&quot;\r\n    &quot;bids&quot;,&quot;3.22900000&quot;,&quot;303.95100000&quot;\r\n    &quot;asks&quot;,&quot;3.24100000&quot;,&quot;15.90200000&quot;\r\n    &quot;asks&quot;,&quot;3.24200000&quot;,&quot;1679.00000000&quot;\r\n    &quot;asks&quot;,&quot;3.24500000&quot;,&quot;953.98800000&quot;\r\n    &quot;asks&quot;,&quot;3.24800000&quot;,&quot;7.57700000&quot;\r\n    &quot;asks&quot;,&quot;3.25400000&quot;,&quot;37.26700000&quot;\r\n\r\n",
        "link": "https://stackoverflow.com/questions/67135550/how-to-export-csv-from-json-data-with-using-jq",
        "title": "How to export csv from JSON data with using JQ"
    },
    {
        "tags": [
            "json",
            "terminal",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1618663076,
                "last_edit_date": 1618663076,
                "creation_date": 1618661590,
                "answer_id": 67138039,
                "question_id": 67137631,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You only need add one line to the jq program:\r\n\r\n```\r\nkeys[] as $k \r\n| select(.[$k]|type==&quot;array&quot;) \r\n| [$k]+.[$k][]\r\n| .[length]= (.[-2:]|map(tonumber)|.[0]*.[1])\r\n|@csv\r\n```\r\n\r\nYou might wish to throw in a `tostring`.",
                "title": "How can I export CSV file from json with the result of multiplication via JQ"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1618663076,
        "creation_date": 1618658810,
        "last_edit_date": 1618659358,
        "question_id": 67137631,
        "body_markdown": "I have json something like this\r\n\r\n    {&quot;lastUpdateId&quot;:18891938,\r\n    &quot;bids&quot;:[\r\n        [&quot;3.23600000&quot;,&quot;101.76600000&quot;],\r\n        [&quot;3.23500000&quot;,&quot;2161.63600000&quot;],\r\n        [&quot;3.23100000&quot;,&quot;30.95000000&quot;],\r\n        [&quot;3.23000000&quot;,&quot;3.12600000&quot;],\r\n        [&quot;3.22900000&quot;,&quot;303.95100000&quot;]\r\n    ],\r\n    &quot;asks&quot;:[\r\n        [&quot;3.24100000&quot;,&quot;15.90200000&quot;],\r\n        [&quot;3.24200000&quot;,&quot;1679.00000000&quot;],\r\n        [&quot;3.24500000&quot;,&quot;953.98800000&quot;],\r\n        [&quot;3.24800000&quot;,&quot;7.57700000&quot;],\r\n        [&quot;3.25400000&quot;,&quot;37.26700000&quot;]\r\n    ]}\r\n\r\nThen I would like to export it to CSV with the result of multiplication for every rows(i.e. 1st row should be something like this)\r\n\r\n&gt; &quot;bids&quot;,&quot;3.23600000&quot;,&quot;101.76600000&quot;,&quot;329.314776&quot; &lt;- this is calculated from 3.23600000 * 101.76600000\r\n\r\nnow, the code below export 1st numbers and 2nd number but the result of their multiplication.\r\n\r\n    jq -r keys[] as $k | select(.[$k]|type==&quot;array&quot;) |[$k]+.[$k][]|@csv\r\n\r\nHow can I export the result of multiplication together in the end of each line?\r\n\r\n\r\nhttps://jqplay.org/s/8zMbHxlfoz",
        "link": "https://stackoverflow.com/questions/67137631/how-can-i-export-csv-file-from-json-with-the-result-of-multiplication-via-jq",
        "title": "How can I export CSV file from json with the result of multiplication via JQ"
    },
    {
        "tags": [
            "json",
            "export-to-csv",
            "jq",
            "reduce"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1618698278,
                "post_id": 67140403,
                "comment_id": 118682111,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1618690016,
                "creation_date": 1618690016,
                "answer_id": 67142501,
                "question_id": 67140403,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "First, a helper function:\r\n\r\n    def mul: (.[0]|tonumber) * (.[1]|tonumber);\r\n\r\nNext, we can adapt the solution you mentioned by first computing the minimum of the &quot;ask&quot; values:\r\n```\r\n  ([.asks[][] | tonumber] | min) as $min\r\n  | keys[] as $k \r\n  | select(.[$k]|type==&quot;array&quot;)\r\n  | ([.[$k][] | mul] | add) as $sum\r\n  | [$k]+.[$k][] \r\n  | (.[-2:]|mul) as $c4\r\n  | . + [$c4, $min, $sum, $c4 / $sum]\r\n  | @csv\r\n```\r\n\r\nTo eliminate the quotation marks for numeric values, you could use `tonumber`.  To eliminate all the quotation marks, you could replace the call to `@csv` by a call to `join(&quot;,&quot;)`, but then the results are not guaranteed to be the CSV you expect.",
                "title": "How can I add calculated values to exported csv when using JQ?"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1618698036,
        "creation_date": 1618676776,
        "last_edit_date": 1618698036,
        "question_id": 67140403,
        "body_markdown": "I have json data just like this below\r\n\r\n    {&quot;lastUpdateId&quot;:18891938,\r\n    &quot;bids&quot;:[\r\n        [&quot;1&quot;,&quot;50&quot;],\r\n        [&quot;2&quot;,&quot;40&quot;],\r\n        [&quot;3&quot;,&quot;30&quot;],\r\n        [&quot;4&quot;,&quot;20&quot;],\r\n        [&quot;5&quot;,&quot;10&quot;]\r\n    ],\r\n    &quot;asks&quot;:[\r\n        [&quot;6&quot;,&quot;10&quot;],\r\n        [&quot;7&quot;,&quot;20&quot;],\r\n        [&quot;8&quot;,&quot;30&quot;],\r\n        [&quot;9&quot;,&quot;40&quot;],\r\n        [&quot;10&quot;,&quot;50&quot;]\r\n    ]}\r\n\r\n\r\nThen the code below can export the result of CSV just like this\r\n\r\n    jq -r keys[] as $k  | select(.[$k]|type==&quot;array&quot;)  | [$k]+.[$k][] | .[length]= (.[-2:]|map(tonumber)|.[0]*.[1]) |@csv\r\n\r\nResult:\r\n\r\n    &quot;asks&quot;,&quot;6&quot;,&quot;10&quot;,60\r\n    &quot;asks&quot;,&quot;7&quot;,&quot;20&quot;,140\r\n    &quot;asks&quot;,&quot;8&quot;,&quot;30&quot;,240\r\n    &quot;asks&quot;,&quot;9&quot;,&quot;40&quot;,360\r\n    &quot;asks&quot;,&quot;10&quot;,&quot;50&quot;,500\r\n    &quot;bids&quot;,&quot;1&quot;,&quot;50&quot;,50\r\n    &quot;bids&quot;,&quot;2&quot;,&quot;40&quot;,80\r\n    &quot;bids&quot;,&quot;3&quot;,&quot;30&quot;,90\r\n    &quot;bids&quot;,&quot;4&quot;,&quot;20&quot;,80\r\n    &quot;bids&quot;,&quot;5&quot;,&quot;10&quot;,50\r\n\r\nwhat if I want another columns for the minimum value of all asks(Here, it&#39;s 6)?,\r\nthe sums for each asks and bid, and the ratio against the sums for each asks and bids?\r\n\r\nSo I&#39;d like to have the CSV result something like this(4-6th columns are the new that I want)\r\n\r\n    asks,6,10,60,6,1300,0.046153846\r\n    asks,7,20,140,6,1300,0.107692308\r\n    asks,8,30,240,6,1300,0.184615385\r\n    asks,9,40,360,6,1300,0.276923077\r\n    asks,10,50,500,6,1300,0.384615385\r\n    bids,1,50,50,6,350,0.142857143\r\n    bids,2,40,80,6,350,0.228571429\r\n    bids,3,30,90,6,350,0.257142857\r\n    bids,4,20,80,6,350,0.228571429\r\n    bids,5,10,50,6,350,0.142857143\r\n\r\n    6 is minimum value for asks. 1300 is total sum for asks(60,140,240,360,500), 350 is total sum for bids(50,80,90,80,50), and the last values for each line is ratio(4th col/6th col)\r\n\r\n\r\nhttps://jqplay.org/s/2Qsdopx8A4\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/67140403/how-can-i-add-calculated-values-to-exported-csv-when-using-jq",
        "title": "How can I add calculated values to exported csv when using JQ?"
    },
    {
        "tags": [
            "json",
            "shell",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 9609,
                    "reputation": 95179,
                    "user_id": 17833,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/ExIEf.png?s=256",
                    "display_name": "Anya Shenanigans",
                    "link": "https://stackoverflow.com/users/17833/anya-shenanigans"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1618832627,
                "post_id": 67161075,
                "comment_id": 118713723,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1618832934,
                "creation_date": 1618832934,
                "answer_id": 67161436,
                "question_id": 67161075,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Assuming the input is valid JSON, for robustness, you could start with:\r\n\r\n    jq &#39;.station_conf.log_level=&quot;ERROR&quot;&#39; station.conf\r\n\r\nTo pass in a shell variable, consider:\r\n\r\n     jq —-arg v &quot;$LOG_LEVEL&quot; &#39;\r\n       .station_conf.log_level=$v&#39; station.conf\r\n\r\n",
                "title": "Using jq to edit key:value in a .conf file from shell"
            },
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1618832987,
                "creation_date": 1618832987,
                "answer_id": 67161447,
                "question_id": 67161075,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You are getting `invalid numeric literal error` because at least your example input is not valid json. As you can see, it contains `/* comment */`, which is not supported by jq. You have several options here.\r\n\r\n1. keep using jq and make your input files valid json.\r\n2. use another tool instead of jq, which support comments and/or other non-standard features.\r\n\r\nIf you choose second way, i.e. different tool, you can find some alternatives either on jq web page (https://github.com/stedolan/jq/wiki/FAQ#processing-not-quite-valid-json) or there is also `scout` (https://github.com/ABridoux/scout).\r\n ",
                "title": "Using jq to edit key:value in a .conf file from shell"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1618832987,
        "creation_date": 1618831503,
        "question_id": 67161075,
        "body_markdown": "I&#39;m trying to write a shell script that passes an env variable into a .conf file so that I can manipulate the `log_file` and `log_level` keys programatically. \r\n\r\nActual file as `station.conf`\r\n\r\n    {\r\n        &quot;SX1301_conf&quot;: {\r\n            &quot;lorawan_public&quot;: true,\r\n            &quot;clksrc&quot;: 1,\r\n            &quot;radio_0&quot;: {\r\n                &quot;type&quot;: &quot;SX1257&quot;,\r\n                &quot;rssi_offset&quot;: -166.0,\r\n                &quot;tx_enable&quot;: true,\r\n                &quot;antenna_gain&quot;: 0\r\n            },\r\n            &quot;radio_1&quot;: {\r\n                &quot;type&quot;: &quot;SX1257&quot;,\r\n                &quot;rssi_offset&quot;: -166.0,\r\n                &quot;tx_enable&quot;: false\r\n            }\r\n        },\r\n        &quot;station_conf&quot;: {\r\n            &quot;log_file&quot;: &quot;stderr&quot;,\r\n            &quot;log_level&quot;: &quot;DEBUG&quot;,\r\n            /* XDEBUG,DEBUG,VERBOSE,INFO,NOTICE,WARNING,ERROR,CRITICAL */\r\n            &quot;log_size&quot;: 10000000,\r\n            &quot;log_rotate&quot;: 3,\r\n            &quot;CUPS_RESYNC_INTV&quot;: &quot;1s&quot;\r\n        }\r\n    }\r\n\r\nI wanted to test manually before passing shell variables so I tried `jq &#39;&quot;.station_conf.log_level=&quot;ERROR&quot;&#39; station.conf`, but I keep getting errors including shell quoting errors and invalid numeric literal errors (which btw, seems to be a open bug: https://github.com/stedolan/jq/issues/501)\r\n\r\nAny tips on how to do this?  Ideally I&#39;d be able to replace log_level value with a $LOG_LEVEL from my env.  Thanks! ",
        "link": "https://stackoverflow.com/questions/67161075/using-jq-to-edit-keyvalue-in-a-conf-file-from-shell",
        "title": "Using jq to edit key:value in a .conf file from shell"
    },
    {
        "tags": [
            "json",
            "shell",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 21318897,
                    "reputation": 209,
                    "user_id": 15692365,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/9fa029a07d705b9be1bad4cdd44b12c9?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Don T Spamme",
                    "link": "https://stackoverflow.com/users/15692365/don-t-spamme"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1618841345,
                "post_id": 67163254,
                "comment_id": 118717680,
                "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": 1618879600,
                "post_id": 67163254,
                "comment_id": 118731272,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 289134,
                    "reputation": 389369,
                    "user_id": 589924,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/b2cf53d5a3d25f95c0db4e025aed4153?s=256&d=identicon&r=PG",
                    "display_name": "ikegami",
                    "link": "https://stackoverflow.com/users/589924/ikegami"
                },
                "reply_to_user": {
                    "account_id": 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": 1618879924,
                "post_id": 67163254,
                "comment_id": 118731313,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "is_answered": false,
        "answer_count": 0,
        "score": 0,
        "last_activity_date": 1618898755,
        "creation_date": 1618839957,
        "question_id": 67163254,
        "body_markdown": "I&#39;m trying to edit a config file with jq with some environment variables, but I&#39;m getting stuck on the double quote escaping and formatting.\r\n  \r\nFor example...\r\n\r\nInside `test.conf` is:\r\n\r\n    {\r\n    \t&quot;log_level&quot;:&quot;INFO&quot;\r\n    }\r\n\r\nI can edit the file with a new hardcoded value without issue by running:\r\n\r\n`jq -e &#39;.station_conf.log_level=&quot;WARN&quot;&#39; test.conf &gt; test.conf.tmp &amp;&amp; cp test.conf.tmp test.conf`\r\n\r\nWhich results in `test.conf`:\r\n\r\n    {\r\n    \t&quot;log_level&quot;:&quot;WARN&quot;\r\n    }\r\n\r\nBut trying to call the env variable:\r\n\r\n`jq -e &#39;.station_conf.log_level=&quot;$LOG_LEVEL&quot;&#39; test.conf &gt; test.conf.tmp &amp;&amp; cp test.conf.tmp test.conf`\r\n\r\nResults in:\r\n\r\n    {\r\n    \t&quot;log_level&quot;:&quot;$LOG_LEVEL&quot;\r\n    }\r\n\r\nWhich of course is because of the double quotes in the jq command.  How do I escape them to let the variable through, but still end up with properly formatted json with the double quotes around the value?\r\n\r\n",
        "link": "https://stackoverflow.com/questions/67163254/jq-with-variables-and-json-and-double-quotes",
        "title": "jq with variables and json and double quotes &quot; &quot; &quot;"
    },
    {
        "tags": [
            "json",
            "csv",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1618856501,
                "post_id": 67164295,
                "comment_id": 118724470,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 113371,
                    "reputation": 104439,
                    "user_id": 298607,
                    "user_type": "registered",
                    "accept_rate": 88,
                    "profile_image": "https://i.sstatic.net/DVW9g.jpg?s=256",
                    "display_name": "dawg",
                    "link": "https://stackoverflow.com/users/298607/dawg"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1619025202,
                "post_id": 67164295,
                "comment_id": 118782335,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 20983379,
                    "reputation": 33,
                    "user_id": 15417733,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/e480bcb593b72bd48c0f5bc436ccca4f?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "fraoudas",
                    "link": "https://stackoverflow.com/users/15417733/fraoudas"
                },
                "reply_to_user": {
                    "account_id": 113371,
                    "reputation": 104439,
                    "user_id": 298607,
                    "user_type": "registered",
                    "accept_rate": 88,
                    "profile_image": "https://i.sstatic.net/DVW9g.jpg?s=256",
                    "display_name": "dawg",
                    "link": "https://stackoverflow.com/users/298607/dawg"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1619025434,
                "post_id": 67164295,
                "comment_id": 118782449,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1618903643,
                "last_edit_date": 1618903643,
                "creation_date": 1618849996,
                "answer_id": 67165906,
                "question_id": 67164295,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If understood the problem correctly, what you can do is have a json file with all the keys set to null and then merge it with the file that has missing keys. You will then have a new json file with all the keys, which you can later convert to csv as usual. This can be done using `jq` `add` as in this example:\r\n\r\n    echo &#39;{&quot;key1&quot;:null}{&quot;key2&quot;:null}{&quot;key3&quot;:null}{&quot;key4&quot;:null}{&quot;key5&quot;:null}&#39; &gt; allkeys.json\r\n    \r\n    echo &#39;{&quot;key1&quot;:&quot;value1&quot;}{&quot;key2&quot;:&quot;value2&quot;}{&quot;key3&quot;:&quot;value3&quot;}&#39; &gt; update.json\r\n    \r\n    jq -s add allkeys.json update.json\r\n\r\noutput:\r\n\r\n    {\r\n      &quot;key1&quot;: &quot;value1&quot;,\r\n      &quot;key2&quot;: &quot;value2&quot;,\r\n      &quot;key3&quot;: &quot;value3&quot;,\r\n      &quot;key4&quot;: null,\r\n      &quot;key5&quot;: null\r\n    }\r\n\r\nadding conversion to csv:\r\n\r\n    jq -s add allkeys.json update.json | jq -r  &#39;[.[]] | @csv&#39;\r\n\r\noutput:\r\n\r\n    &quot;value1&quot;,&quot;value2&quot;,&quot;value3&quot;,,\r\n\r\n",
                "title": "how to convert json of this format to csv with jq"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1618869283,
                "last_edit_date": 1618869283,
                "creation_date": 1618856309,
                "answer_id": 67167321,
                "question_id": 67164295,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "&gt;  I have a list of all the possible keys\r\n\r\nLet&#39;s suppose this list is available as a JSON array of strings, e.g. as $keys.  Then using the following jq filter has several advantages, including efficiency (no use of the -s option), and no loss of data (relative to $keys):\r\n\r\n    $keys, (inputs | [.[$keys[]]]) | @csv\r\n\r\n\r\nExample usage:\r\n```\r\n&lt; input.json jq -nr --argjson keys &#39;[&quot;key1&quot;,&quot;key2&quot;,&quot;key3&quot;,&quot;key4&quot;]&#39; -f program.jq\r\n   \r\n```\r\n### Output\r\n```\r\n&quot;key1&quot;,&quot;key2&quot;,&quot;key3&quot;,&quot;key4&quot;\r\n&quot;value1&quot;,,,\r\n,&quot;value2&quot;,,\r\n,,&quot;value3&quot;,\r\n```\r\n\r\n### Two-pass solution\r\nIf the keys must be inferred from the data, it may still be worth considering a two-pass solution as this would avoid &quot;slurping&quot; the data.  In any case, if a two-pass solution is adopted, the above solution could be used for the second part, with the first part like this:\r\n\r\n    jq -nc &#39;reduce inputs as $x (null; . + $x) | keys_unsorted&#39; input.json\r\n\r\nSo in a bash-like environment, you&#39;d have:\r\n```\r\n&lt;input.json jq -nr \\\r\n  --argjson keys &quot;$(&lt; input.json jq -nc &#39;reduce inputs as $x (null; . + $x) | keys_unsorted&#39;)&quot; &#39;\r\n   $keys, (inputs | [.[$keys[]]]) | @csv\r\n&#39;\r\n```\r\n\r\n\r\n\r\n",
                "title": "how to convert json of this format to csv with jq"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1618856645,
                "creation_date": 1618856645,
                "answer_id": 67167397,
                "question_id": 67164295,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You need to read all the data in your file to determine what set of keys are common to all objects, then output those keys and values if the object contained them. It would be easiest to slurp the data in then process.\r\n\r\n```\r\n$ jq -sr &#39;([.[] | keys[]] | unique) as $keys | $keys, (.[] | [.[$keys[]]]) | @csv&#39; input.json\r\n&quot;key1&quot;,&quot;key2&quot;,&quot;key3&quot;\r\n&quot;value1&quot;,,\r\n,&quot;value2&quot;,\r\n,,&quot;value3&quot;\r\n```\r\n\r\n[jqplay](https://jqplay.org/s/IpdnCcRqDc)",
                "title": "how to convert json of this format to csv with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 0,
        "last_activity_date": 1619025224,
        "creation_date": 1618843873,
        "last_edit_date": 1619025224,
        "question_id": 67164295,
        "body_markdown": "I have a json file that is formatted in this way:\r\n\r\n    {&quot;key1&quot;: &quot;value1&quot;}\r\n    {&quot;key2&quot;: &quot;value2&quot;}\r\n    {&quot;key3&quot;: &quot;value3&quot;}\r\n\r\nI would like to convert this json to csv. However, the keys in all the objects in the file are not the same. I have a list of all the possible keys but some of them may be missing in any json object.  So if that is the case I would like to just insert a null value for that column.\r\n\r\n\r\nHow can I convert a json file formatted this way to the csv that I&#39;d like?\r\n\r\nUpdate:\r\nHere is an example file called objects.json\r\n\r\n    {&quot;key1&quot;: &quot;value1&quot;, &quot;key2&quot;: &quot;value2&quot;}\r\n    {&quot;key1&quot;: &quot;value3&quot;, &quot;key2&quot;: &quot;value4&quot;, &quot;key3&quot;: &quot;value5&quot;}\r\n    {&quot;key1&quot;: &quot;value6&quot;, &quot;key2&quot;: &quot;value7&quot;, &quot;key4&quot;: &quot;value8&quot;}\r\n\r\nEach object is on a new line of the file.  \r\n\r\nI have a json file called allkeys.json with an object that contains all the possible keys with null values:\r\n\r\n`{&quot;key1&quot;: null, &quot;key2&quot;: null, &quot;key3&quot;: null, &quot;key4&quot;: null}`\r\n\r\nI would like to convert example.json into a CSV file with all columns and would have null values for objects with any missing columns.\r\n\r\nSo my desired output is:\r\n\r\n    key1,key2,key3,key4\r\n    value1,value2,,\r\n    value3,value4,value5,\r\n    value6,value7,,value8\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/67164295/how-to-convert-json-of-this-format-to-csv-with-jq",
        "title": "how to convert json of this format to csv with jq"
    },
    {
        "tags": [
            "python",
            "json",
            "pandas",
            "export-to-csv",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 14800121,
                    "reputation": 7833,
                    "user_id": 10824407,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d973adc79135fbb41f70eb8d4759317f?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Olvin Roght",
                    "link": "https://stackoverflow.com/users/10824407/olvin-roght"
                },
                "edited": false,
                "score": 7,
                "creation_date": 1618868051,
                "post_id": 67169611,
                "comment_id": 118728614,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 5880019,
                    "reputation": 19,
                    "user_id": 4629721,
                    "user_type": "registered",
                    "profile_image": "https://lh6.googleusercontent.com/-dKnk84-167Q/AAAAAAAAAAI/AAAAAAAAAjo/sc-n5nV4MsY/s256-rj/photo.jpg",
                    "display_name": "Amy raygada",
                    "link": "https://stackoverflow.com/users/4629721/amy-raygada"
                },
                "reply_to_user": {
                    "account_id": 14800121,
                    "reputation": 7833,
                    "user_id": 10824407,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d973adc79135fbb41f70eb8d4759317f?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Olvin Roght",
                    "link": "https://stackoverflow.com/users/10824407/olvin-roght"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1618870816,
                "post_id": 67169611,
                "comment_id": 118729399,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 21084402,
                    "reputation": 35801,
                    "user_id": 15497888,
                    "user_type": "moderator",
                    "profile_image": "https://i.sstatic.net/VOU20.png?s=256",
                    "display_name": "Henry Ecker",
                    "link": "https://stackoverflow.com/users/15497888/henry-ecker"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1618873539,
                "post_id": 67169611,
                "comment_id": 118730095,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 21084402,
                    "reputation": 35801,
                    "user_id": 15497888,
                    "user_type": "moderator",
                    "profile_image": "https://i.sstatic.net/VOU20.png?s=256",
                    "display_name": "Henry Ecker",
                    "link": "https://stackoverflow.com/users/15497888/henry-ecker"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1618873632,
                "post_id": 67169611,
                "comment_id": 118730122,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 5880019,
                    "reputation": 19,
                    "user_id": 4629721,
                    "user_type": "registered",
                    "profile_image": "https://lh6.googleusercontent.com/-dKnk84-167Q/AAAAAAAAAAI/AAAAAAAAAjo/sc-n5nV4MsY/s256-rj/photo.jpg",
                    "display_name": "Amy raygada",
                    "link": "https://stackoverflow.com/users/4629721/amy-raygada"
                },
                "reply_to_user": {
                    "account_id": 21084402,
                    "reputation": 35801,
                    "user_id": 15497888,
                    "user_type": "moderator",
                    "profile_image": "https://i.sstatic.net/VOU20.png?s=256",
                    "display_name": "Henry Ecker",
                    "link": "https://stackoverflow.com/users/15497888/henry-ecker"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1618905633,
                "post_id": 67169611,
                "comment_id": 118737353,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1618883257,
                "last_edit_date": 1618883257,
                "creation_date": 1618882937,
                "answer_id": 67171383,
                "question_id": 67169611,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "It looks like you just want the top-level keys with scalar values, so, using jq, you could write:\r\n```\r\njq -r &#39;\r\n  ((.recipes[0]\r\n    | with_entries(select(.value|scalars)))\r\n    | keys_unsorted) as $keys\r\n  | $keys,\r\n    (.recipes[] | [ .[$keys[]] ])\r\n  | @csv\r\n&#39;\r\n```\r\n\r\nThis produces a row of headers, and assumes that the objects under `.recipes` are sufficiently conformal.\r\n\r\nIf you want a general solution that will &quot;flatten&quot; an arbitrarily-nested JSON, you might like to consider\r\n the generic JSON-to-CSV converter at https://stackoverflow.com/questions/57242240/jq-object-cannot-be-csv-formatted-only-array",
                "title": "Flatten Complex Nested JSON"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1618905543,
        "creation_date": 1618867940,
        "last_edit_date": 1618905543,
        "question_id": 67169611,
        "body_markdown": "I&#39;m new in Data Engineering I&#39;m having a hard time trying to unflatten and convert to a CSV file the following JSON. I had tried using Pandas, Python, JQ to do it but it seems like I&#39;m not making any progress. I tried several solutions erased them and try again but I cannot make it work. Can I get any advice on this? I tried exploding the arrays in pandas but it did not work.\r\n\r\n    {\r\n    &quot;recipes&quot;: [\r\n        {\r\n            &quot;vegetarian&quot;: true,\r\n            &quot;vegan&quot;: true,\r\n            &quot;glutenFree&quot;: true,\r\n            &quot;dairyFree&quot;: true,\r\n            &quot;veryHealthy&quot;: false,\r\n            &quot;cheap&quot;: false,\r\n            &quot;veryPopular&quot;: false,\r\n            &quot;sustainable&quot;: false,\r\n            &quot;weightWatcherSmartPoints&quot;: 4,\r\n            &quot;gaps&quot;: &quot;no&quot;,\r\n            &quot;lowFodmap&quot;: false,\r\n            &quot;aggregateLikes&quot;: 224,\r\n            &quot;spoonacularScore&quot;: 55.0,\r\n            &quot;healthScore&quot;: 7.0,\r\n            &quot;creditsText&quot;: &quot;Full Belly Sisters&quot;,\r\n            &quot;license&quot;: &quot;CC BY-SA 3.0&quot;,\r\n            &quot;sourceName&quot;: &quot;Full Belly Sisters&quot;,\r\n            &quot;pricePerServing&quot;: 138.79,\r\n            &quot;extendedIngredients&quot;: [\r\n                {\r\n                    &quot;id&quot;: 2069,\r\n                    &quot;aisle&quot;: &quot;Oil, Vinegar, Salad Dressing&quot;,\r\n                    &quot;image&quot;: &quot;balsamic-vinegar.jpg&quot;,\r\n                    &quot;consistency&quot;: &quot;liquid&quot;,\r\n                    &quot;name&quot;: &quot;balsamic vinegar&quot;,\r\n                    &quot;nameClean&quot;: &quot;balsamic vinegar&quot;,\r\n                    &quot;original&quot;: &quot;2T balsamic vinegar&quot;,\r\n                    &quot;originalString&quot;: &quot;2T balsamic vinegar&quot;,\r\n                    &quot;originalName&quot;: &quot;balsamic vinegar&quot;,\r\n                    &quot;amount&quot;: 2.0,\r\n                    &quot;unit&quot;: &quot;T&quot;,\r\n                    &quot;meta&quot;: [],\r\n                    &quot;metaInformation&quot;: [],\r\n                    &quot;measures&quot;: {\r\n                        &quot;us&quot;: {\r\n                            &quot;amount&quot;: 2.0,\r\n                            &quot;unitShort&quot;: &quot;Tbsps&quot;,\r\n                            &quot;unitLong&quot;: &quot;Tbsps&quot;\r\n                        },\r\n                        &quot;metric&quot;: {\r\n                            &quot;amount&quot;: 2.0,\r\n                            &quot;unitShort&quot;: &quot;Tbsps&quot;,\r\n                            &quot;unitLong&quot;: &quot;Tbsps&quot;\r\n                        }\r\n                    }\r\n                },\r\n                {\r\n                    &quot;id&quot;: 1034053,\r\n                    &quot;aisle&quot;: &quot;Oil, Vinegar, Salad Dressing&quot;,\r\n                    &quot;image&quot;: &quot;olive-oil.jpg&quot;,\r\n                    &quot;consistency&quot;: &quot;liquid&quot;,\r\n                    &quot;name&quot;: &quot;extra virgin olive oil&quot;,\r\n                    &quot;nameClean&quot;: &quot;extra virgin olive oil&quot;,\r\n                    &quot;original&quot;: &quot;4T extra virgin olive oil&quot;,\r\n                    &quot;originalString&quot;: &quot;4T extra virgin olive oil&quot;,\r\n                    &quot;originalName&quot;: &quot;extra virgin olive oil&quot;,\r\n                    &quot;amount&quot;: 4.0,\r\n                    &quot;unit&quot;: &quot;T&quot;,\r\n                    &quot;meta&quot;: [],\r\n                    &quot;metaInformation&quot;: [],\r\n                    &quot;measures&quot;: {\r\n                        &quot;us&quot;: {\r\n                            &quot;amount&quot;: 4.0,\r\n                            &quot;unitShort&quot;: &quot;Tbsps&quot;,\r\n                            &quot;unitLong&quot;: &quot;Tbsps&quot;\r\n                        },\r\n                        &quot;metric&quot;: {\r\n                            &quot;amount&quot;: 4.0,\r\n                            &quot;unitShort&quot;: &quot;Tbsps&quot;,\r\n                            &quot;unitLong&quot;: &quot;Tbsps&quot;\r\n                        }\r\n                    }\r\n                },\r\n                {\r\n                    &quot;id&quot;: 2044,\r\n                    &quot;aisle&quot;: &quot;Produce;Spices and Seasonings&quot;,\r\n                    &quot;image&quot;: &quot;basil.jpg&quot;,\r\n                    &quot;consistency&quot;: &quot;solid&quot;,\r\n                    &quot;name&quot;: &quot;fresh basil&quot;,\r\n                    &quot;nameClean&quot;: &quot;basil&quot;,\r\n                    &quot;original&quot;: &quot;1/4c chopped fresh basil&quot;,\r\n                    &quot;originalString&quot;: &quot;1/4c chopped fresh basil&quot;,\r\n                    &quot;originalName&quot;: &quot;chopped fresh basil&quot;,\r\n                    &quot;amount&quot;: 0.25,\r\n                    &quot;unit&quot;: &quot;c&quot;,\r\n                    &quot;meta&quot;: [\r\n                        &quot;fresh&quot;,\r\n                        &quot;chopped&quot;\r\n                    ],\r\n                    &quot;metaInformation&quot;: [\r\n                        &quot;fresh&quot;,\r\n                        &quot;chopped&quot;\r\n                    ],\r\n                    &quot;measures&quot;: {\r\n                        &quot;us&quot;: {\r\n                            &quot;amount&quot;: 0.25,\r\n                            &quot;unitShort&quot;: &quot;cups&quot;,\r\n                            &quot;unitLong&quot;: &quot;cups&quot;\r\n                        },\r\n                        &quot;metric&quot;: {\r\n                            &quot;amount&quot;: 59.147,\r\n                            &quot;unitShort&quot;: &quot;ml&quot;,\r\n                            &quot;unitLong&quot;: &quot;milliliters&quot;\r\n                        }\r\n                    }\r\n                },\r\n                {\r\n                    &quot;id&quot;: 11215,\r\n                    &quot;aisle&quot;: &quot;Produce&quot;,\r\n                    &quot;image&quot;: &quot;garlic.png&quot;,\r\n                    &quot;consistency&quot;: &quot;solid&quot;,\r\n                    &quot;name&quot;: &quot;garlic&quot;,\r\n                    &quot;nameClean&quot;: &quot;garlic&quot;,\r\n                    &quot;original&quot;: &quot;3 cloves garlic&quot;,\r\n                    &quot;originalString&quot;: &quot;3 cloves garlic&quot;,\r\n                    &quot;originalName&quot;: &quot;garlic&quot;,\r\n                    &quot;amount&quot;: 3.0,\r\n                    &quot;unit&quot;: &quot;cloves&quot;,\r\n                    &quot;meta&quot;: [],\r\n                    &quot;metaInformation&quot;: [],\r\n                    &quot;measures&quot;: {\r\n                        &quot;us&quot;: {\r\n                            &quot;amount&quot;: 3.0,\r\n                            &quot;unitShort&quot;: &quot;cloves&quot;,\r\n                            &quot;unitLong&quot;: &quot;cloves&quot;\r\n                        },\r\n                        &quot;metric&quot;: {\r\n                            &quot;amount&quot;: 3.0,\r\n                            &quot;unitShort&quot;: &quot;cloves&quot;,\r\n                            &quot;unitLong&quot;: &quot;cloves&quot;\r\n                        }\r\n                    }\r\n                },\r\n                {\r\n                    &quot;id&quot;: 10111529,\r\n                    &quot;aisle&quot;: &quot;Produce&quot;,\r\n                    &quot;image&quot;: &quot;cherry-tomatoes.png&quot;,\r\n                    &quot;consistency&quot;: &quot;solid&quot;,\r\n                    &quot;name&quot;: &quot;grape tomatoes&quot;,\r\n                    &quot;nameClean&quot;: &quot;grape tomato&quot;,\r\n                    &quot;original&quot;: &quot;2-3 cups grape tomatoes, halved&quot;,\r\n                    &quot;originalString&quot;: &quot;2-3 cups grape tomatoes, halved&quot;,\r\n                    &quot;originalName&quot;: &quot;grape tomatoes, halved&quot;,\r\n                    &quot;amount&quot;: 2.0,\r\n                    &quot;unit&quot;: &quot;cups&quot;,\r\n                    &quot;meta&quot;: [\r\n                        &quot;halved&quot;\r\n                    ],\r\n                    &quot;metaInformation&quot;: [\r\n                        &quot;halved&quot;\r\n                    ],\r\n                    &quot;measures&quot;: {\r\n                        &quot;us&quot;: {\r\n                            &quot;amount&quot;: 2.0,\r\n                            &quot;unitShort&quot;: &quot;cups&quot;,\r\n                            &quot;unitLong&quot;: &quot;cups&quot;\r\n                        },\r\n                        &quot;metric&quot;: {\r\n                            &quot;amount&quot;: 473.176,\r\n                            &quot;unitShort&quot;: &quot;ml&quot;,\r\n                            &quot;unitLong&quot;: &quot;milliliters&quot;\r\n                        }\r\n                    }\r\n                },\r\n                {\r\n                    &quot;id&quot;: 11282,\r\n                    &quot;aisle&quot;: &quot;Produce&quot;,\r\n                    &quot;image&quot;: &quot;brown-onion.png&quot;,\r\n                    &quot;consistency&quot;: &quot;solid&quot;,\r\n                    &quot;name&quot;: &quot;onion&quot;,\r\n                    &quot;nameClean&quot;: &quot;onion&quot;,\r\n                    &quot;original&quot;: &quot;1/2 onion, sliced&quot;,\r\n                    &quot;originalString&quot;: &quot;1/2 onion, sliced&quot;,\r\n                    &quot;originalName&quot;: &quot;onion, sliced&quot;,\r\n                    &quot;amount&quot;: 0.5,\r\n                    &quot;unit&quot;: &quot;&quot;,\r\n                    &quot;meta&quot;: [\r\n                        &quot;sliced&quot;\r\n                    ],\r\n                    &quot;metaInformation&quot;: [\r\n                        &quot;sliced&quot;\r\n                    ],\r\n                    &quot;measures&quot;: {\r\n                        &quot;us&quot;: {\r\n                            &quot;amount&quot;: 0.5,\r\n                            &quot;unitShort&quot;: &quot;&quot;,\r\n                            &quot;unitLong&quot;: &quot;&quot;\r\n                        },\r\n                        &quot;metric&quot;: {\r\n                            &quot;amount&quot;: 0.5,\r\n                            &quot;unitShort&quot;: &quot;&quot;,\r\n                            &quot;unitLong&quot;: &quot;&quot;\r\n                        }\r\n                    }\r\n                },\r\n                {\r\n                    &quot;id&quot;: 1032009,\r\n                    &quot;aisle&quot;: &quot;Spices and Seasonings&quot;,\r\n                    &quot;image&quot;: &quot;red-pepper-flakes.jpg&quot;,\r\n                    &quot;consistency&quot;: &quot;solid&quot;,\r\n                    &quot;name&quot;: &quot;red pepper flakes&quot;,\r\n                    &quot;nameClean&quot;: &quot;red pepper flakes&quot;,\r\n                    &quot;original&quot;: &quot;couple of pinches of red pepper flakes&quot;,\r\n                    &quot;originalString&quot;: &quot;couple of pinches of red pepper flakes&quot;,\r\n                    &quot;originalName&quot;: &quot;couple of of red pepper flakes&quot;,\r\n                    &quot;amount&quot;: 2.0,\r\n                    &quot;unit&quot;: &quot;pinches&quot;,\r\n                    &quot;meta&quot;: [\r\n                        &quot;red&quot;\r\n                    ],\r\n                    &quot;metaInformation&quot;: [\r\n                        &quot;red&quot;\r\n                    ],\r\n                    &quot;measures&quot;: {\r\n                        &quot;us&quot;: {\r\n                            &quot;amount&quot;: 2.0,\r\n                            &quot;unitShort&quot;: &quot;pinches&quot;,\r\n                            &quot;unitLong&quot;: &quot;pinches&quot;\r\n                        },\r\n                        &quot;metric&quot;: {\r\n                            &quot;amount&quot;: 2.0,\r\n                            &quot;unitShort&quot;: &quot;pinches&quot;,\r\n                            &quot;unitLong&quot;: &quot;pinches&quot;\r\n                        }\r\n                    }\r\n                },\r\n                {\r\n                    &quot;id&quot;: 1102047,\r\n                    &quot;aisle&quot;: &quot;Spices and Seasonings&quot;,\r\n                    &quot;image&quot;: &quot;salt-and-pepper.jpg&quot;,\r\n                    &quot;consistency&quot;: &quot;solid&quot;,\r\n                    &quot;name&quot;: &quot;salt and pepper&quot;,\r\n                    &quot;nameClean&quot;: &quot;salt and pepper&quot;,\r\n                    &quot;original&quot;: &quot;salt and freshly-ground pepper, to taste&quot;,\r\n                    &quot;originalString&quot;: &quot;salt and freshly-ground pepper, to taste&quot;,\r\n                    &quot;originalName&quot;: &quot;salt and freshly-ground pepper, to taste&quot;,\r\n                    &quot;amount&quot;: 4.0,\r\n                    &quot;unit&quot;: &quot;servings&quot;,\r\n                    &quot;meta&quot;: [\r\n                        &quot;freshly-ground&quot;,\r\n                        &quot;to taste&quot;\r\n                    ],\r\n                    &quot;metaInformation&quot;: [\r\n                        &quot;freshly-ground&quot;,\r\n                        &quot;to taste&quot;\r\n                    ],\r\n                    &quot;measures&quot;: {\r\n                        &quot;us&quot;: {\r\n                            &quot;amount&quot;: 4.0,\r\n                            &quot;unitShort&quot;: &quot;servings&quot;,\r\n                            &quot;unitLong&quot;: &quot;servings&quot;\r\n                        },\r\n                        &quot;metric&quot;: {\r\n                            &quot;amount&quot;: 4.0,\r\n                            &quot;unitShort&quot;: &quot;servings&quot;,\r\n                            &quot;unitLong&quot;: &quot;servings&quot;\r\n                        }\r\n                    }\r\n                }\r\n            ],\r\n            &quot;id&quot;: 716413,\r\n            &quot;title&quot;: &quot;Oven Roasted Tomato Sauce&quot;,\r\n            &quot;readyInMinutes&quot;: 45,\r\n            &quot;servings&quot;: 4,\r\n            &quot;sourceUrl&quot;: &quot;http://fullbellysisters.blogspot.com/2011/10/oven-roasted-tomato-sauce.html&quot;,\r\n            &quot;image&quot;: &quot;https://spoonacular.com/recipeImages/716413-556x370.jpg&quot;,\r\n            &quot;imageType&quot;: &quot;jpg&quot;,\r\n            &quot;summary&quot;: &quot;Oven Roasted Tomato Sauce might be just the sauce you are searching for. Watching your figure? This caveman, gluten free, primal, and whole 30 recipe has &lt;b&gt;155 calories&lt;/b&gt;, &lt;b&gt;1g of protein&lt;/b&gt;, and &lt;b&gt;14g of fat&lt;/b&gt; per serving. For &lt;b&gt;$1.41 per serving&lt;/b&gt;, this recipe &lt;b&gt;covers 5%&lt;/b&gt; of your daily requirements of vitamins and minerals. Plenty of people made this recipe, and 224 would say it hit the spot. Head to the store and pick up balsamic vinegar, garlic, grape tomatoes, and a few other things to make it today. From preparation to the plate, this recipe takes approximately &lt;b&gt;45 minutes&lt;/b&gt;. All things considered, we decided this recipe &lt;b&gt;deserves a spoonacular score of 61%&lt;/b&gt;. This score is pretty good. Try &lt;a href=\\&quot;https://spoonacular.com/recipes/oven-roasted-tomato-sauce-617765\\&quot;&gt;Oven Roasted Tomato Sauce&lt;/a&gt;, &lt;a href=\\&quot;https://spoonacular.com/recipes/chicken-parmesan-with-oven-roasted-tomato-sauce-360158\\&quot;&gt;Chicken Parmesan with Oven-Roasted Tomato Sauce&lt;/a&gt;, and &lt;a href=\\&quot;https://spoonacular.com/recipes/oven-roasted-tomato-basil-marinara-sauce-800148\\&quot;&gt;Oven-Roasted Tomato Basil Marinara Sauce&lt;/a&gt; for similar recipes.&quot;,\r\n            &quot;cuisines&quot;: [],\r\n            &quot;dishTypes&quot;: [\r\n                &quot;sauce&quot;\r\n            ],\r\n            &quot;diets&quot;: [\r\n                &quot;gluten free&quot;,\r\n                &quot;dairy free&quot;,\r\n                &quot;paleolithic&quot;,\r\n                &quot;lacto ovo vegetarian&quot;,\r\n                &quot;primal&quot;,\r\n                &quot;vegan&quot;\r\n            ],\r\n            &quot;occasions&quot;: [],\r\n            &quot;instructions&quot;: &quot;&quot;,\r\n            &quot;analyzedInstructions&quot;: [],\r\n            &quot;originalId&quot;: null,\r\n            &quot;spoonacularSourceUrl&quot;: &quot;https://spoonacular.com/oven-roasted-tomato-sauce-716413&quot;\r\n        }\r\n    ]\r\n}\r\n\r\nI tried this code:\r\n\r\n    d.apply(lambda x: x.explode() if x.name in [&#39;cuisines&#39; &#39;dishTypes&#39;, &#39;diets&#39;, &#39;occasions&#39;,&#39;analyzedInstructions&#39;] else x) \r\n\r\nThe data comes from Spoonacular API:\r\n\r\n    import json\r\n    import pandas as pd\r\n    import requests # get connection\r\n    import json\r\n    from pandas.io.json import json_normalize  #package for flattening json in pandas df\r\n    \r\n    YOUR_API_KEY=&#39;XXXXXXX&#39;\r\n    base_url = &#39;https://api.spoonacular.com/recipes/random?limitLicense=false&amp;tags=vegan&amp;number=1&amp;apiKey=&#39;+YOUR_API_KEY\r\n    json_text = requests.get(base_url).json()\r\n    \r\n    json_text = json.loads(raw)\r\n    json_text = json_normalize(json_text[&#39;recipes&#39;])\r\n    json_text.head(3)\r\n\r\nI&#39;m expecting a JSON that I can convert to CSV:\r\n\r\nand get the following as headers: \r\n\r\n        &quot;vegetarian&quot;\r\n        &quot;vegan&quot;\r\n        &quot;glutenFree&quot;\r\n        &quot;dairyFree&quot;\r\n        &quot;veryHealthy&quot;\r\n        &quot;cheap&quot;\r\n        &quot;veryPopular&quot;\r\n        &quot;sustainable&quot;\r\n        &quot;weightWatcherSmartPoints&quot;\r\n        &quot;gaps&quot;\r\n        &quot;lowFodmap&quot;\r\n        &quot;aggregateLikes&quot;\r\n        &quot;spoonacularScore&quot;\r\n        &quot;healthScore&quot;\r\n        &quot;pricePerServing&quot;\r\n    \r\n    &quot;extendedIngredients&quot;  \r\n       &quot;id&quot;\r\n       &quot;image&quot;\r\n       &quot;name&quot;\r\n       &quot;original&quot;\r\n       &quot;amount&quot;\r\n        &quot;unit&quot;\r\n            \r\n    &quot;measures&quot;          \r\n       &quot;metric&quot;\r\n       &quot;amount&quot;\r\n       &quot;unitShort&quot;\r\n       &quot;unitLong&quot;\r\n             \r\n     &quot;id&quot;\r\n        &quot;title&quot;: \r\n        &quot;readyInMinutes&quot;\r\n        &quot;servings&quot;\r\n        &quot;sourceUrl&quot;\r\n        &quot;image&quot;\r\n        &quot;summary&quot;\r\n        &quot;cuisines&quot;\r\n        &quot;dishTypes&quot;\r\n        &quot;diets&quot;\r\n        &quot;occasions&quot;\r\n        &quot;instructions&quot;\r\n    \r\n    &quot;analyzedInstructions&quot;:         \r\n       &quot;name&quot;\r\n       &quot;steps&quot;         \r\n       &quot;number&quot;\r\n       &quot;step&quot;\r\n\r\nThanks for any help I could get\r\n\r\n\r\n  [1]: https://i.sstatic.net/HIKqt.png\r\n",
        "link": "https://stackoverflow.com/questions/67169611/flatten-complex-nested-json",
        "title": "Flatten Complex Nested JSON"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 2169075,
                    "reputation": 2911,
                    "user_id": 1921546,
                    "user_type": "registered",
                    "accept_rate": 86,
                    "profile_image": "https://www.gravatar.com/avatar/fe4ac75c43b846d9665f422cdac5cb03?s=256&d=identicon&r=PG",
                    "display_name": "pii_ke",
                    "link": "https://stackoverflow.com/users/1921546/pii-ke"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1618927383,
                "post_id": 67180122,
                "comment_id": 118747540,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2789802,
                    "reputation": 461,
                    "user_id": 3358585,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/2398d6320dc694c1c3a3b099b676ae94?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Boyd",
                    "link": "https://stackoverflow.com/users/3358585/boyd"
                },
                "reply_to_user": {
                    "account_id": 2169075,
                    "reputation": 2911,
                    "user_id": 1921546,
                    "user_type": "registered",
                    "accept_rate": 86,
                    "profile_image": "https://www.gravatar.com/avatar/fe4ac75c43b846d9665f422cdac5cb03?s=256&d=identicon&r=PG",
                    "display_name": "pii_ke",
                    "link": "https://stackoverflow.com/users/1921546/pii-ke"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1618928001,
                "post_id": 67180122,
                "comment_id": 118747855,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1618927449,
                "last_edit_date": 1618927449,
                "creation_date": 1618926946,
                "answer_id": 67180394,
                "question_id": 67180122,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Assuming you have a raw ASCII text file named `file` and an input JSON file, you could do\r\n\r\n```bash\r\njq --rawfile txt file &#39;.data[].values |= ( $txt | split(&quot;\\n&quot;)[:-1] | group_by(.) | map(join(&quot; &quot;)) )&#39; json\r\n```\r\nproduces\r\n\r\n```json\r\n{\r\n  &quot;data&quot;: [\r\n    {\r\n      &quot;name&quot;: &quot;table&quot;,\r\n      &quot;values&quot;: [\r\n        &quot;an an&quot;,\r\n        &quot;array&quot;,\r\n        &quot;is is&quot;,\r\n        &quot;this this this&quot;\r\n      ]\r\n    }\r\n  ]\r\n}\r\n```",
                "title": "jq to replace array key values from file"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1619006441,
                "last_edit_date": 1619006441,
                "creation_date": 1618938322,
                "answer_id": 67183342,
                "question_id": 67180122,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can use `jq` and `awk`.\r\n\r\nGiven:\r\n\r\n    $ cat file\r\n    {\r\n    \t&quot;data&quot;: [                                                         \r\n    \t\t{\r\n    \t\t\t&quot;name&quot;: &quot;table&quot;,\r\n    \t\t\t&quot;values&quot;: [ \r\n    \t\t\t\t&quot;This is old data&quot;,\r\n    \t\t\t\t&quot;that needs to be&quot;,\r\n    \t\t\t\t&quot;replaced.&quot;\r\n    \t\t\t]    \r\n    \t\t}    \r\n    \t]    \r\n    }\r\n\r\n\r\n    $ cat replacement\r\n    this\r\n    this\r\n    this\r\n    is\r\n    is\r\n    an\r\n    an\r\n    array\r\n\r\nFirst create a string for the replacement array (awk is easy to use here):\r\n\r\n    ins=$(awk &#39;!s {s=last=$1; next}\r\n         $1==last{s=s &quot; &quot; $1; next} \r\n         {print s; s=last=$1}\r\n         END{print s}&#39; replacement | tr &#39;\\n&#39; &#39;\\t&#39;)\r\n\r\nThen use `jq` to insert into the JSON:\r\n\r\n    jq --rawfile txt &lt;(echo &quot;$ins&quot;) &#39;.data[].values |= ( $txt | split(&quot;\\t&quot;)[:-1] )&#39; file \r\n    {\r\n      &quot;data&quot;: [\r\n        {\r\n          &quot;name&quot;: &quot;table&quot;,\r\n          &quot;values&quot;: [\r\n            &quot;this this this&quot;,\r\n            &quot;is is&quot;,\r\n            &quot;an an&quot;,\r\n            &quot;array&quot;\r\n          ]\r\n        }\r\n      ]\r\n    }\r\n\r\nYou can also use `ruby` to process both files:\r\n\r\n    ruby -r json -e &#39;\r\n    \tBEGIN{ ar=File.readlines(ARGV[0])\r\n    \t\t\t\t.map{|l| l.rstrip}\r\n    \t\t\t\t.group_by{|e| e}\r\n    \t\t\t\t.values\r\n    \t\t\t\t.map{|v| v.join(&quot; &quot;)}\r\n    \t\tj=JSON.parse(File.read(ARGV[1]))\r\n    \t}\t\r\n    \tj[&quot;data&quot;][0][&quot;values&quot;]=ar\r\n    \tputs JSON.pretty_generate(j)&#39; txt file\r\n\r\n       # same output...\r\n\r\n",
                "title": "jq to replace array key values from file"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1619006441,
        "creation_date": 1618925948,
        "last_edit_date": 1618935427,
        "question_id": 67180122,
        "body_markdown": "I have a json file with this data:\r\n\r\n````\r\n{\r\n  &quot;data&quot;: [                                                                                                                                      \r\n    {\r\n      &quot;name&quot;: &quot;table&quot;,    \r\n      &quot;values&quot;: [    \r\n        &quot;This is old data&quot;,    \r\n        &quot;that needs to be&quot;,    \r\n        &quot;replaced.&quot;    \r\n      ]    \r\n    }    \r\n  ]    \r\n}    \r\n\r\n````\r\n\r\nBut my challege here is I need to replace that values array with words in a text or csv file:\r\n\r\n````\r\nthis\r\nthis\r\nthis\r\nis\r\nis\r\nan\r\nan\r\narray\r\n````\r\n\r\nMy output needs to have (although I could probably get away with the words all on one line...):\r\n\r\n````\r\n      &quot;values&quot;: [\r\n        &quot;this this this&quot;,\r\n        &quot;is is&quot;,\r\n        &quot;an an&quot;,\r\n        &quot;array&quot;    \r\n      ],\r\n````\r\n\r\nIs this possible with only jq?  Or would I have to get awk to help out?\r\nI already started down the awk road with:\r\n\r\n````\r\nawk -F, &#39;BEGIN{ORS=&quot; &quot;; {print &quot;[&quot;}} {print $2} END{{print &quot;]&quot;}}&#39; filename\r\n````\r\n\r\nBut I know there is still some work here...\r\n\r\nAnd then I came across `jq -Rn inputs`.   But I haven&#39;t figured out how or if I can get the desired result.\r\n\r\nThanks for any pointers.\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/67180122/jq-to-replace-array-key-values-from-file",
        "title": "jq to replace array key values from file"
    },
    {
        "tags": [
            "linux",
            "bash",
            "shell",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 5904326,
                    "reputation": 3407,
                    "user_id": 4646662,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/bffd3e98e84de9b48c1d6bc30859711d?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Tonespy",
                    "link": "https://stackoverflow.com/users/4646662/tonespy"
                },
                "reply_to_user": {
                    "account_id": 26377,
                    "reputation": 363501,
                    "user_id": 68587,
                    "user_type": "registered",
                    "accept_rate": 95,
                    "profile_image": "https://www.gravatar.com/avatar/7d9fd158e03cbde94f7e0b33b78222af?s=256&d=identicon&r=PG",
                    "display_name": "John Kugelman",
                    "link": "https://stackoverflow.com/users/68587/john-kugelman"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1618989726,
                "post_id": 67190912,
                "comment_id": 118765884,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1618994183,
                "last_edit_date": 1618994183,
                "creation_date": 1618990259,
                "answer_id": 67191186,
                "question_id": 67190912,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "jq is quite sophisticated. The best bet is probably to do all of this inside a single jq invocation and have minimal or no bash scripting.\r\n\r\n### Values only\r\n\r\nTo start with, you can get each version/branch/hash object by applying `[]` to the `.streams` object. Using `[]` on an object—or key/value map—extracts the values and throws away the keys.\r\n\r\n```\r\n$ jq -c &#39;.streams[]&#39; vs.json\r\n{&quot;version&quot;:&quot;2.33.0&quot;,&quot;branch&quot;:&quot;ewewew&quot;,&quot;hash&quot;:&quot;ewewewewe&quot;,&quot;widgets&quot;:[]}\r\n{&quot;version&quot;:&quot;1.58.0&quot;,&quot;branch&quot;:&quot;ewewew&quot;,&quot;hash&quot;:&quot;ewewew&quot;,&quot;widgets&quot;:[]}\r\n{&quot;version&quot;:&quot;1.42.0&quot;,&quot;branch&quot;:&quot;ewewew&quot;,&quot;hash&quot;:&quot;ewewe&quot;,&quot;widgets&quot;:[]}\r\n{&quot;version&quot;:&quot;1.58.0&quot;,&quot;branch&quot;:&quot;eewfwfef&quot;,&quot;hash&quot;:&quot;vvfffsfsf&quot;,&quot;widgets&quot;:[]}\r\n{&quot;version&quot;:&quot;1.39.0&quot;,&quot;branch&quot;:&quot;fvrvvsdvds&quot;,&quot;hash&quot;:&quot;vvsvdsvds&quot;,&quot;widgets&quot;:[]}\r\n```\r\n\r\nThen you can get the individual fields you&#39;re interested in by piping the above objects to a filter which grabs `.version`, `.branch`, and `.hash` and throws the three values into an array:\r\n\r\n```\r\n$ jq -c &#39;.streams[] | [.version, .branch, .hash]&#39; vs.json\r\n[&quot;2.33.0&quot;,&quot;ewewew&quot;,&quot;ewewewewe&quot;]\r\n[&quot;1.58.0&quot;,&quot;ewewew&quot;,&quot;ewewew&quot;]\r\n[&quot;1.42.0&quot;,&quot;ewewew&quot;,&quot;ewewe&quot;]\r\n[&quot;1.58.0&quot;,&quot;eewfwfef&quot;,&quot;vvfffsfsf&quot;]\r\n[&quot;1.39.0&quot;,&quot;fvrvvsdvds&quot;,&quot;vvsvdsvds&quot;]\r\n```\r\n\r\nTo get it to format the results you can generate strings instead of lists and use `\\(...)` to embed values. The `-r` flag tells it to print raw results: print the strings without quotes, in other words.\r\n\r\n```\r\n$ jq -r &#39;.streams[] | &quot;Version: \\(.version) Branch: \\(.branch) Hash: \\(.hash)&quot;&#39; vs.json\r\nVersion: 2.33.0 Branch: ewewew Hash: ewewewewe\r\nVersion: 1.58.0 Branch: ewewew Hash: ewewew\r\nVersion: 1.42.0 Branch: ewewew Hash: ewewe\r\nVersion: 1.58.0 Branch: eewfwfef Hash: vvfffsfsf\r\nVersion: 1.39.0 Branch: fvrvvsdvds Hash: vvsvdsvds\r\n```\r\n\r\n### Keys and values\r\n\r\nTo add the keys into the mix you can use `to_entries`, which extracts the key/value pairs from an object:\r\n\r\n```\r\n$ jq -c &#39;.streams | to_entries[]&#39; vs.json\r\n{&quot;key&quot;:&quot;vs-first&quot;,&quot;value&quot;:{&quot;version&quot;:&quot;2.33.0&quot;,&quot;branch&quot;:&quot;ewewew&quot;,&quot;hash&quot;:&quot;ewewewewe&quot;,&quot;widgets&quot;:[]}}\r\n{&quot;key&quot;:&quot;vs-second&quot;,&quot;value&quot;:{&quot;version&quot;:&quot;1.58.0&quot;,&quot;branch&quot;:&quot;ewewew&quot;,&quot;hash&quot;:&quot;ewewew&quot;,&quot;widgets&quot;:[]}}\r\n{&quot;key&quot;:&quot;vs-third&quot;,&quot;value&quot;:{&quot;version&quot;:&quot;1.42.0&quot;,&quot;branch&quot;:&quot;ewewew&quot;,&quot;hash&quot;:&quot;ewewe&quot;,&quot;widgets&quot;:[]}}\r\n{&quot;key&quot;:&quot;vs-fourth&quot;,&quot;value&quot;:{&quot;version&quot;:&quot;1.58.0&quot;,&quot;branch&quot;:&quot;eewfwfef&quot;,&quot;hash&quot;:&quot;vvfffsfsf&quot;,&quot;widgets&quot;:[]}}\r\n{&quot;key&quot;:&quot;vs-fifth&quot;,&quot;value&quot;:{&quot;version&quot;:&quot;1.39.0&quot;,&quot;branch&quot;:&quot;fvrvvsdvds&quot;,&quot;hash&quot;:&quot;vvsvdsvds&quot;,&quot;widgets&quot;:[]}}\r\n```\r\n\r\nPulling out the different fields then becomes:\r\n\r\n```\r\n$ jq -c &#39;.streams | to_entries[] | [.key, .value.version, .value.branch, .value.hash]&#39; vs.json\r\n[&quot;vs-first&quot;,&quot;2.33.0&quot;,&quot;ewewew&quot;,&quot;ewewewewe&quot;]\r\n[&quot;vs-second&quot;,&quot;1.58.0&quot;,&quot;ewewew&quot;,&quot;ewewew&quot;]\r\n[&quot;vs-third&quot;,&quot;1.42.0&quot;,&quot;ewewew&quot;,&quot;ewewe&quot;]\r\n[&quot;vs-fourth&quot;,&quot;1.58.0&quot;,&quot;eewfwfef&quot;,&quot;vvfffsfsf&quot;]\r\n[&quot;vs-fifth&quot;,&quot;1.39.0&quot;,&quot;fvrvvsdvds&quot;,&quot;vvsvdsvds&quot;]\r\n```\r\n\r\nOr equivalently, with the repeated `.value` lookups refactored out:\r\n\r\n```\r\njq -c &#39;.streams | to_entries[] | [.key, (.value | .version, .branch, .hash)]&#39; vs.json\r\n[&quot;vs-first&quot;,&quot;2.33.0&quot;,&quot;ewewew&quot;,&quot;ewewewewe&quot;]\r\n[&quot;vs-second&quot;,&quot;1.58.0&quot;,&quot;ewewew&quot;,&quot;ewewew&quot;]\r\n[&quot;vs-third&quot;,&quot;1.42.0&quot;,&quot;ewewew&quot;,&quot;ewewe&quot;]\r\n[&quot;vs-fourth&quot;,&quot;1.58.0&quot;,&quot;eewfwfef&quot;,&quot;vvfffsfsf&quot;]\r\n[&quot;vs-fifth&quot;,&quot;1.39.0&quot;,&quot;fvrvvsdvds&quot;,&quot;vvsvdsvds&quot;]\r\n```\r\n\r\n\r\n### Add bash processing\r\n\r\njq can&#39;t do everything, so if you do want to get the results out to bash to do additional processing—e.g., call curl—you could use `-r` to print each value on a separate line and use `read` to read the lines into variables. It would look something like this:\r\n\r\n```\r\njq -r &#39;.streams | to_entries[] | .key, (.value | .version, .branch, .hash)&#39; vs.json |\r\n    while read -r key &amp;&amp;\r\n          read -r version &amp;&amp;\r\n          read -r branch &amp;&amp;\r\n          read -r hash\r\n    do\r\n        ...\r\n    done",
                "title": "Accessing JQ Variables Using Arguments"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1618999012,
        "creation_date": 1618989039,
        "last_edit_date": 1618999012,
        "question_id": 67190912,
        "body_markdown": "I am trying to get values base on key of this JSON:\r\n```\r\n{\r\n  &quot;streams&quot;: {\r\n    &quot;vs-first&quot;: {\r\n      &quot;version&quot;: &quot;2.33.0&quot;,\r\n      &quot;branch&quot;: &quot;ewewew&quot;,\r\n      &quot;hash&quot;: &quot;ewewewewe&quot;,\r\n      &quot;widgets&quot;: []\r\n    },\r\n    &quot;vs-second&quot;: {\r\n      &quot;version&quot;: &quot;1.58.0&quot;,\r\n      &quot;branch&quot;: &quot;ewewew&quot;,\r\n      &quot;hash&quot;: &quot;ewewew&quot;,\r\n      &quot;widgets&quot;: []\r\n    },\r\n    &quot;vs-third&quot;: {\r\n      &quot;version&quot;: &quot;1.42.0&quot;,\r\n      &quot;branch&quot;: &quot;ewewew&quot;,\r\n      &quot;hash&quot;: &quot;ewewe&quot;,\r\n      &quot;widgets&quot;: []\r\n    },\r\n    &quot;vs-fourth&quot;: {\r\n      &quot;version&quot;: &quot;1.58.0&quot;,\r\n      &quot;branch&quot;: &quot;eewfwfef&quot;,\r\n      &quot;hash&quot;: &quot;vvfffsfsf&quot;,\r\n      &quot;widgets&quot;: []\r\n    },\r\n    &quot;vs-fifth&quot;: {\r\n      &quot;version&quot;: &quot;1.39.0&quot;,\r\n      &quot;branch&quot;: &quot;fvrvvsdvds&quot;,\r\n      &quot;hash&quot;: &quot;vvsvdsvds&quot;,\r\n      &quot;widgets&quot;: [\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\n}\r\n```\r\n\r\nThis is my Script implementation:\r\n```\r\njq -r &#39;.streams|keys[]&#39; $vsconfig | while read key ; do\r\n    if [ $key == &quot;[&quot; ] || [ $key == &quot;]&quot; ]; then\r\n      continue\r\n    fi\r\n\r\n    if [ $key == &quot;vs-first&quot; ]; then\r\n      version=$(jq -r &#39;.streams.vs-first.version&#39; $vsconfig)\r\n      branch=$(jq -r &#39;.streams.vs-first.branch&#39; $vsconfig)\r\n      hash=$(jq -r &#39;.streams.vs-first.hash&#39; $vsconfig)\r\n\r\n      filename=&quot;one_file-$version-$branch-$hash.zip&quot;\r\n      createdUrl=&quot;$someurl/$version/$filename&quot;\r\n\r\n      curl $createdUrl --output ./som/random/dir --create-dirs\r\n      ...\r\n    else\r\n      version=$(jq -r --arg v keyvar $key &#39;streams.[$keyvar].branch&#39; $vsconfig)\r\n      branch=`jq --arg keyvar &quot;streams.$key.branch&quot; &#39;$keyvar&#39; $vsconfig`\r\n      hash=`jq --arg keyvar &quot;streams.$key.hash&quot; &#39;$keyvar&#39; $vsconfig`\r\n\r\n      filename = &quot;$key-$version&quot;\r\n      if [ $branch == &quot;some_branch&quot; ]; then\r\n        filename=&quot;one_file-$version-$branch-$hash.zip&quot;\r\n      else\r\n        filename=&quot;$filename.zip&quot;\r\n      fi\r\n\r\n      curl $createdUrl --output ./som/random/dir --create-dirs\r\n    fi\r\n\r\n    echo &quot;Version: $version Branch: $branch Hash: $hash&quot;\r\ndone\r\n```\r\n\r\nI&#39;ve tried multiple formats, i.e:\r\n```\r\nversion=$(jq -r --arg v keyvar $key &#39;streams.[$keyvar].branch&#39; $vsconfig)\r\n```\r\n\r\nAnd:\r\n```\r\nbranch=`jq --arg keyvar &quot;streams.$key.branch&quot; &#39;$keyvar&#39; $vsconfig`\r\n```\r\n\r\nIt gives this error:\r\n```\r\njq: error: support/0 is not defined at &lt;top-level&gt;, line 1:\r\n```",
        "link": "https://stackoverflow.com/questions/67190912/accessing-jq-variables-using-arguments",
        "title": "Accessing JQ Variables Using Arguments"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 16708895,
                    "reputation": 57,
                    "user_id": 12076640,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/Mp6X3.jpg?s=256",
                    "display_name": "n00b",
                    "link": "https://stackoverflow.com/users/12076640/n00b"
                },
                "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": 1619003314,
                "post_id": 67193713,
                "comment_id": 118772058,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1619083731,
                "last_edit_date": 1619083731,
                "creation_date": 1619003326,
                "answer_id": 67194666,
                "question_id": 67193713,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Construct your desired JSON immediately following the `group_by()`\r\n\r\n```none\r\ngroup_by(.ip) | \r\nmap\r\n( \r\n  { \r\n    ip:    .[0].ip, \r\n    ports: [ .[].ports[].port ] | unique \r\n  } \r\n)\r\n```\r\n\r\n[jq play link][1]\r\n\r\n--- \r\n\r\nFollow-up question to discard IPs that have only port as 0\r\n\r\n```none\r\ngroup_by(.ip) | \r\nmap\r\n( \r\n  { \r\n    ip:    .[0].ip, \r\n    ports: [ .[].ports[] | select(.port != 0 ).port ] | unique\r\n  } |\r\n  select(.ports | length &gt; 0) \r\n)\r\n```\r\n\r\n\r\n  [1]: https://jqplay.org/s/ANvE7_uCKx",
                "title": "JQ Error: Cannot iterate over string while trying to map IP and Ports"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -1,
        "last_activity_date": 1619083731,
        "creation_date": 1618999792,
        "last_edit_date": 1619012218,
        "question_id": 67193713,
        "body_markdown": "I have a below json output, I would love to remove duplicate data and map the data in a table format using jq. I am using the below query but I keep getting an error; \r\n\r\n&gt; Cannot iterate over string (&quot;78.45.196...)\r\n\r\ne.t.c.\r\n\r\n**Json data**\r\n\r\n```json\r\n[\r\n  {\r\n    &quot;ip&quot;: &quot;78.45.196.23&quot;,\r\n    &quot;timestamp&quot;: &quot;1616566245&quot;,\r\n    &quot;ports&quot;: [\r\n      {\r\n        &quot;port&quot;: 5060,\r\n        &quot;proto&quot;: &quot;tcp&quot;,\r\n        &quot;status&quot;: &quot;open&quot;,\r\n        &quot;reason&quot;: &quot;syn-ack&quot;,\r\n        &quot;ttl&quot;: 50\r\n      }\r\n    ]\r\n  },\r\n  {\r\n    &quot;ip&quot;: &quot;67.89.378.82&quot;,\r\n    &quot;timestamp&quot;: &quot;1616566255&quot;,\r\n    &quot;ports&quot;: [\r\n      {\r\n        &quot;port&quot;: 2000,\r\n        &quot;proto&quot;: &quot;tcp&quot;,\r\n        &quot;status&quot;: &quot;open&quot;,\r\n        &quot;reason&quot;: &quot;syn-ack&quot;,\r\n        &quot;ttl&quot;: 50\r\n      }\r\n    ]\r\n  },\r\n  {\r\n    &quot;ip&quot;: &quot;67.89.378.82&quot;,\r\n    &quot;timestamp&quot;: &quot;1616566255&quot;,\r\n    &quot;ports&quot;: [\r\n      {\r\n        &quot;port&quot;: 2080,\r\n        &quot;proto&quot;: &quot;tcp&quot;,\r\n        &quot;status&quot;: &quot;open&quot;,\r\n        &quot;reason&quot;: &quot;syn-ack&quot;,\r\n        &quot;ttl&quot;: 50\r\n      }\r\n    ]\r\n  },\r\n  {\r\n    &quot;ip&quot;: &quot;78.45.196.23&quot;,\r\n    &quot;timestamp&quot;: &quot;1616566245&quot;,\r\n    &quot;ports&quot;: [\r\n      {\r\n        &quot;port&quot;: 5060,\r\n        &quot;proto&quot;: &quot;tcp&quot;,\r\n        &quot;status&quot;: &quot;open&quot;,\r\n        &quot;reason&quot;: &quot;syn-ack&quot;,\r\n        &quot;ttl&quot;: 50\r\n      }\r\n    ]\r\n  },\r\n  {\r\n    &quot;ip&quot;: &quot;67.89.378.82&quot;,\r\n    &quot;timestamp&quot;: &quot;1616566255&quot;,\r\n    &quot;ports&quot;: [\r\n      {\r\n        &quot;port&quot;: 2000,\r\n        &quot;proto&quot;: &quot;tcp&quot;,\r\n        &quot;status&quot;: &quot;open&quot;,\r\n        &quot;reason&quot;: &quot;syn-ack&quot;,\r\n        &quot;ttl&quot;: 50\r\n      }\r\n    ]\r\n  },\r\n  {\r\n    &quot;ip&quot;: &quot;78.45.196.23&quot;,\r\n    &quot;timestamp&quot;: &quot;1616566245&quot;,\r\n    &quot;ports&quot;: [\r\n      {\r\n        &quot;port&quot;: 5080,\r\n        &quot;proto&quot;: &quot;tcp&quot;,\r\n        &quot;status&quot;: &quot;open&quot;,\r\n        &quot;reason&quot;: &quot;syn-ack&quot;,\r\n        &quot;ttl&quot;: 50\r\n      }\r\n    ]\r\n  }\r\n]\r\n```\r\n\r\n**My query**\r\n\r\n```sh\r\njq -r &#39;.[][] | group_by(.ip) | map({ip: .ip, ports: map(.ports[].port) | add | unique})&#39; jsonfile.json\r\n```\r\n\r\n**Expected output**\r\n- To remove duplicates and get ip and ports.\r\n- Or can one explain to me how to get unique values from both IP and ports.\r\n\r\n```json\r\n[\r\n\t{&quot;ip:&quot; &quot;67.89.378.82&quot;, &quot;ports:&quot;[2000, 2080]},\r\n\t{&quot;ip:&quot; &quot;78.45.196.23&quot;, &quot;ports:&quot;[5060, 5080]}\r\n]\r\n```",
        "link": "https://stackoverflow.com/questions/67193713/jq-error-cannot-iterate-over-string-while-trying-to-map-ip-and-ports",
        "title": "JQ Error: Cannot iterate over string while trying to map IP and Ports"
    },
    {
        "tags": [
            "arrays",
            "json",
            "sorting",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1619043751,
                "last_edit_date": 1619043751,
                "creation_date": 1619007372,
                "answer_id": 67195763,
                "question_id": 67194822,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Rather than appending the new elements to the arrays, you could use `bsearch` to find the insertion point, and then use that to perform the two insertions. Specifically, if $x is not in a sorted array, then the insertion point of $x in the array is `-1 - bsearch($x)`.  \r\n\r\nYou might find this helper function useful:\r\n\r\n    def insert($x;$i): .[:$i]+[$x]+.[$i:];\r\n\r\n## Solution\r\nHere then is a solution for the problem at hand:\r\n\r\n```\r\n# It is assumed that (.|f) is a sorted array\r\ndef insert_into_sorted($x; f; $y; g):\r\n  def insert($x;$i): .[:$i]+[$x]+.[$i:];\r\n  (f|bsearch($x)) as $ix\r\n  | (if $ix &gt; -1 then $ix else -1 - $ix end) as $i\r\n  | f|=insert($x; $i)\r\n  | g|=insert($y; $i) ;\r\n\r\ninsert_into_sorted( {&quot;content&quot;: &quot;b&quot;}; .records; \r\n                    {&quot;content&quot;: &quot;new element&quot;}; .comments)\r\n\r\n```",
                "title": "Sorting an array together with other array in jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1619043751,
        "creation_date": 1619003967,
        "last_edit_date": 1619034617,
        "question_id": 67194822,
        "body_markdown": "I have two arrays in a structure but between elements of arrays has logical connections. (Eg. `comments[1]` belongs to `records[1]`, `comments[2]` belongs to `records[2]`)  \r\n\r\nThese arrays are sorted by alpabetical order of records array.\r\nWhen I want to add a new element for both array then I have sort both arrays. For records array it is easy, but the elements of comments array have to move same way as each element of record.\r\n\r\nInput:\r\n```json\r\n{\r\n  &quot;records&quot;:\r\n    [\r\n     {&quot;content&quot;:&quot;a&quot;},\r\n     {&quot;content&quot;:&quot;z&quot;}\r\n    ], \r\n     &quot;comments&quot;:[\r\n         {&quot;content&quot;:&quot;something&quot;},\r\n         {&quot;content&quot;:&quot;anything&quot;}\r\n     ]\r\n}\r\n```\r\nNew elements are added to the end of arrays:\r\n\r\n```json\r\n{ \r\n  &quot;records&quot;:[\r\n      {&quot;content&quot;:&quot;a&quot;},\r\n      {&quot;content&quot;:&quot;z&quot;},\r\n      {&quot;content&quot;:&quot;b&quot;}\r\n  ],\r\n  &quot;comments&quot;:[\r\n      {&quot;content&quot;:&quot;something&quot;},\r\n      {&quot;content&quot;:&quot;anything&quot;},\r\n      {&quot;content&quot;:&quot;new element&quot;}\r\n  ]\r\n}\r\n\r\nExpected sorted output:\r\n\r\n```json\r\n{\r\n  &quot;records&quot;:[\r\n     {&quot;content&quot;:&quot;a&quot;},\r\n     {&quot;content&quot;:&quot;b&quot;},\r\n     {&quot;content&quot;:&quot;z&quot;}\r\n  ],\r\n  &quot;comments&quot;:[\r\n     {&quot;content&quot;:&quot;something&quot;},\r\n     {&quot;content&quot;:&quot;new element&quot;},\r\n     {&quot;content&quot;:&quot;anything&quot;}\r\n  ]\r\n}\r\n```\r\nI tried `&quot;to_elements`, `map`, `transpose` and `add`functions without any (partial) result.",
        "link": "https://stackoverflow.com/questions/67194822/sorting-an-array-together-with-other-array-in-jq",
        "title": "Sorting an array together with other array in jq"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 7,
                "is_accepted": false,
                "score": 7,
                "last_activity_date": 1619042252,
                "creation_date": 1619042252,
                "answer_id": 67203999,
                "question_id": 67203735,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "    jq &#39;.data[] \r\n        | select(.targets[] | .lastReportedStatus==&quot;STOPPED&quot; and .id==2520949)\r\n        | .name&#39; file.json",
                "title": "Select value from array json using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1661935738,
        "creation_date": 1619040632,
        "question_id": 67203735,
        "body_markdown": "I have the following json file which this value \r\n```\r\n{\r\n  &quot;data&quot;: [\r\n      {\r\n          &quot;id&quot;: 60573936,\r\n          &quot;timeCreated&quot;: 1615458564202,\r\n          &quot;timeUpdated&quot;: 1615458564202,\r\n          &quot;name&quot;: &quot;name1&quot;,\r\n          &quot;desiredStatus&quot;: &quot;UNMANAGED&quot;,\r\n          &quot;defaultStatus&quot;: &quot;STARTED&quot;,\r\n          &quot;targets&quot;: [\r\n              {\r\n                  &quot;id&quot;: 2520949,\r\n                  &quot;lastReportedStatus&quot;: &quot;STOPPED&quot;\r\n              }, {\r\n                  &quot;id&quot;: 702881,\r\n                  &quot;lastReportedStatus&quot;: &quot;STARTED&quot;\r\n              }\r\n          ]\r\n      }, {\r\n          &quot;id&quot;: 60574370,\r\n          &quot;timeCreated&quot;: 1615458812565,\r\n          &quot;timeUpdated&quot;: 1615458812565,\r\n          &quot;name&quot;: &quot;name2&quot;,\r\n          &quot;desiredStatus&quot;: &quot;UNMANAGED&quot;,\r\n          &quot;defaultStatus&quot;: &quot;STARTED&quot;,\r\n          &quot;targets&quot;: [\r\n              {\r\n                  &quot;id&quot;: 2520949,\r\n                  &quot;lastReportedStatus&quot;: &quot;STARTED&quot;\r\n              }, {\r\n                  &quot;id&quot;: 702881,\r\n                  &quot;lastReportedStatus&quot;: &quot;STOPPED&quot;\r\n              }\r\n          ]\r\n      }, {\r\n          &quot;id&quot;: 60574329,\r\n          &quot;timeCreated&quot;: 1615458775053,\r\n          &quot;timeUpdated&quot;: 1615458775053,\r\n          &quot;name&quot;: &quot;name3&quot;,\r\n          &quot;desiredStatus&quot;: &quot;UNMANAGED&quot;,\r\n          &quot;defaultStatus&quot;: &quot;STARTED&quot;,\r\n          &quot;targets&quot;: [\r\n              {\r\n                  &quot;id&quot;: 2520949,\r\n                  &quot;lastReportedStatus&quot;: &quot;STOPPED&quot;\r\n              }, {\r\n                  &quot;id&quot;: 702881,\r\n                  &quot;lastReportedStatus&quot;: &quot;STARTED&quot;\r\n              }\r\n          ]\r\n      }\r\n    ]\r\n  }\r\n```\r\nI would like to extract the &quot;name&quot; value only if &quot;id&quot;=&quot;2520949&quot; and &quot;lastReportedStatus&quot;=&quot;STOPPED&quot; using jq. In my example I would like to get &quot;name1&quot; and &quot;name3&quot;. I tried using select feature but I&#39;m not able to satisfy the &quot;and&quot; condition between &quot;id&quot; and &quot;lastReportedStatus&quot; key. What is the correct  code with jq ?",
        "link": "https://stackoverflow.com/questions/67203735/select-value-from-array-json-using-jq",
        "title": "Select value from array json using jq"
    },
    {
        "tags": [
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 6196394,
                    "reputation": 86601,
                    "user_id": 5291015,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/4tAvO.jpg?s=256",
                    "display_name": "Inian",
                    "link": "https://stackoverflow.com/users/5291015/inian"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1619073696,
                "post_id": 67207989,
                "comment_id": 118795370,
                "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": 1619074239,
                "post_id": 67207989,
                "comment_id": 118795566,
                "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": 1619074773,
                "post_id": 67207989,
                "comment_id": 118795737,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 195143,
                    "reputation": 2792,
                    "user_id": 437879,
                    "user_type": "registered",
                    "accept_rate": 56,
                    "profile_image": "https://www.gravatar.com/avatar/b7d66ad6b6bafa7dd5f24a3c890013cb?s=256&d=identicon&r=PG",
                    "display_name": "haschibaschi",
                    "link": "https://stackoverflow.com/users/437879/haschibaschi"
                },
                "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": 1619081933,
                "post_id": 67207989,
                "comment_id": 118798776,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1619387188,
                "creation_date": 1619387188,
                "answer_id": 67258589,
                "question_id": 67207989,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Looking at the jq query in the Q, we can define two useful functions:\r\n```\r\ndef attributes:\r\n  [ .attributes[]\r\n    | select(.objectTypeAttributeId==8)\r\n    | .objectAttributeValues[].referencedObject.attributes[]\r\n    | select(.objectTypeAttributeId==15)\r\n    | .objectAttributeValues[].referencedObject.attributes[] ] ;\r\n\r\n\r\ndef to_o:\r\n   { (&quot;attribute&quot; + (.objectTypeAttributeId|tostring)): first(.objectAttributeValues[].value)};\r\n````\r\n\r\nAnd we see that\r\n\r\n    .objectEntries[] | attributes[] | to_o\r\n\r\nyields:\r\n```\r\n{&quot;attribute36&quot;:&quot;bli&quot;}\r\n{&quot;attribute39&quot;:&quot;blo&quot;}\r\n{&quot;attribute36&quot;:&quot;xxx&quot;}\r\n{&quot;attribute39&quot;:&quot;yyy&quot;}\r\n```\r\n\r\nThis is where the original question becomes a bit difficult to understand.  I&#39;m going to assume the intent is to group these objects together without loss of information and without introducing arrays.\r\n\r\nAt any rate, the following filter does produce the desired result:\r\n```\r\n.objectEntries[]\r\n| .objectType.name as $name\r\n| foreach ((attributes[] | to_o), null ) as $o ({};\r\n     if $o == null then .emit = .object\r\n     elif .object|has($o|keys_unsorted[0])\r\n     then .emit=.object | .object=$o\r\n     else .emit=null | .object += $o\r\n     end;\r\n     select(.emit) | .emit)\r\n| {$name} + .\r\n\r\n```",
                "title": "Object Construction with nested m:n structure in jq"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1619387188,
        "creation_date": 1619073509,
        "last_edit_date": 1619073985,
        "question_id": 67207989,
        "body_markdown": "I have this json\r\n\r\n     {\r\n      &quot;objectEntries&quot;: [\r\n        {\r\n          &quot;objectType&quot;: {\r\n            &quot;name&quot;: &quot;Test&quot;\r\n          },\r\n          &quot;attributes&quot;: [\r\n            {\r\n              &quot;id&quot;: 16,\r\n              &quot;objectTypeAttributeId&quot;: 8,\r\n              &quot;objectAttributeValues&quot;: [\r\n                {\r\n                  &quot;referencedObject&quot;: {\r\n                    &quot;id&quot;: 17,\r\n                    &quot;label&quot;: &quot;TestTest&quot;,\r\n                    &quot;attributes&quot;: [\r\n                      {\r\n                        &quot;id&quot;: 20,\r\n                        &quot;objectTypeAttributeId&quot;: 11,\r\n                        &quot;objectAttributeValues&quot;: [\r\n                          {\r\n                            &quot;value&quot;: &quot;bli&quot;\r\n                          }\r\n                        ],\r\n                        &quot;objectId&quot;: 12\r\n                      },\r\n                      {\r\n                        &quot;id&quot;: 21,\r\n                        &quot;objectTypeAttributeId&quot;: 13,\r\n                        &quot;objectAttributeValues&quot;: [\r\n                          {\r\n                            &quot;value&quot;: &quot;blo&quot;\r\n                          }\r\n                        ],\r\n                        &quot;objectId&quot;: 14\r\n                      },\r\n                      {\r\n                        &quot;id&quot;: 22,\r\n                        &quot;objectTypeAttributeId&quot;: 15,\r\n                        &quot;objectAttributeValues&quot;: [\r\n                         {\r\n                          &quot;referencedObject&quot;: {\r\n                            &quot;id&quot;: 30,\r\n                            &quot;label&quot;: &quot;TestTest&quot;,\r\n                            &quot;attributes&quot;: [\r\n                              {\r\n                                &quot;id&quot;: 35,\r\n                                &quot;objectTypeAttributeId&quot;: 36,\r\n                                &quot;objectAttributeValues&quot;: [\r\n                                  {\r\n                                    &quot;value&quot;: &quot;bli&quot;\r\n                                  }\r\n                                ],\r\n                                &quot;objectId&quot;: 37\r\n                              },\r\n                              {\r\n                                &quot;id&quot;: 38,\r\n                                &quot;objectTypeAttributeId&quot;: 39,\r\n                                &quot;objectAttributeValues&quot;: [\r\n                                  {\r\n                                    &quot;value&quot;: &quot;blo&quot;\r\n                                  }\r\n                                ],\r\n                                &quot;objectId&quot;: 40\r\n                              }\r\n                            ]\r\n                          }\r\n                        }\r\n                      ],\r\n                        &quot;objectId&quot;: 16\r\n                      }\r\n                    ]\r\n                  }\r\n                }\r\n              ]\r\n            },\r\n            {\r\n              &quot;id&quot;: 16,\r\n              &quot;objectTypeAttributeId&quot;: 8,\r\n              &quot;objectAttributeValues&quot;: [\r\n                {\r\n                  &quot;referencedObject&quot;: {\r\n                    &quot;id&quot;: 17,\r\n                    &quot;label&quot;: &quot;TestTest&quot;,\r\n                    &quot;attributes&quot;: [\r\n                      {\r\n                        &quot;id&quot;: 20,\r\n                        &quot;objectTypeAttributeId&quot;: 11,\r\n                        &quot;objectAttributeValues&quot;: [\r\n                          {\r\n                            &quot;value&quot;: &quot;bli&quot;\r\n                          }\r\n                        ],\r\n                        &quot;objectId&quot;: 12\r\n                      },\r\n                      {\r\n                        &quot;id&quot;: 21,\r\n                        &quot;objectTypeAttributeId&quot;: 13,\r\n                        &quot;objectAttributeValues&quot;: [\r\n                          {\r\n                            &quot;value&quot;: &quot;blo&quot;\r\n                          }\r\n                        ],\r\n                        &quot;objectId&quot;: 14\r\n                      },\r\n                      {\r\n                        &quot;id&quot;: 22,\r\n                        &quot;objectTypeAttributeId&quot;: 15,\r\n                        &quot;objectAttributeValues&quot;: [\r\n                         {\r\n                          &quot;referencedObject&quot;: {\r\n                            &quot;id&quot;: 30,\r\n                            &quot;label&quot;: &quot;TestTest&quot;,\r\n                            &quot;attributes&quot;: [\r\n                              {\r\n                                &quot;id&quot;: 35,\r\n                                &quot;objectTypeAttributeId&quot;: 36,\r\n                                &quot;objectAttributeValues&quot;: [\r\n                                  {\r\n                                    &quot;value&quot;: &quot;xxx&quot;\r\n                                  }\r\n                                ],\r\n                                &quot;objectId&quot;: 37\r\n                              },\r\n                              {\r\n                                &quot;id&quot;: 38,\r\n                                &quot;objectTypeAttributeId&quot;: 39,\r\n                                &quot;objectAttributeValues&quot;: [\r\n                                  {\r\n                                    &quot;value&quot;: &quot;yyy&quot;\r\n                                  }\r\n                                ],\r\n                                &quot;objectId&quot;: 40\r\n                              }\r\n                            ]\r\n                          }\r\n                        }\r\n                      ],\r\n                        &quot;objectId&quot;: 16\r\n                      }\r\n                    ]\r\n                  }\r\n                }\r\n              ]\r\n            }\r\n          ]\r\n        }\r\n      ]\r\n    }\r\n\r\n\r\nI want this result.\r\n\r\n    {\r\n      &quot;name&quot;: &quot;Test&quot;,\r\n      &quot;attribute36&quot;: &quot;bli&quot;,\r\n      &quot;attribute39&quot;: &quot;blo&quot;\r\n    }\r\n    {\r\n      &quot;name&quot;: &quot;Test&quot;,\r\n      &quot;attribute36&quot;: &quot;xxx&quot;,\r\n      &quot;attribute39&quot;: &quot;yyy&quot;\r\n    }\r\n\r\nBut what I get is this\r\n\r\n    {\r\n      &quot;name&quot;: &quot;Test&quot;,\r\n      &quot;attribute36&quot;: &quot;bli&quot;,\r\n      &quot;attribute39&quot;: &quot;blo&quot;\r\n    }\r\n    {\r\n      &quot;name&quot;: &quot;Test&quot;,\r\n      &quot;attribute36&quot;: &quot;bli&quot;,\r\n      &quot;attribute39&quot;: &quot;yyy&quot;\r\n    }\r\n    {\r\n      &quot;name&quot;: &quot;Test&quot;,\r\n      &quot;attribute36&quot;: &quot;xxx&quot;,\r\n      &quot;attribute39&quot;: &quot;blo&quot;\r\n    }\r\n    {\r\n      &quot;name&quot;: &quot;Test&quot;,\r\n      &quot;attribute36&quot;: &quot;xxx&quot;,\r\n      &quot;attribute39&quot;: &quot;yyy&quot;\r\n    }\r\n\r\nThe jq query I came up with \r\n\r\n    jq &#39;.objectEntries[] | {&quot;name&quot;: .objectType.name, &quot;attribute36&quot;: .attributes | .[] | select(.objectTypeAttributeId==8) | .objectAttributeValues[].referencedObject.attributes | .[] | select(.objectTypeAttributeId==15) | .objectAttributeValues[].referencedObject.attributes | .[] | select(.objectTypeAttributeId==36) |  .objectAttributeValues | .[] | .value, &quot;attribute39&quot;: .attributes | .[] | select(.objectTypeAttributeId==8) | .objectAttributeValues[].referencedObject.attributes | .[] | select(.objectTypeAttributeId==15) | .objectAttributeValues[].referencedObject.attributes | .[] | select(.objectTypeAttributeId==39) |  .objectAttributeValues | .[] | .value}&#39; stackoverflow.json\r\n\r\nYou can see the problem also on jqplay https://jqplay.org/s/NjqEy7wvQE\r\n\r\nThe goal is to extract certain fields on the different jsonpath depths into a new, flat json object, per toplevel json object, where toplevel are the objects under `objectEntries[]`",
        "link": "https://stackoverflow.com/questions/67207989/object-construction-with-nested-mn-structure-in-jq",
        "title": "Object Construction with nested m:n structure in jq"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1619079132,
                "last_edit_date": 1619079132,
                "creation_date": 1619078757,
                "answer_id": 67209213,
                "question_id": 67208669,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "One way would be to add the objects together with the `.roles` array and delete it after\r\n\r\n```none\r\n.categories[][].resources[] |= ( \r\n  . + { readRole: .roles[0], writeRole: .roles[1] } | del(.roles)\r\n)\r\n```\r\n\r\n&lt;sup&gt;[jqplay demo][1]&lt;/sup&gt;\r\n\r\n\r\n  [1]: https://jqplay.org/s/y7oeIHNRoZ",
                "title": "How to create object fields from array content using JQ"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1619079132,
        "creation_date": 1619076530,
        "question_id": 67208669,
        "body_markdown": "I have following object:\r\n\r\n    {\r\n      &quot;base&quot;: &quot;/templates&quot;,\r\n      &quot;title&quot;: &quot;Templates&quot;,\r\n      &quot;categories&quot;: {\r\n        &quot;category1&quot;: {\r\n          &quot;propertiesResources&quot;: {\r\n            &quot;resources&quot;: {\r\n              &quot;cliTemplate&quot;: {\r\n                &quot;type&quot;: &quot;CLIENT&quot;,\r\n                &quot;path&quot;: &quot;properties/cli.json&quot;,\r\n                &quot;roles&quot;: [\r\n                  &quot;ROLE_SYSTEM_READ&quot;,\r\n                  &quot;ROLE_SYSTEM_WRITE&quot;\r\n                ]\r\n              },\r\n              &quot;viewerTemplate&quot;: {\r\n                &quot;type&quot;: &quot;SERVER&quot;,\r\n                &quot;path&quot;: &quot;properties/server.json&quot;,\r\n                &quot;roles&quot;: [\r\n                  &quot;ROLE_CONFIGURATOR_READ&quot;,\r\n                  &quot;ROLE_CONFIGURATOR_WRITE&quot;\r\n                ]\r\n              }\r\n            }\r\n          }\r\n    \t}\r\n      }\r\n    }\r\nAs you can see the field roles is an array which contains list of roles. The roles are guaranteed to be in this order. What I need is to replace the field `roles` with two new fields: `roleRead` and `roleWrite` where this new fields will have corresponding values from the array.\r\n\r\n    {\r\n      &quot;base&quot;: &quot;/templates&quot;,\r\n      &quot;title&quot;: &quot;Templates&quot;,\r\n      &quot;categories&quot;: {\r\n        &quot;category1&quot;: {\r\n          &quot;propertiesResources&quot;: {\r\n            &quot;resources&quot;: {\r\n              &quot;cliTemplate&quot;: {\r\n                &quot;type&quot;: &quot;CLIENT&quot;,\r\n                &quot;path&quot;: &quot;properties/cli.json&quot;,\r\n                &quot;readRole&quot;: &quot;ROLE_SYSTEM_READ&quot;,\r\n                &quot;writeRole&quot;: &quot;ROLE_SYSTEM_WRITE&quot;\r\n              },\r\n              &quot;viewerTemplate&quot;: {\r\n                &quot;type&quot;: &quot;SERVER&quot;,\r\n                &quot;path&quot;: &quot;properties/server.json&quot;,\r\n                &quot;readRole&quot;: &quot;ROLE_CONFIGURATOR_READ&quot;,\r\n                &quot;writeRole&quot;: &quot;ROLE_CONFIGURATOR_WRITE&quot;\r\n              }\r\n            }\r\n          }\r\n        }\r\n      }\r\n    }\r\n\r\nUsing this command I was able to get half way there\r\n\r\n    .categories[][].resources[].roles|={&quot;readRole&quot;: .[0], &quot;writeRole&quot;: .[1]}\r\n\r\nhttps://jqplay.org/s/QPRMdXR0Os",
        "link": "https://stackoverflow.com/questions/67208669/how-to-create-object-fields-from-array-content-using-jq",
        "title": "How to create object fields from array content using JQ"
    },
    {
        "tags": [
            "node.js",
            "csv",
            "curl",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 6196394,
                    "reputation": 86601,
                    "user_id": 5291015,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/4tAvO.jpg?s=256",
                    "display_name": "Inian",
                    "link": "https://stackoverflow.com/users/5291015/inian"
                },
                "edited": false,
                "score": 3,
                "creation_date": 1619101855,
                "post_id": 67215109,
                "comment_id": 118807828,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 18107898,
                    "reputation": 39,
                    "user_id": 13165125,
                    "user_type": "registered",
                    "profile_image": "https://lh3.googleusercontent.com/a-/AOh14GhXa0e-Eekl3aUsXlPxzU7HqNDpFngSVIcAFSpM_A=k-s256",
                    "display_name": "mehdi shokati",
                    "link": "https://stackoverflow.com/users/13165125/mehdi-shokati"
                },
                "reply_to_user": {
                    "account_id": 6196394,
                    "reputation": 86601,
                    "user_id": 5291015,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/4tAvO.jpg?s=256",
                    "display_name": "Inian",
                    "link": "https://stackoverflow.com/users/5291015/inian"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1619102403,
                "post_id": 67215109,
                "comment_id": 118808103,
                "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": 1619103321,
                "post_id": 67215109,
                "comment_id": 118808618,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 18107898,
                    "reputation": 39,
                    "user_id": 13165125,
                    "user_type": "registered",
                    "profile_image": "https://lh3.googleusercontent.com/a-/AOh14GhXa0e-Eekl3aUsXlPxzU7HqNDpFngSVIcAFSpM_A=k-s256",
                    "display_name": "mehdi shokati",
                    "link": "https://stackoverflow.com/users/13165125/mehdi-shokati"
                },
                "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": 1619103629,
                "post_id": 67215109,
                "comment_id": 118808810,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1638639499,
                "last_edit_date": 1638639499,
                "creation_date": 1619104468,
                "answer_id": 67216070,
                "question_id": 67215109,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "There is no need for `to_entries`, just apply the filter directly to the arrays, e.g.:\r\n```\r\njq -r &#39;.data[] | .[0:-1] | map(tonumber) | @tsv&#39;\r\n```\r\n\r\nNote that the above removes the `&quot;BCHBTC&quot;` text field, as noted by _peak_ in the comments this can be included with the special or operator (`//`):\r\n```\r\njq -r &#39;.data[] | tonumber? // . | @tsv&#39;\r\n``` ",
                "title": "How convert JSON to TSV in bash"
            },
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1638635648,
                "creation_date": 1638635648,
                "answer_id": 70227540,
                "question_id": 67215109,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "\r\n`jq -r &#39;.data[] | @tsv` &#39; solved the problem, thanks @ \r\nInian\r\n ",
                "title": "How convert JSON to TSV in bash"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1638641315,
        "creation_date": 1619101184,
        "last_edit_date": 1638641315,
        "question_id": 67215109,
        "body_markdown": "I am trying to convert JSON file from the command below to CSV format: \r\n\r\n    curl -X GET &#39;https://api.coinex.com/v1/market/kline?market=BCHBTC&amp;type=1min&#39; -H &quot;Accept: application/json&quot;\r\n\r\nI tried jq command as following, but it was unsuccessful : \r\n\r\n    jq &#39;.data |to_entries[] | @csv&#39;\r\n\r\n \r\nOR \r\n\r\n    jq &#39;.data |to_entries[] | [.key,  (.0|tonumber),(.1|tonumber),(.2|tonumber),(.3|tonumber),(.4|tonumber),(.5|tonumber),(.6|tonumber),(.7|tonumber)   )] | @csv&#39;  \r\n\r\ndesired output is like: \r\n  \r\n\r\n                1619094720  0.01738857  0.01742868  0.01742868  0.01737360  1.24151689  0.0215974650849251  BCHBTC\r\n                1619094780  0.01742823  0.01742913  0.01742913  0.01742807  0.89060000  0.0155215977170000  BCHBTC\r\n                1619094840  0.01744941  0.01745423  0.01745423  0.01744941  0.42820000  0.0074724290140000  BCHBTC\r\n                1619094900  0.01745458  0.01740857  0.01745458  0.01740857  0.73530000  0.0128245470890000  BCHBTC",
        "link": "https://stackoverflow.com/questions/67215109/how-convert-json-to-tsv-in-bash",
        "title": "How convert JSON to TSV in bash"
    },
    {
        "tags": [
            "xml",
            "azure",
            "jq",
            "azure-api-management",
            "azure-rest-api"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1619359151,
                "creation_date": 1619359151,
                "answer_id": 67254188,
                "question_id": 67229148,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Try this:\r\n\r\n    policy=`cat &lt;path of file&gt;/test.xml`\r\n    jq -Rs    --arg contentFormat &quot;rawxml&quot;    &#39;{properties: {format: $contentFormat, value: . }}&#39; &lt;&lt;&lt;$policy\r\n\r\n**Result**:\r\n\r\n[![enter image description here][1]][1]\r\n\r\nFor a quick test, use this request body to update policy in postman directly:\r\n[![enter image description here][2]][2]\r\n\r\n\r\n  [1]: https://i.sstatic.net/FkqaE.png\r\n  [2]: https://i.sstatic.net/GEfaQ.png",
                "title": "Azure rest api - APIM policy XML errors"
            },
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1619429037,
                "creation_date": 1619429037,
                "answer_id": 67264008,
                "question_id": 67229148,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "In the meanwhile I managed to solve this, the XML&#39;s special characters had to be replaced(&quot;;&amp;;&lt;;&gt;). \r\nPreviously we did it for the whole document not just in the values.",
                "title": "Azure rest api - APIM policy XML errors"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1619429037,
        "creation_date": 1619177360,
        "question_id": 67229148,
        "body_markdown": "We ran into an issue with API managment, our client wants us to automate adding API level policies to the APIs we have configured there.  \r\nWe are trying it to resolve this with a bash script(we can&#39;t use powershell or any other tool), but we ran into a problem: the API expects Content-Type: application/json, but one of the values should be an [XML string](https://learn.microsoft.com/en-us/rest/api/apimanagement/2019-12-01/apipolicy/createorupdate#policycontentformat).  \r\n\r\n\r\nI tried multiple ways to make the request body for this, but I get errors in the response, like: `&quot;message&quot;:&quot;An error occurred while parsing EntityName. Line 6, position 74.&quot;`\r\n\r\nor `&quot;Data at the root level is invalid. Line 1, position 1.&quot;`\r\n\r\nDoes anyone have any idea how we should form our request body?   \r\nWe are doing this with jq, like this: \r\n```\r\njq -Rs \\\r\n   --arg contentFormat &quot;xml&quot; \\\r\n   &#39;{properties: {format: $contentFormat, value: . }}&#39; &lt;${policy}\r\n```\r\nWhere `policy` is path to xml document which is copied from the manually generated policy from the GUI.\r\n\r\nAny help is appreciated!\r\n\r\nI suspect the problem is with XML formatting, but we tried to encode it in various ways and it didn&#39;t help.",
        "link": "https://stackoverflow.com/questions/67229148/azure-rest-api-apim-policy-xml-errors",
        "title": "Azure rest api - APIM policy XML errors"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1619188161,
                "post_id": 67231685,
                "comment_id": 118837309,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1619315635,
                "creation_date": 1619315635,
                "answer_id": 67249053,
                "question_id": 67231685,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "With your input (once it has been corrected):\r\n\r\n```\r\njq -r &#39;to_entries[] |\r\n  [.key,\r\n   (.value | .total | &quot;\\(.confirmed)-\\(.deceased)-\\(.recovered)-\\(.tested)&quot;)]|@tsv&#39; input.json\r\nAN\t5527-65-5309-357442\r\nBN\t5527-65-5309-357442\r\n```",
                "title": "Print JSON as a table in bash"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1619315635,
        "creation_date": 1619187660,
        "question_id": 67231685,
        "body_markdown": "I have the below JSON data and I am required to print it as a table. I have managed to come up with below query using jq in BASH to print the data in TOTAL section but unable to get headers including AN,BN part(whats the technical term?) of JSON. Total is equal to sum of sub values in it.\r\n\r\n\r\nrequired format for output:\r\n\r\n      Name           Total\r\n    \r\n        -----------------------------------\r\n    \r\n        AN        xxxxxxx\r\n    \r\n        BN        xxxxxxx\r\n\r\n\r\nmy current command:  \r\n\r\n   `curl -s &#39;https://url.json&#39; | jq &#39;.[] | .total | &quot;\\(.confirmed)-\\(.deceased)-\\(.recovered)-\\(.tested)&quot;&#39;`\r\n\r\nDATA: \r\n\r\n    &gt;     {   &quot;AN&quot;: {\r\n    &gt;     &quot;delta7&quot;: {\r\n    &gt;       &quot;confirmed&quot;: 238,\r\n    &gt;       &quot;deceased&quot;: 2,\r\n    &gt;       &quot;recovered&quot;: 199,\r\n    &gt;       &quot;tested&quot;: 9953,\r\n    &gt;       &quot;vaccinated&quot;: 24243\r\n    &gt;     },\r\n    &gt;     &quot;districts&quot;: {\r\n    &gt;       &quot;Unknown&quot;: {\r\n    &gt;         &quot;delta7&quot;: {\r\n    &gt;           &quot;confirmed&quot;: 238,\r\n    &gt;           &quot;deceased&quot;: 2,\r\n    &gt;           &quot;recovered&quot;: 199,\r\n    &gt;           &quot;tested&quot;: 9953\r\n    &gt;         },\r\n    &gt;         &quot;meta&quot;: {\r\n    &gt;           &quot;tested&quot;: {\r\n    &gt;             &quot;last_updated&quot;: &quot;2021-04-21&quot;,\r\n    &gt;             &quot;source&quot;: &quot;https://dhs.andaman.gov.in/NewEvents/642.pdf&quot;\r\n    &gt;           }\r\n    &gt;         },\r\n    &gt;         &quot;total&quot;: {\r\n    &gt;           &quot;confirmed&quot;: 5527,\r\n    &gt;           &quot;deceased&quot;: 65,\r\n    &gt;           &quot;recovered&quot;: 5309,\r\n    &gt;           &quot;tested&quot;: 357442\r\n    &gt;         }\r\n    &gt;       }\r\n    &gt;     },\r\n    &gt;     &quot;meta&quot;: {\r\n    &gt;       &quot;last_updated&quot;: &quot;2021-04-23T00:10:19+05:30&quot;,\r\n    &gt;       &quot;population&quot;: 397000,\r\n    &gt;       &quot;tested&quot;: {\r\n    &gt;         &quot;last_updated&quot;: &quot;2021-04-21&quot;,\r\n    &gt;         &quot;source&quot;: &quot;https://dhs.andaman.gov.in/NewEvents/642.pdf&quot;\r\n    &gt;       }\r\n    &gt;     },\r\n    &gt;     &quot;total&quot;: {\r\n    &gt;       &quot;confirmed&quot;: 5527,\r\n    &gt;       &quot;deceased&quot;: 65,\r\n    &gt;       &quot;recovered&quot;: 5309,\r\n    &gt;       &quot;tested&quot;: 357442,\r\n    &gt;       &quot;vaccinated&quot;: 91977\r\n    &gt;     }   }, {  \r\n    \r\n     &quot;BN&quot;: {\r\n        &quot;delta7&quot;: {\r\n          &quot;confirmed&quot;: 238,\r\n          &quot;deceased&quot;: 2,\r\n          &quot;recovered&quot;: 199,\r\n          &quot;tested&quot;: 9953,\r\n          &quot;vaccinated&quot;: 24243\r\n        },\r\n        &quot;districts&quot;: {\r\n          &quot;Unknown&quot;: {\r\n            &quot;delta7&quot;: {\r\n              &quot;confirmed&quot;: 238,\r\n              &quot;deceased&quot;: 2,\r\n              &quot;recovered&quot;: 199,\r\n              &quot;tested&quot;: 9953\r\n            },\r\n            &quot;meta&quot;: {\r\n              &quot;tested&quot;: {\r\n                &quot;last_updated&quot;: &quot;2021-04-21&quot;,\r\n                &quot;source&quot;: &quot;https://dhs.andaman.gov.in/NewEvents/642.pdf&quot;\r\n              }\r\n            },\r\n            &quot;total&quot;: {\r\n              &quot;confirmed&quot;: 5527,\r\n              &quot;deceased&quot;: 65,\r\n              &quot;recovered&quot;: 5309,\r\n              &quot;tested&quot;: 357442\r\n            }\r\n          }\r\n        },\r\n        &quot;meta&quot;: {\r\n          &quot;last_updated&quot;: &quot;2021-04-23T00:10:19+05:30&quot;,\r\n          &quot;population&quot;: 397000,\r\n          &quot;tested&quot;: {\r\n            &quot;last_updated&quot;: &quot;2021-04-21&quot;,\r\n            &quot;source&quot;: &quot;https://dhs.andaman.gov.in/NewEvents/642.pdf&quot;\r\n          }\r\n        },\r\n        &quot;total&quot;: {\r\n          &quot;confirmed&quot;: 5527,\r\n          &quot;deceased&quot;: 65,\r\n          &quot;recovered&quot;: 5309,\r\n          &quot;tested&quot;: 357442,\r\n          &quot;vaccinated&quot;: 91977\r\n        }   } }",
        "link": "https://stackoverflow.com/questions/67231685/print-json-as-a-table-in-bash",
        "title": "Print JSON as a table in bash"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 16069386,
                    "reputation": 348,
                    "user_id": 11598180,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/7afb69024c68d93c9131de6670d61e5d?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "JordanKobeWade",
                    "link": "https://stackoverflow.com/users/11598180/jordankobewade"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1619191486,
                "post_id": 67232668,
                "comment_id": 118838969,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2147998,
                    "reputation": 387,
                    "user_id": 1905179,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/aa91d5def63e6e70f66545577bf1baa9?s=256&d=identicon&r=PG",
                    "display_name": "martin66",
                    "link": "https://stackoverflow.com/users/1905179/martin66"
                },
                "reply_to_user": {
                    "account_id": 16069386,
                    "reputation": 348,
                    "user_id": 11598180,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/7afb69024c68d93c9131de6670d61e5d?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "JordanKobeWade",
                    "link": "https://stackoverflow.com/users/11598180/jordankobewade"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1619191579,
                "post_id": 67232668,
                "comment_id": 118839016,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": false,
                "score": 4,
                "last_activity_date": 1619237349,
                "last_edit_date": 1619237349,
                "creation_date": 1619200810,
                "answer_id": 67234862,
                "question_id": 67232668,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I found the solution using the following command:\r\n\r\n```none\r\n[ to_entries[] | {&quot;$key&quot;: .key} * .value ]\r\n```\r\n\r\nHow this works?\r\n\r\nThe `to_entries[]` outputs\r\n\r\n    {\r\n     &quot;key&quot;: &quot;key1&quot;,\r\n      &quot;value&quot;: {\r\n        &quot;someKey&quot;: &quot;someValue&quot;\r\n      }\r\n    }\r\n    {\r\n      &quot;key&quot;: &quot;key2&quot;,\r\n      &quot;value&quot;: {\r\n        &quot;someKey&quot;: &quot;someValue&quot;\r\n      }\r\n    }\r\n\r\nThen it pipes this output using &#39;|&#39;, after piping it creates an object\r\n\r\n    {&quot;$key&quot;: .key}\r\n\r\nThen, using the `*` operator, it merges this new object with the object located at the `.value` key from each object from the `to_entries[]` output.\r\n\r\nThe outermost wrapping with `[]` just creates an array from the stream.\r\n",
                "title": "Using jq how to add the key to the existing JSON data structure"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1619237349,
        "creation_date": 1619191255,
        "question_id": 67232668,
        "body_markdown": "Hello and thanks in advance,\r\n\r\nSo I have the following JSON:\r\n\r\n    {\r\n      &quot;key1&quot; : { \r\n         &quot;someKey&quot;: &quot;someValue&quot;\r\n      },\r\n      &quot;key2&quot; : { \r\n         &quot;someKey&quot;: &quot;someValue&quot;\r\n      }\r\n    }\r\n\r\nand the output that I&#39;m looking for is:\r\n\r\n    [\r\n      { \r\n         &quot;someKey&quot;: &quot;someValue&quot;,\r\n         &quot;$key&quot; : &quot;key1&quot;\r\n      },\r\n      { \r\n         &quot;someKey&quot;: &quot;someValue&quot;,\r\n         &quot;$key&quot; : &quot;key2&quot;\r\n      }\r\n    ]\r\n\r\nSo basically I need to append the &#39;key&#39; to the value as a separate property in the value of that key&#39;s object using jq.\r\n\r\nI already figured out how to convert the values into an array, but I cannot figure out how to add the &quot;$key&quot; to the object.\r\n\r\nPlease help. Thanks.",
        "link": "https://stackoverflow.com/questions/67232668/using-jq-how-to-add-the-key-to-the-existing-json-data-structure",
        "title": "Using jq how to add the key to the existing JSON data structure"
    },
    {
        "tags": [
            "bash",
            "jq",
            "aws-cli"
        ],
        "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": 1619213700,
                "post_id": 67237070,
                "comment_id": 118846832,
                "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": 1619213724,
                "post_id": 67237070,
                "comment_id": 118846841,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 13873514,
                    "reputation": 487,
                    "user_id": 10015905,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/ca26b3e416e3105728cdb7d6e346e8c3?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "TravelingLex",
                    "link": "https://stackoverflow.com/users/10015905/travelinglex"
                },
                "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": 1619213812,
                "post_id": 67237070,
                "comment_id": 118846859,
                "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": 1619214298,
                "post_id": 67237070,
                "comment_id": 118846979,
                "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": 1619214346,
                "post_id": 67237070,
                "comment_id": 118846987,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1619214176,
                "creation_date": 1619214176,
                "answer_id": 67237157,
                "question_id": 67237070,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The problem is that `read`, by default, stops at the first newline it sees. (This can be overridden with the `-d` argument). You can work around this by running a separate `read` per variable, or running `read` with a different character used as the record delimiter.\r\n\r\nThe first approach:\r\n\r\n```bash\r\n{ read -r VPC_ID &amp;&amp; read -r VPC_CIDR &amp;&amp; read -r VPC_NAME; } &lt; &lt;(\r\n  aws ec2 describe-vpcs --filters &quot;Name=tag:Name,Values=${AWS_PROFILE}-vpc&quot; --output json \\\r\n  | jq -r &#39;.Vpcs[] | .VpcId,.CidrBlock, (.Tags[]|select(.Key==&quot;Name&quot;)|.Value)&#39;\r\n)\r\n```\r\n\r\nThe second approach, which adds a `printf &#39;\\0&#39;` when the inner command is successful, which `read -d &#39;&#39;` recognizes to mean the record is complete:\r\n\r\n```\r\nIFS=$&#39;\\n&#39; read -r -d &#39;&#39; VPC_ID VPC_CIDR VPC_NAME &lt; &lt;(\r\n  aws ec2 describe-vpcs --filters &quot;Name=tag:Name,Values=${AWS_PROFILE}-vpc&quot; --output json \\\r\n  | jq -r &#39;.Vpcs[] | .VpcId,.CidrBlock, (.Tags[]|select(.Key==&quot;Name&quot;)|.Value)&#39; \\\r\n  &amp;&amp; printf &#39;\\0&#39;\r\n)",
                "title": "Reading several variables from a single command&#39;s multi-line output"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1705451232,
                "creation_date": 1705451232,
                "answer_id": 77829389,
                "question_id": 67237070,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "With modern bash and the AWS CLI v2 you can simplify this and you don&#39;t need jq.\r\n```\r\nread -r VPC_ID VPC_CIDR VPC_NAME&lt; &lt;(aws ec2 describe-vpcs \\\r\n  --filters &quot;Name=tag:Name,Values=${AWS_PROFILE}-vpc&quot;  \\\r\n  --query &quot;Vpcs[*].[VpcId,CidrBlock,Tags[?Key == &#39;Name&#39;]|[0].Value]&quot; \\\r\n  --output text)\r\n```",
                "title": "Reading several variables from a single command&#39;s multi-line output"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1705451232,
        "creation_date": 1619213549,
        "last_edit_date": 1619214044,
        "question_id": 67237070,
        "body_markdown": "I&#39;m running into an issue with the read command. I&#39;m trying to get read to run through the output of my awscli command to extract VPC_ID, VPC_CIDR and VPC_NAME. Unfortunately its no longer working since upgrading to bash 5.0.\r\n\r\nHere is the following code: \r\n```read VPC_ID VPC_CIDR VPC_NAME &lt;&lt;&lt;$(aws ec2 describe-vpcs --filters &quot;Name=tag:Name,Values=${AWS_PROFILE}-vpc&quot; --output json | jq -r &#39;.Vpcs[] | .VpcId,.CidrBlock, (.Tags[]|select(.Key==&quot;Name&quot;)|.Value)&#39;)```\r\n\r\nWhen I run ```aws ec2 describe-vpcs --filters &quot;Name=tag:Name,Values=${AWS_PROFILE}-vpc&quot; --output json | jq -r &#39;.Vpcs[] | .VpcId,.CidrBlock, (.Tags[]|select(.Key==&quot;Name&quot;)|.Value)&#39;``` \r\n\r\nI get my expected output but when I attached the read command in front of it, I&#39;m only able to assign the first variable none of the other ones...",
        "link": "https://stackoverflow.com/questions/67237070/reading-several-variables-from-a-single-commands-multi-line-output",
        "title": "Reading several variables from a single command&#39;s multi-line output"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq",
            "cat"
        ],
        "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": 1,
                "creation_date": 1619214783,
                "post_id": 67237200,
                "comment_id": 118847087,
                "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": 1619215063,
                "post_id": 67237200,
                "comment_id": 118847152,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 4974926,
                    "reputation": 4903,
                    "user_id": 12888470,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/4d9fc180b11cb506d668a5f11b73dc24?s=256&d=identicon&r=PG",
                    "display_name": "Guillermo Brachetta",
                    "link": "https://stackoverflow.com/users/12888470/guillermo-brachetta"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1619215103,
                "post_id": 67237200,
                "comment_id": 118847163,
                "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": 1619215229,
                "post_id": 67237200,
                "comment_id": 118847192,
                "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": 1619215374,
                "post_id": 67237200,
                "comment_id": 118847224,
                "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": 1619215467,
                "post_id": 67237200,
                "comment_id": 118847250,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 4974926,
                    "reputation": 4903,
                    "user_id": 12888470,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/4d9fc180b11cb506d668a5f11b73dc24?s=256&d=identicon&r=PG",
                    "display_name": "Guillermo Brachetta",
                    "link": "https://stackoverflow.com/users/12888470/guillermo-brachetta"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1619215696,
                "post_id": 67237200,
                "comment_id": 118847306,
                "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": 1619215719,
                "post_id": 67237200,
                "comment_id": 118847312,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 4974926,
                    "reputation": 4903,
                    "user_id": 12888470,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/4d9fc180b11cb506d668a5f11b73dc24?s=256&d=identicon&r=PG",
                    "display_name": "Guillermo Brachetta",
                    "link": "https://stackoverflow.com/users/12888470/guillermo-brachetta"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1619215848,
                "post_id": 67237200,
                "comment_id": 118847348,
                "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": 1619216027,
                "post_id": 67237200,
                "comment_id": 118847397,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 4974926,
                    "reputation": 4903,
                    "user_id": 12888470,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/4d9fc180b11cb506d668a5f11b73dc24?s=256&d=identicon&r=PG",
                    "display_name": "Guillermo Brachetta",
                    "link": "https://stackoverflow.com/users/12888470/guillermo-brachetta"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1619216101,
                "post_id": 67237200,
                "comment_id": 118847419,
                "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": 1619216122,
                "post_id": 67237200,
                "comment_id": 118847423,
                "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": 1619216191,
                "post_id": 67237200,
                "comment_id": 118847436,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 4974926,
                    "reputation": 4903,
                    "user_id": 12888470,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/4d9fc180b11cb506d668a5f11b73dc24?s=256&d=identicon&r=PG",
                    "display_name": "Guillermo Brachetta",
                    "link": "https://stackoverflow.com/users/12888470/guillermo-brachetta"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1619216223,
                "post_id": 67237200,
                "comment_id": 118847445,
                "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": 1619216473,
                "post_id": 67237200,
                "comment_id": 118847496,
                "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": 1619216528,
                "post_id": 67237200,
                "comment_id": 118847509,
                "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": 1619217027,
                "post_id": 67237200,
                "comment_id": 118847629,
                "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": 1619217072,
                "post_id": 67237200,
                "comment_id": 118847641,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 4974926,
                    "reputation": 4903,
                    "user_id": 12888470,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/4d9fc180b11cb506d668a5f11b73dc24?s=256&d=identicon&r=PG",
                    "display_name": "Guillermo Brachetta",
                    "link": "https://stackoverflow.com/users/12888470/guillermo-brachetta"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1619217328,
                "post_id": 67237200,
                "comment_id": 118847691,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1662146469,
                "creation_date": 1662146469,
                "answer_id": 73587117,
                "question_id": 67237200,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Simply use `jq` directly, without `cat` and without any indirections:\r\n\r\n```\r\njq &#39;.eslintConfig.extends=&quot;@gbrachetta/eslint-config&quot; | . + {prettier: &quot;@gbrachetta/prettier-config&quot;}&#39; package.json &gt; package.json.tmp\r\nmv package.json.tmp package.json\r\n```\r\n\r\n[GNU `sponge`](https://linux.die.net/man/1/sponge) can help to simplify the script/avoid the second command.",
                "title": "JSON file modified with cat and jq ouputs differently when ran from function script"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1662146469,
        "creation_date": 1619214570,
        "last_edit_date": 1619216086,
        "question_id": 67237200,
        "body_markdown": "I created a bash script that, amongst other things, modifies a json file with `jq`.\r\n\r\nThe line doing that is:\r\n\r\n    cat &lt;&lt;&lt; $(jq &#39;.eslintConfig.extends=&quot;@gbrachetta/eslint-config&quot; | .+ {prettier: &quot;@gbrachetta/prettier-config&quot;}&#39; package.json) &gt; package.json\r\n\r\nThis works great, and running this bash script (MacOS) produces a perfectly formatted json file:\r\n\r\n    {\r\n      &quot;name&quot;: &quot;test&quot;,\r\n      &quot;version&quot;: &quot;0.1.0&quot;,\r\n      &quot;private&quot;: true,\r\n      &quot;scripts&quot;: {\r\n        &quot;dev&quot;: &quot;next dev&quot;,\r\n        &quot;build&quot;: &quot;next build&quot;,\r\n        &quot;start&quot;: &quot;next start&quot;\r\n      },\r\n      &quot;dependencies&quot;: {\r\n        &quot;next&quot;: &quot;10.1.3&quot;,\r\n        &quot;prop-types&quot;: &quot;^15.7.2&quot;,\r\n        &quot;react&quot;: &quot;17.0.2&quot;,\r\n        &quot;react-dom&quot;: &quot;17.0.2&quot;\r\n      },\r\n      &quot;devDependencies&quot;: {\r\n        &quot;@gbrachetta/eslint-config&quot;: &quot;1.3.0&quot;,\r\n        &quot;eslint&quot;: &quot;^7.24.0&quot;,\r\n        &quot;eslint-config-airbnb&quot;: &quot;^18.2.1&quot;,\r\n        &quot;eslint-config-prettier&quot;: &quot;^8.2.0&quot;,\r\n        &quot;eslint-plugin-import&quot;: &quot;^2.22.1&quot;,\r\n        &quot;eslint-plugin-jsx-a11y&quot;: &quot;^6.4.1&quot;,\r\n        &quot;eslint-plugin-prettier&quot;: &quot;^3.4.0&quot;,\r\n        &quot;eslint-plugin-react&quot;: &quot;^7.23.2&quot;,\r\n        &quot;eslint-plugin-react-hooks&quot;: &quot;^4.2.0&quot;,\r\n        &quot;prettier&quot;: &quot;^2.2.1&quot;\r\n      },\r\n      &quot;eslintConfig&quot;: {\r\n        &quot;extends&quot;: &quot;@gbrachetta/eslint-config&quot;\r\n      },\r\n      &quot;prettier&quot;: &quot;@gbrachetta/prettier-config&quot;\r\n    }\r\n\r\nI wanted to improve my script and created a bash script **with functions**.\r\n\r\nThe result is great, and the `cat` command modifies the json file as expected, but the resulting file isn&#39;t formatted and it&#39;s outputted in a single line. \r\n\r\nThis is what I get with my **functional** script:\r\n\r\n    { &quot;name&quot;: &quot;test&quot;, &quot;version&quot;: &quot;0.1.0&quot;, &quot;private&quot;: true, &quot;scripts&quot;: { &quot;dev&quot;: &quot;next dev&quot;, &quot;build&quot;: &quot;next build&quot;, &quot;start&quot;: &quot;next start&quot; }, &quot;dependencies&quot;: { &quot;next&quot;: &quot;10.1.3&quot;, &quot;prop-types&quot;: &quot;^15.7.2&quot;, &quot;react&quot;: &quot;17.0.2&quot;, &quot;react-dom&quot;: &quot;17.0.2&quot; }, &quot;devDependencies&quot;: { &quot;@gbrachetta/eslint-config&quot;: &quot;1.3.0&quot;, &quot;eslint&quot;: &quot;^7.24.0&quot;, &quot;eslint-config-airbnb&quot;: &quot;^18.2.1&quot;, &quot;eslint-config-prettier&quot;: &quot;^8.2.0&quot;, &quot;eslint-plugin-import&quot;: &quot;^2.22.1&quot;, &quot;eslint-plugin-jsx-a11y&quot;: &quot;^6.4.1&quot;, &quot;eslint-plugin-prettier&quot;: &quot;^3.4.0&quot;, &quot;eslint-plugin-react&quot;: &quot;^7.23.2&quot;, &quot;eslint-plugin-react-hooks&quot;: &quot;^4.2.0&quot;, &quot;prettier&quot;: &quot;^2.2.1&quot; }, &quot;eslintConfig&quot;: { &quot;extends&quot;: &quot;@gbrachetta/eslint-config&quot; }, &quot;prettier&quot;: &quot;@gbrachetta/prettier-config&quot; }\r\n\r\nThe `cat` line is identical in both scripts, and the resulting json (except for the formatting) is the same in both cases, but I don&#39;t understand why running the cat command from a function outputs the file in one line.\r\n\r\nI&#39;m really curious to know what I could be doing wrong!\r\n\r\n",
        "link": "https://stackoverflow.com/questions/67237200/json-file-modified-with-cat-and-jq-ouputs-differently-when-ran-from-function-scr",
        "title": "JSON file modified with cat and jq ouputs differently when ran from function script"
    },
    {
        "tags": [
            "arrays",
            "json",
            "nested",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 20472675,
                    "reputation": 19,
                    "user_id": 15022684,
                    "user_type": "registered",
                    "profile_image": "https://lh3.googleusercontent.com/a-/AOh14GiBwUEGGg_gSinXePRfT2hXScMUTRFDZ5YLd_bzKA=k-s256",
                    "display_name": "Ben Thompson",
                    "link": "https://stackoverflow.com/users/15022684/ben-thompson"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1619244835,
                "post_id": 67239806,
                "comment_id": 118851420,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1619249697,
                "creation_date": 1619249697,
                "answer_id": 67240386,
                "question_id": 67239806,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The direct, efficient, and robust approach:\r\n\r\n    .searchResult |= map(to_entries[])",
                "title": "Using jq convert named keys to key value pairs"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1619249697,
        "creation_date": 1619244493,
        "question_id": 67239806,
        "body_markdown": "I have json like this:\r\n\r\n    {&quot;searchResult&quot;:[{&quot;mac&quot;:&quot;xx:xx:xx:xx:xx:xx&quot;},{&quot;time&quot;:&quot;2021_04_11 23:45:01&quot;},{&quot;field_1&quot;:&quot;87&quot;}]}\r\n    {&quot;searchResult&quot;:[{&quot;mac&quot;:&quot;xx:xx:xx:xx:xx:xx&quot;},{&quot;time&quot;:&quot;2021_04_11 01:10:29&quot;},{&quot;field_2&quot;:&quot;Some text&quot;},{&quot;field_3&quot;:&quot;8&quot;}]}\r\n    {&quot;searchResult&quot;:[{&quot;mac&quot;:&quot;xx:xx:xx:xx:xx:xx&quot;},{&quot;time&quot;:&quot;2021_04_11 03:49:14&quot;},{&quot;field_1&quot;:&quot;92&quot;},{&quot;field_3&quot;:&quot;25&quot;}]}\r\n\r\nSome fields are always present. Others are optional, there are 1000s of possible fields, and new ones can be added at any point. To import into the db (BigQuery), I would like them formatted like:\r\n\r\n    {&quot;searchResult&quot;:[{&quot;key&quot;:&quot;mac&quot;,&quot;value&quot;:&quot;xx:xx:xx:xx:xx:xx&quot;},{&quot;key&quot;:&quot;time&quot;,&quot;value&quot;:&quot;2021_04_11 23:45:01&quot;},{&quot;key&quot;:&quot;field_1&quot;,&quot;value&quot;:&quot;87&quot;}]}\r\n    {&quot;searchResult&quot;:[{&quot;key&quot;:&quot;mac&quot;,&quot;value&quot;:&quot;xx:xx:xx:xx:xx:xx&quot;},{&quot;key&quot;:&quot;time&quot;,&quot;value&quot;:&quot;2021_04_11 01:10:29&quot;},{&quot;key&quot;:&quot;field_2&quot;,&quot;value&quot;:&quot;Some text&quot;},{&quot;key&quot;:&quot;field_3&quot;,&quot;value&quot;:&quot;8&quot;}]}\r\n    {&quot;searchResult&quot;:[{&quot;key&quot;:&quot;mac&quot;,&quot;value&quot;:&quot;xx:xx:xx:xx:xx:xx&quot;},{&quot;key&quot;:&quot;time&quot;,&quot;value&quot;:&quot;2021_04_11 03:49:14&quot;},{&quot;key&quot;:&quot;field_1&quot;,&quot;value&quot;:&quot;92&quot;},{&quot;key&quot;:&quot;field_3&quot;,&quot;value&quot;:&quot;25&quot;}]}\r\n\r\nSo far I have:\r\n\r\n    jq -c &#39;.searchResult[] |= to_entries&#39;\r\n\r\nWhich gives:\r\n\r\n    {&quot;searchResult&quot;:[[{&quot;key&quot;:&quot;mac&quot;,&quot;value&quot;:&quot;xx:xx:xx:xx:xx:xx&quot;}],[{&quot;key&quot;:&quot;time&quot;,&quot;value&quot;:&quot;2021_04_11 23:45:01&quot;}],[{&quot;key&quot;:&quot;field_1&quot;,&quot;value&quot;:&quot;87&quot;}]]}\r\n    {&quot;searchResult&quot;:[[{&quot;key&quot;:&quot;mac&quot;,&quot;value&quot;:&quot;xx:xx:xx:xx:xx:xx&quot;}],[{&quot;key&quot;:&quot;time&quot;,&quot;value&quot;:&quot;2021_04_11 01:10:29&quot;}],[{&quot;key&quot;:&quot;field_2&quot;,&quot;value&quot;:&quot;Some text&quot;}],[{&quot;key&quot;:&quot;field_3&quot;,&quot;value&quot;:&quot;8&quot;}]]}\r\n    {&quot;searchResult&quot;:[[{&quot;key&quot;:&quot;mac&quot;,&quot;value&quot;:&quot;xx:xx:xx:xx:xx:xx&quot;}],[{&quot;key&quot;:&quot;time&quot;,&quot;value&quot;:&quot;2021_04_11 03:49:14&quot;}],[{&quot;key&quot;:&quot;field_1&quot;,&quot;value&quot;:&quot;92&quot;}],[{&quot;key&quot;:&quot;field_3&quot;,&quot;value&quot;:&quot;25&quot;}]]}\r\n\r\nWe can&#39;t have the unnecessary arrays around each key/value object, we can&#39;t import nested arrays in BigQuery, and here they are redundant.\r\n\r\nI can fix this with sed, but for my own understanding, I would like this all in done in jq.\r\n\r\nMany thanks\r\n\r\nBen",
        "link": "https://stackoverflow.com/questions/67239806/using-jq-convert-named-keys-to-key-value-pairs",
        "title": "Using jq convert named keys to key value pairs"
    },
    {
        "tags": [
            "node.js",
            "json",
            "bash",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1619452250,
                "last_edit_date": 1619452250,
                "creation_date": 1619297046,
                "answer_id": 67247251,
                "question_id": 67246269,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The problem involves selection rather than &quot;grep&quot;, and here is a solution accordingly:\r\n```\r\n.data[0]\r\n| [paths(scalars) | select( all(.[]; type==&quot;string&quot;)) ] as $paths\r\n| ($paths |  map([&quot;data&quot;] + . | join(&quot;__&quot;))),\r\n  [ getpath($paths[]) ]\r\n| @tsv\r\n```\r\n\r\nThe last-but-one line can perhaps be more easily understood if unwrapped as:\r\n\r\n    [ $paths[] as $p | getpath($p) ]\r\n\r\n## .price\r\n\r\nIf you just want the &quot;price&quot;, you could consider a query along the lines of:\r\n```\r\n.. | objects | select(has(&quot;price&quot;)).price\r\n```\r\nor\r\n```\r\n.. | select(has(&quot;quote&quot;)?) \r\n| .. | select(has(&quot;price&quot;)?).price\r\n```",
                "title": "grep JSON data values in CSV format"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1619452250,
        "creation_date": 1619289695,
        "last_edit_date": 1619290770,
        "question_id": 67246269,
        "body_markdown": "I am trying to get JSON data by `curl` and convert it to CSV with the `jq` command.\n \r\nCode: \r\n\r\n    #!/bin/bash\r\n     \r\n        #Remove previously generated output files \r\n        rm datacsv.csv  output.json \r\n       #Get crypto pairs data from the server (curl) in JSON from the COINAMRKET.COM server, save output.json \r\n                  curl -H &quot;X-CMC_PRO_API_KEY: 45f65521-ad1b-4dbb-9c33-743ba7a63e68&quot; -H &quot;Accept: application/json&quot; -d &quot;start=1&amp;limit=2&amp;convert=USD&quot; -G https://pro-api.coinmarketcap.com/v1/cryptocurrency/listings/latest&gt;output.json \r\n                                 \r\n         #Convert JSON to CSV, Outputfile: datacsv.csv                               \r\n          jq -r &#39;.data[0]  | @csv&#39;  output.json  &gt;datacsv.csv \r\n\r\nThe following is the sample structure of the JSON data: \r\n\r\n    {&quot;status&quot;:{&quot;timestamp&quot;:&quot;2021-04-24T15:51:59.165Z&quot;,&quot;error_code&quot;:0,&quot;error_message&quot;:null,&quot;elapsed&quot;:12,&quot;credit_count&quot;:1,&quot;notice&quot;:null,&quot;total_count&quot;:4824},&quot;data&quot;:[{&quot;id&quot;:1,&quot;name&quot;:&quot;Bitcoin&quot;,&quot;symbol&quot;:&quot;BTC&quot;,&quot;slug&quot;:&quot;bitcoin&quot;,&quot;num_market_pairs&quot;:9553,&quot;date_added&quot;:&quot;2013-04-28T00:00:00.000Z&quot;,&quot;tags&quot;:[&quot;mineable&quot;,&quot;pow&quot;,&quot;sha-256&quot;,&quot;store-of-value&quot;,&quot;state-channels&quot;,&quot;coinbase-ventures-portfolio&quot;,&quot;three-arrows-capital-portfolio&quot;,&quot;polychain-capital-portfolio&quot;,&quot;binance-labs-portfolio&quot;,&quot;arrington-xrp-capital&quot;,&quot;blockchain-capital-portfolio&quot;,&quot;boostvc-portfolio&quot;,&quot;cms-holdings-portfolio&quot;,&quot;dcg-portfolio&quot;,&quot;dragonfly-capital-portfolio&quot;,&quot;electric-capital-portfolio&quot;,&quot;fabric-ventures-portfolio&quot;,&quot;framework-ventures&quot;,&quot;galaxy-digital-portfolio&quot;,&quot;huobi-capital&quot;,&quot;alameda-research-portfolio&quot;,&quot;a16z-portfolio&quot;,&quot;1confirmation-portfolio&quot;,&quot;winklevoss-capital&quot;,&quot;usv-portfolio&quot;,&quot;placeholder-ventures-portfolio&quot;,&quot;pantera-capital-portfolio&quot;,&quot;multicoin-capital-portfolio&quot;,&quot;paradigm-xzy-screener&quot;],&quot;max_supply&quot;:21000000,&quot;circulating_supply&quot;:18690125,&quot;total_supply&quot;:18690125,&quot;platform&quot;:null,&quot;cmc_rank&quot;:1,&quot;last_updated&quot;:&quot;2021-04-24T15:51:02.000Z&quot;,&quot;quote&quot;:{&quot;USD&quot;:{&quot;price&quot;:50199.80286231888,&quot;volume_24h&quot;:54839569429.87117,&quot;percent_change_1h&quot;:1.35143147,&quot;percent_change_24h&quot;:1.22964148,&quot;percent_change_7d&quot;:-17.56716272,&quot;percent_change_30d&quot;:-2.51591082,&quot;percent_change_60d&quot;:7.55313111,&quot;percent_change_90d&quot;:56.29697475,&quot;market_cap&quot;:938240590472.0977,&quot;last_updated&quot;:&quot;2021-04-24T15:51:02.000Z&quot;}}}]}\r\n\r\nI want  to grep the value of the items in data (`id`,`name`,`symbol`,`slug`, `num_market_pairs`, etc.) ignoring: “`tags`”.\r\n\r\n Desired output format:\r\n\r\n        data__id\tdata__name\tdata__symbol\tdata__slug\tdata__num_market_pairs\tdata__date_added\tdata__max_supply\tdata__circulating_supply\tdata__total_supply\tdata__platform\tdata__cmc_rank\tdata__last_updated\tdata__quote__USD__price\tdata__quote__USD__volume_24h\tdata__quote__USD__percent_change_1h\tdata__quote__USD__percent_change_24h\tdata__quote__USD__percent_change_7d\tdata__quote__USD__percent_change_30d\tdata__quote__USD__percent_change_60d\tdata__quote__USD__percent_change_90d\tdata__quote__USD__market_cap\tdata__quote__USD__last_updated\r\n    1\tBitcoin\tBTC\tbitcoin\t9553\t2013-04-28T00:00:00.000Z\t21000000\t18690125\t18690125\tnull\t1\t2021-04-24T15:51:02.000Z\t50199.8028623189\t54839569429.8712\t1.35143147\t1.22964148\t-17.56716272\t-2.51591082\t7.55313111\t56.29697475\t938240590472.098\t2021-04-24T15:51:02.000Z\r\n\r\nTried to grep the values of `.price` for example: \r\n\r\n    jq &#39;.data|to_entries[] |[.key, (.price| (.price|tonumber))] | @csv&#39; output.json &gt;csv1.csv\r\nError: \r\n\r\n    jq: error (at output.json:0): null (null) cannot be parsed as a number\r\n\r\nTried:\r\n\r\n    jq -r &#39;.[]|@csv &#39; &#160;output.json &gt;csv1.csv\r\n\r\nError: \r\n\r\n    jq: error (at output.json:0): object ({&quot;timestamp...) cannot be csv-formatted, only array\r\nAlso tried:\r\n[Stackoverflow Related Topic][1]\r\n\r\n\r\n  [1]: https://stackoverflow.com/questions/57242240/jq-object-cannot-be-csv-formatted-only-array",
        "link": "https://stackoverflow.com/questions/67246269/grep-json-data-values-in-csv-format",
        "title": "grep JSON data values in CSV format"
    },
    {
        "tags": [
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 8306545,
                    "reputation": 58596,
                    "user_id": 6243352,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/193965abcb7230d85c6264e55e2f0bda?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "ggorlen",
                    "link": "https://stackoverflow.com/users/6243352/ggorlen"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1633028821,
                "post_id": 67250481,
                "comment_id": 122659984,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 10,
                "is_accepted": true,
                "score": 10,
                "last_activity_date": 1633028744,
                "last_edit_date": 1633028744,
                "creation_date": 1619334907,
                "answer_id": 67250722,
                "question_id": 67250481,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I forgot the closing parenthesis:\r\n\r\n    aws ecs list-services --cluster splat-dev --profile mfa |\r\n      jq -r &#39;.serviceArns[] | select(contains(&quot;edp-api-dev&quot;))&#39;\r\n    #                                                       ^\r\n",
                "title": "How to filter using jq array of strings which contains a specific value"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 4,
        "last_activity_date": 1741187012,
        "creation_date": 1619332803,
        "last_edit_date": 1741187012,
        "question_id": 67250481,
        "body_markdown": "How do I filter using jq which contains string &quot;edp-api-dev&quot;\r\n\r\n&lt;!-- language: json --&gt;\r\n    {\r\n        &quot;serviceArns&quot;: [\r\n            &quot;arn:aws:ecs:us-east-1:1234:service/splat-dev/abc-api-dev-ecs-abc-api-man-1920299&quot;,\r\n            &quot;arn:aws:ecs:us-east-1:1234:service/edp-api-dev-ecs-edp-api-man-721g8a7d&quot;,\r\n            &quot;arn:aws:ecs:us-east-1:1234:service/tsm-frontend-dev-ecs-tsm-frontend-man&quot;,\r\n            &quot;arn:aws:ecs:us-east-1:1234:service/doc-svc-dev-ecs-doc-svc-man&quot;,\r\n    \t\t&quot;arn:aws:ecs:us-east-1:1234:service/wwk-frontend-dev-ecs-wwk-frontend-man-8fea6a0b&quot;,\r\n            &quot;arn:aws:ecs:us-east-1:1234:service/xyaz-fsse-ecs-xyaz-fsse-man&quot;\r\n        ]\r\n    }\r\n\r\nI tried \r\n\r\n&lt;!-- language: shell --&gt;\r\n    aws ecs list-services --cluster splat-dev --profile mfa | jq -r &#39;.serviceArns[] | select( . | contains(&quot;edp-api-dev&quot;)&#39;\r\n\r\nbut get syntax error",
        "link": "https://stackoverflow.com/questions/67250481/how-to-filter-using-jq-array-of-strings-which-contains-a-specific-value",
        "title": "How to filter using jq array of strings which contains a specific value"
    },
    {
        "tags": [
            "json",
            "bash",
            "redis",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1619899948,
                "last_edit_date": 1619899948,
                "creation_date": 1619461004,
                "answer_id": 67271819,
                "question_id": 67263181,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "A simple way for just pretty-printing would be the following:\r\n```\r\ncat file | jq --raw-input --raw-output &#39;. as $raw | try fromjson catch $raw&#39;\r\n```\r\n\r\nIt tries to parse each line as json with `fromjson`, and just outputs the original line (with `$raw`) if it can&#39;t.\r\n\r\n(The `--raw-input` is there so that we can invoke `fromjson` enclosed in a `try` instead of running it on every line directly, and `--raw-output` is there so that any non-json lines are not enclosed in quotes in the output.)\r\n\r\n---\r\nA solution for the second part of your questions using only jq:\r\n```\r\ncat file \\\r\n    | jq --raw-input --null-input &#39;[inputs] | _nwise(2) | {(.[0]): .[1] | fromjson}&#39; \\\r\n    | jq --null-input &#39;[inputs] | add&#39;\r\n```\r\n* `--null-input` combined with `[inputs]` produces the whole input as an array\r\n* which `_nwise(2)` then chunks into groups of two ([more info on `_nwise`](https://stackoverflow.com/a/51413629/5768147))\r\n* which `{(.[0]): .[1] | fromjson}` then transforms into a list of jsons\r\n* which `| jq --null-input &#39;[inputs] | add&#39;` then combines into a single json\r\n\r\nOr in a single jq invocation:\r\n```\r\ncat file | jq --raw-input --null-input \\\r\n    &#39;[ [inputs] | _nwise(2) | {(.[0]): .[1] | fromjson} ] | add&#39;\r\n```\r\n\r\n\r\n...but by that point you might be better off writing an easier to understand python script.",
                "title": "Pretty-print valid JSONs mixed with string keys"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1619899948,
        "creation_date": 1619425359,
        "last_edit_date": 1619436693,
        "question_id": 67263181,
        "body_markdown": "I have a Redis hash with keys and values like string key -- serialized JSON value. \r\nCorresponding rediscli query (hgetall some_redis_hash) being dumped in a file:\r\n\r\n    redis_key1\r\n    {&quot;value1__key1&quot;: &quot;value1__value1&quot;, &quot;value1__key2&quot;: &quot;value1__value2&quot; ...}\r\n    redis_key2\r\n    {&quot;value2__key1&quot;: &quot;value2__value1&quot;, &quot;value2__key2&quot;: &quot;value2__value2&quot; ...}\r\n    ...\r\n    and so on.\r\n\r\nSo the question is, how do I pretty-print these values enclosed in brackets? (note that key strings between are making the document invalid, if you&#39;ll try to parse the entire one)\r\nThe first thought is to get particular pairs from Redis, strip parasite keys, and use jq on the remaining valid JSON, as shown below:\r\n\r\n    rediscli hget some_redis_hash redis_key1 &gt; file &amp;&amp; tail -n +2 file\r\n    - file now contains valid JSON as value, the first string representing Redis key is stripped by tail -\r\n    cat file | jq\r\n    - produces pretty-printed value -\r\n\r\nSo the question is, how to pretty-print without such preprocessing?\r\nOr (would be better in this particular case) how to merge keys and values in one big JSON, where Redis keys, accessible on the upper level, will be followed by dicts of their values? \r\nLike that:\r\n\r\n    rediscli hgetall some_redis_hash &gt; file\r\n    cat file | cool_parser\r\n    - prints { &quot;redis_key1&quot;: {&quot;value1__key1&quot;: &quot;value1__value1&quot;, ...}, &quot;redis_key2&quot;: ... }\r\n\r\n\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/67263181/pretty-print-valid-jsons-mixed-with-string-keys",
        "title": "Pretty-print valid JSONs mixed with string keys"
    },
    {
        "tags": [
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 6196394,
                    "reputation": 86601,
                    "user_id": 5291015,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/4tAvO.jpg?s=256",
                    "display_name": "Inian",
                    "link": "https://stackoverflow.com/users/5291015/inian"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1619431160,
                "post_id": 67264339,
                "comment_id": 118894271,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1619432129,
                "last_edit_date": 1619432129,
                "creation_date": 1619430926,
                "answer_id": 67264475,
                "question_id": 67264339,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Those single quotes are already present in your input string:\r\n```bash\r\nTEST=&quot;&#39;bfc&#39;, &#39;punch&#39;, &#39;mld&#39;, &#39;extended_mld&#39;, &#39;chargingstation&#39;, &#39;ch&#39;&quot;\r\n```\r\n\r\nI would recommend removing those, and creating a simple csv witch JQ can [split][1] for us\r\n```bash\r\nTEST=&quot;bfc,punch,mld,extended_mld,chargingstation,ch&quot;\r\n```\r\n\r\nTo create an array from that string, use;\r\n```\r\ncompile: $c | split(&quot;,&quot;)\r\n```\r\n\r\nSo the complete code:\r\n```bash\r\n#!/bin/bash\r\nTEST=&quot;bfc,punch,mld,extended_mld,chargingstation,ch&quot;\r\nBFC_TAG=$BUILD_ID\r\nUPLOAD_TO=s3\r\nCOMPILE=$test\r\nREGION=world\r\nPROJECT=bfc\r\nJSON_STRING=$( jq -n \\\r\n--arg a &quot;$BFC_TAG&quot; \\\r\n--arg b &quot;$UPLOAD_TO&quot; \\\r\n--arg c &quot;$TEST&quot; \\\r\n--arg d &quot;$REGION&quot; \\\r\n--arg f &quot;$PROJECT&quot; &#39;\r\n{brfc_tag: $a,\r\nupload_to: $b,\r\ncompile: $c | split(&quot;,&quot;),\r\nregion: $d,\r\nproject: $f\r\n}&#39;)\r\necho ${JSON_STRING}\r\n```\r\n\r\nWill produce:\r\n```json\r\n{ &quot;brfc_tag&quot;: &quot;&quot;, &quot;upload_to&quot;: &quot;s3&quot;, &quot;compile&quot;: [ &quot;bfc&quot;, &quot;punch&quot;, &quot;mld&quot;, &quot;extended_mld&quot;, &quot;chargingstation&quot;, &quot;ch&quot; ], &quot;region&quot;: &quot;world&quot;, &quot;project&quot;: &quot;bfc&quot; }\r\n```\r\n\r\n\r\n  [1]: https://stedolan.github.io/jq/manual/#example60",
                "title": "Getting rid of Double quotes within a value using JQ"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1619432129,
        "creation_date": 1619430402,
        "question_id": 67264339,
        "body_markdown": "I am trying to create a `--data-raw` with the help of `jq` , it works fine for the most part, except where i have a list .\r\n\r\n\r\n    #!/bin/bash\r\n    TEST=&quot;&#39;bfc&#39;, &#39;punch&#39;, &#39;mld&#39;, &#39;extended_mld&#39;, &#39;chargingstation&#39;, &#39;ch&#39;&quot;\r\n    BFC_TAG=$BUILD_ID\r\n    UPLOAD_TO=s3\r\n    COMPILE=$test\r\n    REGION=world\r\n    PROJECT=bfc\r\n    JSON_STRING=$( jq -n \\\r\n    --arg a &quot;$BFC_TAG&quot; \\\r\n    --arg b &quot;$UPLOAD_TO&quot; \\\r\n    --arg c &quot;$TEST&quot; \\\r\n    --arg d &quot;$REGION&quot; \\\r\n    --arg f &quot;$PROJECT&quot; &#39;\r\n    {brfc_tag: $a,\r\n    upload_to: $b,\r\n    compile: [ $c ],\r\n    region: $d,\r\n    project: $f\r\n    }&#39;)\r\n    echo ${JSON_STRING}\r\n\r\n\r\nOutput:\r\n\r\n    { &quot;bfc_tag&quot;: &quot;&quot;, &quot;upload_to&quot;: &quot;s3&quot;, &quot;compile&quot;: [ &quot;&#39;bfc&#39;, &#39;punch&#39;, &#39;mld&#39;, &#39;extended_mld&#39;, &#39;chargingstation&#39;, &#39;ch&#39;&quot; ], &quot;region&quot;: &quot;world&quot;, &quot;project&quot;: &quot;bfc&quot; }\r\n\r\nIf u look at the output particularly in `compile` key it has &quot; in beginning and in the end, which break breaks python code, which consumes this, i need to get rid of the double quotes within compile, any help aprreaciated.",
        "link": "https://stackoverflow.com/questions/67264339/getting-rid-of-double-quotes-within-a-value-using-jq",
        "title": "Getting rid of Double quotes within a value using JQ"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1619455600,
                "creation_date": 1619455600,
                "answer_id": 67270646,
                "question_id": 67269732,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "```sh\r\njq -nR &#39;([inputs | select(length &gt; 0)]) |\r\n{&quot;symbols&quot;:., &quot;symbols_count&quot;:(. | length)}&#39; values.txt\r\n```\r\n\r\nThe `jq` program with comments:\r\n\r\n`values2json` (`chmod +x values2json`)\r\n```jq\r\n#!/usr/bin/env -S jq -fnR\r\n\r\n(\r\n  # Select non-empty input lines as an array\r\n  [ inputs | select( length &gt; 0 ) ]\r\n) |\r\n# Build the object\r\n{\r\n  # with the array created above\r\n  &quot;symbols&quot;: .,\r\n  # and the length of the array\r\n  &quot;symbols_count&quot;: (. | length)\r\n}\r\n```\r\n\r\nUsage:\r\n```sh\r\n./values2json values.txt\r\n```\r\n\r\nOutput from sample data:\r\n```json\r\n{\r\n  &quot;symbols&quot;: [\r\n    &quot;VALUE1&quot;,\r\n    &quot;VALUE2&quot;,\r\n    &quot;VALUE3&quot;\r\n  ],\r\n  &quot;symbols_count&quot;: 3\r\n}\r\n```",
                "title": "Add text file as an array to json field using jq"
            },
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1619455723,
                "creation_date": 1619455723,
                "answer_id": 67270664,
                "question_id": 67269732,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "1) jq expects its input to be either valid JSON or raw text, so it would probably be simplest if you could ensure your &quot;JSON file&quot; is valid JSON.  See the jq FAQ for further details if that is an issue.\r\n\r\n2) One way to handle values.txt is to use the `--rawfile` command-line option:\r\n\r\n```\r\n&lt; input.json jq --rawfile text values.txt &#39;\r\n  .symbols = [$text|splits(&quot;\\n&quot;)|select(length&gt;0)]\r\n  | .symbols_count = (.symbols|length)&#39;\r\n```\r\n",
                "title": "Add text file as an array to json field using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1619583394,
        "creation_date": 1619451859,
        "last_edit_date": 1619583394,
        "question_id": 67269732,
        "body_markdown": "I have a JSON file and a text file as shown below :\r\n\r\n```json\r\n{\r\n    symbols: null,\r\n    symbols_count : null\r\n}\r\n```\r\n\r\nvalues.txt\r\n```\r\nVALUE1\r\nVALUE2\r\nVALUE3\r\n```\r\n\r\nUsing jq, I want to add values of values.txt as an array to the symbols field of the json.\r\n\r\n```shell\r\nsymbols_count=$(wc -l &lt; values.txt)\r\n\r\njq &quot;.symbol_count = $symbols_count&quot; &lt; input.json | \\\r\njq --slurpfile symbols values.txt &#39;.symbols_count=$symbols&#39;\r\n```\r\n\r\nThe last jq command fails because the values in values.txt are not enclosed by &quot;&quot; .\r\n\r\nIs there any way to add double quotes without changing values.txt?",
        "link": "https://stackoverflow.com/questions/67269732/add-text-file-as-an-array-to-json-field-using-jq",
        "title": "Add text file as an array to json field using jq"
    },
    {
        "tags": [
            "json",
            "bash",
            "csv",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1619470852,
                "creation_date": 1619470852,
                "answer_id": 67273755,
                "question_id": 67272032,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "To emit the headers just once, you would use the template: `HEADERS, TABLE`:\r\n```\r\ndef relevantPaths:\r\n   &quot;id,name,symbol,slug,num_market_pairs,date_added,max_supply,circulating_supply,total_supply&quot;\r\n  | split(&quot;,&quot;)\r\n  | map([.]) ;\r\n\r\nrelevantPaths as $paths\r\n| ([[&quot;data&quot;] + $paths[]] | map(join(&quot;__&quot;))),\r\n  (.data[] | [ getpath($paths[]) ])\r\n| @tsv\r\n```",
                "title": "Edit json to csv output files"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1619470852,
        "creation_date": 1619462079,
        "last_edit_date": 1619463243,
        "question_id": 67272032,
        "body_markdown": "I am trying to get `JSON` data by ‘curl’ and convert it to ‘`csv`’ with the ‘`jq`’ command.\r\n \r\nCode: \r\n\r\n    #!/bin/bash\r\n     \r\n        #Remove previously generated output files \r\n        rm datacsv.csv  output.json \r\n       #Get crypto pairs data from the server (curl) in JSON from the COINAMRKET.COM server, save output.json \r\n                  curl -H &quot;X-CMC_PRO_API_KEY: 45f65521-ad1b-4dbb-9c33-743ba7a63e68&quot; -H &quot;Accept: application/json&quot; -d &quot;start=1&amp;limit=50&amp;convert=USD&quot; -G https://pro-api.coinmarketcap.com/v1/cryptocurrency/listings/latest&gt;output.json \r\n                                 \r\n         #Convert JSON to CSV, Outputfile: datacsv.csv                               \r\n          jq -r &#39;.data[]| [paths(scalars) | select( all(.[]; type==&quot;string&quot;)) ] as $paths| ($paths |  map([&quot;data&quot;] + . | join(&quot;__&quot;))),[ getpath($paths[]) ]|@tsv&#39;  output.json  &gt;datacsv.csv \r\n\r\nOutput `csv` file (`datacsv.csv`) has repeated header  for each record:\r\n\r\n    data__id\tdata__name\tdata__symbol\tdata__slug\tdata__num_market_pairs\tdata__date_added\tdata__max_supply\tdata__circulating_supply\tdata__total_supply\tdata__cmc_rank\tdata__last_updated\tdata__quote__USD__price\tdata__quote__USD__volume_24h\tdata__quote__USD__percent_change_1h\tdata__quote__USD__percent_change_24h\tdata__quote__USD__percent_change_7d\tdata__quote__USD__percent_change_30d\tdata__quote__USD__percent_change_60d\tdata__quote__USD__percent_change_90d\tdata__quote__USD__market_cap\tdata__quote__USD__last_updated\t\t\t\t\t\r\n    1\tBitcoin\tBTC\tbitcoin\t9547\t2013-04-28T00:00:00.000Z\t21000000\t18691931\t18691931\t1\t2021-04-26T16:21:02.000Z\t53285.1129054482\t59530205038.6485\t-0.6500853\t5.53203621\t-3.31916623\t-3.33187743\t4.07075949\t69.03589533\t996001653755.848\t2021-04-26T16:21:02.000Z\t\t\t\t\t\r\n    data__id\tdata__name\tdata__symbol\tdata__slug\tdata__num_market_pairs\tdata__date_added\tdata__circulating_supply\tdata__total_supply\tdata__cmc_rank\tdata__last_updated\tdata__quote__USD__price\tdata__quote__USD__volume_24h\tdata__quote__USD__percent_change_1h\tdata__quote__USD__percent_change_24h\tdata__quote__USD__percent_change_7d\tdata__quote__USD__percent_change_30d\tdata__quote__USD__percent_change_60d\tdata__quote__USD__percent_change_90d\tdata__quote__USD__market_cap\tdata__quote__USD__last_updated\t\t\t\t\t\t\r\n    1027\tEthereum\tETH\tethereum\t6312\t2015-08-07T00:00:00.000Z\t115629413.749\t115629413.749\t2\t2021-04-26T16:21:02.000Z\t2482.06593555852\t36892666790.3224\t-0.23795873\t5.43647682\t16.16445289\t46.51867774\t51.11877441\t94.25117671\t286999829014.995\t2021-04-26T16:21:02.000Z\t\t\t\t\t\t\r\n    1839\tBinance Coin\tBNB\tbinance-coin\t579\t2017-07-25T00:00:00.000Z\t170532785\t153432897\t169432897\t3\t2021-04-26T16:20:10.000Z\t533.23090641431\t4373867739.9739\t0.03999376\t3.29006408\t8.84917842\t103.69391599\t108.02152044\t1217.45571414\t81815162741.0835\t2021-04-26T16:20:10.000Z\t\t\t\t\t\r\n    52\tXRP\tXRP\txrp\t664\t2013-08-04T00:00:00.000Z\t100000000000\t45404028640\t99990831162\t4\t2021-04-26T16:21:03.000Z\t1.24569103514058\t13547433610.3615\t0.9120132\t9.79015802\t-4.60461388\t125.54110459\t162.86485803\t372.19710035\t56559391436.1141\t2021-04-26T16:21:03.000Z\t\t\t\t\t\r\n    data__id\tdata__name\tdata__symbol\tdata__slug\tdata__num_market_pairs\tdata__date_added\tdata__circulating_supply\tdata__total_supply\tdata__platform__id\tdata__platform__name\tdata__platform__symbol\tdata__platform__slug\tdata__platform__token_address\tdata__cmc_rank\tdata__last_updated\tdata__quote__USD__price\tdata__quote__USD__volume_24h\tdata__quote__USD__percent_change_1h\tdata__quote__USD__percent_change_24h\tdata__quote__USD__percent_change_7d\tdata__quote__USD__percent_change_30d\tdata__quote__USD__percent_change_60d\tdata__quote__USD__percent_change_90d\tdata__quote__USD__market_cap\tdata__quote__USD__last_updated\t\r\n    825\tTether\tUSDT\ttether\t12325\t2015-02-25T00:00:00.000Z\t50006254438.5217\t51866290994.3298\t1027\tEthereum\tETH\tethereum\t0xdac17f958d2ee523a2206206994597c13d831ec7\t5\t2021-04-26T16:20:10.000Z\t0.99997577777133\t117822325986.94\t-0.01985404\t0.00891016\t0.00656415\t-0.1262222\t-0.05070907\t-0.14745816\t50005043175.5917\t2021-04-26T16:20:10.000Z\t\r\n    2010\tCardano\tADA\tcardano\t259\t2017-10-01T00:00:00.000Z\t45000000000\t31948309440.7478\t45000000000\t6\t2021-04-26T16:20:10.000Z\t1.2163725547586\t3494400505.85215\t-0.63516459\t6.44253956\t1.77358151\t2.5727442\t8.69333792\t266.42366354\t38861046774.6607\t2021-04-26T16:20:10.000Z\t\t\t\t\t\r\n    74\tDogecoin\tDOGE\tdogecoin\t331\t2013-12-15T00:00:00.000Z\t129348760639.944\t129348760639.944\t7\t2021-04-26T16:21:03.000Z\t0.26639640673017\t6963087140.98019\t-0.74842096\t-1.96582346\t-25.83236676\t387.41281461\t386.8290754\t3173.67302946\t34458045049.482\t2021-04-26T16:21:03.000Z\t\t\t\t\t\t\r\n    6636\tPolkadot\tDOT\tpolkadot-new\t186\t2020-08-19T00:00:00.000Z\t932996847.726976\t1068520962.58116\t8\t2021-04-26T16:21:06.000Z\t32.3141434419601\t2146407823.73721\t-0.76428061\t3.64699209\t-7.2706416\t0.41872077\t-5.75544689\t96.74696139\t30148993968.3461\t2021-04-26T16:21:06.000Z\t\t\t\t\t\t\r\n    data__id\tdata__name\tdata__symbol\tdata__slug\tdata__num_market_pairs\tdata__date_added\tdata__max_supply\tdata__circulating_supply\tdata__total_supply\tdata__platform__id\tdata__platform__name\tdata__platform__symbol\tdata__platform__slug\tdata__platform__token_address\tdata__cmc_rank\tdata__last_updated\tdata__quote__USD__price\tdata__quote__USD__volume_24h\tdata__quote__USD__percent_change_1h\tdata__quote__USD__percent_change_24h\tdata__quote__USD__percent_change_7d\tdata__quote__USD__percent_change_30d\tdata__quote__USD__percent_change_60d\tdata__quote__USD__percent_change_90d\tdata__quote__USD__market_cap\tdata__quote__USD__last_updated\r\n    7083\tUniswap\tUNI\tuniswap\t235\t2020-09-17T00:00:00.000Z\t1000000000\t523384243.630469\t1000000000\t1027\tEthereum\tETH\tethereum\t0x1f9840a85d5af5bf1d1762f925bdaddc4201f984\t9\t2021-04-26T16:20:10.000Z\t35.2645393307245\t1159198004.59251\t-0.72129315\t3.06863351\t17.86724054\t24.69707747\t36.43669393\t187.42707789\t18456904244.5882\t2021-04-26T16:20:10.000Z\r\n    2\tLitecoin\tLTC\tlitecoin\t741\t2013-04-28T00:00:00.000Z\t84000000\t66752414.5153875\t66752414.5153875\t10\t2021-04-26T16:21:02.000Z\t241.772049644181\t4873850130.55793\t0.08569225\t3.079198\t-6.01020181\t32.7958836\t20.24742388\t84.55115332\t16138868076.0832\t2021-04-26T16:21:02.000Z\t\t\t\t\t\r\n    1831\tBitcoin Cash\tBCH\tbitcoin-cash\t586\t2017-07-23T00:00:00.000Z\t21000000\t18719506.25\t18719506.25\t11\t2021-04-26T16:20:08.000Z\t825.995177012163\t4098896768.46408\t-0.62457646\t3.13607248\t-8.10372907\t65.63228051\t51.71459366\t96.05126285\t15462221878.549\t2021-04-26T16:20:08.000Z\t\t\t\t\t\r\n    1975\tChainlink\tLINK\tchainlink\t495\t2017-09-20T00:00:00.000Z\t1000000000\t419009556.434445\t1000000000\t1027\tEthereum\tETH\tethereum\t0x514910771af9ca656af840dff83e8264ecf986ca\t12\t2021-04-26T16:20:10.000Z\t34.4665578984855\t1711065668.01118\t0.39416876\t3.37393637\t-5.31781365\t29.84576669\t22.2383717\t55.53806504\t14441817136.8665\t2021-04-26T16:20:10.000Z\r\n    5426\tSolana\tSOL\tsolana\t41\t2020-04-10T00:00:00.000Z\t269856622.936333\t493886983.051495\t13\t2021-04-26T16:21:05.000Z\t46.722213592056\t1743822879.60336\t-1.09733007\t3.84673072\t46.93695628\t195.9965083\t184.71221177\t1146.97970713\t12608298776.0623\t2021-04-26T16:21:05.000Z\t\r\n\r\nI want to filter output ‘csv’ file, get interested  fields (`data__id`,`data__name`,`data__symbol`,`data__slug`,`data__num_market_pairs`,`data__date_added`,`data__max_supply`,`data__circulating_supply`,`data__total_supply` )and exclude rest. \r\n\r\nDesired output:\r\n\r\n    data__id\tdata__name\tdata__symbol\tdata__slug\tdata__num_market_pairs\tdata__date_added\tdata__max_supply\tdata__circulating_supply\tdata__total_supply\r\n    1\tBitcoin\tBTC\tbitcoin\t9547\t2013-04-28T00:00:00.000Z\t21000000\t18691931\t18691931\r\n    1027\tEthereum\tETH\tethereum\t6312\t2015-08-07T00:00:00.000Z\t115629413.749\t115629413.749\t2\r\n    1839\tBinance Coin\tBNB\tbinance-coin\t579\t2017-07-25T00:00:00.000Z\t170532785\t153432897\t169432897\r\n    52\tXRP\tXRP\txrp\t664\t2013-08-04T00:00:00.000Z\t100000000000\t45404028640\t99990831162\r\n    825\tTether\tUSDT\ttether\t12325\t2015-02-25T00:00:00.000Z\t50006254438.5217\t51866290994.3298\t1027\r\n    2010\tCardano\tADA\tcardano\t259\t2017-10-01T00:00:00.000Z\t45000000000\t31948309440.7478\t45000000000\r\n    74\tDogecoin\tDOGE\tdogecoin\t331\t2013-12-15T00:00:00.000Z\t129348760639.944\t129348760639.944\t7\r\n    6636\tPolkadot\tDOT\tpolkadot-new\t186\t2020-08-19T00:00:00.000Z\t932996847.726976\t1068520962.58116\t8\r\n    7083\tUniswap\tUNI\tuniswap\t235\t2020-09-17T00:00:00.000Z\t1000000000\t523384243.630469\t1000000000\r\n    2\tLitecoin\tLTC\tlitecoin\t741\t2013-04-28T00:00:00.000Z\t84000000\t66752414.5153875\t66752414.5153875\r\n    1831\tBitcoin Cash\tBCH\tbitcoin-cash\t586\t2017-07-23T00:00:00.000Z\t21000000\t18719506.25\t18719506.25\r\n    1975\tChainlink\tLINK\tchainlink\t495\t2017-09-20T00:00:00.000Z\t1000000000\t419009556.434445\t1000000000\r\n    5426\tSolana\tSOL\tsolana\t41\t2020-04-10T00:00:00.000Z\t269856622.936333\t493886983.051495\t13\r\n\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/67272032/edit-json-to-csv-output-files",
        "title": "Edit json to csv output files"
    },
    {
        "tags": [
            "json",
            "linux",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1619547682,
                "creation_date": 1619547682,
                "answer_id": 67288629,
                "question_id": 67287642,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The key is `with_entries`.  One possibility would be to use `reduce`:\r\n```\r\n[ {name, online},\r\n  (.test_list\r\n   | . as $in\r\n   | reduce range(0; length) as $i ({}; . + ($in[$i] | with_entries(.key = &quot;\\(.key)\\($i)&quot;)))\r\n   )\r\n]\r\n```\r\n\r\nPlease note that your example output is not quite correct as JSON, and that with your example input, the above jq program produces slightly different results, but if you want to remove certain key-value pairs, you can easily do that, e.g. as a preliminary step in the pipeline. ",
                "title": "jq - how to format pairs of keys and values, then iterate keys in json"
            },
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1619561996,
                "last_edit_date": 1619561996,
                "creation_date": 1619556280,
                "answer_id": 67290437,
                "question_id": 67287642,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s a reduce-free approach: it uses `with_entries` on an array to do the counting:\r\n```\r\n[ {name, online},\r\n  (.test_list\r\n   | with_entries(.key |= tostring\r\n         | .key as $k\r\n\t\t | .value |= with_entries(.key += $k))\r\n   | add\r\n  )\r\n]\r\n```\r\n",
                "title": "jq - how to format pairs of keys and values, then iterate keys in json"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1619561996,
        "creation_date": 1619543313,
        "question_id": 67287642,
        "body_markdown": "Please help me, guys.\r\nI have the following:\r\n```\r\n{\r\n  &quot;id&quot;: 88888,\r\n  &quot;name&quot;: &quot;TESTING&quot;,\r\n  &quot;online&quot;: 1,\r\n  &quot;test_list&quot;: [\r\n    {\r\n      &quot;id&quot;: 0,\r\n      &quot;type&quot;: 34,\r\n      &quot;name&quot;: &quot;Blabla&quot;,\r\n      &quot;used&quot;: 9870,\r\n      &quot;rate&quot;: 31768897891,\r\n      &quot;temp&quot;: 0,\r\n      &quot;percent&quot;: 100,\r\n      &quot;enabled&quot;: 0,\r\n      &quot;reset&quot;: 0,\r\n      &quot;temp&quot;: 2\r\n    },\r\n    {\r\n      &quot;id&quot;: 1,\r\n      &quot;type&quot;: 23,\r\n      &quot;name&quot;: &quot;AlbAlb&quot;,\r\n      &quot;used&quot;: 0865,\r\n      &quot;rate&quot;: 317681675432345678951,\r\n      &quot;temp&quot;: 1,\r\n      &quot;percent&quot;: 99,\r\n      &quot;enabled&quot;: 0,\r\n      &quot;reset&quot;: 0,\r\n      &quot;target&quot;: 2\r\n    },\r\n    {\r\n      &quot;id&quot;: 2,\r\n      &quot;type&quot;: 98,\r\n      &quot;name&quot;: &quot;TztS&quot;,\r\n      &quot;used&quot;: 65,\r\n      &quot;rate&quot;: 6324,\r\n      &quot;temp&quot;: 0,\r\n      &quot;percent&quot;: 80,\r\n      &quot;enabled&quot;: 0,\r\n      &quot;reset&quot;: 0,\r\n      &quot;target&quot;: 2\r\n    }\r\n  ],\r\n  &quot;info&quot;: {\r\n    &quot;version&quot;: &quot;1.0&quot;,\r\n    &quot;no&quot;: &quot;123&quot;,\r\n    &quot;sw&quot;: &quot;321&quot;,\r\n    &quot;version_detail&quot;: {\r\n      &quot;date&quot;: &quot;2021-03-30&quot;,\r\n      &quot;build&quot;: &quot;11&quot;,\r\n      &quot;cot&quot;: &quot;dfgdfgd&quot;\r\n    }\r\n  }\r\n}\r\n```\r\nAnd i need to do the following:\r\n```\r\n[\r\n  {\r\n    &quot;name&quot;: &quot;TESTING&quot;,\r\n    &quot;online&quot;: 1\r\n  },\r\n  {\r\n    &quot;id0&quot;: 0,\r\n    &quot;type0&quot;: 34,\r\n    &quot;name0&quot;: &quot;Blabla&quot;,\r\n    &quot;rate0&quot;: 31768897891,\r\n    &quot;temp0&quot;: 0,\r\n    &quot;percent0&quot;: 100\r\n    &quot;id1&quot;: 1,\r\n    &quot;type1&quot;: 23,\r\n    &quot;name1&quot;: &quot;AlbAlb&quot;,\r\n    &quot;rate1&quot;: 317681675432345670000,\r\n    &quot;temp1&quot;: 1,\r\n    &quot;percent1&quot;: 99\r\n    &quot;id2&quot;: 2,\r\n    &quot;type2&quot;: 98,\r\n    &quot;name2&quot;: &quot;TztS&quot;,\r\n    &quot;rate2&quot;: 6324,\r\n    &quot;temp2&quot;: 0,\r\n    &quot;percent2&quot;: 80\r\n  }\r\n]\r\n```\r\nI want to join the information, what I need into blocks and then set the key numbering by id or iterate.\r\nWill it be possible to somehow realised it using jq and man in one line?\r\n\r\nAfter a long time, I managed to do only the following:\r\n\r\n`jq &#39;[. | {name,online}] + [.test_list[] | {id,type,name,rate,temp,percent} | with_entries(.key |= . + &quot;0&quot;)]&#39;`\r\n\r\nI tried using map tool, but it doesn&#39;t work = (( Help Please...",
        "link": "https://stackoverflow.com/questions/67287642/jq-how-to-format-pairs-of-keys-and-values-then-iterate-keys-in-json",
        "title": "jq - how to format pairs of keys and values, then iterate keys in json"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 2578132,
                    "reputation": 1921,
                    "user_id": 2235381,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/0061f9bd5384a544637692774a6e108f?s=256&d=identicon&r=PG",
                    "display_name": "lojza",
                    "link": "https://stackoverflow.com/users/2235381/lojza"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1619554629,
                "post_id": 67289078,
                "comment_id": 118939697,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1619555484,
                "creation_date": 1619555484,
                "answer_id": 67290259,
                "question_id": 67289078,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Replace `.to` with `[.to]`\r\n\r\n    jq --slurp &#39;{&quot;personalizations&quot;: [.[].root | .to = [.to]]}&#39;",
                "title": "Convert Single JSON Object within JSON document to an Array with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1619555484,
        "creation_date": 1619549675,
        "last_edit_date": 1619554844,
        "question_id": 67289078,
        "body_markdown": "Tryin to use jq to make a slight transformation in a JSON document I am working with.\r\n\r\nI am using this as sample input JSON:\r\n\r\n&lt;!-- begin snippet: js hide: false console: true babel: false --&gt;\r\n\r\n&lt;!-- language: lang-js --&gt;\r\n\r\n    {&quot;root&quot; : {&quot;to&quot; : {&quot;email&quot; : &quot;some-email1@gmail.com&quot;}, &quot;dynamic_template_data&quot; : {&quot;FIRSTNAME&quot; : &quot;BLANCA&quot;, &quot;last_4&quot; : &quot;9999&quot;, &quot;OFFERCODE&quot; : &quot;88888888888888888&quot;}}}\r\n    {&quot;root&quot; : {&quot;to&quot; : {&quot;email&quot; : &quot;some-other-email1@gmail.com&quot;}, &quot;dynamic_template_data&quot; : {&quot;FIRSTNAME&quot; : &quot;Michael&quot;, &quot;last_4&quot; : &quot;8888&quot;, &quot;OFFERCODE&quot; : &quot;9999999999999999999999&quot;}}}\r\n\r\n&lt;!-- end snippet --&gt;\r\n\r\nAt the moment, I am using this jq filter to try to transform the JSON (also specifying slurp option):\r\n\r\n&gt; jq --slurp &#39;{&quot;template_id&quot;:&quot;d-34d9948687504d1f91fa9ddb738e94c0&quot;,&quot;asm&quot;:{&quot;group_id&quot;:14817},&quot;categories&quot;:[&quot;PROD&quot;,&quot;ICAP&quot;],&quot;personalizations&quot;: [.[].root],&quot;from&quot; : {&quot;email&quot; : &quot;offers@bankoftheworld.com&quot;, &quot;name&quot; : &quot;Bank of the World&quot;}, &quot;reply_to&quot; : {&quot;email&quot; : &quot;noreply@bankofthworld.com&quot;, &quot;name&quot; : &quot;Bank of the World&quot;}}&#39;\r\n\r\n...which returns close to what I need below with the &quot;to&quot; element to be an array containing the email address:\r\n\r\n&lt;!-- begin snippet: js hide: false console: true babel: false --&gt;\r\n\r\n&lt;!-- language: lang-js --&gt;\r\n\r\n    {\r\n      &quot;template_id&quot;: &quot;d-34d9948687504d1f91fa9ddb738e94c0&quot;,\r\n      &quot;asm&quot;: {\r\n        &quot;group_id&quot;: 14817\r\n      },\r\n      &quot;categories&quot;: [\r\n        &quot;PROD&quot;,\r\n        &quot;ICAP&quot;\r\n      ],\r\n      &quot;personalizations&quot;: [\r\n        {\r\n          &quot;to&quot;: {\r\n            &quot;email&quot;: &quot;some-email1@gmail.com&quot;\r\n          },\r\n          &quot;dynamic_template_data&quot;: {\r\n            &quot;FIRSTNAME&quot;: &quot;BLANCA&quot;,\r\n            &quot;last_4&quot;: &quot;9999&quot;,\r\n            &quot;OFFERCODE&quot;: &quot;88888888888888888&quot;\r\n          }\r\n        },\r\n        {\r\n          &quot;to&quot;: {\r\n            &quot;email&quot;: &quot;some-other-email1@gmail.com&quot;\r\n          },\r\n          &quot;dynamic_template_data&quot;: {\r\n            &quot;FIRSTNAME&quot;: &quot;Michael&quot;,\r\n            &quot;last_4&quot;: &quot;8888&quot;,\r\n            &quot;OFFERCODE&quot;: &quot;9999999999999999999999&quot;\r\n          }\r\n        }\r\n      ],\r\n      &quot;from&quot;: {\r\n        &quot;email&quot;: &quot;offers@bankoftheworld.com&quot;,\r\n        &quot;name&quot;: &quot;Bank of the World&quot;\r\n      },\r\n      &quot;reply_to&quot;: {\r\n        &quot;email&quot;: &quot;noreply@bankofthworld.com&quot;,\r\n        &quot;name&quot;: &quot;Bank of the World&quot;\r\n      }\r\n    }\r\n\r\n&lt;!-- end snippet --&gt;\r\n\r\n...but the email address is not returning in an array as I need.\r\n\r\nDesired output:\r\n\r\n&lt;!-- begin snippet: js hide: false console: true babel: false --&gt;\r\n\r\n&lt;!-- language: lang-js --&gt;\r\n\r\n    {\r\n    &quot;template_id&quot;: &quot;d-34d9948687504d1f91fa9ddb738e94c0&quot;,\r\n    &quot;asm&quot;: {&quot;group_id&quot;: 14817},\r\n    &quot;categories&quot;: [\r\n        &quot;PROD&quot;,\r\n        &quot;ICAP&quot;\r\n    ],\r\n    &quot;personalizations&quot;: [\r\n        {\r\n            &quot;to&quot;: [\r\n                {&quot;email&quot;: &quot;some-email1@gmail.com&quot;}\r\n            ],\r\n            &quot;dynamic_template_data&quot;: {\r\n                &quot;FIRSTNAME&quot;: &quot;BLANCA&quot;,\r\n                &quot;last_4&quot;: &quot;9999&quot;,\r\n                &quot;OFFERCODE&quot;: &quot;88888888888888888&quot;\r\n            }\r\n        },\r\n        {\r\n            &quot;to&quot;: [\r\n                {&quot;email&quot;: &quot;some-other-email1@gmail.com&quot;}\r\n            ],\r\n            &quot;dynamic_template_data&quot;: {\r\n                &quot;FIRSTNAME&quot;: &quot;Michael&quot;,\r\n                &quot;last_4&quot;: &quot;8888&quot;,\r\n                &quot;OFFERCODE&quot;: &quot;9999999999999999999999&quot;\r\n            }\r\n        }\r\n    ],\r\n    &quot;from&quot;: {\r\n        &quot;email&quot;: &quot;offers@bankoftheworld.com&quot;,\r\n        &quot;name&quot;: &quot;Bank of the World&quot;\r\n    },\r\n    &quot;reply_to&quot;: {\r\n        &quot;email&quot;: &quot;noreply@bankofthworld.com&quot;,\r\n        &quot;name&quot;: &quot;Bank of the World&quot;\r\n    }\r\n}\r\n\r\n\r\n&lt;!-- end snippet --&gt;\r\n\r\n",
        "link": "https://stackoverflow.com/questions/67289078/convert-single-json-object-within-json-document-to-an-array-with-jq",
        "title": "Convert Single JSON Object within JSON document to an Array with jq"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1619557064,
                "creation_date": 1619557064,
                "answer_id": 67290584,
                "question_id": 67289391,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Only `cassandra`\r\n\r\n    jq -r &#39;{a:.Member.Name, b:.DebugConfig.Services[]} | select(.b.Name==&quot;cassandra&quot;) | {a:.a, b:.b.Name, c:.b.Checks[].CheckID} | [.a, .b, .c] | join(&quot;/&quot;)&#39;\r\n    staging-data-0/cassandra/cassandra-client-port\r\n    staging-data-0/cassandra/cassandra-gossip-port\r\n\r\nBoth\r\n\r\n    jq -r &#39;{a:.Member.Name, b:.DebugConfig.Services[]} | {a:.a, b:.b.Name, c:.b.Checks[].CheckID} | [.a, .b, .c] | join(&quot;/&quot;)&#39;\r\n    staging-data-0/cassandra/cassandra-client-port\r\n    staging-data-0/cassandra/cassandra-gossip-port\r\n    staging-data-0/cockroachdb/cockroachdb-tcp",
                "title": "JQ - Join nested arrays and filter"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1619592977,
                "last_edit_date": 1619592977,
                "creation_date": 1619557158,
                "answer_id": 67290602,
                "question_id": 67289391,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "With your input, the jq filter:\r\n```\r\n.DebugConfig.Services[] as $s\r\n| &quot;/\\(.Member.Name)/\\($s.Name)/\\($s.Checks[].CheckID)&quot;\r\n```\r\nproduces:\r\n```\r\n&quot;/staging-data-0/cassandra/cassandra-client-port&quot;\r\n&quot;/staging-data-0/cassandra/cassandra-gossip-port&quot;\r\n&quot;/staging-data-0/cockroachdb/cockroachdb-tcp&quot;\r\n```\r\n\r\nSince you only want the &quot;cassandra&quot; strings, you just need to interject a &quot;select&quot; filter:\r\n\r\n```\r\n.DebugConfig.Services[] as $s\r\n| &quot;/\\(.Member.Name)/\\($s.Name)/&quot; +\r\n    ($s\r\n     | select(.Name == &quot;cassandra&quot;)\r\n     | .Checks[].CheckID)\r\n```\r\n\r\nbut it&#39;s worth noting how easy it is to process all the &quot;Checks&quot; items.\r\n",
                "title": "JQ - Join nested arrays and filter"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1619593037,
        "creation_date": 1619551113,
        "last_edit_date": 1619593037,
        "question_id": 67289391,
        "body_markdown": "I&#39;m trying to use JQ to create the following paths:\r\n```\r\n/staging-data-0/cassandra/cassandra-client-port\r\n/staging-data-0/cassandra/cassandra-gossip-port\r\n```\r\nfrom the following blob of JSON (I&#39;ve stripped unnecessary bits out):\r\n\r\n```\r\n{\r\n  &quot;DebugConfig&quot;: {\r\n    &quot;ServerPort&quot;: 8300,\r\n    &quot;Services&quot;: [\r\n      {\r\n        &quot;Checks&quot;: [\r\n          {\r\n            &quot;CheckID&quot;: &quot;cassandra-client-port&quot;,\r\n            &quot;Timeout&quot;: &quot;1s&quot;\r\n          },\r\n          {\r\n            &quot;CheckID&quot;: &quot;cassandra-gossip-port&quot;,\r\n            &quot;Timeout&quot;: &quot;1s&quot;\r\n          }\r\n        ],\r\n        &quot;Name&quot;: &quot;cassandra&quot;\r\n      },\r\n      {\r\n        &quot;Checks&quot;: [\r\n          {\r\n            &quot;CheckID&quot;: &quot;cockroachdb-tcp&quot;,\r\n            &quot;Timeout&quot;: &quot;1s&quot;\r\n          }\r\n        ],\r\n        &quot;Name&quot;: &quot;cockroachdb&quot;\r\n      }\r\n    ]\r\n  },\r\n  &quot;Member&quot;: {\r\n    &quot;Name&quot;: &quot;staging-data-0&quot;\r\n  },\r\n  &quot;Meta&quot;: {\r\n      &quot;consul-network-segment&quot;: &quot;&quot;\r\n  }\r\n}\r\n```\r\n\r\nI&#39;m struggling with the JQ manual to generate the paths, I can only pull out the last part so far with \r\n```\r\njq &#39;.DebugConfig.Services | map(select(.Name==&quot;cassandra&quot;)) | map(.Checks[].CheckID)&#39;\r\n```\r\nThe final path should be `/{.Member.Name}/{.DebugConfig.Services.Name}/{.DebugConfig.Services.Checks.CheckID}`",
        "link": "https://stackoverflow.com/questions/67289391/jq-join-nested-arrays-and-filter",
        "title": "JQ - Join nested arrays and filter"
    },
    {
        "tags": [
            "json",
            "object",
            "merge",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1619591056,
                "creation_date": 1619591056,
                "answer_id": 67294769,
                "question_id": 67294619,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Since you want to modify and output the first file, let&#39;s use `--slurpfile` to read the second file into a variable `$other`. Then we can merge the second file in place with `*=`, which both merges and assigns:\r\n\r\n```\r\n$ jq --slurpfile other jsonFile2.json &#39;.ENV.DEV *= $other[].ENV.DEV&#39; jsonFile1.json\r\n{\r\n  &quot;ENV&quot;: {\r\n    &quot;DEV&quot;: {\r\n      &quot;middleware&quot;: [],\r\n      &quot;system&quot;: [],\r\n      &quot;application&quot;: [\r\n        {\r\n          &quot;artefact&quot;: &quot;abc&quot;,\r\n          &quot;domain&quot;: &quot;df&quot;,\r\n          &quot;hostname&quot;: &quot;sfa&quot;\r\n        },\r\n        {\r\n          &quot;artefact&quot;: &quot;awe&quot;,\r\n          &quot;domain&quot;: &quot;csd&quot;,\r\n          &quot;hostname&quot;: &quot;wer&quot;\r\n        }\r\n      ],\r\n      &quot;utility&quot;: []\r\n    },\r\n    &quot;ST&quot;: {\r\n      &quot;middleware&quot;: [],\r\n      &quot;system&quot;: [],\r\n      &quot;application&quot;: [],\r\n      &quot;utility&quot;: []\r\n    },\r\n    &quot;ESIT&quot;: {\r\n      &quot;middleware&quot;: [],\r\n      &quot;system&quot;: [],\r\n      &quot;application&quot;: [],\r\n      &quot;utility&quot;: []\r\n    }\r\n  }\r\n}\r\n```\r\n\r\nYou can use `*=` to merge or `=` to overwrite.",
                "title": "Merge two JSON objects with jq"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1619761591,
                "last_edit_date": 1619761591,
                "creation_date": 1619592759,
                "answer_id": 67295158,
                "question_id": 67294619,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "It looks as though you simply want to set .ENV.DEV in the first file to .ENV.DEV in the second.  If so, then assuming the contents of the second file is somehow in the jq variable $f2, all you need is an assignment statement:\r\n\r\n    .ENV.DEV = $f2.ENV.DEV\r\n\r\nSo, if you don&#39;t mind using --argfile, you could write:\r\n\r\n    jq --argfile f2 jsonFile2.json &#39;.ENV.DEV=$f2.ENV.DEV&#39; jsonFile1.json\r\n\r\nThis at least gives the expected result (modulo some technical issues in the given sample).\r\n\r\nSince --argfile is technically deprecated, you might wish to use `--slurpfile` instead, and I could imagine you might want to use `+=`, but unless you really know what using `*` or `*=` implies, I&#39;d avoid them.",
                "title": "Merge two JSON objects with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 3,
        "last_activity_date": 1619761662,
        "creation_date": 1619590241,
        "last_edit_date": 1619761662,
        "question_id": 67294619,
        "body_markdown": "I have the following two json files and I am trying to merge the DEV object. \r\n\r\njsonFile1:\r\n```\r\n{\r\n  &quot;ENV&quot;: {\r\n    &quot;DEV&quot;: {},\r\n    &quot;ST&quot;: {\r\n      &quot;middleware&quot;: [],\r\n      &quot;system&quot;: [],\r\n      &quot;application&quot;: [],\r\n      &quot;utility&quot;: []\r\n    },\r\n    &quot;ESIT&quot;: {\r\n      &quot;middleware&quot;: [],\r\n      &quot;system&quot;: [],\r\n      &quot;application&quot;: [],\r\n      &quot;utility&quot;: []\r\n    }\r\n  }\r\n}\r\n\r\n```\r\njsonFile2:\r\n```\r\n{\r\n  &quot;ENV&quot;: {\r\n    &quot;DEV&quot;: {\r\n      &quot;middleware&quot;: [],\r\n      &quot;system&quot;: [],\r\n      &quot;application&quot;: [\r\n         {\r\n          &quot;artefact&quot;: &quot;abc&quot;,\r\n          &quot;domain&quot;: &quot;df&quot;,\r\n          &quot;hostname&quot;: &quot;sfa&quot;\r\n        },\r\n        {\r\n          &quot;artefact&quot;: &quot;awe&quot;,\r\n          &quot;domain&quot;: &quot;csd&quot;,\r\n          &quot;hostname&quot;: &quot;wer&quot;\r\n        }\r\n      ],\r\n      &quot;utility&quot;: []\r\n    }\r\n  }\r\n}\r\n```\r\n\r\nExpected Resulting Json Fi:\r\n```\r\n{\r\n  &quot;ENV&quot;: {\r\n    &quot;DEV&quot;: {\r\n      &quot;middleware&quot;: [],\r\n      &quot;system&quot;: [],\r\n      &quot;application&quot;: [\r\n         {\r\n          &quot;artefact&quot;: &quot;abc&quot;,\r\n          &quot;domain&quot;: &quot;df&quot;,\r\n          &quot;hostname&quot;: &quot;sfa&quot;,\r\n        },\r\n        {\r\n          &quot;artefact&quot;: &quot;awe&quot;,\r\n          &quot;domain&quot;: &quot;csd&quot;,\r\n          &quot;hostname&quot;: &quot;wer&quot;,\r\n        }\r\n      ],\r\n      &quot;utility&quot;: []\r\n    },\r\n    &quot;ST&quot;: {\r\n      &quot;middleware&quot;: [],\r\n      &quot;system&quot;: [],\r\n      &quot;application&quot;: [],\r\n      &quot;utility&quot;: []\r\n    },\r\n    &quot;ESIT&quot;: {\r\n      &quot;middleware&quot;: [],\r\n      &quot;system&quot;: [],\r\n      &quot;application&quot;: [],\r\n      &quot;utility&quot;: []\r\n    }\r\n  }\r\n}\r\n```\r\n\r\nI have already tried:\r\n```\r\njq -s &#39;.ENV[&quot;DEV&quot;][] * .ENV[&quot;DEV&quot;][]&#39; jsonFile1.json jsonFile2.json\r\n```\r\nHowever that raises the error &#39;Cannot index array with string &quot;ENV&quot;&#39;. I can also delete the &#39;&quot;DEV&quot;: {}&#39; object out of jsonFile1 if that makes the merging process any easier.",
        "link": "https://stackoverflow.com/questions/67294619/merge-two-json-objects-with-jq",
        "title": "Merge two JSON objects with jq"
    },
    {
        "tags": [
            "json",
            "shell",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 6196394,
                    "reputation": 86601,
                    "user_id": 5291015,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/4tAvO.jpg?s=256",
                    "display_name": "Inian",
                    "link": "https://stackoverflow.com/users/5291015/inian"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1619631750,
                "post_id": 67305277,
                "comment_id": 118966235,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 6196394,
                    "reputation": 86601,
                    "user_id": 5291015,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/4tAvO.jpg?s=256",
                    "display_name": "Inian",
                    "link": "https://stackoverflow.com/users/5291015/inian"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1619631861,
                "post_id": 67305277,
                "comment_id": 118966271,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 14181171,
                    "reputation": 75,
                    "user_id": 10244725,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/UsJli.jpg?s=256",
                    "display_name": "luciela",
                    "link": "https://stackoverflow.com/users/10244725/luciela"
                },
                "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": 1619634622,
                "post_id": 67305277,
                "comment_id": 118967381,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 14181171,
                    "reputation": 75,
                    "user_id": 10244725,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/UsJli.jpg?s=256",
                    "display_name": "luciela",
                    "link": "https://stackoverflow.com/users/10244725/luciela"
                },
                "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": 1619635387,
                "post_id": 67305277,
                "comment_id": 118967716,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1619636844,
                "post_id": 67305277,
                "comment_id": 118968316,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 14181171,
                    "reputation": 75,
                    "user_id": 10244725,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/UsJli.jpg?s=256",
                    "display_name": "luciela",
                    "link": "https://stackoverflow.com/users/10244725/luciela"
                },
                "reply_to_user": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1619637627,
                "post_id": 67305277,
                "comment_id": 118968656,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1619638774,
                "post_id": 67305277,
                "comment_id": 118969115,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 14181171,
                    "reputation": 75,
                    "user_id": 10244725,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/UsJli.jpg?s=256",
                    "display_name": "luciela",
                    "link": "https://stackoverflow.com/users/10244725/luciela"
                },
                "reply_to_user": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1619639714,
                "post_id": 67305277,
                "comment_id": 118969462,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1619638551,
                "creation_date": 1619638551,
                "answer_id": 67306828,
                "question_id": 67305277,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Your requirements are a bit difficult to follow, especially since the &quot;expected output&quot; does not correspond exactly to the given input, but the following is either what you&#39;re looking for, or very close to it:\r\n\r\n```\r\n.data[]\r\n| [.id,.attempt_count,.billing_reason,.created,.customer,.customer_email]\r\n  + (.lines.data[] | [.id, [.plan.id, .plan.currency, .plan.product]])\r\n  + [.paid,.status]\r\n```",
                "title": "How to filter JSON array using JQ in shell (STRIPE)?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1619638551,
        "creation_date": 1619631590,
        "last_edit_date": 1619635157,
        "question_id": 67305277,
        "body_markdown": "Hello internet people,\r\n\r\nApparently I had the same problem of many but after searching a lot even here I could not find a reasonable answer at all!\r\n\r\n**My problem:**\r\n\r\nOn shell I did enter the command:\r\n`\r\nstripe invoices list --customer MY_CUSTOMER_ID_HERE\r\n`\r\n\r\nThen the following JSON appeared:\r\n\r\n\r\n```\r\n{\r\n  &quot;object&quot;: &quot;list&quot;,\r\n  &quot;data&quot;: [\r\n    {\r\n      &quot;id&quot;: &quot;INVOICE_ID&quot;,\r\n      &quot;object&quot;: &quot;invoice&quot;,\r\n      &quot;account_country&quot;: &quot;COUNTRY&quot;,\r\n      &quot;account_name&quot;: &quot;MY_BUSYNESS_NAME&quot;,\r\n      &quot;account_tax_ids&quot;: null,\r\n      &quot;amount_due&quot;: 1000,\r\n      &quot;amount_paid&quot;: 1000,\r\n      &quot;amount_remaining&quot;: 0,\r\n      &quot;application_fee_amount&quot;: null,\r\n      &quot;attempt_count&quot;: 1,\r\n      &quot;attempted&quot;: true,\r\n      &quot;auto_advance&quot;: false,\r\n      &quot;billing_reason&quot;: &quot;subscription_create&quot;,\r\n      &quot;charge&quot;: &quot;CHARGE_ID&quot;,\r\n      &quot;collection_method&quot;: &quot;charge_automatically&quot;,\r\n      &quot;created&quot;: SOME_UNIXTIME,\r\n      &quot;currency&quot;: &quot;usd&quot;,\r\n      &quot;custom_fields&quot;: null,\r\n      &quot;customer&quot;: &quot;CUSTOMER_ID&quot;,\r\n      &quot;customer_address&quot;: null,\r\n      &quot;customer_email&quot;: &quot;CUSTOMER_EMAIL&quot;,\r\n      &quot;customer_name&quot;: null,\r\n      &quot;customer_phone&quot;: &quot;CUSTOMER_PHONE&quot;,\r\n      &quot;customer_shipping&quot;: null,\r\n      &quot;customer_tax_exempt&quot;: &quot;none&quot;,\r\n      &quot;customer_tax_ids&quot;: [\r\n\r\n      ],\r\n      &quot;default_payment_method&quot;: null,\r\n      &quot;default_source&quot;: null,\r\n      &quot;default_tax_rates&quot;: [\r\n\r\n      ],\r\n      &quot;description&quot;: null,\r\n      &quot;discount&quot;: null,\r\n      &quot;discounts&quot;: [\r\n\r\n      ],\r\n      &quot;due_date&quot;: null,\r\n      &quot;ending_balance&quot;: 0,\r\n      &quot;footer&quot;: null,\r\n      &quot;hosted_invoice_url&quot;: &quot;INVOICE_URL_GOES_HERE&quot;,\r\n      &quot;invoice_pdf&quot;: &quot;INVOICE_PDF_URL_GOES_HERE&quot;,\r\n      &quot;last_finalization_error&quot;: null,\r\n      &quot;lines&quot;: {\r\n        &quot;object&quot;: &quot;list&quot;,\r\n        &quot;data&quot;: [\r\n          {\r\n            &quot;id&quot;: &quot;ID&quot;,\r\n            &quot;object&quot;: &quot;line_item&quot;,\r\n            &quot;amount&quot;: 1000,\r\n            &quot;currency&quot;: &quot;usd&quot;,\r\n            &quot;description&quot;: &quot;PLAN_DESCRIPTION&quot;,\r\n            &quot;discount_amounts&quot;: [\r\n\r\n            ],\r\n            &quot;discountable&quot;: true,\r\n            &quot;discounts&quot;: [\r\n\r\n            ],\r\n            &quot;livemode&quot;: false,\r\n            &quot;metadata&quot;: {\r\n            },\r\n            &quot;period&quot;: {\r\n              &quot;end&quot;: SOME_UNIXTIME,\r\n              &quot;start&quot;: SOME_UNIXTIME\r\n            },\r\n            &quot;plan&quot;: {\r\n              &quot;id&quot;: &quot;PRICE_ID_HERE&quot;,\r\n              &quot;object&quot;: &quot;plan&quot;,\r\n              &quot;active&quot;: true,\r\n              &quot;aggregate_usage&quot;: null,\r\n              &quot;amount&quot;: 1000,\r\n              &quot;amount_decimal&quot;: &quot;1000&quot;,\r\n              &quot;billing_scheme&quot;: &quot;per_unit&quot;,\r\n              &quot;created&quot;: SOME_UNIXTIME,\r\n              &quot;currency&quot;: &quot;usd&quot;,\r\n              &quot;interval&quot;: &quot;month&quot;,\r\n              &quot;interval_count&quot;: 1,\r\n              &quot;livemode&quot;: false,\r\n              &quot;metadata&quot;: {\r\n              },\r\n              &quot;nickname&quot;: null,\r\n              &quot;product&quot;: &quot;PRODUCT_ID_HERE&quot;,\r\n              &quot;tiers_mode&quot;: null,\r\n              &quot;transform_usage&quot;: null,\r\n              &quot;trial_period_days&quot;: null,\r\n              &quot;usage_type&quot;: &quot;licensed&quot;\r\n            },\r\n            &quot;price&quot;: {\r\n              &quot;id&quot;: &quot;MORE_ID_HERE&quot;,\r\n              &quot;object&quot;: &quot;price&quot;,\r\n              &quot;active&quot;: true,\r\n              &quot;billing_scheme&quot;: &quot;per_unit&quot;,\r\n              &quot;created&quot;: SOME_UNIXTIME,\r\n              &quot;currency&quot;: &quot;usd&quot;,\r\n              &quot;livemode&quot;: false,\r\n              &quot;lookup_key&quot;: null,\r\n              &quot;metadata&quot;: {\r\n              },\r\n              &quot;nickname&quot;: null,\r\n              &quot;product&quot;: &quot;PRODUCT_ID_HERE&quot;,\r\n              &quot;recurring&quot;: {\r\n                &quot;aggregate_usage&quot;: null,\r\n                &quot;interval&quot;: &quot;month&quot;,\r\n                &quot;interval_count&quot;: 1,\r\n                &quot;trial_period_days&quot;: null,\r\n                &quot;usage_type&quot;: &quot;licensed&quot;\r\n              },\r\n              &quot;tiers_mode&quot;: null,\r\n              &quot;transform_quantity&quot;: null,\r\n              &quot;type&quot;: &quot;recurring&quot;,\r\n              &quot;unit_amount&quot;: 1000,\r\n              &quot;unit_amount_decimal&quot;: &quot;1000&quot;\r\n            },\r\n            &quot;proration&quot;: false,\r\n            &quot;quantity&quot;: 1,\r\n            &quot;subscription&quot;: &quot;SUBSCRIPTION_ID_HERE&quot;,\r\n            &quot;subscription_item&quot;: &quot;SUBS_ITEM_ID_HERE&quot;,\r\n            &quot;tax_amounts&quot;: [\r\n\r\n            ],\r\n            &quot;tax_rates&quot;: [\r\n\r\n            ],\r\n            &quot;type&quot;: &quot;subscription&quot;\r\n          }\r\n        ],\r\n        &quot;has_more&quot;: false,\r\n        &quot;total_count&quot;: 1,\r\n        &quot;url&quot;: &quot;IV_URL_HERE&quot;\r\n      },\r\n      &quot;livemode&quot;: false,\r\n      &quot;metadata&quot;: {\r\n      },\r\n      &quot;next_payment_attempt&quot;: null,\r\n      &quot;number&quot;: &quot;NUMBER_IV_XXXX&quot;,\r\n      &quot;on_behalf_of&quot;: null,\r\n      &quot;paid&quot;: true,\r\n      &quot;payment_intent&quot;: &quot;PAYMENT_INTENT_ID_HERE&quot;,\r\n      &quot;payment_settings&quot;: {\r\n        &quot;payment_method_options&quot;: null,\r\n        &quot;payment_method_types&quot;: null\r\n      },\r\n      &quot;period_end&quot;: SOME_UNIXTIME,\r\n      &quot;period_start&quot;: SOME_UNIXTIME,\r\n      &quot;post_payment_credit_notes_amount&quot;: 0,\r\n      &quot;pre_payment_credit_notes_amount&quot;: 0,\r\n      &quot;receipt_number&quot;: null,\r\n      &quot;starting_balance&quot;: 0,\r\n      &quot;statement_descriptor&quot;: null,\r\n      &quot;status&quot;: &quot;paid&quot;,\r\n      &quot;status_transitions&quot;: {\r\n        &quot;finalized_at&quot;: SOME_UNIXTIME,\r\n        &quot;marked_uncollectible_at&quot;: null,\r\n        &quot;paid_at&quot;: SOME_UNIXTIME,\r\n        &quot;voided_at&quot;: null\r\n      },\r\n      &quot;subscription&quot;: &quot;SUBSCRIPTION_ID_HERE&quot;,\r\n      &quot;subtotal&quot;: 1000,\r\n      &quot;tax&quot;: null,\r\n      &quot;total&quot;: 1000,\r\n      &quot;total_discount_amounts&quot;: [\r\n\r\n      ],\r\n      &quot;total_tax_amounts&quot;: [\r\n\r\n      ],\r\n      &quot;transfer_data&quot;: null,\r\n      &quot;webhooks_delivered_at&quot;: SOME_UNIXTIME\r\n    }\r\n  ],\r\n  &quot;has_more&quot;: false,\r\n  &quot;url&quot;: &quot;/some_path&quot;\r\n}\r\n```\r\n\r\nI&#39;m able to access the second level with this command:\r\n\r\n`\r\nstripe invoices list --customer MY_CUSTOMER_ID_HERE | [.id,.attempt_count,.billing_reason,.created,.customer,.customer_email,.lines.data[],.paid,.status]&#39;\r\n`\r\n\r\nWhich returns a nice response, but I do want to filter few values inside data *(data.lines.data[])* like **id**, **plan** and inside plan the **id**, **currency** and **product** for example.\r\n\r\n**My question:**\r\n\r\nDoes any one knows how to do that with this kind of commands?\r\n\r\n\r\n----------\r\n\r\n\r\nJust in case, those are the questions and answer that I tried but couldn&#39;t figured how to do it at all!\r\n\r\n[How to filter array of objects by element property values using jq?][1]\r\n\r\n[How to filter arrays in json based on specific value using jq][2]\r\n\r\n[How to filter nested arrays in JSON while maintaining structure using jq][3]\r\n\r\n[filtering from JSON output from curl using JQ][4]\r\n\r\n[Filtering JSON by object name using jq][5]\r\n\r\n[How to filter JSON using jq stream (duplicate)][6]\r\n\r\n[How to filter and replace values in json with jq][7]\r\n\r\n[Filtering JSON list in shell using jq][8]\r\n\r\nI did also try a lot attempts on my own, like:\r\n\r\n`\r\nstripe invoices list --customer MY_CUSTOMER_ID_HERE | [.id,.attempt_count,.billing_reason,.created,.customer,.customer_email,.lines.data[.id.plan[][.id,.plan[.id,.currency,.product]],.paid,.status]&#39;\r\n`\r\n\r\n**Response:**\r\njq: error (at &lt;stdin&gt;:179): Cannot index string with string &quot;plan&quot;\r\n\r\n`\r\nstripe invoices list --customer MY_CUSTOMER_ID_HERE | [.id,.attempt_count,.billing_reason,.created,.customer,.customer_email,.lines.data[][],.paid,.status]&#39;\r\n`\r\n- This one return a null value for the second data content.\r\n\r\n**Response:**\r\n```\r\n[\r\n  &quot;DESIRED_ID&quot;,\r\n  1,\r\n  &quot;value_retrieved_ok&quot;,\r\n  unixtime_ok,\r\n  &quot;SOME_ID_OK&quot;,\r\n  &quot;customer_mail@ok.com&quot;,\r\n  null, &lt;&lt;&lt; ??? \r\n  true,\r\n  &quot;paid&quot;\r\n]\r\n```\r\n\r\n**EDIT:**\r\n\r\nDesired result should look like:\r\n\r\n```\r\n[\r\n  &quot;DESIRED_ID&quot;,\r\n  1,\r\n  &quot;value_retrieved_ok&quot;,\r\n  unixtime_ok,\r\n  &quot;SOME_ID_OK&quot;,\r\n  &quot;customer_mail@ok.com&quot;,\r\n  &quot;id&quot;             // the id inside lines.data{}\r\n    [&quot;id&quot;,         // the id inside lines.data.plan\r\n     &quot;currency&quot;,   // the currency inside lines.data.plan\r\n     &quot;product&quot;     // the product inside lines.data.plan\r\n    ]\r\n  true,\r\n  &quot;paid&quot;\r\n]\r\n```\r\n\r\n\r\nAnyway I do hope that there&#39;s a good soul out there have mercy!\r\n\r\n\r\n  [1]: https://stackoverflow.com/questions/38121740/how-to-filter-array-of-objects-by-element-property-values-using-jq\r\n  [2]: https://stackoverflow.com/questions/48956030/how-to-filter-arrays-in-json-based-on-specific-value-using-jq\r\n  [3]: https://stackoverflow.com/questions/58775875/how-to-filter-nested-arrays-in-json-while-maintaining-structure-using-jq\r\n  [4]: https://stackoverflow.com/questions/62595453/filtering-from-json-output-from-curl-using-jq\r\n  [5]: https://stackoverflow.com/questions/55583568/filtering-json-by-object-name-using-jq\r\n  [6]: https://stackoverflow.com/questions/52324497/how-to-filter-json-using-jq-stream\r\n  [7]: https://stackoverflow.com/questions/58763507/how-to-filter-and-replace-values-in-json-with-jq\r\n  [8]: https://stackoverflow.com/questions/50882417/filtering-json-list-in-shell-using-jq\r\n",
        "link": "https://stackoverflow.com/questions/67305277/how-to-filter-json-array-using-jq-in-shell-stripe",
        "title": "How to filter JSON array using JQ in shell (STRIPE)?"
    },
    {
        "tags": [
            "json",
            "substring",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1619636444,
                "post_id": 67305962,
                "comment_id": 118968158,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 5223146,
                    "reputation": 6006,
                    "user_id": 4175960,
                    "user_type": "registered",
                    "accept_rate": 75,
                    "profile_image": "https://i.sstatic.net/QbvYc.png?s=256",
                    "display_name": "Eddy Hernandez",
                    "link": "https://stackoverflow.com/users/4175960/eddy-hernandez"
                },
                "reply_to_user": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1619638922,
                "post_id": 67305962,
                "comment_id": 118969178,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1619638563,
                "creation_date": 1619638563,
                "answer_id": 67306830,
                "question_id": 67305962,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can use jq&#39;s `capture` function with regular expressions. \r\n\r\n```\r\njq &#39;[.[] | capture(&quot;(?&lt;captured&gt;app-[0-9]+\\\\.[0-9]+\\\\.[0-9]+)&quot;) | .[]]&#39;\r\n```\r\n\r\n[Try it out on jq playground][1].\r\n\r\nDocumentation: https://stedolan.github.io/jq/manual/#RegularexpressionsPCRE\r\n\r\n\r\n  [1]: https://jqplay.org/s/J1rxbFttze",
                "title": "Extract part of the string elements in an array using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1619644681,
        "creation_date": 1619634621,
        "last_edit_date": 1619644681,
        "question_id": 67305962,
        "body_markdown": "I&#39;m trying to extract part of the string in elements of an array, and create a new array with these extractions.\r\n\r\n    [\r\n      &quot;local/binaries/app-2.21.0.tar.gz&quot;,\r\n      &quot;local/binaries/app-2.20.0.tar.gz&quot;,\r\n      &quot;local/binaries/app-2.19.1.tar.gz&quot;,\r\n      &quot;local/binaries/app-2.19.0.tar.gz&quot;,\r\n      &quot;local/binaries/app-2.18.0.tar.gz&quot;\r\n    ]\r\n\r\nDesired output\r\n\r\n    [\r\n      &quot;app-2.21.0&quot;,\r\n      &quot;app-2.20.0&quot;,\r\n      &quot;app-2.19.1&quot;,\r\n      &quot;app-2.19.0&quot;,\r\n      &quot;app-2.18.0&quot;\r\n    ]",
        "link": "https://stackoverflow.com/questions/67305962/extract-part-of-the-string-elements-in-an-array-using-jq",
        "title": "Extract part of the string elements in an array using jq"
    },
    {
        "tags": [
            "arrays",
            "amazon-web-services",
            "stream",
            "jq",
            "amazon-iam"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1619651364,
                "last_edit_date": 1619651364,
                "creation_date": 1619650932,
                "answer_id": 67308984,
                "question_id": 67308772,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The last part of your jq pipeline is:\r\n\r\n    | .[]\r\n\r\nThis results in the stream that you don&#39;t want. One solution therefore would be to enclose your entire expression in square brackets; one of several better alternatives would be:\r\n```\r\n.Statement\r\n| [.[]\r\n   | select(.Effect == &quot;Allow&quot;)\r\n   | .Action\r\n   | if type == &quot;string&quot; then . else .[] end ]\r\n```",
                "title": "How to use jq on an AWS IAM policy?"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1619651279,
                "creation_date": 1619651279,
                "answer_id": 67309028,
                "question_id": 67308772,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Ok that was silly, surrounding my final output with `[]` did the trick\r\n\r\n```\r\n.Statement | [map(select(.Effect == &quot;Allow&quot;))[].Action | if type == &quot;string&quot; then . else .[] end]\r\n```",
                "title": "How to use jq on an AWS IAM policy?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1685091885,
        "creation_date": 1619649376,
        "last_edit_date": 1619651591,
        "question_id": 67308772,
        "body_markdown": "**The Question** - Why does jq generate lines with values, instead of generating the built-in json array? (I&#39;ve tried using `[.[]]` with no success)\r\n\r\nThe code snippet @ [jqplay.org](https://jqplay.org) - https://jqplay.org/s/IDhVa5KID8\r\n\r\n**The Challenge** - Generate an array of allowed **Action**s (`Effect == Allow`).\r\n\r\nIAM Policy (input)\r\n\r\n```json\r\n{\r\n    &quot;Version&quot;: &quot;2012-10-17&quot;,\r\n    &quot;Statement&quot;: [\r\n        {\r\n            &quot;Action&quot;: &quot;cloudformation:UpdateStack&quot;,\r\n            &quot;Resource&quot;: &quot;arn:aws:cloudformation:eu-west-1:123456789012:stack/sokker-stack-dev/*&quot;,\r\n            &quot;Effect&quot;: &quot;Allow&quot;\r\n        },\r\n        {\r\n            &quot;Action&quot;: [\r\n                &quot;lambda:UpdateFunctionConfiguration&quot;,\r\n                &quot;lambda:InvokeFunction&quot;\r\n            ],\r\n            &quot;Resource&quot;: &quot;arn:aws:lambda:eu-west-1:123456789012:function:sokker-api-dev-GetApiKeyValueFunction-MYDISTRIBID&quot;,\r\n            &quot;Effect&quot;: &quot;Allow&quot;\r\n        },\r\n        {\r\n            &quot;Action&quot;: [\r\n                &quot;cloudfront:GetDistribution&quot;,\r\n                &quot;cloudfront:UpdateDistribution&quot;\r\n            ],\r\n            &quot;Resource&quot;: &quot;arn:aws:cloudfront::*:distribution/MYDISTRIBID&quot;,\r\n            &quot;Effect&quot;: &quot;Allow&quot;\r\n        },\r\n        {\r\n            &quot;Action&quot;: [\r\n                &quot;apigateway:GET&quot;,\r\n                &quot;apigateway:HEAD&quot;,\r\n                &quot;apigateway:OPTIONS&quot;,\r\n                &quot;apigateway:PUT&quot;,\r\n                &quot;iam:GetRole&quot;,\r\n                &quot;iam:PassRole&quot;,\r\n                &quot;lambda:GetFunctionConfiguration&quot;\r\n            ],\r\n            &quot;Resource&quot;: &quot;*&quot;,\r\n            &quot;Effect&quot;: &quot;Allow&quot;\r\n        }\r\n    ]\r\n}\r\n```\r\n\r\nMy Solution (not good enough):\r\n\r\n```bash\r\njq &#39;.Statement | map(select(.Effect == &quot;Allow&quot;))[].Action | if type == &quot;string&quot; then . else .[] end&#39; iampolicy.json\r\n```\r\n\r\nMy Solution&#39;s Output:\r\n\r\n```bash\r\n# Why is it a list of values? Why isn&#39;t it a json array?\r\n&quot;cloudformation:UpdateStack&quot;\r\n&quot;lambda:UpdateFunctionConfiguration&quot;\r\n&quot;lambda:InvokeFunction&quot;\r\n&quot;cloudfront:GetDistribution&quot;\r\n&quot;cloudfront:UpdateDistribution&quot;\r\n&quot;apigateway:GET&quot;\r\n&quot;apigateway:HEAD&quot;\r\n&quot;apigateway:OPTIONS&quot;\r\n&quot;apigateway:PUT&quot;\r\n&quot;iam:GetRole&quot;\r\n&quot;iam:PassRole&quot;\r\n&quot;lambda:GetFunctionConfiguration&quot;\r\n```\r\n\r\n**Desired** output:\r\n\r\n```json\r\n[\r\n  &quot;cloudformation:UpdateStack&quot;,\r\n  &quot;lambda:UpdateFunctionConfiguration&quot;,\r\n  &quot;lambda:InvokeFunction&quot;,\r\n  &quot;cloudfront:GetDistribution&quot;,\r\n  &quot;cloudfront:UpdateDistribution&quot;,\r\n  &quot;apigateway:GET&quot;,\r\n  &quot;apigateway:HEAD&quot;,\r\n  &quot;apigateway:OPTIONS&quot;,\r\n  &quot;apigateway:PUT&quot;,\r\n  &quot;iam:GetRole&quot;,\r\n  &quot;iam:PassRole&quot;,\r\n  &quot;lambda:GetFunctionConfiguration&quot;\r\n]\r\n```",
        "link": "https://stackoverflow.com/questions/67308772/how-to-use-jq-on-an-aws-iam-policy",
        "title": "How to use jq on an AWS IAM policy?"
    },
    {
        "tags": [
            "json",
            "key",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 10015983,
                    "reputation": 144648,
                    "user_id": 9072753,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/EPmGy.jpg?s=256",
                    "display_name": "KamilCuk",
                    "link": "https://stackoverflow.com/users/9072753/kamilcuk"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1619698186,
                "post_id": 67317017,
                "comment_id": 118987031,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1619699632,
                "last_edit_date": 1619699632,
                "creation_date": 1619699130,
                "answer_id": 67317323,
                "question_id": 67317017,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "In `jq` you can use the `with_entries()` function. It puts the keys and values of each record in the object into named variables `.key` and `.value` and you basically have to evaluate if they are _not_ the same.\r\n\r\n\r\n```\r\njq &#39;with_entries(select(.key != .value))&#39;\r\n```\r\n\r\nSee [with_entries(..)][1] from the manual to know more\r\n\r\n---\r\n\r\nFollow-up question to do a case insensitive comparison. Can be done by converting both key/value to a particular case\r\n\r\n```none\r\nwith_entries(select( (.key| ascii_downcase) != (.value| ascii_downcase)))\r\n```\r\n\r\n\r\n\r\n\r\n  [1]: https://stedolan.github.io/jq/manual/#to_entries,from_entries,with_entries",
                "title": "Print JSON attributes whose key and value are different"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1619699272,
                "creation_date": 1619699272,
                "answer_id": 67317367,
                "question_id": 67317017,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "\r\n    sed &#39;/\\(\\&quot;.*\\&quot;\\): \\1/d&#39; file.json\r\n\r\nOr if you also want to eliminate the braces:\r\n\r\n    sed &#39;/\\&quot;/!d;/\\(\\&quot;.*\\&quot;\\): \\1/d&#39; file.json",
                "title": "Print JSON attributes whose key and value are different"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1620117910,
        "creation_date": 1619697896,
        "last_edit_date": 1620117910,
        "question_id": 67317017,
        "body_markdown": "I have a very long JSON file with the following structure (there are no nested attributes):\r\n\r\n```\r\n{\r\n\t&quot;Aaa aaa aaa&quot;: &quot;Aaa aaa aaa&quot;,\r\n\t&quot;Bbb bbb bbb&quot;: &quot;Bbb bbb bbb&quot;,\r\n\t&quot;Ccc ccc ccc&quot;: &quot;Xxx xxx xxx&quot;,\r\n\t&quot;Ddd ddd ddd&quot;: &quot;Ddd ddd ddd&quot;,\r\n\t&quot;Eee eee eee&quot;: &quot;Yyy yyy yyy&quot;\r\n}\r\n```\r\nAnd I need to print those pairs whose key does not match the value. In this example, I&#39;m expecting this kind of result:\r\n```\r\n\t&quot;Ccc ccc ccc&quot;: &quot;Xxx xxx xxx&quot;,\r\n\t&quot;Eee eee eee&quot;: &quot;Yyy yyy yyy&quot;\r\n```\r\n\r\n\r\nI know how to capture and print keys and values with **sed**...\r\n\r\n```\r\nsed -n &quot;s/^\\t\\&quot;\\(.*\\)\\&quot;: \\&quot;\\(.*\\)\\&quot;,\\?$/\\1 \\2/p&quot; file.json\r\n```\r\n...but I do not know how to make the comparison between both groups. Maybe **sed** is not the right tool for this task and I should be using **awk** or **jq** instead, however in don&#39;t have any experience with the latter.\r\n\r\nTherefore, which would be the right way or tool to search differences in name-value pairs within a JSON file?",
        "link": "https://stackoverflow.com/questions/67317017/print-json-attributes-whose-key-and-value-are-different",
        "title": "Print JSON attributes whose key and value are different"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1619711255,
                "creation_date": 1619711255,
                "answer_id": 67320821,
                "question_id": 67319985,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "    jq &#39;[.[] + {x:&quot;X&quot;}]&#39;\r\n\r\nOr you could use `map`",
                "title": "how to add entry to object inside array using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1619711255,
        "creation_date": 1619708613,
        "question_id": 67319985,
        "body_markdown": "Title says it all. So far I get this:\r\n\r\n    echo &#39;[{&quot;a&quot;: &quot;A&quot;, &quot;b&quot;: &quot;B&quot;}, {&quot;c&quot;: &quot;C&quot;, &quot;d&quot;: &quot;D&quot;}]&#39; | jq &#39;.[] + {x:&quot;X&quot;}&#39;\r\n\r\nWhich will result to this:\r\n\r\n    {\r\n      &quot;a&quot;: &quot;A&quot;,\r\n      &quot;b&quot;: &quot;B&quot;,\r\n      &quot;x&quot;: &quot;X&quot;\r\n    }\r\n    {\r\n      &quot;c&quot;: &quot;C&quot;,\r\n      &quot;d&quot;: &quot;D&quot;,\r\n      &quot;x&quot;: &quot;X&quot;\r\n    }\r\n\r\nbut it will not &quot;wrap&quot; the result in array and also does not add comma after each entry.\r\n",
        "link": "https://stackoverflow.com/questions/67319985/how-to-add-entry-to-object-inside-array-using-jq",
        "title": "how to add entry to object inside array using jq"
    },
    {
        "tags": [
            "python",
            "json",
            "command-line-arguments",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 19501447,
                    "reputation": 418,
                    "user_id": 14267431,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/6ad10e80b5050400bc7017774a2ca6c8?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Daniyal Shaikh",
                    "link": "https://stackoverflow.com/users/14267431/daniyal-shaikh"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1619723243,
                "post_id": 67323578,
                "comment_id": 118998781,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 15741270,
                    "reputation": 406,
                    "user_id": 11358602,
                    "user_type": "registered",
                    "profile_image": "https://lh4.googleusercontent.com/-jbkt1uXOmqg/AAAAAAAAAAI/AAAAAAAAAAA/ACHi3rc5r0cIUlX2eL_eynOqOMs96_lHBQ/mo/s256-rj/photo.jpg",
                    "display_name": "Silver",
                    "link": "https://stackoverflow.com/users/11358602/silver"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1619723274,
                "post_id": 67323578,
                "comment_id": 118998792,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1619738358,
                "last_edit_date": 1619738358,
                "creation_date": 1619727302,
                "answer_id": 67324476,
                "question_id": 67323578,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "In short: don&#39;t join.\r\n\r\nMore specifically:\r\n```\r\n$ python app_parsing_lists.py --lista $(echo &#39;{&quot;field&quot;: [6, 7, 8]}&#39; | jq -r .field[])\r\nlista: [&#39;6&#39;, &#39;7&#39;, &#39;8&#39;]\r\n```\r\nIn long: consider these examples, all using `%r` --\r\n\r\n```\r\n$ inlist=(&quot;4&quot; &quot;5&quot; &quot;6&quot;)\r\n$ python app_parsing_lists.py --lista ${inlist[@]}\r\nlista: [&#39;4&#39;, &#39;5&#39;, &#39;6&#39;]\r\n$ python app_parsing_lists.py --lista &quot;${inlist[@]}&quot;\r\nlista: [&#39;4&#39;, &#39;5&#39;, &#39;6&#39;]\r\n$ python app_parsing_lists.py --lista $(jq -n &#39;5,6,7&#39;)\r\nlista: [&#39;5&#39;, &#39;6&#39;, &#39;7&#39;]\r\n$ inlist=($(jq -n &#39;5,6,7&#39;))\r\n$ python app_parsing_lists.py --lista $inlist\r\nlista: [&#39;5&#39;]\r\n$ python app_parsing_lists.py --lista &quot;$inlist&quot;\r\nlista: [&#39;5&#39;]\r\n$ python app_parsing_lists.py --lista ${inlist[@]}\r\nlista: [&#39;5&#39;, &#39;6&#39;, &#39;7&#39;]\r\n$ \r\n```\r\n\r\n### Caveat\r\nIf any of the list items contains a space, a different approach will be needed, as illustrated by:\r\n\r\n```\r\n$ lista=(&quot;a b&quot; 2 3)\r\n\r\n$ for i in &quot;${lista[@]}&quot; ; do echo $i ; done\r\na b\r\n2\r\n3\r\n\r\n$ python app_parsing_lists.py --lista &quot;${lista[@]}&quot;\r\nlista: [&#39;a b&#39;, &#39;2&#39;, &#39;3&#39;]\r\n\r\n$ lista=($(echo &#39;{&quot;field&quot;: [&quot;a b&quot;, 7, 8]}&#39; | jq .field[]))\r\n$ python app_parsing_lists.py --lista &quot;${lista[@]}&quot;\r\nlista: [&#39;&quot;a&#39;, &#39;b&quot;&#39;, &#39;7&#39;, &#39;8&#39;]\r\n```\r\n#### Solution\r\n```\r\nunset lista\r\nwhile IFS= read -r line ; do lista+=($line)\r\ndone &lt; &lt;(printf &quot;%s\\n&quot; &#39;{&quot;field&quot;: [&quot;a b&quot;, 7, 8]}&#39; | jq -r .field[])\r\n\r\n$ python app_parsing_lists.py --lista ${lista[@]}\r\nlista: [&#39;a b&#39;, &#39;7&#39;, &#39;8&#39;]\r\n$\r\n``` ",
                "title": "How to pass an entire list as command line argument in Python when the list comes from a json file"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1619750486,
        "creation_date": 1619722829,
        "last_edit_date": 1619750486,
        "question_id": 67323578,
        "body_markdown": "Based on one of the answers from [this post](https://stackoverflow.com/questions/32761999/how-to-pass-an-entire-list-as-command-line-argument-in-python/32763023), one can successfully pass a list using `nargs`. \r\n\r\nHowever, I am not sure how to pass correctly a list when the list is actually retrieved from a json file. All the attempts made returns always a list of one and I was wondering how can one successfully do that from the command line (i.e. no use of json parsing inside the python script).\r\n\r\nMain attempt using a toy example (very similar to the one of the post mentioned above).\r\n\r\n**app_parsing_lists.py**\r\n\r\n```python\r\nimport argparse\r\n# defined command line options\r\n# this also generates --help and error handling\r\nCLI=argparse.ArgumentParser()\r\nCLI.add_argument(\r\n  &quot;--lista&quot;,  # name on the CLI - drop the `--` for positional/required parameters\r\n  nargs=&quot;*&quot;,  # 0 or more values expected =&gt; creates a list\r\n  type=str,\r\n  default=[&quot;1&quot;, &quot;2&quot;, &quot;3&quot;],  # default if nothing is provided\r\n)\r\n\r\n# parse the command line\r\nargs = CLI.parse_args()\r\n# access CLI options\r\nprint(&quot;lista: %r&quot; % args.lista)\r\n```\r\n\r\n**file.json**\r\n```json\r\n{&quot;field&quot;: [6, 7, 8]}\r\n```\r\n\r\nFrom CLI:\r\n\r\n```bash\r\ninlist=$(jq -r &#39;.field | join(&quot; &quot;)&#39; file.json)\r\npython app_parsing_lists.py --lista $inlist\r\n```\r\nIt prints `lista: [&#39;6 7 8&#39;]`\r\n\r\nBut the behavior wanted is `lista: [&#39;6&#39;, &#39;7&#39;, &#39;8&#39;]`\r\n\r\nHow can one achieve that?",
        "link": "https://stackoverflow.com/questions/67323578/how-to-pass-an-entire-list-as-command-line-argument-in-python-when-the-list-come",
        "title": "How to pass an entire list as command line argument in Python when the list comes from a json file"
    },
    {
        "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": 1619782797,
                "post_id": 67333141,
                "comment_id": 119014835,
                "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": 1619783578,
                "post_id": 67333141,
                "comment_id": 119015124,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1707399,
                    "reputation": 11184,
                    "user_id": 1566187,
                    "user_type": "registered",
                    "accept_rate": 85,
                    "profile_image": "https://www.gravatar.com/avatar/00cb2ecc49f0f05736dc7c14bbccfeaa?s=256&d=identicon&r=PG",
                    "display_name": "Ely",
                    "link": "https://stackoverflow.com/users/1566187/ely"
                },
                "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": 1619784845,
                "post_id": 67333141,
                "comment_id": 119015641,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1619801652,
                "last_edit_date": 1619801652,
                "creation_date": 1619785748,
                "answer_id": 67333942,
                "question_id": 67333141,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "One way using `jq` would be to do\r\n\r\n```bash\r\njq &#39;\r\n  ( map ( select( .endpoint_url == &quot;assignment/import&quot; ) ) ) as $d |\r\n  ( map ( select( .body_payload.assignmentName == $d[].body_payload.name ) ) ) as $l | \r\n  $d | \r\n  map( .body_payload += { roles : [ $l[].body_payload.roleName ] } )&#39; json\r\n```",
                "title": "jq - Create an array in an object and add to it all values of objects that share a same value"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1619801652,
        "creation_date": 1619782299,
        "last_edit_date": 1619784712,
        "question_id": 67333141,
        "body_markdown": "I am trying to make the following structure\r\n\r\n\r\n    {\r\n      &quot;endpoint_url&quot;: &quot;assignment/import&quot;,\r\n      &quot;body_payload&quot;: {\r\n        &quot;name&quot;: &quot;assignment1&quot;,\r\n        &quot;description&quot;: &quot;assignment 1 description&quot;\r\n      }\r\n    }\r\n    ...\r\n    {\r\n      &quot;endpoint_url&quot;: &quot;assignment-role/create&quot;,\r\n      &quot;body_payload&quot;: {\r\n        &quot;roleName&quot;: &quot;role1&quot;,\r\n        &quot;assignmentName&quot;: &quot;assignment1&quot;\r\n      }\r\n    },\r\n    {\r\n      &quot;endpoint_url&quot;: &quot;assignment-role/create&quot;,\r\n      &quot;body_payload&quot;: {\r\n        &quot;roleName&quot;: &quot;role2&quot;,\r\n        &quot;assignmentName&quot;: &quot;assignment1&quot;\r\n      }\r\n    },\r\n    {\r\n      &quot;endpoint_url&quot;: &quot;assignment-role/create&quot;,\r\n      &quot;body_payload&quot;: {\r\n        &quot;roleName&quot;: &quot;role3&quot;,\r\n        &quot;assignmentName&quot;: &quot;assignment1&quot;\r\n      }\r\n    }\r\n\r\nto become\r\n\r\n    {\r\n      &quot;endpoint_url&quot;: &quot;assignment/import&quot;,\r\n      &quot;body_payload&quot;: {\r\n        &quot;name&quot;: &quot;assignment1&quot;,\r\n        &quot;description&quot;: &quot;assignment 1 description&quot;,\r\n        &quot;roles&quot;: [ &quot;role1&quot;, &quot;role2&quot;, &quot;role3&quot; ]\r\n      }\r\n    }\r\n    ...\r\n\r\nThe idea is the following:\r\n\r\nFor each object that satisfies `.endpoint_url == &quot;assignment/import&quot;` identify the objects that have the same assignment name (e.g. `.body_payload.name == .body_payload.assignmentName`) and add the role name to the roles array (e.g. `if .body_payload.roles then .body_payload.roles += .body_payload.roleName else .body_payload += {&quot;roles&quot;: []} end`\r\n\r\nI am sure this programmatic approach is not correct. I better refrain from showing what I have tried (and is awfully wrong too) and would like to ask a knowledgable person what is the correct way to achieve the expected result.\r\n\r\n\r\n### Update (showing a valid input example) ###\r\n\r\nA valid minimal input can be as follows:\r\n\r\n    [\r\n      {\r\n        &quot;endpoint_url&quot;: &quot;assignment/import&quot;,\r\n        &quot;body_payload&quot;: {\r\n          &quot;name&quot;: &quot;assignment1&quot;,\r\n          &quot;description&quot;: &quot;assignment 1 description&quot;\r\n        }\r\n      },\r\n      {\r\n        &quot;endpoint_url&quot;: &quot;assignment-role/create&quot;,\r\n        &quot;body_payload&quot;: {\r\n          &quot;roleName&quot;: &quot;role1&quot;,\r\n          &quot;assignmentName&quot;: &quot;assignment1&quot;\r\n        }\r\n      },\r\n      {\r\n        &quot;endpoint_url&quot;: &quot;assignment-role/create&quot;,\r\n        &quot;body_payload&quot;: {\r\n          &quot;roleName&quot;: &quot;role2&quot;,\r\n          &quot;assignmentName&quot;: &quot;assignment1&quot;\r\n        }\r\n      },\r\n      {\r\n        &quot;endpoint_url&quot;: &quot;assignment-role/create&quot;,\r\n        &quot;body_payload&quot;: {\r\n          &quot;roleName&quot;: &quot;role3&quot;,\r\n          &quot;assignmentName&quot;: &quot;assignment1&quot;\r\n        }\r\n      }\r\n    ]\r\n\r\nThe expected output can be just:\r\n\r\n    {\r\n      &quot;endpoint_url&quot;: &quot;assignment/import&quot;,\r\n      &quot;body_payload&quot;: {\r\n        &quot;name&quot;: &quot;assignment1&quot;,\r\n        &quot;description&quot;: &quot;assignment 1 description&quot;,\r\n        &quot;roles&quot;: [ &quot;role1&quot;, &quot;role2&quot;, &quot;role3&quot; ]\r\n      }\r\n    }\r\n\r\nThough I do not care too much really if the previous/old objects still are there. Whatever you find easiest to do is ok.",
        "link": "https://stackoverflow.com/questions/67333141/jq-create-an-array-in-an-object-and-add-to-it-all-values-of-objects-that-share",
        "title": "jq - Create an array in an object and add to it all values of objects that share a same value"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1620070062,
                "creation_date": 1620070062,
                "answer_id": 67374735,
                "question_id": 67334934,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You&#39;ve got two different object types in your array. They are distinguished by the child keys of `.body_payload`, so let&#39;s destructure all keys and check which ones are not null. We&#39;ll use `reduce/2` for this since we need to update the same parts of our tree repeatedly.\r\n\r\n```\r\nreduce .[] as\r\n  { body_payload:\r\n    { $name\r\n    , $description\r\n    , $roleName\r\n    , $assignmentName\r\n    }\r\n  }\r\n( null\r\n; if $name and $description\r\n  then .[$name] += {$name, $description}\r\n\r\n  elif $roleName and $assignmentName\r\n  then .[$assignmentName].roles += [$roleName]\r\n\r\n  else error(&quot;some required parameter is null&quot;)\r\n  end\r\n)\r\n```\r\n\r\nThis produces an object of the form\r\n\r\n```json\r\n{\r\n  &quot;assignment1&quot;: {\r\n    &quot;name&quot;: &quot;assignment1&quot;,\r\n    &quot;description&quot;: &quot;assignment 1 description&quot;,\r\n    &quot;roles&quot;: [\r\n      &quot;role1&quot;,\r\n      &quot;role2&quot;\r\n    ]\r\n  },\r\n  &quot;assignment2&quot;: {\r\n     ...\r\n  },\r\n  ...\r\n}\r\n```\r\n\r\nwhich we can convert to the desired array of objects with `to_entries|map`.\r\n\r\n```\r\n| to_entries\r\n| map\r\n  ( { endpoint_url: &quot;assignment/import&quot;\r\n    , body_payload: .value\r\n    }\r\n  )\r\n```",
                "title": "jq - merge values of objects having the same key/value and add them to an array in a related object"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1620070062,
        "creation_date": 1619789947,
        "question_id": 67334934,
        "body_markdown": "The question is a bit more sophisticated and takes [this question][1] to the next level.\r\n\r\nI would like to present an example to describe my problem. Let&#39;s say I have the following input:\r\n\r\n    [\r\n      {\r\n        &quot;endpoint_url&quot;: &quot;assignment/import&quot;,\r\n        &quot;body_payload&quot;: {\r\n          &quot;name&quot;: &quot;assignment1&quot;,\r\n          &quot;description&quot;: &quot;assignment 1 description&quot;\r\n        }\r\n      },\r\n      {\r\n        &quot;endpoint_url&quot;: &quot;assignment-role/create&quot;,\r\n        &quot;body_payload&quot;: {\r\n          &quot;roleName&quot;: &quot;role1&quot;,\r\n          &quot;assignmentName&quot;: &quot;assignment1&quot;\r\n        }\r\n      },\r\n      {\r\n        &quot;endpoint_url&quot;: &quot;assignment-role/create&quot;,\r\n        &quot;body_payload&quot;: {\r\n          &quot;roleName&quot;: &quot;role2&quot;,\r\n          &quot;assignmentName&quot;: &quot;assignment1&quot;\r\n        }\r\n      },\r\n      {\r\n        &quot;endpoint_url&quot;: &quot;assignment/import&quot;,\r\n        &quot;body_payload&quot;: {\r\n          &quot;name&quot;: &quot;assignment2&quot;,\r\n          &quot;description&quot;: &quot;assignment 2 description&quot;\r\n        }\r\n      },\r\n      {\r\n        &quot;endpoint_url&quot;: &quot;assignment-role/create&quot;,\r\n        &quot;body_payload&quot;: {\r\n          &quot;roleName&quot;: &quot;role3&quot;,\r\n          &quot;assignmentName&quot;: &quot;assignment2&quot;\r\n        }\r\n      },\r\n      {\r\n        &quot;endpoint_url&quot;: &quot;assignment-role/create&quot;,\r\n        &quot;body_payload&quot;: {\r\n          &quot;roleName&quot;: &quot;role4&quot;,\r\n          &quot;assignmentName&quot;: &quot;assignment2&quot;\r\n        }\r\n      },\r\n      {\r\n        &quot;endpoint_url&quot;: &quot;assignment-role/create&quot;,\r\n        &quot;body_payload&quot;: {\r\n          &quot;roleName&quot;: &quot;role5&quot;,\r\n          &quot;assignmentName&quot;: &quot;assignment2&quot;\r\n        }\r\n      },\r\n      {\r\n        &quot;endpoint_url&quot;: &quot;assignment/import&quot;,\r\n        &quot;body_payload&quot;: {\r\n          &quot;name&quot;: &quot;assignment3&quot;,\r\n          &quot;description&quot;: &quot;assignment 3 description&quot;\r\n        }\r\n      },\r\n      {\r\n        &quot;endpoint_url&quot;: &quot;assignment-role/create&quot;,\r\n        &quot;body_payload&quot;: {\r\n          &quot;roleName&quot;: &quot;role6&quot;,\r\n          &quot;assignmentName&quot;: &quot;assignment3&quot;\r\n        }\r\n      },\r\n    ]\r\n\r\nAn exepected output can be along the lines:\r\n\r\n    [\r\n      {\r\n        &quot;endpoint_url&quot;: &quot;assignment/import&quot;,\r\n        &quot;body_payload&quot;: {\r\n          &quot;name&quot;: &quot;assignment1&quot;,\r\n          &quot;description&quot;: &quot;assignment 1 description&quot;,\r\n          &quot;roles&quot;: [ &quot;role1&quot;, &quot;role2&quot; ]\r\n        }\r\n      },\r\n      {\r\n        &quot;endpoint_url&quot;: &quot;assignment/import&quot;,\r\n        &quot;body_payload&quot;: {\r\n          &quot;name&quot;: &quot;assignment2&quot;,\r\n          &quot;description&quot;: &quot;assignment 2 description&quot;,\r\n          &quot;roles&quot;: [ &quot;role3&quot;, &quot;role4&quot;, &quot;role5&quot; ]\r\n        }\r\n      },\r\n      {\r\n        &quot;endpoint_url&quot;: &quot;assignment/import&quot;,\r\n        &quot;body_payload&quot;: {\r\n          &quot;name&quot;: &quot;assignment3&quot;,\r\n          &quot;description&quot;: &quot;assignment 3 description&quot;,\r\n          &quot;roles&quot;: [ &quot;role6&quot; ]\r\n        }\r\n      }\r\n    ]\r\n\r\nI hope you can see I wish to do the following. For each object having an `assignment/import` I would like to extract all roles of the corresponding `assignment-role/create` (objects having an `assignment-role/create` and whose `assignmentName` equals the `name` of the corresponding object having an `assignment/import`) and add these roles to it.&lt;br&gt;\r\nMy description may be a bit clumsy but I hope the example gives the essence away.\r\n\r\n  [1]: https://stackoverflow.com/q/67333141/1566187",
        "link": "https://stackoverflow.com/questions/67334934/jq-merge-values-of-objects-having-the-same-key-value-and-add-them-to-an-array",
        "title": "jq - merge values of objects having the same key/value and add them to an array in a related object"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1619792815,
                "last_edit_date": 1619792815,
                "creation_date": 1619792590,
                "answer_id": 67335565,
                "question_id": 67335453,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "To avoid &quot;slurping&quot; the input, you would use either `reduce` or `foreach`.  Here&#39;s a suitable abstraction built from `reduce`:\r\n```\r\ndef count(s; f; g):\r\n  reduce s as $s ([0,0];\r\n    if $s|f then .[0]+=1 else . end\r\n    | if $s|g then .[1]+=1 else . end);\r\n```\r\nWith this, you would invoke jq with the -n command-line option and run a query such as:\r\n```\r\ncount(inputs|.value; .==&quot;active&quot;; .==&quot;inactive&quot;)\r\n```\r\n\r\nNotice that one cannot use `count/1` (defined analogously) twice since `inputs` consumes the input stream. ",
                "title": "How can I count objects in jq (not in an array)"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 3,
        "last_activity_date": 1620025066,
        "creation_date": 1619792042,
        "last_edit_date": 1620025066,
        "question_id": 67335453,
        "body_markdown": "I have some json input that comes as a list of objects (not as a json array) like, for which I want to count the number of active, and the number of inactive:\r\n```\r\n{\r\n  &quot;key&quot; : &quot;state&quot;,\r\n  &quot;value&quot; : &quot;active&quot;\r\n}\r\n{\r\n  &quot;key&quot; : &quot;state&quot;,\r\n  &quot;value&quot; : &quot;active&quot;\r\n}\r\n{\r\n  &quot;key&quot; : &quot;state&quot;,\r\n  &quot;value&quot; : &quot;active&quot;\r\n}\r\n{\r\n  &quot;key&quot; : &quot;state&quot;,\r\n  &quot;value&quot; : &quot;inactive&quot;\r\n}\r\n```\r\n\r\nI want to transform using only JQ (in fact it will be handled by jackson-jq in java code, so I can not use some shell tricks).\r\n\r\nI tried many things, like ``select(.value == &quot;active&quot;) | length`` to get the number of active, but  it is always handle object per object.\r\nEven when using reduce, it is always handled object per object.\r\n\r\nExample of output is :\r\n```\r\n2\r\n2\r\n2\r\n```\r\n (I have 3 objects with 2 fields that match value=&quot;active)\r\n\r\nThe output that I expect is :\r\n```\r\n3\r\n````\r\n\r\n[Here][1] is a playground with my example.\r\n\r\n\r\n  [1]: https://jqplay.org/s/-8E8lVluCn",
        "link": "https://stackoverflow.com/questions/67335453/how-can-i-count-objects-in-jq-not-in-an-array",
        "title": "How can I count objects in jq (not in an array)"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1619794484,
                "creation_date": 1619794484,
                "answer_id": 67336039,
                "question_id": 67335790,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You were almost there. Use `map` to create a single array instead of two independent objects, then use `add` to merge its contents.\r\n\r\n    jq &#39;.application[]\r\n        | select(.name == &quot;app1&quot;)\r\n        | .policies\r\n        | map({ (.name) : .orderNumber } )\r\n        | add&#39; file.json",
                "title": "Transform JSON to a compact format"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1620117804,
        "creation_date": 1619793512,
        "last_edit_date": 1620117804,
        "question_id": 67335790,
        "body_markdown": "I&#39;m trying to Transform the following json\r\n```\r\n{ &quot;application&quot; : [\r\n   { &quot;name&quot; : &quot;app1&quot;,\r\n     &quot;policies&quot; : [ \r\n                    { &quot;name&quot; : &quot;pol_1&quot;,\r\n                      &quot;orderNumber&quot; : &quot;10&quot;\r\n                    },\r\n                    { &quot;name&quot; : &quot;pol_2&quot;,\r\n                      &quot;orderNumber&quot; : &quot;20&quot;\r\n                    }\r\n                ]\r\n   },\r\n   { &quot;name&quot; : &quot;app2&quot;,\r\n     &quot;policies&quot; : [ \r\n                    { &quot;name&quot; : &quot;pol_A&quot;,\r\n                      &quot;orderNumber&quot; : &quot;10&quot;\r\n                    },\r\n                    { &quot;name&quot; : &quot;pol_B&quot;,\r\n                      &quot;orderNumber&quot; : &quot;20&quot;\r\n                    }\r\n                ]\r\n   }\r\n]\r\n}\r\n```\r\nTo the following \r\n```\r\n{ &quot;pol_1&quot;:&quot;10&quot;, &quot;pol_2&quot;:&quot;20&quot; }\r\n```\r\n\r\nUsing\r\n```\r\njq -r &quot;.application[] | select(.name==\\&quot;app1\\&quot;) | .policies[] | {\\&quot;.name\\&quot; : .orderNumber}&quot; \r\n```\r\nI was able to get \r\n```\r\n{\r\n &quot;pol_1&quot;:&quot;10&quot;\r\n}\r\n{ \r\n &quot;pol_2&quot;:&quot;20&quot; \r\n}\r\n```\r\nAny idea how I can merge them.  Am I missing something Or am I doing it the wrong way?",
        "link": "https://stackoverflow.com/questions/67335790/transform-json-to-a-compact-format",
        "title": "Transform JSON to a compact format"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1619811759,
                "creation_date": 1619811759,
                "answer_id": 67339608,
                "question_id": 67339472,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "It looks like I needed `--slurp` combined with a simple `add`.\r\n\r\n    erin@laptop:~/tmp$ cat a.json \r\n    {\r\n        &quot;a&quot;: {\r\n            &quot;1&quot;: &quot;1&quot;,\r\n            &quot;2&quot;: &quot;2&quot;\r\n        }\r\n    }\r\n    \r\n    erin@laptop:~/tmp$ cat b.json \r\n    {\r\n        &quot;a&quot;: {\r\n            &quot;3&quot;: &quot;3&quot;\r\n        },\r\n        &quot;b&quot;: {\r\n            &quot;1&quot;: &quot;1&quot;\r\n        }\r\n    }\r\n    \r\n    erin@laptop:~/tmp$ jq -s &#39;add&#39; b.json a.json\r\n    {\r\n      &quot;a&quot;: {\r\n        &quot;1&quot;: &quot;1&quot;,\r\n        &quot;2&quot;: &quot;2&quot;\r\n      },\r\n      &quot;b&quot;: {\r\n        &quot;1&quot;: &quot;1&quot;\r\n      }\r\n    }\r\n    erin@laptop:~/tmp$ \r\n\r\n",
                "title": "JQ - non-recursive merge of top-level keys and values only"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1619811759,
        "creation_date": 1619810929,
        "last_edit_date": 1619811276,
        "question_id": 67339472,
        "body_markdown": "Lots of JQ questions on here, but none of them seem to address what I&#39;m looking for. I would like to take two JSON objects and merge them non-recursively.\r\n\r\n    {\r\n    \t&quot;a&quot;: {\r\n    \t\t&quot;1&quot;: &quot;1&quot;,\r\n    \t\t&quot;2&quot;: &quot;2&quot;\r\n    \t}\r\n    }\r\n\r\nmerged into\r\n\r\n    {\r\n    \t&quot;a&quot;: {\r\n    \t\t&quot;3&quot;: &quot;3&quot;\r\n    \t},\r\n    \t&quot;b&quot;: {\r\n    \t\t&quot;1&quot;: &quot;1&quot;\r\n    \t}\r\n    }\r\n\r\nshould result in\r\n\r\n    {\r\n    \t&quot;a&quot;: {\r\n    \t\t// Note &quot;3&quot; is not present, object &quot;a&quot; is completely replaced.\r\n    \t\t&quot;1&quot;: &quot;1&quot;,\r\n    \t\t&quot;2&quot;: &quot;2&quot;\r\n    \t},\r\n    \t&quot;b&quot;: {\r\n    \t\t&quot;1&quot;: &quot;1&quot;\r\n    \t}\r\n    }\r\n\r\nThanks! Your help is very much appreciated.",
        "link": "https://stackoverflow.com/questions/67339472/jq-non-recursive-merge-of-top-level-keys-and-values-only",
        "title": "JQ - non-recursive merge of top-level keys and values only"
    },
    {
        "tags": [
            "json",
            "export-to-csv",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1619814339,
                "post_id": 67339698,
                "comment_id": 119027548,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1619813236,
                "last_edit_date": 1619813236,
                "creation_date": 1619812924,
                "answer_id": 67339820,
                "question_id": 67339698,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Not sure this is the cleanest way to handle this, but the following will get the desired output:\r\n```none\r\n.Users[].Attributes | map(.Value) | @csv\r\n```\r\n1) Loop through all the deep Attributes `.Users[].Attributes`\r\n2) [`map()`](https://stedolan.github.io/jq/manual/#example21) to get all the `Value`&#39;s\r\n3) Convert to `@csv`\r\n### [jqPlay demo](https://jqplay.org/s/Y3mTqmOHC7)",
                "title": "use jq to format json data into csv data"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1619875902,
                "last_edit_date": 1619875902,
                "creation_date": 1619813094,
                "answer_id": 67339846,
                "question_id": 67339698,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If you don&#39;t need the output to be guaranteed to be CSV, and if you&#39;re sure the &quot;Name&quot; values are presented in the same order, you could go with:\r\n```\r\n.Users[].Attributes\r\n| from_entries\r\n| [.[]]\r\n| join(&quot;,&quot;)\r\n```\r\n\r\nTo be safe though it would be better to ensure consistency of ordering:\r\n```\r\n(.Users[0] | [.Attributes[] | .Name]) as $keys\r\n| .Users[]\r\n| .Attributes\r\n| from_entries\r\n| [.[ $keys[] ]]\r\n| join(&quot;,&quot;)\r\n```\r\n\r\nUsing `join(&quot;,&quot;)` will produce the comma-separated values as shown in the Q (without the quotation marks), but is not **guaranteed** to produce the expected CSV for all valid values of the input.  If you don&#39;t mind the pesky quotation marks, you could use `@csv`, or if you want to skip the quotation marks around all numeric values:\r\n\r\n    map(tonumber? // .) | @csv",
                "title": "use jq to format json data into csv data"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": -1,
        "last_activity_date": 1619875902,
        "creation_date": 1619812265,
        "last_edit_date": 1619812796,
        "question_id": 67339698,
        "body_markdown": "    {\r\n        &quot;Users&quot;: [\r\n            {\r\n                &quot;Attributes&quot;: [\r\n                    {\r\n                        &quot;Name&quot;: &quot;sub&quot;,\r\n                        &quot;Value&quot;: &quot;1&quot;\r\n                    },\r\n                    {\r\n                        &quot;Name&quot;: &quot;phone_number&quot;,\r\n                        &quot;Value&quot;: &quot;1234&quot;\r\n                    },\r\n                    {\r\n                        &quot;Name&quot;: &quot;referral_code&quot;,\r\n                        &quot;Value&quot;: &quot;abc&quot;\r\n                    }\r\n                ]\r\n            },\r\n            {\r\n                &quot;Attributes&quot;: [\r\n                    {\r\n                        &quot;Name&quot;: &quot;sub&quot;,\r\n                        &quot;Value&quot;: &quot;2&quot;\r\n                    },\r\n                    {\r\n                        &quot;Name&quot;: &quot;phone_number&quot;,\r\n                        &quot;Value&quot;: &quot;5678&quot;\r\n                    },\r\n                    {\r\n                        &quot;Name&quot;: &quot;referral_code&quot;,\r\n                        &quot;Value&quot;: &quot;def&quot;\r\n                    }\r\n                ]\r\n            }\r\n        ]\r\n    }\r\n\t\r\nHow can I produce output like below ?\r\n\r\n1,1234,abc\r\n\r\n2,5678,def\r\n\r\n    jq &#39;.Users[] .Attributes[] .Value&#39; test.json\r\n\r\n    produces\r\n\r\n\r\n    1\r\n    1234\r\n    abc\r\n    2\r\n    5678\r\n    def",
        "link": "https://stackoverflow.com/questions/67339698/use-jq-to-format-json-data-into-csv-data",
        "title": "use jq to format json data into csv data"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1619871484,
                "creation_date": 1619871484,
                "answer_id": 67346186,
                "question_id": 67345336,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You just need to add an equal sign :\r\n\r\n```\r\n&lt; tfplan.json jq --arg MODULE_SEARCH &#39;module.cname[&quot;tiger2&quot;]&#39; \\\r\n                 --arg FILTER_SEARCH service \\\r\n                 --arg TO_UPDATE new_service \\\r\n&#39;.resources[] |= if .module == $MODULE_SEARCH and\r\n                    .name == $FILTER_SEARCH\r\n                 then .type |= $TO_UPDATE\r\n                 else . end&#39;\r\n```",
                "title": "How to use jq to extract object with condition (if) and put it back in an array"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1619871484,
        "creation_date": 1619865931,
        "last_edit_date": 1619866978,
        "question_id": 67345336,
        "body_markdown": "I have a problem with a jq command, i have tried to parse all my :\r\n - resources[] \r\n\r\nAdd some filter:\r\n- if .module == $MODULE_SEARCH and .name ==\r\n   $FILTER_SEARCH\r\n\r\nAnd then do an update: \r\n- (.type |=$TO_UPDATE)\r\n\r\nBut with this command, i&#39;m destroying my json\r\n\r\nI have the following input (terraform state):\r\n\r\nstate.json\r\n\r\n    {\r\n      &quot;version&quot;: 4,\r\n      &quot;terraform_version&quot;: &quot;0.13.4&quot;,\r\n      &quot;serial&quot;: 1,\r\n      &quot;lineage&quot;: &quot;xxx&quot;,\r\n      &quot;resources&quot;: [\r\n        {\r\n          &quot;module&quot;: &quot;module.cname[\\&quot;tiger2\\&quot;]&quot;,\r\n          &quot;mode&quot;: &quot;managed&quot;,\r\n          &quot;type&quot;: &quot;service&quot;,\r\n          &quot;name&quot;: &quot;service&quot;,\r\n          &quot;xxx&quot; : &quot;xxx&quot;\r\n        },\r\n        {\r\n          &quot;module&quot;: &quot;module.cname[\\&quot;tiger2\\&quot;]&quot;,\r\n          &quot;mode&quot;: &quot;managed&quot;,\r\n          &quot;type&quot;: &quot;user&quot;,\r\n          &quot;name&quot;: &quot;other1&quot;,\r\n          &quot;xxx&quot; : &quot;xxx&quot;\r\n        },\r\n        {\r\n          &quot;module&quot;: &quot;module.cname[\\&quot;tiger1\\&quot;]&quot;,\r\n          &quot;mode&quot;: &quot;managed&quot;,\r\n          &quot;type&quot;: &quot;project&quot;,\r\n          &quot;name&quot;: &quot;other2&quot;,\r\n          &quot;xxx&quot; : &quot;xxx&quot;\r\n        }\r\n      ]\r\n    }\r\n\r\nI want to change it to:\r\n\r\n    {\r\n          &quot;version&quot;: 4,\r\n          &quot;terraform_version&quot;: &quot;0.13.4&quot;,\r\n          &quot;serial&quot;: 1,\r\n          &quot;lineage&quot;: &quot;xxx&quot;,\r\n          &quot;resources&quot;: [\r\n            {\r\n              &quot;module&quot;: &quot;module.cname[\\&quot;tiger2\\&quot;]&quot;, # Filter one\r\n              &quot;mode&quot;: &quot;managed&quot;,\r\n              &quot;type&quot;: &quot;new_service&quot;,                # Only this one\r\n              &quot;name&quot;: &quot;service&quot;,                    # filter two\r\n              &quot;xxx&quot; : &quot;xxx&quot;\r\n            },\r\n            {\r\n              &quot;module&quot;: &quot;module.cname[\\&quot;tiger2\\&quot;]&quot;,\r\n              &quot;mode&quot;: &quot;managed&quot;,\r\n              &quot;type&quot;: &quot;user&quot;,\r\n              &quot;name&quot;: &quot;other1&quot;,\r\n              &quot;xxx&quot; : &quot;xxx&quot;\r\n            },\r\n            {\r\n              &quot;module&quot;: &quot;module.cname[\\&quot;tiger2\\&quot;]&quot;,\r\n              &quot;mode&quot;: &quot;managed&quot;,\r\n              &quot;type&quot;: &quot;project&quot;,\r\n              &quot;name&quot;: &quot;other2&quot;,\r\n              &quot;xxx&quot; : &quot;xxx&quot;\r\n            }\r\n          ]\r\n        }\r\n\r\nI have tried:\r\n\r\n    &lt; tfplan.json jq --arg MODULE_SEARCH &#39;module.cname[&quot;tiger2&quot;]&#39; \\\r\n                --arg FILTER_SEARCH service \\\r\n                --arg TO_UPDATE new_service \\\r\n                &#39;.resources[] | if .module == $MODULE_SEARCH and .name == $FILTER_SEARCH then (.type |=$TO_UPDATE) else . end&#39;\r\n\r\nWhich give me:\r\n\r\n    {\r\n      &quot;module&quot;: &quot;module.cname[\\&quot;tiger2\\&quot;]&quot;,\r\n      &quot;mode&quot;: &quot;managed&quot;,\r\n      &quot;type&quot;: &quot;new_service&quot;,\r\n      &quot;name&quot;: &quot;service&quot;,\r\n      &quot;xxx&quot;: &quot;xxx&quot;\r\n    }\r\n    {\r\n      &quot;module&quot;: &quot;module.cname[\\&quot;tiger2\\&quot;]&quot;,\r\n      &quot;mode&quot;: &quot;managed&quot;,\r\n      &quot;type&quot;: &quot;user&quot;,\r\n      &quot;name&quot;: &quot;other1&quot;,\r\n      &quot;xxx&quot; : &quot;xxx&quot;\r\n    }\r\n    {\r\n      &quot;module&quot;: &quot;module.cname[\\&quot;tiger2\\&quot;]&quot;,\r\n      &quot;mode&quot;: &quot;managed&quot;,\r\n      &quot;type&quot;: &quot;project&quot;,\r\n      &quot;name&quot;: &quot;other2&quot;,\r\n      &quot;xxx&quot; : &quot;xxx&quot;\r\n    }\r\n\r\nI have two issues with this:\r\n - between each module the comma &quot;,&quot; was removed.\r\n - I have to put it back in &quot;resources&quot;: [] and then back to my original input file but i don&#39;t know how\r\n\r\nThanks",
        "link": "https://stackoverflow.com/questions/67345336/how-to-use-jq-to-extract-object-with-condition-if-and-put-it-back-in-an-array",
        "title": "How to use jq to extract object with condition (if) and put it back in an array"
    },
    {
        "tags": [
            "shell",
            "jq",
            "aws-cli"
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1619958937,
                "last_edit_date": 1619958937,
                "creation_date": 1619957833,
                "answer_id": 67356288,
                "question_id": 67355917,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If you have two conditions to meet, filter twice\r\n\r\n```jq\r\nselect(condition1) | select(condition2)\r\n```\r\n\r\nor `and` the conditions\r\n\r\n```jq\r\nselect(condition1 and condition2)\r\n```\r\n\r\nAs you discovered, `and`-ing the results of `select` doesn&#39;t make sense.\r\n\r\n```sh\r\njq -r &#39;\r\n   .StackSummaries[] |\r\n   select( \r\n      .StackName == &quot;some-service-name&quot; and (\r\n         .StackStatus == &quot;CREATE_COMPLETE&quot; or\r\n         .StackStatus == &quot;UPDATE_COMPLETE&quot;\r\n       )\r\n   ) |\r\n   .StackId\r\n&#39;\r\n```\r\n\r\n[jqplay](https://jqplay.org/s/Z_dtedGdLj)\r\n\r\n---\r\n\r\nNote that `|` has very low precedence, so \r\n\r\n```jq\r\na | b and c | d\r\n```\r\n\r\nmeans\r\n\r\n```jq\r\na | ( b and c ) | d\r\n```\r\n\r\nUse parens if you mean\r\n\r\n```jq\r\n( a | b ) and ( c | d )\r\n```\r\n",
                "title": "jq: How to get a value rather than boolean when matching two statements?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1619958937,
        "creation_date": 1619955508,
        "last_edit_date": 1619958652,
        "question_id": 67355917,
        "body_markdown": "I&#39;m trying to extract the ARN&#39;s (.StackId) of all AWS CloudFormation stacks which match a specific string in key StackName and StackStatus of &quot;CREATE COMPLETE&quot; or &quot;UPDATE_COMPLETE&quot;.\r\n\r\nExample:\r\n\r\n    {\r\n      &quot;StackSummaries&quot;: [\r\n        {\r\n          &quot;StackId&quot;: &quot;arn:aws:cloudformation:us-east-1:AWS_ACCOUNT_ID:stack/some-service-name/9ad489b0-ab22-11eb-af8f-0a56fXXXX8ad&quot;,\r\n          &quot;StackName&quot;: &quot;some-service-name&quot;,\r\n          &quot;CreationTime&quot;: &quot;2021-05-02T08:44:28.106000+00:00&quot;,\r\n          &quot;StackStatus&quot;: &quot;CREATE_COMPLETE&quot;,\r\n          &quot;DriftInformation&quot;: {\r\n            &quot;StackDriftStatus&quot;: &quot;NOT_CHECKED&quot;\r\n          }\r\n        },\r\n        {\r\n          &quot;StackId&quot;: &quot;arn:aws:cloudformation:us-east-1:AWS_ACCOUNT_ID:stack/some-service-name/44239210-9703-11eb-b085-12daXXXX6186&quot;,\r\n          &quot;StackName&quot;: &quot;some-service-name&quot;,\r\n          &quot;TemplateDescription&quot;: &quot;some-service-name&quot;,\r\n          &quot;CreationTime&quot;: &quot;2021-04-06T18:09:45.470000+00:00&quot;,\r\n          &quot;LastUpdatedTime&quot;: &quot;2021-04-13T13:09:37.683000+00:00&quot;,\r\n          &quot;StackStatus&quot;: &quot;UPDATE_COMPLETE&quot;,\r\n          &quot;DriftInformation&quot;: {\r\n            &quot;StackDriftStatus&quot;: &quot;NOT_CHECKED&quot;\r\n          }\r\n        }\r\n      ]\r\n    }\r\n\r\nThese are the commands I&#39;ve tried:\r\n\r\n```\r\naws cloudformation list-stacks --profile production |\r\n    jq -r &#39;.StackSummaries[] |\r\n        select(.StackName | match(&quot;some-service-name&quot;;&quot;i&quot;)) and\r\n        select(.StackStatus | match(&quot;UPDATE_COMPLETE&quot;;&quot;i&quot;)) .StackId&#39;\r\n```\r\n```\r\naws cloudformation list-stacks --profile production |\r\n    jq -r &#39;.StackSummaries[] |\r\n        select(.StackName | contains(&quot;some-service-name&quot;)) and\r\n        select(.StackStatus | contains(&quot;UPDATE_COMPLETE&quot;)) .StackId&#39;\r\n```\r\n```\r\naws cloudformation list-stacks --profile production |\r\n    jq -r &#39;.StackSummaries[] |\r\n        select(.StackName | match(&quot;some-service-name&quot;;&quot;i&quot;)) and\r\n        select(.StackStatus | match(&quot;UPDATE_COMPLETE&quot;;&quot;i&quot;) or\r\n        select(.StackStatus | match(&quot;CREATE_COMPLETE&quot;;&quot;i&quot;))) .StackId&#39;\r\n```\r\n\r\nAll of the above commands return boolean value instead of the StackId itself. How can I get the StackId instead of a boolean value?",
        "link": "https://stackoverflow.com/questions/67355917/jq-how-to-get-a-value-rather-than-boolean-when-matching-two-statements",
        "title": "jq: How to get a value rather than boolean when matching two statements?"
    },
    {
        "tags": [
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 468289,
                    "reputation": 190915,
                    "user_id": 874188,
                    "user_type": "registered",
                    "accept_rate": 62,
                    "profile_image": "https://www.gravatar.com/avatar/091f411d57db5be8298e057a32e5ad72?s=256&d=identicon&r=PG",
                    "display_name": "tripleee",
                    "link": "https://stackoverflow.com/users/874188/tripleee"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1620041108,
                "post_id": 67367991,
                "comment_id": 119075586,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1025507,
                    "reputation": 4662,
                    "user_id": 1034897,
                    "user_type": "registered",
                    "accept_rate": 57,
                    "profile_image": "https://i.sstatic.net/3RxYm.jpg?s=256",
                    "display_name": "KnowHoper",
                    "link": "https://stackoverflow.com/users/1034897/knowhoper"
                },
                "reply_to_user": {
                    "account_id": 468289,
                    "reputation": 190915,
                    "user_id": 874188,
                    "user_type": "registered",
                    "accept_rate": 62,
                    "profile_image": "https://www.gravatar.com/avatar/091f411d57db5be8298e057a32e5ad72?s=256&d=identicon&r=PG",
                    "display_name": "tripleee",
                    "link": "https://stackoverflow.com/users/874188/tripleee"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1620041595,
                "post_id": 67367991,
                "comment_id": 119075771,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1025507,
                    "reputation": 4662,
                    "user_id": 1034897,
                    "user_type": "registered",
                    "accept_rate": 57,
                    "profile_image": "https://i.sstatic.net/3RxYm.jpg?s=256",
                    "display_name": "KnowHoper",
                    "link": "https://stackoverflow.com/users/1034897/knowhoper"
                },
                "reply_to_user": {
                    "account_id": 468289,
                    "reputation": 190915,
                    "user_id": 874188,
                    "user_type": "registered",
                    "accept_rate": 62,
                    "profile_image": "https://www.gravatar.com/avatar/091f411d57db5be8298e057a32e5ad72?s=256&d=identicon&r=PG",
                    "display_name": "tripleee",
                    "link": "https://stackoverflow.com/users/874188/tripleee"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1620042287,
                "post_id": 67367991,
                "comment_id": 119076027,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1620041988,
                "last_edit_date": 1620041988,
                "creation_date": 1620041902,
                "answer_id": 67368306,
                "question_id": 67367991,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If you are asking, given\r\n\r\n```bash\r\nbash$ echo &#39;[{&quot;name&quot;: &quot;tarzan&quot;, &quot;resourceGroup&quot;: &quot;froup&quot;, &quot;id&quot;: &quot;/subscriptions/I-need-Selecting/resourcegroups/blahblah/blahblah&quot; }]&#39; |\r\n&gt; jq -r &#39;.[] | &quot;az aks get-credentials --name \\(.name) --resource-group \\(.resourceGroup) --subscription=\\(.id)&quot;&#39;\r\naz aks get-credentials --name tarzan --resource-group froup --subscription=/subscriptions/I-need-Selecting/resourcegroups/blahblah/blahblah\r\n```\r\n\r\n... how to reduce the &quot;subscription&quot; parameter to just a substring, try\r\n\r\n```\r\njq &#39;.[] |  &quot;az aks get-credentials --name \\(.name) --resource-group \\(.resourceGroup) --subscription=\\(.id | split(&quot;/&quot;)[3])&quot;&#39;\r\n```\r\n\r\nIt&#39;s not impossible to run Awk here, but given that `jq` has much the same capabilities and a built-in JSON parser, it seems better to do this natively in `jq`.",
                "title": "Extract path name component in jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1620043020,
        "creation_date": 1620040396,
        "last_edit_date": 1620043020,
        "question_id": 67367991,
        "body_markdown": "I have the following bash command\r\n\r\n```\r\nsomething something ... |\r\nxargs -L 1 az aks list --subscription |\r\njq -r &#39;.[] | &quot;az aks get-credentials --name \\(.name) --resource-group \\(.resourceGroup) --subscription=\\(.id)&quot;&#39;\r\n```\r\n\r\nThis works except the final argument `\\(.id)` is a string I need to substring using the following commands output embedded in the final output string\r\n\r\n```\r\nawk -F &quot;/&quot; &#39;{print $3}&#39; &lt;&lt;&lt; &quot;/subscriptions/I-need-Selecting/resourcegroups/blahblah/blahblah&quot;\r\n```\r\n\r\nI cannot seem to get this command to execute in the outputted command - I cannot escape the `&quot;` or `&#39;` in the `awk` effectively. \r\n\r\nThe output from the `aks list --subscriptions` command looks something like\r\n\r\n```javascript\r\n[{&quot;name&quot;: &quot;foo&quot;, &quot;resourceGroup&quot;: &quot;bar&quot;, &quot;subscription&quot;: &quot;/subscriptions/I-need-Selecting/resourcegroups/blahblah/blahblah&quot;},\r\n... ]\r\n```\r\n\r\nCan anyone help?",
        "link": "https://stackoverflow.com/questions/67367991/extract-path-name-component-in-jq",
        "title": "Extract path name component in jq"
    },
    {
        "tags": [
            "json",
            "replace",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1620069516,
                "post_id": 67369023,
                "comment_id": 119087477,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1620046319,
                "last_edit_date": 1620046319,
                "creation_date": 1620045743,
                "answer_id": 67369102,
                "question_id": 67369023,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "No need for &quot;contains&quot;. If there&#39;s no `abc`, it won&#39;t be replaced.\r\n\r\n    [ .[] | .name |= gsub(&quot;abc&quot;; &quot;XYZ&quot;) ]\r\n\r\nor, shorter and cleaner using `map`:\r\n\r\n    map(.name |= gsub(&quot;abc&quot;; &quot;XYZ&quot;))\r\n\r\nIf the condition is different, the correct syntax is\r\n\r\n    map(.name |= if contains(&quot;abc&quot;) then gsub(&quot;abc&quot;; &quot;XYZ&quot;) else . end)\r\n\r\nor\r\n\r\n    [ .[] | .name |= if contains(&quot;abc&quot;) then gsub(&quot;abc&quot;; &quot;XYZ&quot;) else . end ]",
                "title": "Search and replace text pattern"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1620101987,
        "creation_date": 1620045355,
        "last_edit_date": 1620101987,
        "question_id": 67369023,
        "body_markdown": "I am looking for a way to search/replace portion of the text in some of the values. In this example, I am looking to search for &quot;abc&quot; and replace with &quot;xyz&quot;.\r\n\r\nI tried this command without any luck: \r\n\r\n    jq -r &#39;.[].name | |= if . contains(&quot;abc&quot;) then . = gsub(&quot;abc&quot;,&quot;XYZ&quot;) else . end&#39; testfile \r\n\r\n\r\n----------\r\n\r\n\r\n\r\n```json\r\n[\r\n  {\r\n    &quot;id&quot;: 202,\r\n    &quot;name&quot;: &quot;abctext123&quot;,\r\n    &quot;module_name&quot;: &quot;xxxxxxxxxxx&quot;\r\n  },\r\n  {\r\n    &quot;id&quot;: 223,\r\n    &quot;name&quot;: &quot;abcanothertext789&quot;,\r\n    &quot;module_name&quot;: &quot;yyyyyyyyyyy&quot;\r\n  },\r\n  {\r\n    &quot;id&quot;: 202,\r\n    &quot;name&quot;: &quot;anypattern&quot;,\r\n    &quot;module_name&quot;: &quot;zzzzzzzzzzz&quot;\r\n  },\r\n  {\r\n    &quot;id&quot;: 223,\r\n    &quot;name&quot;: &quot;anothertest&quot;,\r\n    &quot;module_name&quot;: &quot;anothervalue&quot;\r\n  }\r\n]\r\n```\r\n\r\nExpected output\r\n\r\n```json\r\n[\r\n  {\r\n    &quot;id&quot;: 202,\r\n    &quot;name&quot;: &quot;XYZtext123&quot;,\r\n    &quot;module_name&quot;: &quot;xxxxxxxxxxx&quot;\r\n  },\r\n  {\r\n    &quot;id&quot;: 223,\r\n    &quot;name&quot;: &quot;XYZanothertext789&quot;,\r\n    &quot;module_name&quot;: &quot;yyyyyyyyyyy&quot;\r\n  },\r\n  {\r\n    &quot;id&quot;: 202,\r\n    &quot;name&quot;: &quot;anypattern&quot;,\r\n    &quot;module_name&quot;: &quot;zzzzzzzzzzz&quot;\r\n  },\r\n  {\r\n    &quot;id&quot;: 223,\r\n    &quot;name&quot;: &quot;anothertest&quot;,\r\n    &quot;module_name&quot;: &quot;anothervalue&quot;\r\n  }\r\n]\r\n```",
        "link": "https://stackoverflow.com/questions/67369023/search-and-replace-text-pattern",
        "title": "Search and replace text pattern"
    },
    {
        "tags": [
            "json",
            "rest",
            "sorting",
            "parsing",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1620057237,
                "creation_date": 1620057237,
                "answer_id": 67371978,
                "question_id": 67371792,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Does this achieve what you wanted ?\r\n\r\n```\r\njq &#39;.data |= sort_by(.attributes.&quot;status-timestamps&quot;.&quot;planned-at&quot;)&#39;\r\n```",
                "title": "Sorting json with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1620117751,
        "creation_date": 1620056434,
        "last_edit_date": 1620117751,
        "question_id": 67371792,
        "body_markdown": "I have this json (simplified) coming from a REST api:\r\n\r\n```json\r\n\r\n{\r\n  &quot;data&quot;: [\r\n    {\r\n      &quot;id&quot;: &quot;run-bWSq4YeYpfrW4mx7&quot;,\r\n      &quot;type&quot;: &quot;runs&quot;,\r\n      &quot;attributes&quot;: {\r\n        &quot;source&quot;: &quot;tfe-configuration-version&quot;,\r\n        &quot;status&quot;: &quot;planned&quot;,\r\n        &quot;status-timestamps&quot;: {\r\n          &quot;planned-at&quot;: &quot;2017-11-28T22:52:51+00:00&quot;\r\n        }\r\n    }\r\n    },\r\n    {\r\n      &quot;id&quot;: &quot;run-bWSq4YeYpfrW4ft7&quot;,\r\n      &quot;type&quot;: &quot;runs&quot;,\r\n      &quot;attributes&quot;: {\r\n        &quot;source&quot;: &quot;tfe-configuration-version&quot;,\r\n        &quot;status&quot;: &quot;planned&quot;,\r\n        &quot;status-timestamps&quot;: {\r\n          &quot;planned-at&quot;: &quot;2017-11-28T21:52:51+00:00&quot;\r\n        }\r\n    }\r\n    }\r\n    ]\r\n}\r\n\r\n\r\n```\r\n\r\nHow I can sort it based `status-timestamps.planned-at`?\r\n\r\nAmong other things I tried this `jq &#39;[.data[].attributes | sort_by(.status-timestamps.planned-at) ]&#39;`",
        "link": "https://stackoverflow.com/questions/67371792/sorting-json-with-jq",
        "title": "Sorting json with jq"
    },
    {
        "tags": [
            "bash",
            "ubuntu",
            "jq",
            "webhooks",
            "slack"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1620165794,
                "last_edit_date": 1620165794,
                "creation_date": 1620153490,
                "answer_id": 67390352,
                "question_id": 67389971,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Alright I figured it out. I&#39;ll leave this up in case it&#39;s helpful for anyone.\r\n\r\nSee [this post](https://stackoverflow.com/questions/67391180/use-newline-with-jq/67391273#67391273) for instructions to escape the markdown string\r\n\r\n```\r\n# Setup messages\r\nfallback_message=&quot;TEST MESSAGE - $HOSTNAME&quot;\r\nmarkdown_message=&quot;TEST MESSAGE - $HOSTNAME \\n Hi &lt;@U12345678&gt;\\n\\`\\`\\`Can we do a\\nmultiline code block\\`\\`\\`&quot;\r\n\r\n# Convert markdown message to correct format for jq parse\r\nprintf -v markdown_message_unescaped %b &quot;$markdown_message&quot;\r\n\r\n# Create the json string\r\njson_string=$( jq -nr \\\r\n    --arg jq_fallback_message &quot;$fallback_message&quot; \\\r\n    --arg jq_section_type &quot;section&quot; \\\r\n    --arg jq_markdown_type &quot;mrkdwn&quot; \\\r\n    --arg jq_markdown_message &quot;$markdown_message_unescaped&quot; \\\r\n    &#39;{\r\n        text: $jq_fallback_message, \r\n        blocks: [\r\n            {\r\n                type: $jq_section_type,\r\n                text: {\r\n                    type: $jq_markdown_type, \r\n                    text: $jq_markdown_message\r\n                }\r\n            }\r\n        ]\r\n    }&#39;)\r\n\r\n# Echo and send to slack\r\necho $json_string\r\ncurl -X POST -H &#39;Content-type: application/json&#39; --data &quot;$json_string&quot; https://hooks.slack.com/services/123456789\r\n```",
                "title": "Create jq json for slack bot"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1620165794,
        "creation_date": 1620151651,
        "last_edit_date": 1620165704,
        "question_id": 67389971,
        "body_markdown": "Update: I got this working and posted an answer.\r\n\r\nI am trying to create a markdown block for a slack bot using [jq](https://stedolan.github.io/jq/manual/) inside of a bash script. Most of the tutorials I&#39;ve found are for reading json but I am trying to create json.\r\n\r\nI&#39;m close but I&#39;m still doing something wrong. This is the [desired slack format](https://api.slack.com/messaging/webhooks), I&#39;ve copied the relevant section below:\r\n\r\n```\r\n{\r\n    &quot;text&quot;: &quot;Danny Torrence left a 1 star review for your property.&quot;,\r\n    &quot;blocks&quot;: [\r\n    \t{\r\n    \t\t&quot;type&quot;: &quot;section&quot;,\r\n    \t\t&quot;text&quot;: {\r\n    \t\t\t&quot;type&quot;: &quot;mrkdwn&quot;,\r\n    \t\t\t&quot;text&quot;: &quot;Danny Torrence left the following review for your property:&quot;\r\n    \t\t}\r\n    \t},\r\n```\r\n\r\nAnd here is a portion of my script:\r\n\r\n```\r\nFALLBACK_MESSAGE=&quot;TEST MESSAGE - $HOSTNAME&quot;\r\nFIRST_INNER_SECTION=$(jq -n --arg secType &quot;mrkdwn&quot; --arg textVal &quot;Hi\\nperson\\n&lt;@U12345789&gt;&quot; &#39;{type: $secType, text: $textVal}&#39;)\r\nFIRST_OUTER_SECTION=$(jq -n --arg secType &quot;section&quot; --arg textVal &quot;$FIRST_INNER_SECTION&quot; &#39;{type: $secType, text: $textVal}&#39;)\r\necho $FIRST_INNER_SECTION\r\necho $FIRST_OUTER_SECTION\r\nMY_STR=$(jq -n --arg text &quot;$FALLBACK_MESSAGE&quot; --arg blocks &quot;$FIRST_OUTER_SECTION&quot; &#39;{text: $text, blocks: [$blocks]}&#39;);\r\necho $MY_STR\r\ncurl -X POST -H &#39;Content-type: application/json&#39; --data &quot;$MY_STR&quot; https://hooks.slack.com/services/123456789\r\n```\r\n\r\nI am getting an invalid blocks format error. I think it&#39;s due to creating multiple strings and trying to combine them with jq (seeing lots of slashes and newlines). I tried using different flags besides -n but they didn&#39;t work. I am going to try creating a mega string now but would prefer to split it up like I&#39;ve done. Any help here?\r\n\r\nUpdate with Megastring working. Would still like to find a way to format this better.\r\n\r\n```\r\nJSON_STRING=$( jq -n --arg fallbackText &quot;Fallback message&quot; --arg sectionType &quot;section&quot; --arg markdownType &quot;mrkdwn&quot; --arg textType &quot;test&quot; &#39;{text: $fallbackText, blocks: [{type: $sectionType, text: {type: $markdownType, text: $textType}}]}&#39;)\r\necho $JSON_STRING\r\ncurl -X POST -H &#39;Content-type: application/json&#39; --data &quot;$JSON_STRING&quot; https://hooks.slack.com/services/12345678\r\n```\r\n\r\n",
        "link": "https://stackoverflow.com/questions/67389971/create-jq-json-for-slack-bot",
        "title": "Create jq json for slack bot"
    },
    {
        "tags": [
            "json",
            "bash",
            "ubuntu",
            "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": 2,
                "creation_date": 1620157497,
                "post_id": 67391180,
                "comment_id": 119116995,
                "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": 1620157510,
                "post_id": 67391180,
                "comment_id": 119117002,
                "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": 1620157535,
                "post_id": 67391180,
                "comment_id": 119117012,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1620158076,
                "post_id": 67391180,
                "comment_id": 119117234,
                "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": 1620158757,
                "post_id": 67391180,
                "comment_id": 119117546,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 89073,
                    "reputation": 41716,
                    "user_id": 245966,
                    "user_type": "registered",
                    "accept_rate": 82,
                    "profile_image": "https://www.gravatar.com/avatar/96246ecff3f790f6b8a35c80c6f67ea3?s=256&d=identicon&r=PG",
                    "display_name": "jakub.g",
                    "link": "https://stackoverflow.com/users/245966/jakub-g"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1664470339,
                "post_id": 67391180,
                "comment_id": 130485020,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 5,
                "is_accepted": true,
                "score": 5,
                "last_activity_date": 1620158639,
                "last_edit_date": 1620158639,
                "creation_date": 1620157710,
                "answer_id": 67391273,
                "question_id": 67391180,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Make sure your shell variables contain _actual newlines_, not `\\n` sequences.\r\n\r\nIf you want bash to convert escape sequences in a string into the characters they refer to, `printf %b` can be used for this purpose.\r\n\r\n```bash\r\n#!/usr/bin/env bash\r\n\r\nfallback_message=&quot;TEST MESSAGE - $HOSTNAME&quot;\r\nmarkdown_message=&quot;TEST MESSAGE - $HOSTNAME \\(0x0a) \\(\\n) Hi &lt;@U12345789&gt;\\n\\`\\`\\`Can we do a\\nmultiline code block\\`\\`\\`&quot;\r\n\r\n# create markdown_message_unescaped with an unescaped version of markdown_message\r\nprintf -v markdown_message_unescaped %b &quot;$markdown_message&quot;\r\n\r\njq -n \\\r\n  --arg textMessage &quot;$markdown_message_unescaped&quot; \\\r\n  --arg fallbackMessage &quot;$fallback_message&quot; \\\r\n  --arg sectionType section --arg markdownType markdown &#39;\r\n    {\r\n      text: $fallbackMessage, \r\n      blocks: [\r\n        {\r\n          type: $sectionType,\r\n          text: {\r\n                    type: $markdownType, \r\n                    text: $textMessage\r\n                }\r\n            }\r\n        ]\r\n    }&#39;\r\n```\r\n\r\n...properly emits as output:\r\n\r\n```json\r\n{\r\n  &quot;text&quot;: &quot;TEST MESSAGE - YOUR_HOSTNAME&quot;,\r\n  &quot;blocks&quot;: [\r\n    {\r\n      &quot;type&quot;: &quot;section&quot;,\r\n      &quot;text&quot;: {\r\n        &quot;type&quot;: &quot;markdown&quot;,\r\n        &quot;text&quot;: &quot;TEST MESSAGE - YOUR_HOSTNAME (0x0a) (\\n)\\nHi &lt;@U12345789&gt;\\n```\\nCan we do a multiline code block\\n```&quot;\r\n      }\r\n    }\r\n  ]\r\n}\r\n```",
                "title": "Use newline with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 4,
        "last_activity_date": 1620158639,
        "creation_date": 1620157291,
        "question_id": 67391180,
        "body_markdown": "I&#39;ve seen a number of posts on this but can&#39;t figure out what I need exactly. I&#39;ve tried `-r` and `argjson` among other things.\r\n\r\nI need the newlines to remain as `\\n` and not be escaped to `\\\\n`. \r\n\r\nI&#39;d also like to be able to use ``` for code blocks but it ignores that section of the string.\r\n\r\n```\r\nFALLBACK_MESSAGE=&quot;TEST MESSAGE - $HOSTNAME&quot;\r\nMARKDOWN_MESSAGE=&quot;TEST MESSAGE - $HOSTNAME \\(0x0a) \\(\\n) Hi &lt;@U12345789&gt;\\n```Can we do a\\nmultiline code block```&quot;\r\nJSON_STRING=$( jq -nr \\\r\n    --arg fallbackMessage &quot;$FALLBACK_MESSAGE&quot; \\\r\n    --arg sectionType &quot;section&quot; \\\r\n    --arg markdownType &quot;mrkdwn&quot; \\\r\n    --arg textMessage &quot;$MARKDOWN_MESSAGE&quot; \\\r\n    &#39;{\r\n        text: $fallbackMessage, \r\n        blocks: [\r\n            {\r\n                type: $sectionType,\r\n                text: {\r\n                    type: $markdownType, \r\n                    text: $textMessage\r\n                }\r\n            }\r\n        ]\r\n    }&#39;)\r\necho $JSON_STRING\r\n```\r\n\r\nOutputs:\r\n\r\n```\r\n{ &quot;text&quot;: &quot;TEST MESSAGE - devDebug&quot;, &quot;blocks&quot;: [ { &quot;type&quot;: &quot;section&quot;, &quot;text&quot;: { &quot;type&quot;: &quot;mrkdwn&quot;, &quot;text&quot;: &quot;TEST MESSAGE - devDebug \\\\(0x0a) \\\\(\\\\n) Hi &lt;@U12345789&gt;\\\\n&quot; } } ] }\r\n```\r\n\r\n",
        "link": "https://stackoverflow.com/questions/67391180/use-newline-with-jq",
        "title": "Use newline with jq"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq",
            "gcloud"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1620227360,
                "creation_date": 1620227360,
                "answer_id": 67403979,
                "question_id": 67402087,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "There are various ways to do this, but I would recommend you to just do it with ```awk``` since you can use the ``,`` and then ``/`` as the separators from the output of the command. \r\n\r\nYou can use something like this based on the command you shared:\r\n```gcloud compute instances list --project $projectname --format=json | jq -r &#39;.[]| .name +&quot;,&quot;+.machineType&#39; | awk -F&#39;,&#39; &#39;{print $1&quot;/&quot;$2}&#39; | awk -F&#39;/&#39; &#39;{print $1&quot;=&quot;$12}&#39;```.\r\n\r\nAnd you would get ``$instance-name=$machine-type``\r\n\r\nHope you find this useful.",
                "title": "Gcloud json format get not the full url of machine tpye"
            },
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1620229550,
                "last_edit_date": 1620229550,
                "creation_date": 1620229070,
                "answer_id": 67404436,
                "question_id": 67402087,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "See Cloud SDK (gcloud) topic formats:\r\n\r\nhttps://cloud.google.com/sdk/gcloud/reference/topic/formats\r\nhttps://cloud.google.com/sdk/gcloud/reference/topic/projections#scope\r\n\r\n```bash\r\ngcloud compute instances list \\\r\n--project=${PROJECT} \\\r\n--format=&quot;value(machineType.scope(machineTypes))&quot;\r\n```\r\n\r\n&gt; **NOTE** You asked how to do this with `gcloud` and this is the way. @rsalinas&#39; point is good. There&#39;s a philosophy that tech should &quot;do one thing well&quot; and `gcloud`&#39;s formatting|filtering break this. Personally, I prefer to `gcloud ... --format=json | jq .` and use [jq](https://stedolan.github.io/jq/) to process `gcloud` output partly because I can use the same theory with `kubectl`, `doctl` etc. etc. etc. `awk` is another magical tool that is generally useful.",
                "title": "Gcloud json format get not the full url of machine tpye"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1620229550,
        "creation_date": 1620220553,
        "last_edit_date": 1620226188,
        "question_id": 67402087,
        "body_markdown": "Running a gcloud query and trying to get the output of the json to only include the actual machine type in stead of the full url.  \r\n\r\n```\r\ngcloud compute instances list --project $projectname --format=json | jq -r &#39;.[]| .name +&quot;,&quot;+.machineType&#39;\r\n```\r\n  \r\nWhich prints out as  \r\n```\r\n$instancename,https://www.googleapis.com/compute/v1/projects/$projectname/zones/europe-west2-a/machineTypes/n1-standard-4\r\n```  \r\n\r\nIt currently prints out the full machineType, wondering if anyone knows of a way to short the url to get just the machine type as the string instead of the full url.\r\n\r\nI&#39;ve got this sed as well to clear the format but how does one apply to only the second string without deleting the name `sed &#39;s@.*/@@&#39;`  \r\n\r\nThanks in advance\r\n\r\nedit: found some potential with split in jq  \r\n```\r\ngcloud compute instances list --project $projectname --format=json | jq -r &#39;.[]|(.machineType|split(&quot;https://www.googleapis.com/compute/v1/projects/&quot;))&#39;\r\n```\r\n",
        "link": "https://stackoverflow.com/questions/67402087/gcloud-json-format-get-not-the-full-url-of-machine-tpye",
        "title": "Gcloud json format get not the full url of machine tpye"
    },
    {
        "tags": [
            "json",
            "datetime",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 5848223,
                    "reputation": 7889,
                    "user_id": 4607733,
                    "user_type": "registered",
                    "accept_rate": 80,
                    "profile_image": "https://www.gravatar.com/avatar/4317a6c4af486878dd8eded6c251e41a?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "logi-kal",
                    "link": "https://stackoverflow.com/users/4607733/logi-kal"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1620222006,
                "post_id": 67402313,
                "comment_id": 119136537,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 370815,
                    "reputation": 2677,
                    "user_id": 719001,
                    "user_type": "registered",
                    "accept_rate": 83,
                    "profile_image": "https://www.gravatar.com/avatar/2b1e8be0851df051f538c08ba23a0208?s=256&d=identicon&r=PG",
                    "display_name": "Nir",
                    "link": "https://stackoverflow.com/users/719001/nir"
                },
                "reply_to_user": {
                    "account_id": 5848223,
                    "reputation": 7889,
                    "user_id": 4607733,
                    "user_type": "registered",
                    "accept_rate": 80,
                    "profile_image": "https://www.gravatar.com/avatar/4317a6c4af486878dd8eded6c251e41a?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "logi-kal",
                    "link": "https://stackoverflow.com/users/4607733/logi-kal"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1620222189,
                "post_id": 67402313,
                "comment_id": 119136637,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 5848223,
                    "reputation": 7889,
                    "user_id": 4607733,
                    "user_type": "registered",
                    "accept_rate": 80,
                    "profile_image": "https://www.gravatar.com/avatar/4317a6c4af486878dd8eded6c251e41a?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "logi-kal",
                    "link": "https://stackoverflow.com/users/4607733/logi-kal"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1620222738,
                "post_id": 67402313,
                "comment_id": 119136920,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": false,
                "score": 4,
                "last_activity_date": 1620229659,
                "last_edit_date": 1620229659,
                "creation_date": 1620222433,
                "answer_id": 67402599,
                "question_id": 67402313,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can do it in sed, but you can also call `sub` directly in `jq`:\r\n\r\n    jq -r &#39;[.a, .b,\r\n               ( .time \r\n                 | sub(&quot;(?&lt;y&gt;\\\\d{4})(?&lt;m&gt;\\\\d{2})(?&lt;d&gt;\\\\d{2})T&quot;;\r\n                       .y+&quot;-&quot;+.m+&quot;-&quot;+.d+&quot; &quot;)\r\n               )\r\n           ] | @tsv&#39;",
                "title": "replace string with jq"
            },
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1620224030,
                "creation_date": 1620224030,
                "answer_id": 67403066,
                "question_id": 67402313,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "With sed:\r\n```bash\r\n$ echo &quot;20210427T19:23:00&quot; | sed -r &#39;s|([[:digit:]]{4})([[:digit:]]{2})([[:digit:]]\r\n{2})T|\\1-\\2-\\3 |&#39;\r\n2021-04-27 19:23:00\r\n```",
                "title": "replace string with jq"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1620229966,
                "creation_date": 1620229966,
                "answer_id": 67404660,
                "question_id": 67402313,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Use `strptime` for date interpretation and `strftime` for formatting:\r\n\r\n_parse.jq_\r\n\r\n```jq\r\n[ \r\n  .a,\r\n  .b,\r\n  ( .time\r\n    | strptime(&quot;%Y%m%dT%H:%M:%S&quot;)\r\n    | strftime(&quot;%Y-%d-%m %H:%M:%S&quot;)\r\n  )\r\n] | @tsv\r\n```\r\nRun it like this:\r\n```\r\n&lt;input.json jq -rf parse.jq\r\n```\r\nOr as a one-liner:\r\n```\r\n&lt;input.json jq -r &#39;[.a,.b,(.time|strptime(&quot;%Y%m%dT%H:%M:%S&quot;)|strftime(&quot;%Y-%d-%m %H:%M:%S&quot;))]|@tsv&#39;\r\n```\r\nOutput:\r\n```none\r\na\ta\t2021-10-02 10:10:00\r\nb\tb\t2021-10-02 11:10:00\r\n```",
                "title": "replace string with jq"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1620231088,
                "last_edit_date": 1620231088,
                "creation_date": 1620230763,
                "answer_id": 67404875,
                "question_id": 67402313,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Since speed is an issue, and since there does not appear to be a need for anything more than string splitting, you could compare string splitting done with jq using\r\n\r\n    [.a, .b,\r\n     (.time | &quot;\\(.[:4])-\\(.[4:6])-\\(.[6:8]) \\(.[9:])&quot;]\r\n\r\nvs similar splitting using `jq` with `awk -F\\\\t &#39;BEGIN{OFS=FS} ....&#39;` (`awk` for ease of handling the TSV).\r\n\r\n",
                "title": "replace string with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 4,
        "score": 2,
        "last_activity_date": 1620322660,
        "creation_date": 1620221430,
        "last_edit_date": 1620322660,
        "question_id": 67402313,
        "body_markdown": "I have the following file `file.txt`:\r\n\r\n    {&quot;a&quot;: &quot;a&quot;, &quot;b&quot;: &quot;a&quot;, &quot;time&quot;: &quot;20210210T10:10:00&quot;}\r\n    {&quot;a&quot;: &quot;b&quot;, &quot;b&quot;: &quot;b&quot;, &quot;time&quot;: &quot;20210210T11:10:00&quot;}\r\n\r\nI extract the values with `bash` command `jq` (I use this command on massive 100g files):\r\n\r\n    jq -r &#39;[.a, .b, .time] | @tsv&#39;\r\n\r\nThis returns good result of:\r\n\r\n    a        a        20210210T10:10:00\r\n    b        b        20210210T11:10:00\r\n\r\nThe output I would like is:\r\n\r\n    a        a        2021-02-10 10:10:00\r\n    b        b        2021-02-10 11:10:00\r\n\r\n\r\nThe problem is that I want to change the format of the date in the most efficient way possible.\r\nHow do I do that?",
        "link": "https://stackoverflow.com/questions/67402313/replace-string-with-jq",
        "title": "replace string with jq"
    },
    {
        "tags": [
            "json",
            "shell",
            "unix",
            "split",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1620242877,
                "post_id": 67404726,
                "comment_id": 119146243,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1620230853,
                "creation_date": 1620230853,
                "answer_id": 67404902,
                "question_id": 67404726,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You could use JQ to process the input file - reformat it using `-c` (compact) and then use standard unix tools to split the files, i.e.\r\n\r\n    cat input | jq --slurp -c .[] | head -5 | jq . &gt; FirstTopObject.json\r\n    cat input | jq --slurp -c .[] | sed &#39;6,10!d&#39; | jq . &gt; SecondTopObject.json\r\n    cat input | jq --slurp -c .[] | tail -5 | jq . &gt; ThirdTopObject.json",
                "title": "Retrieving required set-off json objects using through &quot;Jq&quot; method"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1620242560,
                "last_edit_date": 1620242560,
                "creation_date": 1620231923,
                "answer_id": 67405189,
                "question_id": 67404726,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "There is no need to slurp the input file!  Even if the output must be pretty-printed, there is no need for more than four invocations of jq altogether.\r\n\r\n## Handling a small input file\r\n\r\nIf the input is not so big, you can simply run\r\n\r\n      jq -c . input\r\n\r\ndirecting the output to a temporary file, and then split that file into three using whichever standard command-line tools you find most convenient (a single invocation of awk might be worth considering ...).\r\n\r\n### Handling a very large input file\r\n\r\nIf the input file is very large, then it would make sense to use jq just to copy the (15) items of interest into a temporary file, and then process that file:\r\n\r\n**Step 1**\r\nInvoke the following program with `jq -cn`:\r\n\r\n```\r\ndef echo($n1; $n2; $last):\r\n   foreach (inputs,null) as $in ({ix:-1, first:[], second:[], last:[]};\r\n      if $in then\r\n        .ix += 1\r\n        | if .ix &lt; $n1\r\n          then .first += [$in]\r\n          elif .ix &lt; $n1+n2 then .second += [$in]\r\n          else .last += [$in]\r\n          | .last = (.last[ - $last: ])\r\n          end\r\n       else . end;\r\n      if $in == null then del(.ix) else empty end\r\n      )\r\n      | .[];\r\n\r\necho(5;5;5)\r\n\r\n```\r\n(This program is somewhat complex because it makes no assumptions about the relative sizes of the three blocks.)\r\n\r\n**Step 2**\r\nAssuming the output from Step 1 is in input.tmp, then run:\r\n\r\n     sed -n 1p input.tmp | jq .[] &gt; FirstTopObject.json\r\n     sed -n 2p input.tmp | jq .[] &gt; SecondTopObject.json\r\n     sed -n 3p input.tmp | jq .[] &gt; ThirdTopObject.json\r\n\r\n",
                "title": "Retrieving required set-off json objects using through &quot;Jq&quot; method"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1620237438,
                "creation_date": 1620237438,
                "answer_id": 67406449,
                "question_id": 67404726,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can use a combination of the jq functions `to_entries` and `group_by` for this, along with a little bash.\r\n\r\nThis snippet will create 25 strings (`&quot;line 0&quot;`, `&quot;line 1&quot;`, etc.), group them by 5s, and write them into files `0.json`, `1.json`, etc. Everything before `to_entries` can be replaced with any list. In your case, you can use the slurp flag `-s` to get all your JSON objects in your input file into a list.\r\n\r\n```\r\nFILE_NUM=0\r\njq -nc &#39;\r\n  # create input\r\n  [&quot;line &quot; + (range(25) | tostring)] | \r\n\r\n  # process input\r\n  to_entries | group_by(.key / 5 | floor)[] | map(.value)\r\n&#39; | while read LINE; do echo &quot;$LINE&quot; &gt; &quot;/tmp/$((FILE_NUM++)).json&quot;; done\r\n```",
                "title": "Retrieving required set-off json objects using through &quot;Jq&quot; method"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 1,
        "last_activity_date": 1620242560,
        "creation_date": 1620230162,
        "last_edit_date": 1620232076,
        "question_id": 67404726,
        "body_markdown": "I have below mentioned Json file. I wanted to do the below checks. \r\n\r\n1.\tGet 1st 5 objects from the whole list and save them in a separate file (i.e FirstTopObject.json)\r\n2.\tGet another set-off 5 objects and store them into another file (i.e SecondTopObject.json)\r\n3.\tGet the last 5 objects and store them into another file (i.e ThirdTopObject.json)\r\n\r\nBasically, wanted to split the Objects based on the Numbers and save them into a separate file. \r\n\r\nIs there any solution is available to achieve through the **“jq”** function/method?\r\n\r\n\r\nInput File: \r\n\r\n    {\r\n      &quot;storeId&quot;: &quot;0001&quot;\r\n    }\r\n    {\r\n      &quot;storeId&quot;: &quot;0002&quot;\r\n    }\r\n    {\r\n      &quot;storeId&quot;: &quot;0003&quot;\r\n    }\r\n    {\r\n      &quot;storeId&quot;: &quot;0004&quot;\r\n    }\r\n    {\r\n      &quot;storeId&quot;: &quot;0005&quot;\r\n    }\r\n    {\r\n      &quot;storeId&quot;: &quot;0006&quot;\r\n    }\r\n    {\r\n      &quot;storeId&quot;: &quot;0007&quot;\r\n    }\r\n    {\r\n      &quot;storeId&quot;: &quot;0008&quot;\r\n    }\r\n    {\r\n      &quot;storeId&quot;: &quot;0009&quot;\r\n    }\r\n    {\r\n      &quot;storeId&quot;: &quot;00010&quot;\r\n    }\r\n    {\r\n      &quot;storeId&quot;: &quot;00011&quot;\r\n    }\r\n    {\r\n      &quot;storeId&quot;: &quot;00012&quot;\r\n    }\r\n    {\r\n      &quot;storeId&quot;: &quot;00013&quot;\r\n    }\r\n    {\r\n      &quot;storeId&quot;: &quot;00014&quot;\r\n    }\r\n    {\r\n      &quot;storeId&quot;: &quot;00015&quot;\r\n    }\r\n    enter code here\r\n    enter code here\r\n\r\nExpecting output: \r\nFirstTopObject.json should have the below set. \r\n\r\n    {\r\n      &quot;storeId&quot;: &quot;0001&quot;\r\n    }\r\n    {\r\n      &quot;storeId&quot;: &quot;0002&quot;\r\n    }\r\n    {\r\n      &quot;storeId&quot;: &quot;0003&quot;\r\n    }\r\n    {\r\n      &quot;storeId&quot;: &quot;0004&quot;\r\n    }\r\n    {\r\n      &quot;storeId&quot;: &quot;0005&quot;\r\n    }\r\n\r\nSecondTopObject.json - shold contain below setoff objects. \r\n\r\n    {\r\n      &quot;storeId&quot;: &quot;0006&quot;\r\n    }\r\n    {\r\n      &quot;storeId&quot;: &quot;0007&quot;\r\n    }\r\n    {\r\n      &quot;storeId&quot;: &quot;0008&quot;\r\n    }\r\n    {\r\n      &quot;storeId&quot;: &quot;0009&quot;\r\n    }\r\n    {\r\n      &quot;storeId&quot;: &quot;00010&quot;\r\n    }\r\n\r\nLike wise for other set. \r\n\r\nIt Would be more helpful if some help me. \r\n\r\nThanks in advance! \r\n\r\n",
        "link": "https://stackoverflow.com/questions/67404726/retrieving-required-set-off-json-objects-using-through-jq-method",
        "title": "Retrieving required set-off json objects using through &quot;Jq&quot; method"
    },
    {
        "tags": [
            "json",
            "parsing",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1620232290,
                "post_id": 67405114,
                "comment_id": 119141897,
                "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": 1620232383,
                "post_id": 67405114,
                "comment_id": 119141949,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1620238226,
                "creation_date": 1620238226,
                "answer_id": 67406617,
                "question_id": 67405114,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The input you provided is an array of strings. The command `.foo1` is trying to get the `foo1` field of an input object, but the input is an array, not an object. Likewise, the command `.[] | .foo1` is trying to iterate through the input array (this is fine) and then get the `foo1` field of each item object, but these items are strings, not objects.\r\n\r\nIf you want to get the `xxxxxx` that is in the string beginning with `foo1:`, you can do something like this:\r\n```\r\n$ jq &#39;.[] | select(startswith(&quot;foo1&quot;)) | sub(&quot;foo1:\\\\s+&quot;; &quot;&quot;)&#39; file.txt\r\n&quot;xxxxxx&quot;\r\n```\r\n\r\nIf you want to turn your input into an actual JSON object, you can iterate over each string, use `capture` to get the key and value, and then use `from_entries` to stitch it all back together into a single object. At this point, you can append your original `.foo1` and you&#39;ll get the behavior you originally expected.\r\n```\r\n$ jq &#39;map(capture(&quot;^(?&lt;key&gt;.*):\\\\s*(?&lt;value&gt;.*)$&quot;)) | from_entries&#39; file.txt\r\n{\r\n  &quot;foo1&quot;: &quot;xxxxxx&quot;,\r\n  &quot;foo2&quot;: &quot;xxxxxx&quot;,\r\n  &quot;foo3&quot;: &quot;xxxxxx&quot;,\r\n  &quot;foo4&quot;: &quot;xxxxxx&quot;,\r\n  &quot;foo5&quot;: &quot;xxxxxx&quot;,\r\n  &quot;foo6&quot;: &quot;xxxxxx&quot;\r\n}\r\n```",
                "title": "Cannot index string : Wrong command with jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -1,
        "last_activity_date": 1620238226,
        "creation_date": 1620231701,
        "question_id": 67405114,
        "body_markdown": "I&#39;ve this type of data :\r\n\r\n```\r\n[\r\n  &quot;foo1:         xxxxxx&quot;,\r\n  &quot;foo2:    xxxxxx&quot;,\r\n  &quot;foo3:     xxxxxx&quot;,\r\n  &quot;foo4:         xxxxxx&quot;,\r\n  &quot;foo5:   xxxxxx&quot;,\r\n  &quot;foo6:       xxxxxx&quot;\r\n]\r\n\r\n```\r\n\r\nI would like to parse it with jq. I&#39;ve tried that : \r\n```\r\ncat file.txt | jq &#39;.foo1&#39;\r\n```\r\n```\r\ncat file.txt | jq &#39;.[] | .foo1&#39;\r\n```\r\n\r\nAnd I&#39;ve this error everytime :\r\n```\r\njq: error (at &lt;stdin&gt;:8): Cannot index string with string &quot;foo1&quot;\r\nexit status 5\r\n```\r\nBut I don&#39;t know why ! \r\n\r\nThere is someone to show me what is wrong with my jq command ?\r\n\r\nThanks",
        "link": "https://stackoverflow.com/questions/67405114/cannot-index-string-wrong-command-with-jq",
        "title": "Cannot index string : Wrong command with jq?"
    },
    {
        "tags": [
            "json",
            "linux",
            "bash",
            "export-to-csv",
            "jq"
        ],
        "comments": [
            {
                "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": 0,
                "creation_date": 1620249570,
                "post_id": 67408791,
                "comment_id": 119148652,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 8634572,
                    "reputation": 344,
                    "user_id": 6465229,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/qAMDZ.png?s=256",
                    "display_name": "Maulik Pipaliya Joyy",
                    "link": "https://stackoverflow.com/users/6465229/maulik-pipaliya-joyy"
                },
                "reply_to_user": {
                    "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": 0,
                "creation_date": 1620249671,
                "post_id": 67408791,
                "comment_id": 119148682,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1620249835,
                "creation_date": 1620249835,
                "answer_id": 67408906,
                "question_id": 67408791,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can use `@csv` to generate CSV output from arrays, and `to_entries` to break up the object&#39;s elements into said arrays:\r\n\r\n```sh\r\n$ jq -r &#39;.rates | to_entries[] | [ .key, .value ] | @csv&#39; input.json\r\n&quot;611&quot;,0.389165\r\n&quot;ABC&quot;,59.99\r\n&quot;ACP&quot;,0.014931\r\n&quot;ACT&quot;,0.021098\r\n&quot;ACT*&quot;,0.017178\r\n&quot;ADA&quot;,1.460965\r\n```",
                "title": "jq : print key and value for each entry in nested object"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1620249835,
        "creation_date": 1620249173,
        "question_id": 67408791,
        "body_markdown": "This is JSON Object\r\n\r\n    {\r\n        &quot;success&quot;: true,\r\n        &quot;terms&quot;: &quot;https://coinlayer.com/terms&quot;,\r\n        &quot;privacy&quot;: &quot;https://coinlayer.com/privacy&quot;,\r\n        &quot;timestamp&quot;: 1620244806,\r\n        &quot;target&quot;: &quot;USD&quot;,\r\n        &quot;rates&quot;: {\r\n          &quot;611&quot;: 0.389165,\r\n          &quot;ABC&quot;: 59.99,\r\n          &quot;ACP&quot;: 0.014931,\r\n          &quot;ACT&quot;: 0.021098,\r\n          &quot;ACT*&quot;: 0.017178,\r\n          &quot;ADA&quot;: 1.460965\r\n        }\r\n      }\r\n\r\n\r\nI require this type of output:\r\n\r\n    611,0.389165\r\n    ABC,59.99\r\n    ACP,0.014931\r\n    ACT,0.021098\r\n    ACT*,0.017178\r\n    ADA,1.460965\r\n\r\n\r\nCan somebody help me figure out doing it preferably with **jq**, shell script or command.",
        "link": "https://stackoverflow.com/questions/67408791/jq-print-key-and-value-for-each-entry-in-nested-object",
        "title": "jq : print key and value for each entry in nested object"
    },
    {
        "tags": [
            "gzip",
            "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": 1620288684,
                "post_id": 67414225,
                "comment_id": 119157908,
                "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": 1620291288,
                "post_id": 67414225,
                "comment_id": 119158995,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 370815,
                    "reputation": 2677,
                    "user_id": 719001,
                    "user_type": "registered",
                    "accept_rate": 83,
                    "profile_image": "https://www.gravatar.com/avatar/2b1e8be0851df051f538c08ba23a0208?s=256&d=identicon&r=PG",
                    "display_name": "Nir",
                    "link": "https://stackoverflow.com/users/719001/nir"
                },
                "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": 1620291716,
                "post_id": 67414225,
                "comment_id": 119159151,
                "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": 1620292450,
                "post_id": 67414225,
                "comment_id": 119159427,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 289134,
                    "reputation": 389369,
                    "user_id": 589924,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/b2cf53d5a3d25f95c0db4e025aed4153?s=256&d=identicon&r=PG",
                    "display_name": "ikegami",
                    "link": "https://stackoverflow.com/users/589924/ikegami"
                },
                "reply_to_user": {
                    "account_id": 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": 1620304717,
                "post_id": 67414225,
                "comment_id": 119165038,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 7522752,
                    "reputation": 1237,
                    "user_id": 5714068,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/028164512c08d2916841123a424d5786?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "tomc",
                    "link": "https://stackoverflow.com/users/5714068/tomc"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1621022271,
                "post_id": 67414225,
                "comment_id": 119379362,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 5,
                "is_accepted": true,
                "score": 5,
                "last_activity_date": 1714534371,
                "last_edit_date": 1714534371,
                "creation_date": 1620301617,
                "answer_id": 67417499,
                "question_id": 67414225,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If it takes 20 minutes to unzip, it&#39;s going to take 20 minutes to unzip whether the library is used by `gunzip` or by `jq`.\r\n\r\nBut, you could avoid writing the unzipped file to disk and the time related to that. This would be achieved by using one of the following:\r\n\r\n```sh\r\ngunzip -c file.gz | jq -r &#39;[ .a, .b, .time ] | @tsv&#39; &gt;file.tsv\r\n```\r\n\r\n```sh\r\ngunzip &lt;file.gz | jq -r &#39;[ .a, .b, .time ] | @tsv&#39; &gt;file.tsv\r\n```\r\n\r\n---\r\n\r\nTo be clear, the above uses minimal memory given that the input is a series of small JSON documents. (The input is a series of JSON documents of the form `{&quot;a&quot;: &quot;a&quot;, &quot;b&quot;: &quot;a&quot;, &quot;time&quot;: &quot;20210210T10:10:00&quot;}`.) Not one of the three files (compressed, decompressed or TSV) is found in memory in its entirety at any time.\r\n\r\nThe following demonstrates the streaming nature of `jq`:\r\n\r\n```lang-none\r\n$ (\r\n   j=&#39;{&quot;a&quot;: &quot;a&quot;, &quot;b&quot;: &quot;a&quot;, &quot;time&quot;: &quot;20210210T10:10:00&quot;}&#39;\r\n   printf &#39;%s\\n&#39; &quot;$j&quot;\r\n   printf &#39;%s\\n&#39; &quot;$j&quot;\r\n   sleep 4\r\n   printf &#39;%s\\n&#39; &quot;$j&quot;\r\n) | jq -r &#39;[ .a, .b, .time, now ] | @tsv&#39;\r\na       a       20210210T10:10:00       1620305187.460741\r\na       a       20210210T10:10:00       1620305187.460791\r\n[4 second pause]\r\na       a       20210210T10:10:00       1620305191.459734\r\n```\r\n\r\nThe first two records are emitted without delay, and the third is emitted after 4 seconds. This is reflected by the timestamps.\r\n",
                "title": "Is it possible to read gzip file directly with jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1714534371,
        "creation_date": 1620288569,
        "question_id": 67414225,
        "body_markdown": "I&#39;m reading huge json files with `jq`, something like:\r\n\r\n    jq -r &#39;[.a, .b, .time] | @tsv&#39; file.txt\r\n\r\nthose files are coming as `gz` files and I spend each day 20 minutes just to `gunzip` them.\r\nI was wondering is it possible to read the files with `jq` directly from the `gz` format? and if so, will it faster overall or will it slow down my process?",
        "link": "https://stackoverflow.com/questions/67414225/is-it-possible-to-read-gzip-file-directly-with-jq",
        "title": "Is it possible to read gzip file directly with jq?"
    },
    {
        "tags": [
            "json",
            "select",
            "key",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1620390256,
                "last_edit_date": 1620390256,
                "creation_date": 1620385139,
                "answer_id": 67433696,
                "question_id": 67433142,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If you get the path to where you will be adding the new field first, you can simply extract the parent key from that.\r\n```\r\nreduce path(.TopB[] | select(.Type == &quot;that&quot;) .Properties.newElement) as $p (.; setpath($p; &quot;Prefix-\\($p[1])&quot;))\r\n```\r\n&lt;sup&gt;[Online demo](https://jqplay.org/s/7j6UOO8r2u)&lt;/sup&gt;",
                "title": "Using JQ to inject element at specific position based on conditions"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1620625152,
                "last_edit_date": 1620625152,
                "creation_date": 1620624829,
                "answer_id": 67465225,
                "question_id": 67433142,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;a solution that uses `walk/1` and is therefore perhaps quite intuitive:\r\n```\r\nwalk(if (type == &quot;object&quot;) and .TopB\r\n     then .TopB |= with_entries( \r\n       .key as $key\r\n       | if .value.Type == &quot;that&quot; \r\n         then .value.Properties += { newElement: (&quot;Prefix-&quot; + $key) }\r\n         else . end)\r\n     else . end)\r\n```\r\n\r\nOne advantage of this solution is that it meets the stated requirement:\r\n\r\n&gt; The goal is to add an element to the Properties node of any TopB child ...\r\n\r\nin the sense that no assumptions are made about the locations of  objects with the &quot;topB&quot; key.\r\n",
                "title": "Using JQ to inject element at specific position based on conditions"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1620625275,
        "creation_date": 1620382912,
        "last_edit_date": 1620625275,
        "question_id": 67433142,
        "body_markdown": "Pulling my hair here, trying to use jq to parse and extend a JSON file and adding an element at a specific position based on a certain condition. \r\nHere is a sample file (also at https://jqplay.org/s/6cjmbnvrqu)\r\n```\r\n{\r\n  &quot;TopA&quot;: { &quot;stuff&quot;: &quot;here&quot;},\r\n  &quot;TopB&quot;: {\r\n    &quot;C591AB7E&quot;: {\r\n      &quot;Type&quot;: &quot;this&quot;,\r\n      &quot;Properties&quot;: {\r\n        &quot;lots&quot;: 1,\r\n        &quot;of&quot;: 2,\r\n        &quot;values&quot; : 3\r\n      }\r\n    },\r\n    &quot;7E16765A&quot;: {\r\n      &quot;Type&quot;: &quot;this&quot;,\r\n      &quot;Properties&quot;: {\r\n        &quot;lots&quot;: 4,\r\n        &quot;of&quot;: 5,\r\n        &quot;values&quot; : 6\r\n      }\r\n    },\r\n    &quot;AAD76465&quot;: {\r\n      &quot;Type&quot;: &quot;that&quot;,\r\n      &quot;Properties&quot;: {\r\n        &quot;lots&quot;: 7,\r\n        &quot;of&quot;: 8,\r\n        &quot;values&quot; : 9\r\n      }\r\n    }\r\n  }\r\n}\r\n```\r\n\r\nThe goal is to add an element to the Properties node of any TopB child where .Type == &quot;that&quot;. And the kicker is that I need to put the child node&#39;s key into the new element value with an added prefix.\r\nSo essentially I need the last element to look like this:\r\n\r\n```\r\n&quot;AAD76465&quot;: {\r\n  &quot;Type&quot;: &quot;that&quot;,\r\n  &quot;Properties&quot;: {\r\n    &quot;lots&quot;: 7,\r\n    &quot;of&quot;: 8,\r\n    &quot;values&quot;: 9,\r\n    &quot;newElement&quot;: &quot;Prefix-AAD76465&quot;\r\n  }\r\n}\r\n```\r\n\r\nI also need to retain the whole rest of the file (or a new file for that matter). So I don&#39;t need a query but really a jq call to manipulate the existing file. Parallel to TopB there could be other elements that I&#39;d still need in the file. And no, I don&#39;t know, neither do I have control over the naming of the children of TopB. All I have is that my targets are nested children of TopB with .Type == &quot;that&quot;. There can be multiple of those.\r\n\r\nThanks for looking.",
        "link": "https://stackoverflow.com/questions/67433142/using-jq-to-inject-element-at-specific-position-based-on-conditions",
        "title": "Using JQ to inject element at specific position based on conditions"
    },
    {
        "tags": [
            "json",
            "jq",
            "text-processing"
        ],
        "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": 1620390649,
                "post_id": 67434948,
                "comment_id": 119193633,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 10377092,
                    "reputation": 604,
                    "user_id": 7652996,
                    "user_type": "registered",
                    "accept_rate": 67,
                    "profile_image": "https://i.sstatic.net/ItnHH.png?s=256",
                    "display_name": "Volker Raschek",
                    "link": "https://stackoverflow.com/users/7652996/volker-raschek"
                },
                "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": 1620391265,
                "post_id": 67434948,
                "comment_id": 119193906,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1620391370,
                "last_edit_date": 1620391370,
                "creation_date": 1620390972,
                "answer_id": 67435077,
                "question_id": 67434948,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can pass the base version as a variable and sort on that. E.g. for your provided input\r\n\r\n```\r\njq --arg base &quot;84.3400&quot; &#39;.Tags | map(select(startswith($base))) | sort | last&#39;\r\n```\r\n\r\nThis works, if your versions are named _as_ int the question. In-place of `last`, you could also just do `reverse | first`",
                "title": "jq - find latest container image tag for a specific minor branch"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1648083271,
                "creation_date": 1648083271,
                "answer_id": 71595810,
                "question_id": 67434948,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Demo https://jqplay.org/s/t8dyM4tmmJ\r\n\r\n```\r\nfilter:\r\n&quot;84.3400&quot; as $base | .Tags | map(select(startswith($base))) | sort | last\r\n```",
                "title": "jq - find latest container image tag for a specific minor branch"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1648231087,
        "creation_date": 1620390390,
        "last_edit_date": 1648231087,
        "question_id": 67434948,
        "body_markdown": "crrently I am writing a small script to find out if newer images, which are defined in my docker-compose, are available on a registry. \r\n\r\nTo get a list of all available tags I use skopeo and get the following output.\r\n\r\n```json \r\n{\r\n  &quot;Repository&quot;: &quot;registry.example:8080/my-namespace/my-app&quot;,\r\n  &quot;Tags&quot;: [\r\n    &quot;84.3200.0-alpha-1&quot;,\r\n    &quot;84.3200.0-alpha-2&quot;,\r\n    &quot;84.3200.0-alpha-3&quot;,\r\n    &quot;84.3200.1&quot;,\r\n    &quot;84.3300.0-alpha-1&quot;,\r\n    &quot;84.3300.0-alpha-2&quot;,\r\n    &quot;84.3300.1&quot;,\r\n    &quot;84.3400.0-alpha-1&quot;,\r\n    &quot;84.3400.0-alpha-2&quot;,\r\n    &quot;84.3400.0-alpha-3&quot;,\r\n    &quot;84.3400.0-alpha-4&quot;,\r\n    &quot;84.3400.1&quot;,\r\n    &quot;84.3400.2&quot;,\r\n    &quot;84.3500.0-alpha-1&quot;,\r\n    &quot;84.3500.0-alpha-2&quot;,\r\n    &quot;84.3500.1&quot;,\r\n    &quot;84.3500.2&quot;,\r\n    &quot;84.3502.1&quot;,\r\n    &quot;84.3600.1&quot;,\r\n    &quot;84.3600.2&quot;,\r\n    &quot;84.3600.3&quot;,\r\n    &quot;84.3600.4&quot;,\r\n    &quot;latest&quot;\r\n  ]\r\n}\r\n``` \r\n\r\nNow, in my `docker-compose.yaml` is currently the following image tag defined: `image: registry.example:8080/my-namespace/my-app:84.3400.0-alpha-1`. With `jq` I want to sort and filter the json to get the latest version of 84.3400 branch. Which is tag `84.3400.2`. \r\n\r\nThere are also newer tags available, for example for the branch `84.3500.x` and `84.3600.x`. This images should not be used to detect the latest version until any one has updated the tag inside the `docker-compose.yaml` manually to one of the this branch.\r\n\r\nHas any one a good idea how to sort and filter the json to get the latest version of the branch?\r\n\r\n# EDIT: \r\n\r\nHello, the solution from @inian is incomplete because the sort command sorts the characters one by one. This means that version `84.3400.2` is greater than `84.3400.12`. \r\n\r\nDoes anyone have an idea how I can sort the versions correctly in ascending order?\r\n\r\nHere is an adapted json: \r\n\r\n```json\r\n{\r\n  &quot;Repository&quot;: &quot;registry.example:8080/my-namespace/my-app&quot;,\r\n  &quot;Tags&quot;: [\r\n    &quot;84.3400.1&quot;,\r\n    &quot;84.3400.12&quot;,\r\n    &quot;84.3400.2&quot;,\r\n    &quot;latest&quot;\r\n  ]\r\n}\r\n``` \r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/67434948/jq-find-latest-container-image-tag-for-a-specific-minor-branch",
        "title": "jq - find latest container image tag for a specific minor branch"
    }
]