[
    {
        "tags": [
            "multidimensional-array",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1715676775,
                "post_id": 78476686,
                "comment_id": 138351654,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1715708380,
                "last_edit_date": 1715708380,
                "creation_date": 1715675481,
                "answer_id": 78476772,
                "question_id": 78476686,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Use `|=` to partially update by traversing down on the LHS, selecting the parts being relevant (e.g. matching `.groupId == &quot;banner&quot;`):\r\n```sh\r\n(.valuesToUpload[] | select(.groupId == &quot;banner&quot;).fields) |= map(. + (\r\n  .imageValue[] | {valueId, toUpload, imageValue: {imageId, imageSchema, url}}\r\n))\r\n```\r\n[Demo](https://jqplay.org/s/JRmxjcXgpug)\r\n\r\n---\r\n\r\n&gt; groupid or title can be random. I need to desire base on empty valueId or type of imageValue\r\n\r\nAs you&#39;ve provided a solution using `.imageValue | type == &quot;array&quot;` yourself, here&#39;s my approach from above checking for a non-truthy `.valueId`:\r\n```sh\r\n.valuesToUpload[].fields |= map(select(.valueId) // . + (\r\n  .imageValue[] | {valueId, toUpload, imageValue: {imageId, imageSchema, url}}\r\n))\r\n```\r\n[Demo](https://jqplay.org/s/_O58aVPScx0)",
                "title": "JQ filter and recompilation data"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1715694591,
                "creation_date": 1715694591,
                "answer_id": 78478547,
                "question_id": 78476686,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "so I found solution that recompile only(!) fields with array in imageValue:\r\n\r\n    {&quot;valuesToUpload&quot;:[.payload.valuesToUpload[]|\r\n        {groupId,groupTitle,fields:\r\n        [\r\n        .fields[]|\r\n        if .imageValue|type == &quot;array&quot;\r\n            then .imageValue[] + {fieldName} +{checksIds} + {fieldTitle} + {fieldType} |                                                                   {\r\n                                                checksIds,\r\n                                                fieldName,\r\n                                                fieldTitle,\r\n                                                fieldType,\r\n                                                toUpload,\r\n                                                valueId,\r\n                                                imageValue:{\r\n                                                    url,\r\n                                                    imageId,\r\n                                                    imageSchema\r\n                                                }\r\n                        }\r\n            else .\r\n            end \r\n        ]\r\n    }\r\n    ]}",
                "title": "JQ filter and recompilation data"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1715708380,
        "creation_date": 1715674640,
        "last_edit_date": 1715688719,
        "question_id": 78476686,
        "body_markdown": "My data provider sends me data in 2 different structures.\r\nDifference in **imageValue** field\r\n - object in **about group**\r\n - array in **banner group**\r\n\r\n```\r\n{\r\n    &quot;valuesToUpload&quot;: [\r\n      {\r\n        &quot;groupId&quot;: &quot;about_2&quot;,\r\n        &quot;groupTitle&quot;: &quot;&quot;,\r\n        &quot;fields&quot;: [\r\n          {\r\n            &quot;fieldType&quot;: &quot;image&quot;,\r\n            &quot;valueId&quot;: &quot;cd262467-e683-4b1a-8fff-b22c42722f2c&quot;,\r\n            &quot;toUpload&quot;: true,\r\n            &quot;imageValue&quot;: {\r\n              &quot;imageId&quot;: 27606887612,\r\n              &quot;imageSchema&quot;: &quot;profile_composition&quot;,\r\n              &quot;url&quot;: &quot;http://img10/image/1/1.YaE0cFYle0oRLlTPlS7HAwtEINoMkYFRuB_k&quot;\r\n            }\r\n          },\r\n          {\r\n            &quot;fieldType&quot;: &quot;image&quot;,\r\n            &quot;fieldName&quot;: &quot;example_images&quot;,\r\n            &quot;valueId&quot;: &quot;5b394732-28c1-424c-a5c8-5edd553a3711&quot;,\r\n            &quot;toUpload&quot;: true,\r\n            &quot;imageValue&quot;: {\r\n              &quot;imageId&quot;: 27606306642,\r\n              &quot;imageSchema&quot;: &quot;profile_composition&quot;,\r\n              &quot;url&quot;: &quot;http://img40/image/1/1.j_RTsLassXjnkzZKMn-0czdeML_SxCdo-c&quot;\r\n            }\r\n          },\r\n          {\r\n            &quot;fieldType&quot;: &quot;image&quot;,\r\n            &quot;fieldName&quot;: &quot;example_images&quot;,\r\n            &quot;valueId&quot;: &quot;efaeca0d-9dbe-4b1c-93a1-51cb54b9ec1b&quot;,\r\n            &quot;toUpload&quot;: true,\r\n            &quot;imageValue&quot;: {\r\n              &quot;imageId&quot;: 27606343705,\r\n              &quot;imageSchema&quot;: &quot;profile_composition&quot;,\r\n              &quot;url&quot;: &quot;http://img00/image/1/1.xNLAhbas-l50pn65eZTqgqHrazl2.r39lMZMqeTovl4Cj2EY&quot;\r\n            }\r\n          }]\r\n      },\r\n      {\r\n            &quot;groupId&quot;: &quot;banner&quot;,\r\n            &quot;groupTitle&quot;: &quot;banner&quot;,\r\n            &quot;fields&quot;: [\r\n              {\r\n                &quot;fieldType&quot;: &quot;image&quot;,\r\n                &quot;imageValue&quot;: [\r\n                  {\r\n                    &quot;imageId&quot;: 0000001,\r\n                    &quot;toUpload&quot;: true,\r\n                    &quot;valueId&quot;: &quot;efaeca0d-9dbe-4b1c-93a1-51cb54b9ec00&quot;,\r\n                    &quot;imageSchema&quot;: &quot;profile_composition&quot;,\r\n                    &quot;url&quot;: &quot;https://20.img.st/image/1/link1&quot;\r\n                  },\r\n                  {\r\n                    &quot;imageId&quot;: 0000002,\r\n                    &quot;toUpload&quot;: false,\r\n                    &quot;valueId&quot;: &quot;efaeca0d-9dbe-4b1c-93a1-51cb54b9ec01&quot;,\r\n                    &quot;imageSchema&quot;: &quot;profile_composition&quot;,\r\n                    &quot;url&quot;: &quot;https://20.img.st/image/1/link2&quot;\r\n                  }\r\n                ],\r\n                &quot;fieldName&quot;: &quot;banner&quot;,\r\n                &quot;fieldTitle&quot;: &quot;banner&quot;\r\n              }\r\n            ]\r\n       }\r\n    ],\r\n    &quot;reload&quot;: {\r\n      &quot;on&quot;: false\r\n    }\r\n}\r\n```\r\n- I need to &quot;recompile&quot; **banner group** image fields to format same as in **about_2 group**\r\n\r\n- I found out how to select only separate object format (about_2):\r\n\r\n```\r\n{&quot;valuesToUpload&quot;:[\r\n        .payload.valuesToUpload[]|{groupId,groupTitle,fields:[.fields[]| select(.valueId != null)]}\r\n]}\r\n\r\n```\r\nAnd get only &quot;about_2&quot; section.\r\n\r\nBut how to write jQuery to recompile banner section to same format and not lost about_2 section. \r\n\r\nBanner section must be like:\r\n\r\n```\r\n{\r\n        &quot;groupId&quot;: &quot;banner&quot;,\r\n        &quot;groupTitle&quot;: &quot;banner&quot;,\r\n        &quot;fields&quot;: [\r\n          {\r\n            &quot;fieldType&quot;: &quot;image&quot;,\r\n            &quot;valueId&quot;: &quot;efaeca0d-9dbe-4b1c-93a1-51cb54b9ec00&quot;,\r\n            &quot;toUpload&quot;: true,\r\n            &quot;imageValue&quot;: {\r\n              &quot;imageId&quot;: 0000001,\r\n              &quot;imageSchema&quot;: &quot;profile_composition&quot;,\r\n              &quot;url&quot;: &quot;https://20.img.st/image/1/link1&quot;\r\n            }\r\n          },\r\n          {\r\n            &quot;fieldType&quot;: &quot;image&quot;,\r\n            &quot;valueId&quot;: &quot;efaeca0d-9dbe-4b1c-93a1-51cb54b9ec01&quot;,\r\n            &quot;toUpload&quot;: true,\r\n            &quot;imageValue&quot;: {\r\n              &quot;imageId&quot;: 0000002,\r\n              &quot;imageSchema&quot;: &quot;profile_composition&quot;,\r\n              &quot;url&quot;: &quot;https://20.img.st/image/1/link2&quot;\r\n            }\r\n          }\r\n        ]\r\n}\r\n\r\n```",
        "link": "https://stackoverflow.com/questions/78476686/jq-filter-and-recompilation-data",
        "title": "JQ filter and recompilation data"
    },
    {
        "tags": [
            "bash",
            "sorting",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 3959308,
                    "reputation": 53394,
                    "user_id": 3266847,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/U0oyt.png?s=256",
                    "display_name": "Benjamin W.",
                    "link": "https://stackoverflow.com/users/3266847/benjamin-w"
                },
                "edited": false,
                "score": 3,
                "creation_date": 1715779489,
                "post_id": 78484156,
                "comment_id": 138364753,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 11829413,
                    "reputation": 15849,
                    "user_id": 8656552,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/BP640.png?s=256",
                    "display_name": "Paul Hodges",
                    "link": "https://stackoverflow.com/users/8656552/paul-hodges"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1715779543,
                "post_id": 78484156,
                "comment_id": 138364763,
                "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": 1715779545,
                "post_id": 78484156,
                "comment_id": 138364764,
                "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": 1715779614,
                "post_id": 78484156,
                "comment_id": 138364781,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 11829413,
                    "reputation": 15849,
                    "user_id": 8656552,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/BP640.png?s=256",
                    "display_name": "Paul Hodges",
                    "link": "https://stackoverflow.com/users/8656552/paul-hodges"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1715780048,
                "post_id": 78484156,
                "comment_id": 138364853,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 5745825,
                    "reputation": 12983,
                    "user_id": 4537090,
                    "user_type": "registered",
                    "accept_rate": 79,
                    "profile_image": "https://i.sstatic.net/Dwxvn.jpg?s=256",
                    "display_name": "WesternGun",
                    "link": "https://stackoverflow.com/users/4537090/westerngun"
                },
                "reply_to_user": {
                    "account_id": 39208,
                    "reputation": 267964,
                    "user_id": 112968,
                    "user_type": "registered",
                    "accept_rate": 68,
                    "profile_image": "https://i.sstatic.net/zHTaT.png?s=256",
                    "display_name": "knittl",
                    "link": "https://stackoverflow.com/users/112968/knittl"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1715780121,
                "post_id": 78484156,
                "comment_id": 138364863,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 39208,
                    "reputation": 267964,
                    "user_id": 112968,
                    "user_type": "registered",
                    "accept_rate": 68,
                    "profile_image": "https://i.sstatic.net/zHTaT.png?s=256",
                    "display_name": "knittl",
                    "link": "https://stackoverflow.com/users/112968/knittl"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1715780714,
                "post_id": 78484156,
                "comment_id": 138364973,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1715781390,
                "last_edit_date": 1715781390,
                "creation_date": 1715779168,
                "answer_id": 78484245,
                "question_id": 78484156,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "To sort by `.fields.field1[0]` use `sort_by(.fields.field1[0])`. But as you want to output the same values used as criteria, reduce beforehand using `map`, and just use `sort` on the result array:\r\n```sh\r\njq -r &#39;.hits.hits | map(.fields.field1[0]) | sort[]&#39; file.json\r\n```\r\n[Demo](https://jqplay.org/s/hByVc8afnA1)\r\n\r\nNote that this performs string sorting as all first items of the `.field1` arrays are actually strings (despite containing digits only, `11` would be sorted before `2`). If you want numeric sorting (in the sense that two is smaller than eleven), convert the items into numbers first using `tonumber`. In this case, you could also drop the `-r` flag as JSON numbers don&#39;t have special encoding.\r\n```sh\r\njq -r &#39;.hits.hits | map(.fields.field1[0] | tonumber) | sort[]&#39; file.json\r\n```\r\n[Demo](https://jqplay.org/s/tDO7X6kbJH2)\r\n\r\nAs the sample data only has digit-only string items of equal lengths,  both approaches yield the same output:\r\n```\r\n111111113034864\r\n111111113034877\r\n111111113034894\r\n111111113046053\r\n111111113046124\r\n:\r\n```\r\n\r\n---\r\n&gt; I want a CSV file with both `field1` and `field2` separated by `,`\r\n\r\nWith output items differing from the sorting criteria, I&#39;d revert to using `sort_by(.fields.field1[0])` as it gives you more freedom to mix and match, and have `@csv` construct the output, which also takes care of escaping special characters:\r\n```sh\r\n.hits.hits | sort_by(.fields.field1[0])[].fields\r\n| [.field1[0], .field2[0]] | @csv\r\n```\r\n```csv\r\n&quot;111111113034864&quot;,&quot;FOO&quot;\r\n&quot;111111113034877&quot;,&quot;FOO&quot;\r\n&quot;111111113034894&quot;,&quot;FOO&quot;\r\n&quot;111111113046053&quot;,&quot;FOO&quot;\r\n&quot;111111113046124&quot;,&quot;FOO&quot;\r\n```\r\n[Demo](https://jqplay.org/s/h32y4kjOgAh)",
                "title": "Sorting user-defined array with strings gives wrong order, even when file content is fully available on disk"
            },
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1715779255,
                "creation_date": 1715779255,
                "answer_id": 78484256,
                "question_id": 78484156,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You&#39;re looking for something like this:\r\n```\r\n.hits.hits | map(.fields | .field1[0] + &quot;,&quot; + .field2[0]) | sort[]\r\n```\r\n&lt;sup&gt;[Online demo](https://jqplay.org/s/sv_7NVfIWmV)&lt;/sup&gt;",
                "title": "Sorting user-defined array with strings gives wrong order, even when file content is fully available on disk"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": -1,
        "last_activity_date": 1715781390,
        "creation_date": 1715778269,
        "last_edit_date": 1715779365,
        "question_id": 78484156,
        "body_markdown": "I am querying ElasticSearch and sorting the documents locally in Bash with `jq`, as sorting in ES is too slow for me.\r\n\r\nThe original purpose is to create a CSV file.\r\n\r\nBut I find the sorting does not work properly, it seems `sort` step does nothing. \r\n\r\nAs I am launching `cURL` requests, I thought the wrong order is due to content is chunked so I save some results into a local `test.json` file and tried again, but it still does not work. \r\n\r\n`test.json`:\r\n```lang-json\r\n{\r\n\t&quot;took&quot;: 680,\r\n\t&quot;timed_out&quot;: false,\r\n\t&quot;_shards&quot;: {\r\n\t\t&quot;total&quot;: 1,\r\n\t\t&quot;successful&quot;: 1,\r\n\t\t&quot;skipped&quot;: 0,\r\n\t\t&quot;failed&quot;: 0\r\n\t},\r\n\t&quot;hits&quot;: {\r\n\t\t&quot;max_score&quot;: 1.0,\r\n\t\t&quot;hits&quot;: [\r\n\t\t\t{\r\n\t\t\t\t&quot;_index&quot;: &quot;my-index&quot;,\r\n\t\t\t\t&quot;_type&quot;: &quot;_doc&quot;,\r\n\t\t\t\t&quot;_id&quot;: &quot;111111113584925&quot;,\r\n\t\t\t\t&quot;_score&quot;: 1.0,\r\n\t\t\t\t&quot;fields&quot;: {\r\n\t\t\t\t\t&quot;field2&quot;: [\r\n\t\t\t\t\t\t&quot;FOO&quot;\r\n\t\t\t\t\t],\r\n\t\t\t\t\t&quot;field1&quot;: [\r\n\t\t\t\t\t\t&quot;111111113584925&quot;\r\n\t\t\t\t\t]\r\n\t\t\t\t}\r\n\t\t\t},\r\n\t\t\t{\r\n\t\t\t\t&quot;_index&quot;: &quot;my-index&quot;,\r\n\t\t\t\t&quot;_type&quot;: &quot;_doc&quot;,\r\n\t\t\t\t&quot;_id&quot;: &quot;111111121254059&quot;,\r\n\t\t\t\t&quot;_score&quot;: 1.0,\r\n\t\t\t\t&quot;fields&quot;: {\r\n\t\t\t\t\t&quot;field2&quot;: [\r\n\t\t\t\t\t\t&quot;FOO&quot;\r\n\t\t\t\t\t],\r\n\t\t\t\t\t&quot;field1&quot;: [\r\n\t\t\t\t\t\t&quot;111111121254059&quot;\r\n\t\t\t\t\t]\r\n\t\t\t\t}\r\n\t\t\t}\r\n\t\t]\r\n\t}\r\n}\r\n```\r\n(There are many more records - edited for brevity.)\r\n\r\nCommand that I use:\r\n```bash\r\njq &#39;.hits.hits[].fields | [.field1[0] + &quot;,&quot; + .field2[0]] | sort | .[0]&#39; -r test.json\r\n```\r\nThe result:\r\n```\r\n111111113584925,FOO\r\n111111121254059,FOO\r\n111111116879444,FOO\r\n```\r\netc.\r\n\r\nWhy? \r\n\r\nShould I rely on `jq` sorting? Am I using it correctly? I mean I want to do string comparison by alphabetical order, and `field1` all have unique values, so it will never be a tie and start to compare values of `field2`(it also could have various values but I only want to sort by `field1`)\r\n\r\nShould I use Bash `sort -k 1` instead? Which is faster when it comes to 100K rows?\r\n",
        "link": "https://stackoverflow.com/questions/78484156/sorting-user-defined-array-with-strings-gives-wrong-order-even-when-file-conten",
        "title": "Sorting user-defined array with strings gives wrong order, even when file content is fully available on disk"
    },
    {
        "tags": [
            "amazon-web-services",
            "bash",
            "amazon-s3",
            "jq",
            "aws-cli"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 11699980,
                    "reputation": 8019,
                    "user_id": 8565438,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/pgbqc.jpg?s=256",
                    "display_name": "zabop",
                    "link": "https://stackoverflow.com/users/8565438/zabop"
                },
                "reply_to_user": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1715857883,
                "post_id": 78489072,
                "comment_id": 138373945,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1715858703,
                "creation_date": 1715858703,
                "answer_id": 78489498,
                "question_id": 78489072,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Use jq&#39;s `--raw-output` (or `-r`) flag to decode JSON strings into raw text (essentially resolving escaped characters and removing the double quotes). Without it, the Bash variable storing each result would still contain the encoded output. (Yet, manually copying that into a command on the terminal may accidentally still work because the shell would consume those quotes when reading the command.)\r\n\r\n```sh\r\nwhile read -r source\r\ndo aws s3 cp &quot;${source}&quot; .\r\ndone &lt; &lt;(jq -r &#39;.[]&#39; sources.lst)\r\n```",
                "title": "How to avoid &quot;Invalid argument type&quot; error when executing a seemingly valid AWS CLI command created using jq and bash?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1715858703,
        "creation_date": 1715853766,
        "question_id": 78489072,
        "body_markdown": "I have a file of s3 paths, `sources.lst`. Contents:\r\n\r\n    [\r\n      &quot;s3://bucket-name/path/to/file0.tif&quot;,\r\n      &quot;s3://bucket-name/path/to/file1.tif&quot;,\r\n    ]\r\n\r\nI am attempting to iterate over these s3 paths &amp; download the files. I am trying to using `jq` and a bash while loop. My `download.sh`:\r\n\r\n    #!/bin/bash\r\n    \r\n    set -o errexit\r\n    \r\n    while read -r source\r\n    do\r\n        echo &quot;Attempting to execute:&quot;\r\n        echo &quot;aws s3 cp &quot;${source}&quot; .&quot;\r\n    \r\n        aws s3 cp &quot;${source}&quot; .\r\n    done &lt; &lt;(cat sources.lst | jq &#39;.[]&#39;)\r\n\r\nExecuting `bash download.sh` gives me:\r\n\r\n    Attempting to execute:\r\n    aws s3 cp &quot;s3://bucket-name/path/to/file0.tif&quot; .\r\n    \r\n    usage: aws s3 cp &lt;LocalPath&gt; &lt;S3Uri&gt; or &lt;S3Uri&gt; &lt;LocalPath&gt; or &lt;S3Uri&gt; &lt;S3Uri&gt;\r\n    Error: Invalid argument type\r\n\r\nWhich is strange, since if I copy the line causing the error, ie \r\n\r\n    aws s3 cp &quot;s3://bucket-name/path/to/file0.tif&quot; .\r\n\r\nand execute it in the terminal I run `bash download.sh`, the download succeeds.\r\n\r\n**How do I download the files specified in `sources.lst` using bash?**\r\n\r\nI am using Mac, `bash --version`: `GNU bash, version 5.2.26(1)-release (aarch64-apple-darwin22.6.0)`, `aws --version`: `aws-cli/2.13.1 Python/3.11.4 Darwin/23.4.0 exe/x86_64 prompt/off` \r\n \r\n",
        "link": "https://stackoverflow.com/questions/78489072/how-to-avoid-invalid-argument-type-error-when-executing-a-seemingly-valid-aws",
        "title": "How to avoid &quot;Invalid argument type&quot; error when executing a seemingly valid AWS CLI command created using jq and bash?"
    },
    {
        "tags": [
            "curl",
            "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": 1715958367,
                "post_id": 78496482,
                "comment_id": 138385981,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 6313442,
                    "reputation": 45115,
                    "user_id": 5625547,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/oqCND.jpg?s=256",
                    "display_name": "0stone0",
                    "link": "https://stackoverflow.com/users/5625547/0stone0"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1715958715,
                "post_id": 78496482,
                "comment_id": 138386041,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 6313442,
                    "reputation": 45115,
                    "user_id": 5625547,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/oqCND.jpg?s=256",
                    "display_name": "0stone0",
                    "link": "https://stackoverflow.com/users/5625547/0stone0"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1715958823,
                "post_id": 78496482,
                "comment_id": 138386060,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 6313442,
                    "reputation": 45115,
                    "user_id": 5625547,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/oqCND.jpg?s=256",
                    "display_name": "0stone0",
                    "link": "https://stackoverflow.com/users/5625547/0stone0"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1715958832,
                "post_id": 78496482,
                "comment_id": 138386062,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1715968542,
                "creation_date": 1715968542,
                "answer_id": 78497239,
                "question_id": 78496482,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "`jq -r &#39;.[] | select(.name | startswith(&quot;Hello&quot;)) | .name&#39;`\r\n\r\nThis is the solution for my problem.",
                "title": "Curl JQ filter results where a value starts with string"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1715968542,
        "creation_date": 1715958248,
        "last_edit_date": 1715961441,
        "question_id": 78496482,
        "body_markdown": "```sh\r\ncurl -X GET \\\r\n      --url &quot;${API_URL_PREFIX}/orgs/${ORG}/repos?type=private&amp;page=${PAGE}&amp;per_page=100&quot; \\\r\n      -H &quot;Accept: application/vnd.github+json&quot; \\\r\n      -H &quot;Authorization: Bearer $GITHUB_TOKEN&quot; | jq -r &#39;.[] | select(.name | startswith(&quot;test-&quot;))&#39;\r\n```\r\n\r\nTrying to filter the repo results using JQ to only give me repositories that start with `test-`.\r\n\r\nThis responds with blank with the code above.\r\n\r\nIf I change the query to `jq -r &#39;.[] | .name` it gives me all the repos but I need to filter them.\r\n\r\nHave tried the variations \r\n\r\n`jq -r &#39;.[] | .name | select(.name | startswith(&quot;ng-&quot;))`\r\n`jq -r &#39;.[] | select(.name | startswith(&quot;ng-&quot;))`\r\n`\r\n\r\nThe input is a GitHub API response for getting a list of repos:\r\n```json\r\n[\r\n  {\r\n    &quot;id&quot;: 1296269,\r\n    &quot;node_id&quot;: &quot;MDEwOlJlcG9zaXRvcnkxMjk2MjY5&quot;,\r\n    &quot;name&quot;: &quot;Hello-World&quot;,\r\n    &quot;full_name&quot;: &quot;octocat/Hello-World&quot;,\r\n    &quot;owner&quot;: {\r\n      &quot;login&quot;: &quot;octocat&quot;,\r\n      &quot;id&quot;: 1,\r\n      &quot;node_id&quot;: &quot;MDQ6VXNlcjE=&quot;,\r\n      &quot;avatar_url&quot;: &quot;https://github.com/images/error/octocat_happy.gif&quot;,\r\n      &quot;gravatar_id&quot;: &quot;&quot;,\r\n      &quot;url&quot;: &quot;https://api.github.com/users/octocat&quot;,\r\n      &quot;html_url&quot;: &quot;https://github.com/octocat&quot;,\r\n      &quot;followers_url&quot;: &quot;https://api.github.com/users/octocat/followers&quot;,\r\n      &quot;following_url&quot;: &quot;https://api.github.com/users/octocat/following{/other_user}&quot;,\r\n      &quot;gists_url&quot;: &quot;https://api.github.com/users/octocat/gists{/gist_id}&quot;,\r\n      &quot;starred_url&quot;: &quot;https://api.github.com/users/octocat/starred{/owner}{/repo}&quot;,\r\n      &quot;subscriptions_url&quot;: &quot;https://api.github.com/users/octocat/subscriptions&quot;,\r\n      &quot;organizations_url&quot;: &quot;https://api.github.com/users/octocat/orgs&quot;,\r\n      &quot;repos_url&quot;: &quot;https://api.github.com/users/octocat/repos&quot;,\r\n      &quot;events_url&quot;: &quot;https://api.github.com/users/octocat/events{/privacy}&quot;,\r\n      &quot;received_events_url&quot;: &quot;https://api.github.com/users/octocat/received_events&quot;,\r\n      &quot;type&quot;: &quot;User&quot;,\r\n      &quot;site_admin&quot;: false\r\n    },\r\n    &quot;private&quot;: false,\r\n    &quot;html_url&quot;: &quot;https://github.com/octocat/Hello-World&quot;,\r\n    &quot;description&quot;: &quot;This your first repo!&quot;,\r\n    &quot;fork&quot;: false,\r\n    &quot;url&quot;: &quot;https://api.github.com/repos/octocat/Hello-World&quot;,\r\n    &quot;archive_url&quot;: &quot;https://api.github.com/repos/octocat/Hello-World/{archive_format}{/ref}&quot;,\r\n    &quot;assignees_url&quot;: &quot;https://api.github.com/repos/octocat/Hello-World/assignees{/user}&quot;,\r\n    &quot;blobs_url&quot;: &quot;https://api.github.com/repos/octocat/Hello-World/git/blobs{/sha}&quot;,\r\n    &quot;branches_url&quot;: &quot;https://api.github.com/repos/octocat/Hello-World/branches{/branch}&quot;,\r\n    &quot;collaborators_url&quot;: &quot;https://api.github.com/repos/octocat/Hello-World/collaborators{/collaborator}&quot;,\r\n    &quot;comments_url&quot;: &quot;https://api.github.com/repos/octocat/Hello-World/comments{/number}&quot;,\r\n    &quot;commits_url&quot;: &quot;https://api.github.com/repos/octocat/Hello-World/commits{/sha}&quot;,\r\n    &quot;compare_url&quot;: &quot;https://api.github.com/repos/octocat/Hello-World/compare/{base}...{head}&quot;,\r\n    &quot;contents_url&quot;: &quot;https://api.github.com/repos/octocat/Hello-World/contents/{+path}&quot;,\r\n    &quot;contributors_url&quot;: &quot;https://api.github.com/repos/octocat/Hello-World/contributors&quot;,\r\n    &quot;deployments_url&quot;: &quot;https://api.github.com/repos/octocat/Hello-World/deployments&quot;,\r\n    &quot;downloads_url&quot;: &quot;https://api.github.com/repos/octocat/Hello-World/downloads&quot;,\r\n    &quot;events_url&quot;: &quot;https://api.github.com/repos/octocat/Hello-World/events&quot;,\r\n    &quot;forks_url&quot;: &quot;https://api.github.com/repos/octocat/Hello-World/forks&quot;,\r\n    &quot;git_commits_url&quot;: &quot;https://api.github.com/repos/octocat/Hello-World/git/commits{/sha}&quot;,\r\n    &quot;git_refs_url&quot;: &quot;https://api.github.com/repos/octocat/Hello-World/git/refs{/sha}&quot;,\r\n    &quot;git_tags_url&quot;: &quot;https://api.github.com/repos/octocat/Hello-World/git/tags{/sha}&quot;,\r\n    &quot;git_url&quot;: &quot;git:github.com/octocat/Hello-World.git&quot;,\r\n    &quot;issue_comment_url&quot;: &quot;https://api.github.com/repos/octocat/Hello-World/issues/comments{/number}&quot;,\r\n    &quot;issue_events_url&quot;: &quot;https://api.github.com/repos/octocat/Hello-World/issues/events{/number}&quot;,\r\n    &quot;issues_url&quot;: &quot;https://api.github.com/repos/octocat/Hello-World/issues{/number}&quot;,\r\n    &quot;keys_url&quot;: &quot;https://api.github.com/repos/octocat/Hello-World/keys{/key_id}&quot;,\r\n    &quot;labels_url&quot;: &quot;https://api.github.com/repos/octocat/Hello-World/labels{/name}&quot;,\r\n    &quot;languages_url&quot;: &quot;https://api.github.com/repos/octocat/Hello-World/languages&quot;,\r\n    &quot;merges_url&quot;: &quot;https://api.github.com/repos/octocat/Hello-World/merges&quot;,\r\n    &quot;milestones_url&quot;: &quot;https://api.github.com/repos/octocat/Hello-World/milestones{/number}&quot;,\r\n    &quot;notifications_url&quot;: &quot;https://api.github.com/repos/octocat/Hello-World/notifications{?since,all,participating}&quot;,\r\n    &quot;pulls_url&quot;: &quot;https://api.github.com/repos/octocat/Hello-World/pulls{/number}&quot;,\r\n    &quot;releases_url&quot;: &quot;https://api.github.com/repos/octocat/Hello-World/releases{/id}&quot;,\r\n    &quot;ssh_url&quot;: &quot;git@github.com:octocat/Hello-World.git&quot;,\r\n    &quot;stargazers_url&quot;: &quot;https://api.github.com/repos/octocat/Hello-World/stargazers&quot;,\r\n    &quot;statuses_url&quot;: &quot;https://api.github.com/repos/octocat/Hello-World/statuses/{sha}&quot;,\r\n    &quot;subscribers_url&quot;: &quot;https://api.github.com/repos/octocat/Hello-World/subscribers&quot;,\r\n    &quot;subscription_url&quot;: &quot;https://api.github.com/repos/octocat/Hello-World/subscription&quot;,\r\n    &quot;tags_url&quot;: &quot;https://api.github.com/repos/octocat/Hello-World/tags&quot;,\r\n    &quot;teams_url&quot;: &quot;https://api.github.com/repos/octocat/Hello-World/teams&quot;,\r\n    &quot;trees_url&quot;: &quot;https://api.github.com/repos/octocat/Hello-World/git/trees{/sha}&quot;,\r\n    &quot;clone_url&quot;: &quot;https://github.com/octocat/Hello-World.git&quot;,\r\n    &quot;mirror_url&quot;: &quot;git:git.example.com/octocat/Hello-World&quot;,\r\n    &quot;hooks_url&quot;: &quot;https://api.github.com/repos/octocat/Hello-World/hooks&quot;,\r\n    &quot;svn_url&quot;: &quot;https://svn.github.com/octocat/Hello-World&quot;,\r\n    &quot;homepage&quot;: &quot;https://github.com&quot;,\r\n    &quot;language&quot;: null,\r\n    &quot;forks_count&quot;: 9,\r\n    &quot;stargazers_count&quot;: 80,\r\n    &quot;watchers_count&quot;: 80,\r\n    &quot;size&quot;: 108,\r\n    &quot;default_branch&quot;: &quot;master&quot;,\r\n    &quot;open_issues_count&quot;: 0,\r\n    &quot;is_template&quot;: false,\r\n    &quot;topics&quot;: [\r\n      &quot;octocat&quot;,\r\n      &quot;atom&quot;,\r\n      &quot;electron&quot;,\r\n      &quot;api&quot;\r\n    ],\r\n    &quot;has_issues&quot;: true,\r\n    &quot;has_projects&quot;: true,\r\n    &quot;has_wiki&quot;: true,\r\n    &quot;has_pages&quot;: false,\r\n    &quot;has_downloads&quot;: true,\r\n    &quot;has_discussions&quot;: false,\r\n    &quot;archived&quot;: false,\r\n    &quot;disabled&quot;: false,\r\n    &quot;visibility&quot;: &quot;public&quot;,\r\n    &quot;pushed_at&quot;: &quot;2011-01-26T19:06:43Z&quot;,\r\n    &quot;created_at&quot;: &quot;2011-01-26T19:01:12Z&quot;,\r\n    &quot;updated_at&quot;: &quot;2011-01-26T19:14:43Z&quot;,\r\n    &quot;permissions&quot;: {\r\n      &quot;admin&quot;: false,\r\n      &quot;push&quot;: false,\r\n      &quot;pull&quot;: true\r\n    },\r\n    &quot;security_and_analysis&quot;: {\r\n      &quot;advanced_security&quot;: {\r\n        &quot;status&quot;: &quot;enabled&quot;\r\n      },\r\n      &quot;secret_scanning&quot;: {\r\n        &quot;status&quot;: &quot;enabled&quot;\r\n      },\r\n      &quot;secret_scanning_push_protection&quot;: {\r\n        &quot;status&quot;: &quot;disabled&quot;\r\n      }\r\n    }\r\n  }\r\n]\r\n```",
        "link": "https://stackoverflow.com/questions/78496482/curl-jq-filter-results-where-a-value-starts-with-string",
        "title": "Curl JQ filter results where a value starts with string"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 1143565,
                    "reputation": 535973,
                    "user_id": 1126841,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/fa05233b2357f8d11c22ef4cfc7bb85c?s=256&d=identicon&r=PG",
                    "display_name": "chepner",
                    "link": "https://stackoverflow.com/users/1126841/chepner"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1716148703,
                "post_id": 78503733,
                "comment_id": 138398591,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1716148346,
                "last_edit_date": 1716148346,
                "creation_date": 1716147921,
                "answer_id": 78503741,
                "question_id": 78503733,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Use `inputs` in combination with the `--null-input` (or `-n`) flag. It will provide an iteration of all inputs. Accordingly, the singular `input` will fetch one input on evaluation. The `--null-input` (or `-n`) flag is necessary as the context `.` would have already consumed the first input when reaching `input` or `inputs`, which then starts fetching starting from the second input. With `--null-input` (or `-n`) set, the context `.` is bound to `null`, so `input` and `inputs` get all the inputs available.\r\n\r\nExample 1:\r\n```sh\r\njq -n &#39;inputs | keys&#39;\r\n```\r\n```json\r\n[\r\n  &quot;a&quot;,\r\n  &quot;b&quot;\r\n]\r\n[\r\n  &quot;c&quot;,\r\n  &quot;d&quot;\r\n]\r\n```\r\n[Demo](https://jqplay.org/s/22Gzd9QChfp)\r\n\r\nExample 2:\r\n```sh\r\njq -n &#39;{head: input, tail: [inputs]}&#39;\r\n```\r\n```json\r\n{\r\n  &quot;head&quot;: {\r\n    &quot;a&quot;: 1,\r\n    &quot;b&quot;: 2\r\n  },\r\n  &quot;tail&quot;: [\r\n    {\r\n      &quot;c&quot;: 3,\r\n      &quot;d&quot;: 4\r\n    }\r\n  ]\r\n}\r\n```\r\n[Demo](https://jqplay.org/s/4-1pYG-7KiL)\r\n\r\nNote that for cases like the latter example, where the first input is treated individually, you can revert to using `.` for that first input. `jq &#39;{head: ., tail: [inputs]}&#39;` (without `-n`) yields the same result ([Demo](https://jqplay.org/s/DpN2MWH34WV)).",
                "title": "Iterate through objects without array"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1716191882,
        "creation_date": 1716147756,
        "last_edit_date": 1716191882,
        "question_id": 78503733,
        "body_markdown": "I&#39;ve got JSON data that looks like this (notice that it&#39;s a list of individual objects without wrapping by `[]`). I would like to walk each object using `jq` but it is not an array of objects. So how can I walk to each object without fixing the data to be a valid array of objects? \r\n\r\n```\r\n{\r\n  &quot;a&quot;: 1,\r\n  &quot;b&quot;: 2\r\n}\r\n{\r\n  &quot;c&quot;: 3,\r\n  &quot;d&quot;: 4\r\n}\r\n```\r\n\r\n",
        "link": "https://stackoverflow.com/questions/78503733/iterate-through-objects-without-array",
        "title": "Iterate through objects without array"
    },
    {
        "tags": [
            "json",
            "csv",
            "jq",
            "ndjson"
        ],
        "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": 1716326615,
                "post_id": 78514365,
                "comment_id": 138416686,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 16164,
                    "reputation": 21603,
                    "user_id": 34935,
                    "user_type": "registered",
                    "accept_rate": 60,
                    "profile_image": "https://www.gravatar.com/avatar/27079559125269ea0a30acba3fb06235?s=256&d=identicon&r=PG",
                    "display_name": "dfrankow",
                    "link": "https://stackoverflow.com/users/34935/dfrankow"
                },
                "reply_to_user": {
                    "account_id": 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": 1716327497,
                "post_id": 78514365,
                "comment_id": 138416774,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1716329089,
                "last_edit_date": 1716329089,
                "creation_date": 1716327521,
                "answer_id": 78514471,
                "question_id": 78514365,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "[`.[]`][1] will create an output for each `.labeled_values`.\r\n\r\nTo convert `.id` to a string and add a `\\t` use a [string interpolation][2]. \r\n\r\nUse [`@tsv`][3] to convert the array to tsv\r\n\r\n```\r\n&quot;\\(.id)\\t\\(.labeled_values[] | @tsv)&quot;\r\n```\r\n\r\n##### [Try it online](https://jqplay.org/s/oamM3pHjQ3f)\r\n\r\n\r\n  [1]: https://jqlang.github.io/jq/manual/#array-object-value-iterator\r\n  [2]: https://jqlang.github.io/jq/manual/#string-interpolation\r\n  [3]: https://jqlang.github.io/jq/manual/#format-strings-and-escaping",
                "title": "How to get jq to output a long dataset (part 2)?"
            },
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1716352819,
                "creation_date": 1716352819,
                "answer_id": 78515349,
                "question_id": 78514365,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Or simply:\r\n\r\n      [.id] + .labeled_values[] | @tsv",
                "title": "How to get jq to output a long dataset (part 2)?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": -1,
        "last_activity_date": 1716352819,
        "creation_date": 1716325707,
        "last_edit_date": 1716352375,
        "question_id": 78514365,
        "body_markdown": "Suppose I have this ndjson file:\r\n\r\n```\r\n{&quot;id&quot;: 99, &quot;labeled_values&quot;: [[&quot;one&quot;, &quot;green&quot;], [&quot;two&quot;, &quot;red&quot;], [&quot;three&quot;, &quot;blue&quot;]]}\r\n{&quot;id&quot;: 100, &quot;labeled_values&quot;: [[&quot;four&quot;, &quot;green&quot;], [&quot;five&quot;, &quot;red&quot;]]}\r\n```\r\n\r\nHow do I get the output below (tab-separated)?  That is: id on every line, and the pairs of (value, label) flattened.\r\n\r\n```\r\n99 one green\r\n99 two red\r\n99 three blue\r\n100 four green\r\n100 five red\r\n```\r\n\r\nHere are two failed attempts:\r\n\r\n```\r\n$ cat tmp/foo.ndjson | jq -r &#39;.id as $id | [$id, .labeled_values.[0], .labeled_values.[1]] &#39;\r\n[\r\n  99,\r\n  [\r\n    &quot;one&quot;,\r\n    &quot;green&quot;\r\n  ],\r\n  [\r\n    &quot;two&quot;,\r\n    &quot;red&quot;\r\n  ]\r\n]\r\n[\r\n  100,\r\n  [\r\n    &quot;four&quot;,\r\n    &quot;green&quot;\r\n  ],\r\n  [\r\n    &quot;five&quot;,\r\n    &quot;red&quot;\r\n  ]\r\n]\r\n\r\n$ cat tmp/foo.ndjson | jq -r &#39;.id as $id | [$id, .labeled_values[].[0], .labeled_values[].[1]] &#39;\r\n[\r\n  99,\r\n  &quot;one&quot;,\r\n  &quot;two&quot;,\r\n  &quot;three&quot;,\r\n  &quot;green&quot;,\r\n  &quot;red&quot;,\r\n  &quot;blue&quot;\r\n]\r\n[\r\n  100,\r\n  &quot;four&quot;,\r\n  &quot;five&quot;,\r\n  &quot;green&quot;,\r\n  &quot;red&quot;\r\n]\r\n```\r\n\r\n[This question][1] is very related, but I still don&#39;t understand jq well enough.\r\n\r\nA related question: how do I learn enough about the processing model of jq to understand how to break down nested structures like this into flat structures?\r\n\r\nMost of the examples I find are flat and simple.  They pick out single fields, not nested things.\r\n\r\n\r\n  [1]: https://stackoverflow.com/questions/78415979/how-to-get-jq-to-output-a-long-dataset",
        "link": "https://stackoverflow.com/questions/78514365/how-to-get-jq-to-output-a-long-dataset-part-2",
        "title": "How to get jq to output a long dataset (part 2)?"
    },
    {
        "tags": [
            "json",
            "jq",
            "cartesian-product"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1716392487,
                "creation_date": 1716392487,
                "answer_id": 78518651,
                "question_id": 78518591,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here is an answer that worked, but seems ugly to me:\r\n\r\n```\r\n$ cat tmp/foo.ndjson | jq -r &#39;\r\n  .id as $id |\r\n  .labeled_values[] as $lv |\r\n  .flavors[] as $fl |\r\n  [$id, $lv[0], $lv[1], $fl] | @tsv&#39; \r\n99\tone\tgreen\thot\r\n99\tone\tgreen\tcold\r\n99\ttwo\tred\thot\r\n99\ttwo\tred\tcold\r\n99\tthree\tblue\thot\r\n99\tthree\tblue\tcold\r\n100\tfour\tgreen\thot\r\n100\tfive\tred\thot\r\n```\r\n",
                "title": "How to make a certain double cartesian product with jq?"
            },
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1716397213,
                "last_edit_date": 1716397213,
                "creation_date": 1716394566,
                "answer_id": 78518831,
                "question_id": 78518591,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can use the &lt;a href=&quot;https://jqlang.github.io/jq/manual/#combinations&quot;&gt;`combinations`&lt;/a&gt; filter:\r\n\r\n```bash\r\njq -r &#39;[[.id],.labeled_values,.flavors] | combinations | flatten | @tsv&#39; file.json\r\n```\r\n```text\r\n99\tone\tgreen\thot\r\n99\tone\tgreen\tcold\r\n99\ttwo\tred\thot\r\n99\ttwo\tred\tcold\r\n99\tthree\tblue\thot\r\n99\tthree\tblue\tcold\r\n100\tfour\tgreen\thot\r\n100\tfive\tred\thot\r\n```",
                "title": "How to make a certain double cartesian product with jq?"
            },
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1716405155,
                "creation_date": 1716405155,
                "answer_id": 78519575,
                "question_id": 78518591,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "&gt; This code (from &lt;a href=&quot;https://stackoverflow.com/questions/78514365/how-to-get-jq-to-output-a-long-dataset-part-2&quot;&gt;here&lt;/a&gt; works without the flavors:\r\n&gt; \r\n&gt; ```bash\r\n&gt; $ cat tmp/foo.ndjson | jq -r &#39;[.id] + .labeled_values[] | @tsv&#39;\r\n&gt; ```\r\n\r\nJust add `.flavors[]` and wrap each item into its own array using `[.]`:\r\n```sh\r\njq -r &#39;[.id] + .labeled_values[] + (.flavors[] | [.]) | @tsv&#39;\r\n```\r\n```json\r\n99\tone\tgreen\thot\r\n99\ttwo\tred\thot\r\n99\tthree\tblue\thot\r\n99\tone\tgreen\tcold\r\n99\ttwo\tred\tcold\r\n99\tthree\tblue\tcold\r\n100\tfour\tgreen\thot\r\n100\tfive\tred\thot\r\n```\r\n[Demo](https://jqplay.org/s/dz9y_7gD4S0)\r\n",
                "title": "How to make a certain double cartesian product with jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 1,
        "last_activity_date": 1718283543,
        "creation_date": 1716391819,
        "last_edit_date": 1718283543,
        "question_id": 78518591,
        "body_markdown": "Suppose I have this dataset:\r\n\r\n```json\r\n{&quot;id&quot;: 99, &quot;labeled_values&quot;: [[&quot;one&quot;, &quot;green&quot;], [&quot;two&quot;, &quot;red&quot;], [&quot;three&quot;, &quot;blue&quot;]], &quot;flavors&quot;: [&quot;hot&quot;, &quot;cold&quot;]}\r\n{&quot;id&quot;: 100, &quot;labeled_values&quot;: [[&quot;four&quot;, &quot;green&quot;], [&quot;five&quot;, &quot;red&quot;]], &quot;flavors&quot;: [&quot;hot&quot;]}\r\n```\r\n\r\nand I would like this output (tab-separated):\r\n\r\n```tsv\r\n99 one green hot\r\n99 two red hot\r\n99 one green cold\r\n99 two red cold\r\n100 four green hot\r\n100 five red hot\r\n```\r\n\r\nThis code (from &lt;a href=&quot;https://stackoverflow.com/questions/78514365/how-to-get-jq-to-output-a-long-dataset-part-2&quot;&gt;here&lt;/a&gt;) works without the flavors:\r\n\r\n```bash\r\n$ cat tmp/foo.ndjson | jq -r &#39;[.id] + .labeled_values[] | @tsv&#39;\r\n99\tone\tgreen\r\n99\ttwo\tred\r\n99\tthree\tblue\r\n100\tfour\tgreen\r\n100\tfive\tred\r\n```\r\n\r\nHere is a failed attempt to add the flavor.  It concatenates all the flavors, not one at a time.\r\n\r\n```bash\r\n$ cat tmp/foo.ndjson | jq -r &#39;[.id] + .labeled_values[] + .flavors | @tsv&#39;\r\n99\tone\tgreen\thot\tcold\r\n99\ttwo\tred\thot\tcold\r\n99\tthree\tblue\thot\tcold\r\n100\tfour\tgreen\thot\r\n100\tfive\tred\thot\r\n```\r\n",
        "link": "https://stackoverflow.com/questions/78518591/how-to-make-a-certain-double-cartesian-product-with-jq",
        "title": "How to make a certain double cartesian product with jq?"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 4,
                "creation_date": 1716423770,
                "post_id": 78520461,
                "comment_id": 138427586,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 7912798,
                    "reputation": 57,
                    "user_id": 5976304,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/e51cd0fca60c8d9f216c37ed76dd6bfe?s=256&d=identicon&r=PG",
                    "display_name": "I J",
                    "link": "https://stackoverflow.com/users/5976304/i-j"
                },
                "reply_to_user": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1716424338,
                "post_id": 78520461,
                "comment_id": 138427630,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 7912798,
                    "reputation": 57,
                    "user_id": 5976304,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/e51cd0fca60c8d9f216c37ed76dd6bfe?s=256&d=identicon&r=PG",
                    "display_name": "I J",
                    "link": "https://stackoverflow.com/users/5976304/i-j"
                },
                "reply_to_user": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1716424472,
                "post_id": 78520461,
                "comment_id": 138427639,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1716424589,
                "post_id": 78520461,
                "comment_id": 138427646,
                "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": 1716425820,
                "post_id": 78520461,
                "comment_id": 138427712,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1716430551,
                "last_edit_date": 1716430551,
                "creation_date": 1716426130,
                "answer_id": 78520528,
                "question_id": 78520461,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "`.key[ &quot;value&quot; ]` and `.key.value` are equivalent.\r\n\r\nThese are specific uses of `EXPR[ EXPR2 ]` and `EXPR.IDENT`, two syntax for indexing. The differences in syntax impose the following differences in functionality:\r\n \r\n* `EXPR.IDENT` requires a hard-coded identifier.\r\n* `EXPR[ EXPR2 ]` accepts an expression which is evaluated at run-time.\r\n* `EXPR[ EXPR2 ]`&#39;s `EXPR2` isn&#39;t limited to return identifiers.\r\n* `EXPR[ EXPR2 ]`&#39;s `EXPR2` isn&#39;t limited to return strings.\r\n\r\nWhile any uses of `EXPR.IDENT` can be converted to the `EXPR[ EXPR2 ]` syntax, the above means there&#39;s no way to convert the following uses of `EXPR[ EXPR2 ]` into the `EXPR.IDENT` syntax:\r\n\r\n* `EXPR[ $key ]` (The value of `$key` isn&#39;t known during development.)\r\n* `EXPR[ &quot;foo.bar&quot; ]` (`foo.bar` isn&#39;t an identifier.)\r\n* `EXPR[ 0 ]`, to access an array element. (`0` isn&#39;t an identifier.)\r\n",
                "title": "What is jq &#39;.key[&quot;value&quot;]&#39;?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -1,
        "last_activity_date": 1716430551,
        "creation_date": 1716423672,
        "last_edit_date": 1716425813,
        "question_id": 78520461,
        "body_markdown": "`jq &#39;.key[&quot;value&quot;]&#39; config.json` is found in some of our bash scripts and when I tested it, it seems to be doing the same thing that `jq &#39;.key.value&#39; config.json` does.  So I am not sure why the latter (which I see everywhere else) is not used instead.  I tried to research this notation but found nothing.\r\n\r\nThanks in advance!",
        "link": "https://stackoverflow.com/questions/78520461/what-is-jq-keyvalue",
        "title": "What is jq &#39;.key[&quot;value&quot;]&#39;?"
    },
    {
        "tags": [
            "json",
            "key",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1716584487,
                "creation_date": 1716584487,
                "answer_id": 78530669,
                "question_id": 78530632,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Either will work\r\n```\r\nto_entries[] | select(.value.prop2 == &quot;yyyy&quot;) .key\r\n```\r\n```\r\npath(.[] | select(.prop2 == &quot;yyyy&quot;))[0]\r\n```",
                "title": "How to get the name of the enclosing object while filtering for property values in that enclosed object"
            },
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1716584584,
                "creation_date": 1716584584,
                "answer_id": 78530675,
                "question_id": 78530632,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "One way would be to first filter the outer object using `select` inside `map_values` (or `.[] |=`), and then get all its `keys`:\r\n```sh\r\nmap_values(select(.prop2 == &quot;yyyy&quot;)) | keys\r\n```\r\n```json\r\n[\r\n  &quot;anothername&quot;,\r\n  &quot;fubar&quot;\r\n]\r\n```\r\n[Demo](https://jqplay.org/s/HZufPBDABgh)",
                "title": "How to get the name of the enclosing object while filtering for property values in that enclosed object"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1716756343,
                "creation_date": 1716756343,
                "answer_id": 78536435,
                "question_id": 78530632,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39; another way to do it using [streaming](https://jqlang.github.io/jq/manual/#streaming).\r\n```\r\ntostream\r\n| if .[0][-1]==&quot;prop2&quot; and .[1]==&quot;yyyy&quot;\r\n  then .[0][0]\r\n  else empty\r\n  end\r\n```\r\nTry it on [jqplay.org](https://jqplay.org/s/7fXSmzQaDRe &quot;Click me!&quot;).",
                "title": "How to get the name of the enclosing object while filtering for property values in that enclosed object"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 1,
        "last_activity_date": 1716756343,
        "creation_date": 1716583901,
        "last_edit_date": 1716641674,
        "question_id": 78530632,
        "body_markdown": "I have a JSON file that looks like this:\r\n\r\n\t{\r\n\t  &quot;somename&quot;: {\r\n\t\t&quot;prop1&quot;: &quot;https://xxxx&quot;,\r\n\t\t&quot;prop2&quot;: &quot;xxxx&quot;,\r\n\t\t&quot;prop3&quot;: false\r\n\t  },\r\n\t  &quot;anothername&quot;: {\r\n\t\t&quot;prop1&quot;: &quot;https://yyyy&quot;,\r\n\t\t&quot;prop2&quot;: &quot;yyyy&quot;,\r\n\t\t&quot;prop3&quot;: false\r\n\t  },\r\n\t  &quot;fubar&quot;: {\r\n\t\t&quot;prop1&quot;: &quot;https://yyyy&quot;,\r\n\t\t&quot;prop2&quot;: &quot;yyyy&quot;,\r\n\t\t&quot;prop3&quot;: false\r\n\t  }\r\n\t}\r\n\r\nI mostly work with JSON files where the property NAMES of things are constant, and the VALUES vary, and I filter based on the values of named properties.\r\n\r\nIn this case, the &quot;prop1&quot;, &quot;prop2&quot;, and &quot;prop3&quot; properties are known, but the name of the enclosing object, essentially the name of that property, is what varies. It&#39;s those property names that I need to get.  For instance, I need to get the list of named blocks where the &quot;prop2&quot; property is equal to &quot;yyyy&quot;.  In this case, it would be &quot;anothername&quot; and &quot;fubar&quot;, but I can&#39;t figure out how to do that in jq.",
        "link": "https://stackoverflow.com/questions/78530632/how-to-get-the-name-of-the-enclosing-object-while-filtering-for-property-values",
        "title": "How to get the name of the enclosing object while filtering for property values in that enclosed object"
    },
    {
        "tags": [
            "json",
            "jq",
            "teleport"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1717704312,
                "post_id": 78588829,
                "comment_id": 138551201,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 12707478,
                    "reputation": 107,
                    "user_id": 9232236,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/AiP6D.png?s=256",
                    "display_name": "Kannan Varadhan",
                    "link": "https://stackoverflow.com/users/9232236/kannan-varadhan"
                },
                "reply_to_user": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1717705770,
                "post_id": 78588829,
                "comment_id": 138551403,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1717705944,
                "post_id": 78588829,
                "comment_id": 138551420,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1717709365,
                "creation_date": 1717709365,
                "answer_id": 78589133,
                "question_id": 78588829,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "This generates the expected output :\r\n\r\n```\r\njq -r &#39;.[]\r\n| .metadata.labels\r\n  , (.spec.labels\r\n  | with_entries(.value |= .result))\r\n| to_entries[]\r\n| map(tojson)\r\n| join(&quot;: &quot;)&#39; tmp/x.json\r\n```",
                "title": "stuck parsing a json object, to extract &quot;key/value&quot; pairs"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -1,
        "last_activity_date": 1717709365,
        "creation_date": 1717704013,
        "last_edit_date": 1717705649,
        "question_id": 78588829,
        "body_markdown": "I have an application that generates data in this form:\r\n```\r\n[\r\n  {\r\n    &quot;metadata&quot;: {\r\n      &quot;labels&quot;: {\r\n        &quot;team&quot;: &quot;eng&quot;\r\n      }\r\n    },\r\n    &quot;spec&quot;: {\r\n      &quot;labels&quot;: {\r\n        &quot;instance_id&quot;: {\r\n          &quot;result&quot;: &quot;x387j&quot;\r\n        },\r\n        &quot;another_field&quot;: {\r\n          &quot;result&quot;: &quot;dfsf&quot;\r\n        }\r\n      }\r\n    }\r\n  },\r\n  {\r\n    &quot;metadata&quot;: {\r\n      &quot;labels&quot;: {\r\n        &quot;team&quot;: &quot;sre&quot;\r\n      }\r\n    },\r\n    &quot;spec&quot;: {\r\n      &quot;labels&quot;: {\r\n        &quot;instance_id&quot;: {\r\n          &quot;result&quot;: &quot;sd9f&quot;\r\n        }\r\n      }\r\n    }\r\n  }\r\n]\r\n```\r\n\r\nLabels, here are the keys in `.metadata.labels` and `.spec.labels`.\r\nI can extract the labels as:\r\n\r\n```\r\n% jq -C &#39; .[] | ( .metadata.labels , .spec.labels ) | keys | .[] &#39; tmp/x.json | sort | uniq\r\n&quot;instance_id&quot;\r\n&quot;team&quot;\r\n```\r\n\r\nI want to extract the label and result pairs as:\r\n\r\n```\r\n&quot;team&quot;: &quot;eng&quot;\r\n&quot;instance_id&quot;: &quot;x387j&quot;\r\n&quot;another_field&quot;: &quot;dfsf&quot;\r\n&quot;team&quot;: &quot;sre&quot;\r\n&quot;instance_id&quot;: &quot;sd9f&quot;\r\n```\r\n\r\n\r\nI can get the objects in .metadata.labels, albiet in different form:\r\n```\r\n% jq -C &#39;.[] | (.metadata.labels) &#39; tmp/x.json\r\n{\r\n  &quot;team&quot;: &quot;eng&quot;\r\n}\r\n{\r\n  &quot;team&quot;: &quot;sre&quot;\r\n}\r\n```\r\ngenerates one part, but here, I am not able to remove just the braces.\r\nThe suggestion [here, to remove brackets, quotes, and commas](https://stackoverflow.com/questions/58566524/jq-how-to-define-filter-to-remove-brackets-quotes-and-commas-from-output-arra)\r\nremoves the braces, but also the keys.\r\n```\r\n% jq -C &#39;.[] | (.metadata.labels) | .[] &#39; tmp/x.json\r\n&quot;eng&quot;\r\n&quot;sre&quot;\r\n```\r\n\r\n\r\nAlso, I am then not able to figure out to get the objects in .spec.labels.",
        "link": "https://stackoverflow.com/questions/78588829/stuck-parsing-a-json-object-to-extract-key-value-pairs",
        "title": "stuck parsing a json object, to extract &quot;key/value&quot; pairs"
    },
    {
        "tags": [
            "datetime",
            "jq",
            "timezone-offset"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 1526477,
                    "reputation": 279,
                    "user_id": 1424780,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/1e5ea3e89e31b212093676ee8f0036b1?s=256&d=identicon&r=PG",
                    "display_name": "davidgo",
                    "link": "https://stackoverflow.com/users/1424780/davidgo"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1717749393,
                "post_id": 78604042,
                "comment_id": 138578873,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1450087,
                    "reputation": 12022,
                    "user_id": 1409374,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/97d424fe924f2139812a4a6de1ef6b79?s=256&d=identicon&r=PG",
                    "display_name": "rickhg12hs",
                    "link": "https://stackoverflow.com/users/1409374/rickhg12hs"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1718047388,
                "post_id": 78604042,
                "comment_id": 138579142,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1450087,
                    "reputation": 12022,
                    "user_id": 1409374,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/97d424fe924f2139812a4a6de1ef6b79?s=256&d=identicon&r=PG",
                    "display_name": "rickhg12hs",
                    "link": "https://stackoverflow.com/users/1409374/rickhg12hs"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1718049311,
                "post_id": 78604042,
                "comment_id": 138579400,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1718159618,
                "last_edit_date": 1718159618,
                "creation_date": 1718050043,
                "answer_id": 78604340,
                "question_id": 78604042,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "jq does support `strflocaltime` and if you are using gojq or a sufficiently recent version of the C implementation of jq, you could use that, e.g.:\r\n```\r\nTZ=Asia/Seoul gojq -n &#39;&quot;2024-06-07 00:00:00&quot; \r\n  | strptime(&quot;%Y-%m-%d %H:%M:%S&quot;)\r\n  | mktime\r\n  | strflocaltime(&quot;%FT%T %Z&quot;)&#39;\r\n```\r\nyields `&quot;2024-06-07T09:00:00 KST&quot;`\r\n\r\nIf using the C implementation, please check the result.\r\n\r\nAn alternative would be to do the calculation yourself, e.g. along these lines:\r\n```\r\njq -n &#39;&quot;2024-06-07 00:00:00&quot; \r\n| strptime(&quot;%Y-%m-%d %H:%M:%S&quot;)\r\n| .[3] += 9 \r\n| mktime\r\n| strftime(&quot;%FT%T KST&quot;)&#39;\r\n```\r\n\r\n--- \r\n\r\n### DST considerations\r\n\r\nSouth Korea has historically observed daylight savings time at various periods, but as best I can tell has not done so since 1988.  The &quot;TZ database&quot; uses the letters &quot;KDT&quot; to refer to the periods when DST was observed in South Korea.  This means that using `strflocaltime` in conjunction with &quot;TZ=Asia/Seoul&quot; can result in &quot;KDT&quot; times.  \r\n\r\nFor example, using the TZ technique outline above, gojq converts &quot;1951-05-05 15:00:00&quot; to &quot;1951-05-06T01:00:00 KDT&quot;.\r\n\r\n\r\n",
                "title": "How to convert GMT to GMT + 09(KST) from jq result"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1718159618,
        "creation_date": 1717724053,
        "last_edit_date": 1718084982,
        "question_id": 78604042,
        "body_markdown": "jq result is below.\r\n\r\n{date = 2024-06-07 00:00:00}\r\n\r\nThat is GMT.\r\n\r\nHow do I change timezone GMT+09(KST)?\r\n\r\nRegards.\r\n",
        "link": "https://stackoverflow.com/questions/78604042/how-to-convert-gmt-to-gmt-09kst-from-jq-result",
        "title": "How to convert GMT to GMT + 09(KST) from jq result"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1718049217,
                "post_id": 78604131,
                "comment_id": 138579386,
                "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": 1718049413,
                "post_id": 78604131,
                "comment_id": 138579414,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 26389,
                    "reputation": 9875,
                    "user_id": 68612,
                    "user_type": "registered",
                    "accept_rate": 81,
                    "profile_image": "https://i.sstatic.net/gCXRz.jpg?s=256",
                    "display_name": "Gandalf",
                    "link": "https://stackoverflow.com/users/68612/gandalf"
                },
                "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": 1718049596,
                "post_id": 78604131,
                "comment_id": 138579438,
                "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": 1718049925,
                "post_id": 78604131,
                "comment_id": 138579481,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2435703,
                    "reputation": 27493,
                    "user_id": 2125671,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/13a492143ab4a2575b5a1f500691193c?s=256&d=identicon&r=PG",
                    "display_name": "Philippe",
                    "link": "https://stackoverflow.com/users/2125671/philippe"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1718054340,
                "post_id": 78604131,
                "comment_id": 138579974,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1718110792,
                "post_id": 78604131,
                "comment_id": 138585386,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1718050231,
                "last_edit_date": 1718050231,
                "creation_date": 1718047287,
                "answer_id": 78604174,
                "question_id": 78604131,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If you `map` over the outer array, `select` the item where `.ParameterKey == &quot;EnvironmentParam&quot;`, and set `.ParameterValue = env.MY_ENV`.\r\n```sh\r\nmap(select(.ParameterKey == &quot;EnvironmentParam&quot;).ParameterValue = env.MY_ENV)\r\n```\r\n\r\nTo import the name (not the value of) `MY_ENV` from the shell, use the `--arg` flag:\r\n```sh\r\njq --arg e MY_ENV &#39;map(select(…).ParameterValue = env[$e])&#39;\r\n```",
                "title": "Edit JSON property file for use in bash script"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1718050231,
        "creation_date": 1718046560,
        "last_edit_date": 1718049636,
        "question_id": 78604131,
        "body_markdown": "I have a .sh script and a .json properties file for use with AWS CLI v2 to create a CF Stack.  I have a parameters file in JSON that I need to substitute one value, but all th key/value pairs are the same and I cannot figure out how to get it to pick the right one, the variable `MY_ENV` in defined in the script and the line below is what I need to pass the edited JSON file into.  I believe it will also take it s a full String Blob instead of file if that is easier.  I was trying `jq` with no luck but maybe there&#39;s an even easier solution\r\n\r\n    aws cloudformation create-stack --capabilities CAPABILITY_NAMED_IAM --stack-name $lambda-$env --template-url &lt;url&gt; --output json --parameter $property_file &lt;-- file I am passing in\r\n\r\nproperty_file\r\n\r\n    [\r\n      {&quot;ParameterKey&quot;:&quot;RuleState&quot;, &quot;ParameterValue&quot;: &quot;DISABLED&quot;},\r\n      {&quot;ParameterKey&quot;:&quot;LambdaSchedule&quot;, &quot;ParameterValue&quot;:&quot;rate(20 minutes)&quot;},\r\n      {&quot;ParameterKey&quot;:&quot;EnvironmentParam&quot;, &quot;ParameterValue&quot;:&quot;$MY_ENV&quot;}, &lt;-- the string I need changed\r\n      {&quot;ParameterKey&quot;:&quot;Method&quot;, &quot;ParameterValue&quot;:&quot;POST&quot;},\r\n      {&quot;ParameterKey&quot;:&quot;LambdaName&quot;, &quot;ParameterValue&quot;:&quot;TestLambda&quot;}\r\n    ]",
        "link": "https://stackoverflow.com/questions/78604131/edit-json-property-file-for-use-in-bash-script",
        "title": "Edit JSON property file for use in bash script"
    },
    {
        "tags": [
            "arrays",
            "json",
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1718123161,
                "post_id": 78608644,
                "comment_id": 138587564,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1718121868,
                "creation_date": 1718121868,
                "answer_id": 78608661,
                "question_id": 78608644,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Since your `add` key is static, I&#39;d only pass the `value` of the item you want to add using the correct key as varibale.\r\n\r\nThen you can add it by doing `.. |= { $add }`\r\n:\r\n\r\n```\r\njq --arg add &quot;labelValue&quot; &#39;.update.labels |= { $add }&#39; &lt;&lt;&lt; &quot;$data&quot;\r\n```",
                "title": "Add key:value pairs to JSON object in Bash"
            },
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1718124835,
                "last_edit_date": 1718124835,
                "creation_date": 1718121956,
                "answer_id": 78608668,
                "question_id": 78608644,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Why not do everything in a single call to jq, using `--args &quot;$@&quot;` to transfer all arguments to jq, and therein the `$ARGS.positional` array to reference them:\r\n```sh\r\n#!/bin/bash\r\n\r\ndata=&#39;{&quot;update&quot;: { &quot;labels&quot;: [] } }&#39;\r\n\r\njq &#39;.update.labels += [{add: $ARGS.positional[]}]&#39; --args &quot;$@&quot; &lt;&lt;&lt; &quot;$data&quot; &gt; output.json\r\n```\r\n\r\nOr, if you let jq also generate the initial document, it&#39;s really just that one call:\r\n```\r\n#!/bin/sh\r\n\r\njq -n &#39;.update.labels = [{add: $ARGS.positional[]}]&#39; --args &quot;$@&quot; &gt; output.json\r\n```",
                "title": "Add key:value pairs to JSON object in Bash"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1718124009,
                "creation_date": 1718124009,
                "answer_id": 78608808,
                "question_id": 78608644,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Make sure to escape your key/value quotes:\r\n\r\n```sh\r\nfor label in &quot;$@&quot;; do\r\n    objJSON=$(echo &quot;{ \\&quot;add\\&quot;: \\&quot;$label\\&quot; }&quot; | jq -c .)\r\n###       escape here-^----^---^-------^   compact-^\r\n    data=$(echo &quot;$data&quot; | jq --argjson jsonString &quot;$objJSON&quot; &#39;.update.labels += [$jsonString]&#39;)\r\ndone\r\n```\r\n\r\nHere is a Bash script that handles adding new objects to the update labels array.\r\n\r\n```sh\r\n#!/usr/bin/env bash\r\n\r\nDEFAULT_OUTPUT_FILENAME=output.txt\r\n\r\n# Function to display help\r\nshow_help() {\r\n    echo &quot;Usage: $(basename &quot;$0&quot;) [options] [label1] [label2] ... [labelN]&quot;\r\n    echo\r\n    echo &quot;This script takes key-value pair arguments and adds them to a JSON document.&quot;\r\n    echo\r\n    echo &quot;Options:&quot;\r\n    echo &quot;  -i, --input FILE   Input JSON file to append labels to (default: ${DEFAULT_OUTPUT_FILENAME}).&quot;\r\n    echo &quot;  -o, --output FILE  Output to FILE instead of ${DEFAULT_OUTPUT_FILENAME}.&quot;\r\n    echo &quot;  -h, --help         Display this help message.&quot;\r\n    echo\r\n    echo &quot;Arguments:&quot;\r\n    echo &quot;  labelN        The key-value pair to add to the JSON document.&quot;\r\n    echo\r\n    echo &quot;Example:&quot;\r\n    echo &quot;  $(basename &quot;$0&quot;) \\&quot;label1\\&quot; \\&quot;label2\\&quot; \\&quot;label3\\&quot;&quot;\r\n    echo &quot;  $(basename &quot;$0&quot;) -i existing.json -o updated.json \\&quot;label1\\&quot; \\&quot;label2\\&quot;&quot;\r\n}\r\n\r\n# Initialize variables\r\ninput_file=${DEFAULT_OUTPUT_FILENAME}\r\noutput_file=${DEFAULT_OUTPUT_FILENAME}\r\n\r\n# Parse options\r\nwhile [[ &quot;$1&quot; == -* ]]; do\r\n    case &quot;$1&quot; in\r\n        -i|--input)\r\n            input_file=&quot;$2&quot;\r\n            shift 2\r\n            ;;\r\n        -o|--output)\r\n            output_file=&quot;$2&quot;\r\n            shift 2\r\n            ;;\r\n        -h|--help)\r\n            show_help\r\n            exit 0\r\n            ;;\r\n        *)\r\n            echo &quot;Unknown option: $1&quot;\r\n            show_help\r\n            exit 1\r\n            ;;\r\n    esac\r\ndone\r\n\r\n# Ensure at least one label is provided\r\nif [[ $# -eq 0 ]]; then\r\n    echo &quot;No labels provided. Use -h or --help for usage information.&quot;\r\n    exit 1\r\nfi\r\n\r\n# Initialize JSON data\r\nif [[ -f &quot;$input_file&quot; ]]; then\r\n    data=$(cat &quot;$input_file&quot;)\r\nelse\r\n    data=&#39;{&quot;update&quot;: { &quot;labels&quot;: [] } }&#39;\r\nfi\r\n\r\n# Iterate over the labels\r\nfor label in &quot;$@&quot;; do\r\n    # Create JSON object from the label\r\n    objJSON=$(echo &quot;{ \\&quot;add\\&quot;: \\&quot;$label\\&quot; }&quot; | jq -c .)\r\n    # Append the JSON object to the labels array\r\n    data=$(echo &quot;$data&quot; | jq --argjson jsonString &quot;$objJSON&quot; &#39;.update.labels += [$jsonString]&#39;)\r\ndone\r\n\r\n# Output the final JSON to a file\r\necho &quot;$data&quot; &gt; &quot;$output_file&quot;\r\n\r\n# Pretty print the JSON\r\njq --color-output . &quot;$output_file&quot;\r\n```\r\n\r\nHere is the usage:\r\n\r\n```sh\r\n[user@host ~]$ ./json_add.sh --help\r\nUsage: json_add.sh [options] [label1] [label2] ... [labelN]\r\n\r\nThis script takes key-value pair arguments and adds them to a JSON document.\r\n\r\nOptions:\r\n  -i, --input FILE   Input JSON file to append labels to (default: output.txt).\r\n  -o, --output FILE  Output to FILE instead of output.txt.\r\n  -h, --help         Display this help message.\r\n\r\nArguments:\r\n  labelN        The key-value pair to add to the JSON document.\r\n\r\nExample:\r\n  json_add.sh &quot;label1&quot; &quot;label2&quot; &quot;label3&quot;\r\n  json_add.sh -i existing.json -o updated.json &quot;label1&quot; &quot;label2&quot;\r\n```",
                "title": "Add key:value pairs to JSON object in Bash"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 1,
        "last_activity_date": 1718124835,
        "creation_date": 1718121590,
        "last_edit_date": 1718122491,
        "question_id": 78608644,
        "body_markdown": "I would like to add a number of key:value pairs to an existing JSON string. The values are passed as command line arguments to my script.\r\n\r\nSo far I&#39;ve got this\r\n\r\n```bash\r\ndata=&#39;{&quot;update&quot;: { &quot;labels&quot;: [] } }&#39;\r\n\r\nfor label in &quot;${@}&quot;;do\r\n   objJSON=$(printf &#39;%s\\n&#39; &quot;{ &quot;add&quot;: ${label} }&quot; | jq -R . | jq -s .)\r\n   data=$(echo ${data} | jq  --argjson jsonString &quot;$objJSON&quot; &#39;.update.labels += $jsonString&#39;)\r\ndone\r\necho ${data} &gt;output.txt\r\n\r\njq --color-output . output.txt\r\n```\r\n\r\nMy output is this:\r\n\r\n```json\r\n{\r\n  &quot;update&quot;: {\r\n    &quot;labels&quot;: [\r\n      &quot;{ add: value1 }&quot;,\r\n      &quot;{ add: value2 }&quot;\r\n    ]\r\n  }\r\n}\r\n```\r\n\r\nbut I&#39;m trying to get this (note the quotes surrounding `add` and each value):\r\n\r\n```json\r\n{\r\n  &quot;update&quot;: {\r\n    &quot;labels&quot;: [\r\n      { &quot;add&quot;: &quot;value1&quot; },\r\n      { &quot;add&quot;: &quot;value2&quot; }\r\n    ]\r\n  }\r\n}\r\n```\r\n\r\nI can&#39;t see where I&#39;m going wrong - can anyone help please?",
        "link": "https://stackoverflow.com/questions/78608644/add-keyvalue-pairs-to-json-object-in-bash",
        "title": "Add key:value pairs to JSON object in Bash"
    },
    {
        "tags": [
            "json",
            "jq",
            "gcloud",
            "google-cloud-pubsub"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 3,
                "creation_date": 1718136672,
                "post_id": 78609562,
                "comment_id": 138589200,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1713685,
                    "reputation": 61,
                    "user_id": 1571242,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/44a2cc6c395ae87bbec79e34a4d574f9?s=256&d=identicon&r=PG",
                    "display_name": "Thomas Hansen",
                    "link": "https://stackoverflow.com/users/1571242/thomas-hansen"
                },
                "reply_to_user": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1718137720,
                "post_id": 78609562,
                "comment_id": 138589317,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1713685,
                    "reputation": 61,
                    "user_id": 1571242,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/44a2cc6c395ae87bbec79e34a4d574f9?s=256&d=identicon&r=PG",
                    "display_name": "Thomas Hansen",
                    "link": "https://stackoverflow.com/users/1571242/thomas-hansen"
                },
                "reply_to_user": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1718188324,
                "post_id": 78609562,
                "comment_id": 138593796,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "is_answered": false,
        "answer_count": 0,
        "score": 0,
        "last_activity_date": 1718162734,
        "creation_date": 1718136499,
        "last_edit_date": 1718136937,
        "question_id": 78609562,
        "body_markdown": "I have a JSON file named `countries/list.json` I want to publish the content with `gcloud` CLI.\r\n```json\r\n{\r\n  &quot;countries&quot;: [\r\n   {\r\n      &quot;id&quot;: &quot;SE&quot;,\r\n      &quot;name&quot;: &quot;Sweden&quot;\r\n    },\r\n    {\r\n      &quot;id&quot;: &quot;UK&quot;,\r\n      &quot;name&quot;: &quot;United Kingdom&quot;\r\n    }\r\n  ]\r\n}\r\n```\r\n\r\n\r\nAccoring to the CLI [docs](https://cloud.google.com/pubsub/docs/publisher#gcloud) I should be able to use \r\n```\r\ngcloud pubsub topics publish projects/&lt;PROJECT&gt;/topics/&lt;TOPIC&gt;--message=$(jq -c &quot;.&quot; countries/list.json) --attribute &quot;Content-Type=application/json&quot;\r\n```\r\nThis results in \r\n\r\n```\r\nERROR: (gcloud.pubsub.topics.publish) unrecognized arguments: Kingdom&quot;}]} \r\n```\r\n\r\n\r\nIf I change `&quot;United Kingdom&quot;` to `&quot;United-Kingdom&quot;` it works, but that is not what I want.",
        "link": "https://stackoverflow.com/questions/78609562/gcloud-publish-pub-sub-json-message-where-json-properties-contain-space-characte",
        "title": "gcloud publish Pub/Sub JSON message where JSON properties contain space characters"
    },
    {
        "tags": [
            "json",
            "error-handling",
            "jq",
            "export-to-csv"
        ],
        "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": 1718223329,
                "post_id": 78614783,
                "comment_id": 138598802,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1718223660,
                "creation_date": 1718223660,
                "answer_id": 78614813,
                "question_id": 78614783,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can suppress errors caused by non-existing parts by using `?`, and provide a default alternative using `//`. For example:\r\n\r\n```sh\r\n.[] | [\r\n  .hostname,\r\n  .distribution,\r\n  first(.hardware[] | select(.[0] == &quot;serial&quot;) | .[1])? // &quot;n/a&quot;\r\n] | @csv\r\n```\r\n[Demo](https://jqplay.org/s/9uybYos2Trz)",
                "title": "how to display specific array of arrays elements matching pattern"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1718236032,
        "creation_date": 1718223178,
        "last_edit_date": 1718236032,
        "question_id": 78614783,
        "body_markdown": "I have the following array, with thoushand json elements, like the following\r\n\r\n\r\n    [\r\n      {                                                                                                                                                                                                                                     \r\n        &quot;id&quot;: 302,\r\n        &quot;hostname&quot;: &quot;laptop857&quot;,\r\n        &quot;total_memory&quot;: 31722,\r\n        &quot;total_swap&quot;: 92535,\r\n        &quot;distribution&quot;: &quot;22.04&quot;,\r\n        &quot;hardware&quot;: [\r\n          [\r\n            &quot;product&quot;,\r\n            &quot;XPS 15 7590 (0905)&quot;,\r\n            null\r\n          ],\r\n          [\r\n            &quot;vendor&quot;,\r\n            &quot;Dell Inc.&quot;,\r\n            null\r\n          ],\r\n          [\r\n            &quot;serial&quot;,\r\n            &quot;XXDPXXX&quot;,\r\n            null\r\n          ]\r\n        ]\r\n      }\r\n      {\r\n        &quot;id&quot;: 303,\r\n        &quot;hostname&quot;: &quot;laptop858&quot;,\r\n      ....\r\n      }, \r\n    ]\r\n\r\nMy goal is to parse the json file and for each elements extract the hostname, distribution and serial number. I want to create a report where each line represent a computer, like\r\nlaptop857,22.04,XXDPXXX\r\nlaptop858, ....\r\n\r\n\r\nI&#39;m able to output for hostname and distribution , together\r\nI&#39;m also able to do it for serial, but some entries do not have serial number and failed the parsing\r\nI keep getting error for whatever I try to get the 3 elements together on the same line\r\n\r\nAny chance someone could provide hit or what I should look at to achieve my result\r\nI could live with an entry like\r\nlaptop857,22.04,serial XXDPXXX null\r\n\r\n",
        "link": "https://stackoverflow.com/questions/78614783/how-to-display-specific-array-of-arrays-elements-matching-pattern",
        "title": "how to display specific array of arrays elements matching pattern"
    },
    {
        "tags": [
            "json",
            "shell",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1718287301,
                "post_id": 78618296,
                "comment_id": 138605390,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 3614295,
                    "reputation": 421,
                    "user_id": 3014588,
                    "user_type": "registered",
                    "accept_rate": 50,
                    "profile_image": "https://www.gravatar.com/avatar/71c9b8bff89d2034b959616ff2ec55b5?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Ashish Mishra",
                    "link": "https://stackoverflow.com/users/3014588/ashish-mishra"
                },
                "reply_to_user": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1718293955,
                "post_id": 78618296,
                "comment_id": 138606428,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1143565,
                    "reputation": 535973,
                    "user_id": 1126841,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/fa05233b2357f8d11c22ef4cfc7bb85c?s=256&d=identicon&r=PG",
                    "display_name": "chepner",
                    "link": "https://stackoverflow.com/users/1126841/chepner"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1718294840,
                "post_id": 78618296,
                "comment_id": 138606607,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 3614295,
                    "reputation": 421,
                    "user_id": 3014588,
                    "user_type": "registered",
                    "accept_rate": 50,
                    "profile_image": "https://www.gravatar.com/avatar/71c9b8bff89d2034b959616ff2ec55b5?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Ashish Mishra",
                    "link": "https://stackoverflow.com/users/3014588/ashish-mishra"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1718295891,
                "post_id": 78618296,
                "comment_id": 138606765,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 3614295,
                    "reputation": 421,
                    "user_id": 3014588,
                    "user_type": "registered",
                    "accept_rate": 50,
                    "profile_image": "https://www.gravatar.com/avatar/71c9b8bff89d2034b959616ff2ec55b5?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Ashish Mishra",
                    "link": "https://stackoverflow.com/users/3014588/ashish-mishra"
                },
                "reply_to_user": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1718302821,
                "post_id": 78618296,
                "comment_id": 138607643,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "is_answered": false,
        "answer_count": 0,
        "score": 1,
        "last_activity_date": 1718323110,
        "creation_date": 1718286797,
        "last_edit_date": 1718323110,
        "question_id": 78618296,
        "body_markdown": "I have a some url array like below, Later I want to do some post method for each array element. somehow array element not working, but when I try direct url value its working.\r\n\r\n    # Print the uncommon URLs\r\n    echo &quot;Uncommon URLs:&quot;\r\n    printf &quot;%s\\n&quot; &quot;${uncommon_urls[@]}&quot;\r\n    \r\n\r\n    IFS=$&#39;\\n&#39; read -d &#39;&#39; -r -a array1 &lt;&lt;&lt; &quot;${uncommon_urls[@]}&quot;\r\n    getApp=$(curl -X GET -H &quot;$headers&quot; -H &quot;Content-Type: application/json&quot; &quot;$uri&quot;)\r\n    #echo $getApp\r\n    for url in &quot;${array1[@]}&quot;; do\r\n            echo $url\r\n            url=$(echo &quot;$url&quot; | rev | cut -c2- | rev)\r\n            echo $url\r\n            url=$(echo &quot;$url&quot; | tr -d &#39;&quot;&#39;)\r\n            echo $url\r\n           #getApp=$(echo &quot;$getApp&quot; | jq &#39;.redirect_uris -= [&quot;https://172.16.19.31:1111/login/callback&quot;]&#39;)\r\n           getApp=$(echo &quot;$getApp&quot; | jq &#39;.redirect_uris -= [&quot;&#39;$url&#39;&quot;]&#39;)\r\n           getAppnew=$(curl -X PUT -H &quot;$headers&quot; -H &quot;Content-Type: application/json&quot; -d &quot;$getApp&quot; &quot;$uri&quot;)\r\n    done\r\n    \r\n    echo urslnew\r\n    echo $getAppnew\r\n\r\n\r\noutput \r\n\r\n    Uncommon URLs:\r\n    [\r\n      &quot;https://172.xx.xx.31:3610/login/callback&quot;,\r\n      &quot;https://172.xx.xx.31:3611/login/callback&quot;\r\n      \r\n    ]\r\n    \r\n    &quot;https://172.xx.xx.31:3611/login/callback&quot;,\r\n    &quot;https://172.xx.xx.31:3611/login/callback&quot;\r\n    https://172.xx.xx.31:3611/login/callback\r\n      % Total    % Received % Xferd  Average Speed   Time    Time     Time  Current\r\n                                     Dload  Upload   Total   Spent    Left  Speed\r\n    100  3411    0  1597  100  1814   2321   2636 --:--:-- --:--:-- --:--:--  4950\r\n    &quot;https://172.xx.xx.31:3612/login/callback&quot;,\r\n    &quot;https://172.xx.xx.31:3612/login/callback&quot;\r\n    https://172.xx.xx.31:3612/login/callback\r\n      % Total    % Received % Xferd  Average Speed   Time    Time     Time  Current\r\n                                     Dload  Upload   Total   Spent    Left  Speed\r\n    100  3411    0  1597  100  1814   3013   3422 --:--:-- --:--:-- --:--:--  6423\r\n\r\n\r\nCode which is working is below.If I put url value directly, its working\r\n\r\n    getApp=$(echo &quot;$getApp&quot; | jq &#39;.redirect_uris -= [&quot;https://172.xx.xx.31:1111/login/callback&quot;]&#39;)\r\n\r\n\r\nIf I define manually like this all works fine\r\n\r\n    uncommon_urls=(\r\n      &quot;https://172.16.19.31:12163/login/callback&quot;\r\n      &quot;https://172.16.19.31:20383/login/callback&quot;\r\n      &quot;https://172.16.19.31:31990/login/callback&quot;\r\n      &quot;https://172.16.19.31:21480/login/callback&quot;\r\n      &quot;https://172.16.19.31:2851/login/callback&quot;\r\n      &quot;https://172.16.19.31:8549/login/callback&quot;\r\n      &quot;https://172.16.19.31:11092/login/callback&quot;\r\n      &quot;https://172.16.19.31:11092/auth/login/callback&quot;\r\n      &quot;https://172.16.19.31:3355/auth/login/callback&quot;\r\n      &quot;https://172.16.19.31:10602/auth/login/callback&quot;\r\n    )\r\n\r\n",
        "link": "https://stackoverflow.com/questions/78618296/shell-script-array-element-value-not-working-in-json-post-query",
        "title": "Shell script array element value not working in json post query"
    },
    {
        "tags": [
            "arrays",
            "json",
            "concatenation",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 4657170,
                    "reputation": 436,
                    "user_id": 3775361,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/5aa5263454ebce9dc0b2b885a6928fe8?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "bob",
                    "link": "https://stackoverflow.com/users/3775361/bob"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1718412088,
                "post_id": 78625351,
                "comment_id": 138618490,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1718410992,
                "creation_date": 1718410992,
                "answer_id": 78625356,
                "question_id": 78625351,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Read both files into an array, use `transpose` to combine by their index, and perform the operation on the resulting array, i.e. `add` the subarrays.\r\n```sh\r\njq -nc --slurpfile f1 file1.json --slurpfile f2 file2.json \\\r\n  &#39;[$f1, $f2] | transpose[] | add&#39;\r\n```\r\n\r\nAlternatively, read them into one array, and split that single array in half to produce the two subarrays:\r\n```sh\r\njq -sc &#39;[.[:length/2], .[length/2:]] | transpose[] | add&#39; file1.json file2.json\r\n```\r\n\r\nOutput:\r\n```json\r\n[0,1,2,3,4,5]\r\n[&quot;a&quot;,&quot;b&quot;,&quot;c&quot;,&quot;d&quot;,&quot;e&quot;,&quot;f&quot;]\r\n```",
                "title": "How to combine lists on the command line (jq)?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -1,
        "last_activity_date": 1718418656,
        "creation_date": 1718410722,
        "last_edit_date": 1718418656,
        "question_id": 78625351,
        "body_markdown": "I have two files with JSON lists:\r\n\r\nFile 1\r\n\r\n    [0,1,2]\r\n    [&quot;a&quot;, &quot;b&quot;, &quot;c&quot;]\r\n\r\nFile 2\r\n\r\n    [3,4,5]\r\n    [&quot;d&quot;, &quot;e&quot;, &quot;f&quot;]\r\n\r\nHow can I use `jq` or a similar command line tool to combine the lists in each line? The result from combining the two files above should be :\r\n\r\n    [0,1,2,3,4,5]\r\n    [&quot;a&quot;, &quot;b&quot;, &quot;c&quot;, &quot;d&quot;, &quot;e&quot;, &quot;f&quot;]",
        "link": "https://stackoverflow.com/questions/78625351/how-to-combine-lists-on-the-command-line-jq",
        "title": "How to combine lists on the command line (jq)?"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 39208,
                    "reputation": 267964,
                    "user_id": 112968,
                    "user_type": "registered",
                    "accept_rate": 68,
                    "profile_image": "https://i.sstatic.net/zHTaT.png?s=256",
                    "display_name": "knittl",
                    "link": "https://stackoverflow.com/users/112968/knittl"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1718651771,
                "post_id": 78634265,
                "comment_id": 138635517,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 202552,
                    "reputation": 12401,
                    "user_id": 449693,
                    "user_type": "registered",
                    "accept_rate": 58,
                    "profile_image": "https://www.gravatar.com/avatar/059e801224986097231a37e6042de92a?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Tony Ennis",
                    "link": "https://stackoverflow.com/users/449693/tony-ennis"
                },
                "reply_to_user": {
                    "account_id": 39208,
                    "reputation": 267964,
                    "user_id": 112968,
                    "user_type": "registered",
                    "accept_rate": 68,
                    "profile_image": "https://i.sstatic.net/zHTaT.png?s=256",
                    "display_name": "knittl",
                    "link": "https://stackoverflow.com/users/112968/knittl"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1718653113,
                "post_id": 78634265,
                "comment_id": 138635660,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1718653090,
                "last_edit_date": 1718653090,
                "creation_date": 1718652148,
                "answer_id": 78634346,
                "question_id": 78634265,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "This works fine with the example input:\r\n```\r\nmap(. + (.msg | {&quot;msg.a&quot;: .a, &quot;msg.b&quot;: .b}))\r\n```\r\nThis is more flexible if the actual task involves more keys or keys with longer names:\r\n```\r\nmap(. + (.msg | {a, b} | with_entries(.key |= &quot;msg.\\(.)&quot;)))\r\n```\r\nAnd if you do this for several fields like `msg`, a function could help shorten the code:\r\n```\r\ndef f(x): . as $in\r\n| reduce path(x) as $p ({};\r\n  . + {($p | join(&quot;.&quot;)): $in | getpath($p)}\r\n);\r\nmap(. + f(.msg | .a, .b))\r\n```",
                "title": "flattening a json file using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1718653208,
        "creation_date": 1718650816,
        "last_edit_date": 1718653208,
        "question_id": 78634265,
        "body_markdown": "I would like to flatten a json file in order to meet the needs of a legacy program.  I would prefer to use `jq` for this as I know it is available to me.\r\n\r\nI have a file something like this:\r\n\r\n    [\r\n    {\r\n    &quot;field1&quot;:10,\r\n    &quot;field2&quot;:20,\r\n    &quot;msg&quot;:\r\n      {\r\n      &quot;a&quot;:1,\r\n      &quot;b&quot;:2,\r\n      &quot;c&quot;:3\r\n      }\r\n    }\r\n    ]\r\n\r\nFor reasons, I need to pull the a and b fields from `msg` and flatten their names:\r\n\r\n    [\r\n    {\r\n    &quot;field1&quot;:10,\r\n    &quot;field2&quot;:20,\r\n    &quot;msg.a&quot;:1,\r\n    &quot;msg.b&quot;:2,\r\n    &quot;msg&quot;:   # the entire msg structure is now optional; if it falls off that&#39;s ok\r\n      {\r\n      &quot;a&quot;:1,\r\n      &quot;b&quot;:2,\r\n      &quot;c&quot;:3\r\n      },\r\n    }, ...\r\n    ]\r\n\r\nHow is the miracle accomplished?",
        "link": "https://stackoverflow.com/questions/78634265/flattening-a-json-file-using-jq",
        "title": "flattening a json file using jq"
    },
    {
        "tags": [
            "json",
            "merge",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": -1,
                "last_activity_date": 1718859321,
                "last_edit_date": 1718859321,
                "creation_date": 1718858875,
                "answer_id": 78645557,
                "question_id": 78645462,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "```jq -s &#39;reduce .[] as $item ({}; . + ($item | with_entries(if .key == &quot;key1&quot; then .value = (.value + $item.key1) else . end)))&#39; a.json b.json```\r\n",
                "title": "How to merge 2 json files using jq (deep merge and concat array)"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1718883759,
                "last_edit_date": 1718883759,
                "creation_date": 1718882249,
                "answer_id": 78647131,
                "question_id": 78645462,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The problem is, that you want to merge like `*` would, but treat colliding arrays like `+` would. You could prepare those arrays such that merging with `*` will eventually work as desired, e.g. by pre-processing the addition, and storing it in the last affected array.\r\n\r\n```sh\r\n# Use with option `jq -s` so that the inputs are collected into an array\r\nreduce (\r\n  # Find highest ranked arrays\r\n  [paths(arrays) | select(all(.[1:][]; type == &quot;string&quot;))]\r\n  # Group those that would collide\r\n  | group_by(.[1:])[]\r\n) as $group (.;\r\n  # Store the addition into the last of those arrays\r\n  setpath($group[-1]; [getpath($group[])] | add)\r\n)\r\n# Perform the actual merge (for only two inputs, `first * last` would suffice)\r\n| reduce .[1:][] as $next (first; . * $next)\r\n```\r\n```json\r\n{\r\n  &quot;key1&quot;: {\r\n    &quot;key2&quot;: [\r\n      1,\r\n      2,\r\n      3,\r\n      4,\r\n      5\r\n    ]\r\n  },\r\n  &quot;key3&quot;: &quot;aaa&quot;,\r\n  &quot;key4&quot;: &quot;bbb&quot;\r\n}\r\n```\r\n[Demo](https://jqplay.org/s/wr6aPfST3DFiLuK)\r\n\r\n---\r\nAlternatively, use another JSON processor that provides such merging techniques. For example, [mikefarah/yq](https://github.com/mikefarah/yq) implements a `*+` [operator](https://mikefarah.gitbook.io/yq/operators/multiply-merge#merge-appending-arrays) that &quot;merges objects, but appends arrays&quot;. Note that `yq` is primarily a YAML processor (so the manual is focused around YAML examples) but it can also handle JSON input/output (if not clear from the filename extensions, use the explicit `-pj -oj` flags).\r\n```sh\r\nyq &#39;. *+ load(&quot;b.json&quot;)&#39; a.json\r\n```",
                "title": "How to merge 2 json files using jq (deep merge and concat array)"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1719005833,
                "last_edit_date": 1719005833,
                "creation_date": 1719005352,
                "answer_id": 78654491,
                "question_id": 78645462,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You&#39;ll need to implement your own merge method to resolve how you want to merge arrays.  Something like this:\r\n\r\n```\r\ndef deep_merge($val1; $val2):\r\n\t[($val1, $val2) | type] as $types |\r\n\tif $types == [&quot;object&quot;, &quot;object&quot;] then\r\n\t\t# merge objects\r\n\t\treduce ([($val1, $val2) | keys[]] | unique[]) as $k ({};\r\n\t\t\tif all($val1, $val2; has($k)) then\r\n\t\t\t\t.[$k] = deep_merge($val1[$k]; $val2[$k])\r\n\t\t\telse\r\n\t\t\t\t.[$k] = ($val1[$k] // $val2[$k])\r\n\t\t\tend\r\n\t\t)\r\n\telif $types == [&quot;array&quot;, &quot;array&quot;] then\r\n\t\t# both arrays, concatenate\r\n\t\t$val1 + $val2\r\n\telse\r\n\t\t# use default merge\r\n\t\t$val1 * $val2\r\n\tend\r\n\t;\r\n```\r\n\r\nAdd to your .jq file or inline your filter.\r\n\r\nThen to merge your files:\r\n\r\n```sh\r\n$ jq -n &#39;deep_merge(input; input)&#39; a.json b.json\r\n{\r\n  &quot;key1&quot;: {\r\n    &quot;key2&quot;: [\r\n      1,\r\n      2,\r\n      3,\r\n      4,\r\n      5\r\n    ]\r\n  },\r\n  &quot;key3&quot;: &quot;aaa&quot;,\r\n  &quot;key4&quot;: &quot;bbb&quot;\r\n}\r\n```\r\n\r\n----\r\n\r\nIf you need to add the option to change how to handle arrays, you could use this version:\r\n\r\n```\r\n# provide filter to resolve arrays\r\ndef deep_merge($val1; $val2; resolve_array):\r\n\t[($val1, $val2) | type] as $types |\r\n\tif $types == [&quot;object&quot;, &quot;object&quot;] then\r\n\t\t# merge objects\r\n\t\treduce ([($val1, $val2) | keys[]] | unique[]) as $k ({};\r\n\t\t\tif all($val1, $val2; has($k)) then\r\n\t\t\t\t.[$k] = deep_merge($val1[$k]; $val2[$k]; resolve_array)\r\n\t\t\telse\r\n\t\t\t\t.[$k] = ($val1[$k] // $val2[$k])\r\n\t\t\tend\r\n\t\t)\r\n\telif $types == [&quot;array&quot;, &quot;array&quot;] then\r\n\t\t# both arrays, resolve\r\n\t\t[$val1, $val2] | resolve_array\r\n\telse\r\n\t\t# use default merge\r\n\t\t$val1 * $val2\r\n\tend\r\n\t;\r\n\r\n# concatenates (adds) arrays by default\r\ndef deep_merge($val1; $val2): deep_merge($val1; $val2; add);\r\n```",
                "title": "How to merge 2 json files using jq (deep merge and concat array)"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1719006449,
                "creation_date": 1719006449,
                "answer_id": 78654531,
                "question_id": 78645462,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s a &quot;recursive-merge&quot; filter that makes it easy to make modifications according to specific requirements about the handling of nulls and mismatches and so on:\r\n```\r\n# A &quot;lossless recursive merge&quot; of two JSON objects \r\n# using `unique` for arrays.\r\ndef merge_two_objects($o2):\r\n . as $o1\r\n | reduce ($o2|keys_unsorted[]) as $k (.; \r\n\r\n      if ($o1[$k] == null)\r\n      then .[$k] = $o2[$k]\r\n\r\n      elif ($o1[$k] | type == &quot;array&quot;) and ($o2[$k] | type) == &quot;array&quot;\r\n      then .[$k] |= ( (. + $o2[$k]) | unique )\r\n\r\n      elif ($o1[$k] | type == &quot;object&quot;) and ($o2[$k] | type) == &quot;object&quot;\r\n      then .[$k] |=  merge_two_objects($o2[$k])\r\n\r\n      elif has($k)\r\n      then .[$k] =  [$o1[$k], $o2[$k]]  \r\n\r\n      else .[$k] = $o2[$k]\r\n      end );\r\n\r\n",
                "title": "How to merge 2 json files using jq (deep merge and concat array)"
            }
        ],
        "is_answered": true,
        "answer_count": 4,
        "score": 1,
        "last_activity_date": 1719007189,
        "creation_date": 1718856621,
        "last_edit_date": 1719007189,
        "question_id": 78645462,
        "body_markdown": "\r\nWith `jq` command, I want to merge multiple json files.\r\n\r\nBut I have no idea how to achieve below expectation.\r\n\r\nthanks in advance\r\n\r\n**a.json**\r\n\r\n```\r\n{\r\n    &quot;key1&quot;: {\r\n        &quot;key2&quot;: [\r\n            1,\r\n            2\r\n        ]\r\n    },\r\n    &quot;key3&quot;: &quot;aaa&quot;\r\n}\r\n```\r\n\r\n**b.json**\r\n\r\n```\r\n{\r\n    &quot;key1&quot;: {\r\n        &quot;key2&quot;: [\r\n            3,\r\n            4,\r\n            5\r\n        ]\r\n    },\r\n    &quot;key4&quot;: &quot;bbb&quot;\r\n}\r\n```\r\n\r\n**expected result**\r\n\r\n```\r\n{\r\n    &quot;key1&quot;: {\r\n        &quot;key2&quot;: [\r\n            1,\r\n            2,\r\n            3,\r\n            4,\r\n            5\r\n        ]\r\n    },\r\n    &quot;key3&quot;: &quot;aaa&quot;,\r\n    &quot;key4&quot;: &quot;bbb&quot;\r\n}\r\n```",
        "link": "https://stackoverflow.com/questions/78645462/how-to-merge-2-json-files-using-jq-deep-merge-and-concat-array",
        "title": "How to merge 2 json files using jq (deep merge and concat array)"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1718903227,
                "creation_date": 1718903227,
                "answer_id": 78648825,
                "question_id": 78648797,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You could use `to_entries` to destructure each input into its object key and the array value, then use regular addition:\r\n```sh\r\njq &#39;reduce (inputs | to_entries)[] as {$key, $value} (.; .[$key] += $value)&#39;\r\n```\r\n[Demo](https://jqplay.org/s/4L3F36vTufoOCjH)\r\n\r\nOr, with just a single key, use the first item of the `keys` array:\r\n```sh\r\njq &#39;reduce inputs as $input (.; .[$input | keys[0]] += $input[])&#39;\r\n```\r\n[Demo](https://jqplay.org/s/jJh9crTLMMOu7MH)\r\n\r\nOutput:\r\n```json\r\n{\r\n  &quot;SomeCategory&quot;: [\r\n    {\r\n      &quot;Key&quot;: &quot;value1&quot;\r\n    },\r\n    {\r\n      &quot;Key&quot;: &quot;value2&quot;\r\n    },\r\n    {\r\n      &quot;Key&quot;: &quot;valueA&quot;\r\n    },\r\n    {\r\n      &quot;Key&quot;: &quot;valueA+1&quot;\r\n    },\r\n    {\r\n      &quot;Key&quot;: &quot;valueA+2&quot;\r\n    },\r\n    {\r\n      &quot;Key&quot;: &quot;valueA+B&quot;\r\n    }\r\n  ]\r\n}\r\n```\r\n",
                "title": "Using jq to merge arrays inside merged objects"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1718903227,
        "creation_date": 1718902788,
        "question_id": 78648797,
        "body_markdown": "There are multiple questions on this topic already, and they all *look* closely related:\r\n- [jq merge values of same key into an array?](https://unix.stackexchange.com/questions/663924/jq-merge-values-of-same-key-into-an-array) requires knowledge of the keys in each object, as far as I can tell; we won&#39;t have that in advance\r\n- [How to combine JSON objects with the same key, using jq](https://unix.stackexchange.com/questions/706593/how-to-combine-json-objects-with-the-same-key-using-jq) mentions _&quot;Note that if two or more objects share the same key and if that key refers to a scalar or array, then the later objects in the input will overwrite the value&quot;_ which is exactly the problem I&#39;m trying to avoid.\r\n- [How to combine the sequence of objects in jq into one object?](https://stackoverflow.com/questions/34477547/how-to-combine-the-sequence-of-objects-in-jq-into-one-object) looks hopeful but requires more jq syntax knowledge than I can figure out.\r\n\r\nSo there are related examples, it&#39;s not clear how to modify the `reduce` statement from those examples to do what I want.\r\n\r\n**Problem:**  We&#39;ve got a file containing multiple JSON object-blobs.  Each top-level object has a single key, with an array as its value.  Essentially it&#39;s\r\n```json\r\n{\r\n\t&quot;SomeCategory&quot;: [\r\n\t\t{\r\n\t\t\t&quot;Key&quot;: &quot;value1&quot;    # very first entry\r\n\t\t},\r\n\t\t{\r\n\t\t\t&quot;Key&quot;: &quot;value2&quot;\r\n\t\t},\r\n\t\t{ ... },\r\n\t\t{\r\n\t\t\t&quot;Key&quot;: &quot;valueA&quot;\r\n\t\t}\r\n\t]\r\n}\r\n{\r\n\t&quot;SomeCategory&quot;: [\r\n\t\t{\r\n\t\t\t&quot;Key&quot;: &quot;valueA+1&quot;\r\n\t\t},\r\n\t\t{\r\n\t\t\t&quot;Key&quot;: &quot;valueA+2&quot;\r\n\t\t},\r\n\t\t{ ... },\r\n\t\t{\r\n\t\t\t&quot;Key&quot;: &quot;valueA+B&quot;    # very last entry\r\n\t\t}\r\n\t]\r\n}\r\n{\r\n\t... repeat ad nauseam with different values ...\r\n}\r\n```\r\n\r\n\r\n**Goal:** Here&#39;s what I&#39;m hoping to end up with:\r\n```json\r\n{\r\n\t&quot;SomeCategory&quot;: [\r\n\t\t{\r\n\t\t\t&quot;Key&quot;: &quot;value1&quot;    # very first entry\r\n\t\t},\r\n\t\t{\r\n\t\t\t&quot;Key&quot;: &quot;value2&quot;\r\n\t\t},\r\n        { ... },\r\n\t\t{\r\n\t\t\t&quot;Key&quot;: &quot;valueA+B&quot;    # very last entry\r\n\t\t}\r\n\t]\r\n}\r\n```\r\nThat is, all the top-level blobs have been merged into a single top-level blob, **and** the arrays **contained** in the blobs&#39; single key are all merged.\r\n\r\n**Attempts:** The linked examples all recommend things along the lines of\r\n\r\n```shell\r\njq -n &#39;reduce inputs as $foo ({}; . *= $foo)&#39;\r\n```\r\nwhich runs into the problem of _&quot;if that key refers to a scalar or array, then the later objects in the input will overwrite the value&quot;_:\r\n\r\n```json\r\n{\r\n\t&quot;SomeCategory&quot;: [\r\n\t\t{\r\n\t\t\t&quot;Key&quot;: &quot;valueY+1&quot;    \r\n\t\t},\r\n\t\t{\r\n\t\t\t&quot;Key&quot;: &quot;valueY+2&quot;\r\n\t\t},\r\n        { ... },\r\n\t\t{\r\n\t\t\t&quot;Key&quot;: &quot;valueY+Z&quot;    # very last entry\r\n\t\t}\r\n\t]\r\n}\r\n```\r\ni.e., only the _last_ top-level blob survives.\r\n\r\nOther things that might matter:\r\n- There&#39;s only a single key (`&quot;SomeCategory&quot;`) in all the top-level object blobs, and it&#39;s always the same key, but how that key is spelled isn&#39;t known in advance.\r\n- There are lots of individual object keys; I&#39;ve only shown one `&quot;Key&quot;` here.\r\n- The individual object keys (`&quot;Key&quot;`) are the same in every individual object.  I&#39;m not looking to merge any of _those_ objects, since their values will be violently unique.\r\n\r\nI&#39;m guessing that some nested merge in the &quot;UPDATE&quot; clause in `reduce EXP as $var (INIT;  UPDATE)` will do this, but I cannot figure out from the `jq` man page what that syntax is supposed to look like (all its examples are extremely contrived and simplistic).  The instances of `reduce` that google can find don&#39;t use any nested update pipelines, so perhaps it&#39;s not even supported and that idea was dumb.  Normally the right answer is some form of &quot;pipelined expressions in a single jq invocation&quot; but we haven&#39;t figure out how to avoid the replacing of the array value on each update.\r\n",
        "link": "https://stackoverflow.com/questions/78648797/using-jq-to-merge-arrays-inside-merged-objects",
        "title": "Using jq to merge arrays inside merged objects"
    },
    {
        "tags": [
            "json",
            "parsing",
            "jq",
            "min"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1718917164,
                "creation_date": 1718917164,
                "answer_id": 78649557,
                "question_id": 78649424,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Use `select` to filter, `tonumber` to convert, and `min` to aggregate:\r\n```sh\r\njq &#39;.refpos | map(select(.name == &quot;GRCH38#0#chr19&quot;).offset | tonumber) | min&#39;\r\n```\r\n```json\r\n23803754\r\n```\r\n[Demo](https://jqplay.org/s/0tgot5QBKJEt6xw)",
                "title": "Map on conditional produces jq: error Cannot iterate over null (null)"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1718975929,
        "creation_date": 1718914400,
        "last_edit_date": 1718975929,
        "question_id": 78649424,
        "body_markdown": "I want to get the minimum value of each nested refpos that&#39;s associated with GRCH38.\r\n\r\nAn example .refpos looks like this :\r\n```\r\n[\r\n  {\r\n    &quot;name&quot;: &quot;_alt_a5760de0b8c517ac3d2929ec9455ac640b540f5a_0&quot;\r\n  },\r\n  {\r\n    &quot;name&quot;: &quot;GRCH38#0#chr19&quot;,\r\n    &quot;offset&quot;: &quot;23803754&quot;\r\n  },\r\n  {\r\n    &quot;name&quot;: &quot;GRCH38#0#chr19&quot;,\r\n    &quot;offset&quot;: &quot;23803764&quot;\r\n  },\r\n  {\r\n    &quot;name&quot;: &quot;GRCH38#0#chr19&quot;,\r\n    &quot;offset&quot;: &quot;23803796&quot;\r\n  },\r\n  {\r\n    &quot;name&quot;: &quot;GRCH38#0#chr19&quot;,\r\n    &quot;offset&quot;: &quot;23803828&quot;\r\n  }\r\n]\r\n```\r\n\r\nHere&#39;s a command that prints all offsets associated with GRCH38:\r\n```vg view -aj ${EXPERIMENT_NAME}.gam | jq -r &#39;select(.refpos) | .refpos[] | if .name==&quot;GRCH38#0#chr19&quot; then .offset else empty end &#39; &gt;${EXPERIMENT_NAME}.experiment.tsv```\r\n\r\ne.g. \r\n```\r\n23803754\r\n23803764\r\n23803796\r\n23803828\r\n```\r\n\r\nBut I don&#39;t want all the offsets, I want just one. To do so, I&#39;ve tried a command like the following:\r\n\r\n```vg view -aj ${EXPERIMENT_NAME}.gam | jq -r &#39;select(.refpos) | map(.refpos[] | if .name==&quot;GRCH38#0#chr19&quot; then .offset else empty end | tonumber) | min&#39;  &gt;${EXPERIMENT_NAME}.experiment.tsv```\r\n\r\nBut this produces the error in the title:\r\n\r\njq: error (at &lt;stdin&gt;:1): Cannot iterate over null (null)\r\n\r\nHow can I structure the command so that I get the minimum value of this set of values, instead of an error?",
        "link": "https://stackoverflow.com/questions/78649424/map-on-conditional-produces-jq-error-cannot-iterate-over-null-null",
        "title": "Map on conditional produces jq: error Cannot iterate over null (null)"
    },
    {
        "tags": [
            "json",
            "schema",
            "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": 1719184001,
                "post_id": 78660023,
                "comment_id": 138682713,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 20205621,
                    "reputation": 959,
                    "user_id": 14820140,
                    "user_type": "registered",
                    "profile_image": "https://lh5.googleusercontent.com/-Gm5T3JLO_H4/AAAAAAAAAAI/AAAAAAAAAAA/AMZuucm5IvoBYdEJ_8z-uOON4iIIufxB3Q/s96-c/s256-rj/photo.jpg",
                    "display_name": "Starbucks Admin",
                    "link": "https://stackoverflow.com/users/14820140/starbucks-admin"
                },
                "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": 1719184148,
                "post_id": 78660023,
                "comment_id": 138682720,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1719195179,
                "last_edit_date": 1719195179,
                "creation_date": 1719185711,
                "answer_id": 78660093,
                "question_id": 78660023,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If you don&#39;t want to tangle with a full-fledged generic schema definition ecosystem and don&#39;t mind &quot;rolling your own&quot; validation engine, you might wish to consider the following illustration:\r\n\r\n```\r\n&lt; input.json jq --slurpfile template template.json &#39;\r\n  def validate($template):\r\n    ($template | .remoteIds[0] | keys) as $keys\r\n    | (type == &quot;object&quot;) and\r\n      (.remoteIds | type) == &quot;array&quot; and\r\n      all(.remoteIds[]; keys == $keys) and\r\n      all(.remoteIds[].remoteId; \r\n          test(&quot;^\\\\[.*\\\\]--[(]http://.*[.]nspace[.]pod:8080[)]$&quot;) )\r\n  ;\r\n\r\nvalidate($template[0])\r\n&#39;\r\n```\r\n\r\nThis incidentally works with all three of the major jq implementations:\r\nthe standard C-based implementation; gojq; and jaq.",
                "title": "How can i validate a json against a template in jq?"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1719331587,
                "last_edit_date": 1719331587,
                "creation_date": 1719203997,
                "answer_id": 78660565,
                "question_id": 78660023,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s how you could use the JESS validation tool for JSON.\r\n\r\n(**JESS** stands for *JSON Extended Structural Schemas*, and refers to\r\nboth a schema specification language and a validation tool.  The\r\nhome page on github is at https://github.com/pkoppstein/JESS)\r\n\r\nYou can either create a JESS schema by hand, or\r\ngenerate a very basic structural schema as described below, and then\r\ntweak it according to your requirements.  Either way, let&#39;s\r\nassume your structural schema is in a file named\r\nvalidate.schema and that it looks like this:\r\n\r\n```\r\n{\r\n  &quot;remoteIds&quot;: [\r\n    {\r\n      &quot;remoteId&quot;: &quot;/^\\\\[.*\\\\]--[(]http://.*[.]nspace[.]pod:8080[)]$/&quot;,\r\n      &quot;requestsReceived&quot;: &quot;number&quot;\r\n    }\r\n  ]\r\n}\r\n```\r\n\r\nFeel free to tweak the above regexp, and indeed the entire schema, in accordance with your requirements.\r\n\r\n\r\nAssuming you have installed the JESS validation tool, you would run it like so:\r\n\r\n```\r\nJESS --schema validate.schema input.json\r\n```\r\n\r\nNote that the JESS script only reports non-conformances.\r\nThat is, it produces no output if the JSON conforms to the schema.\r\n\r\n---\r\n\r\nTo create a basic structural schema automatically, you can use &quot;schema.jq&quot;\r\n(https://gist.github.com/pkoppstein/a5abb4ebef3b0f72a6ed) like so:\r\n```\r\n&lt; input.json jq &#39;include &quot;schema&quot; {search: &quot;.&quot;}; schema&#39; &gt; validate.schema\r\n```\r\n\r\n",
                "title": "How can i validate a json against a template in jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1719331587,
        "creation_date": 1719183001,
        "last_edit_date": 1719209386,
        "question_id": 78660023,
        "body_markdown": "I am having a shell script . in my shell script i have a command that returns the following data as a json . \r\n\r\n    {\r\n      &quot;remoteIds&quot;: [\r\n        {\r\n          &quot;remoteId&quot;: &quot;[fd00:10:244:1:0:0:0:12]--(http://fd00-10-244-1--12.nspace.pod:8080)&quot;,\r\n          &quot;requestsReceived&quot;: 1\r\n        }\r\n    }\r\n\r\ni want to validate the above output with a json template. in my json template i can provide the port, nspace , protocol (http) &amp; requestsReceived . How can i design a json template and validate against the json data . i can use jq and bash script\r\n\r\nThe following will be a template in my mind\r\n\r\n\r\n    {\r\n      &quot;remoteIds&quot;: [\r\n        {\r\n          &quot;remoteId&quot;: &quot;[*]--(http://*.nspace.pod:8080)&quot;,\r\n          &quot;requestsReceived&quot;: 1\r\n        }\r\n    }\r\n\r\n\r\nthank you\r\n\r\n\r\n\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/78660023/how-can-i-validate-a-json-against-a-template-in-jq",
        "title": "How can i validate a json against a template in jq?"
    },
    {
        "tags": [
            "json",
            "sh",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 106364,
                    "reputation": 165516,
                    "user_id": 283366,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/9ad213d8adabe4b64c2d53c5e0e3cab4?s=256&d=identicon&r=PG",
                    "display_name": "Phil",
                    "link": "https://stackoverflow.com/users/283366/phil"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1719185409,
                "post_id": 78660079,
                "comment_id": 138682785,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 106364,
                    "reputation": 165516,
                    "user_id": 283366,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/9ad213d8adabe4b64c2d53c5e0e3cab4?s=256&d=identicon&r=PG",
                    "display_name": "Phil",
                    "link": "https://stackoverflow.com/users/283366/phil"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1719185514,
                "post_id": 78660079,
                "comment_id": 138682793,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 308303,
                    "reputation": 37458,
                    "user_id": 620097,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/820980fd43f2607a815c1f3dbfe152cc?s=256&d=identicon&r=PG",
                    "display_name": "shellter",
                    "link": "https://stackoverflow.com/users/620097/shellter"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1719186468,
                "post_id": 78660079,
                "comment_id": 138682842,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 106364,
                    "reputation": 165516,
                    "user_id": 283366,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/9ad213d8adabe4b64c2d53c5e0e3cab4?s=256&d=identicon&r=PG",
                    "display_name": "Phil",
                    "link": "https://stackoverflow.com/users/283366/phil"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1719186950,
                "post_id": 78660079,
                "comment_id": 138682874,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 3959308,
                    "reputation": 53394,
                    "user_id": 3266847,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/U0oyt.png?s=256",
                    "display_name": "Benjamin W.",
                    "link": "https://stackoverflow.com/users/3266847/benjamin-w"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1719188145,
                "post_id": 78660079,
                "comment_id": 138682931,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 308303,
                    "reputation": 37458,
                    "user_id": 620097,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/820980fd43f2607a815c1f3dbfe152cc?s=256&d=identicon&r=PG",
                    "display_name": "shellter",
                    "link": "https://stackoverflow.com/users/620097/shellter"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1719188672,
                "post_id": 78660079,
                "comment_id": 138682956,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1719186684,
                "creation_date": 1719186684,
                "answer_id": 78660108,
                "question_id": 78660079,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Remove the white spaces around your assignments for `expected_template` and `actual_json`. Edit it to:\r\n\r\n`actual_json=&#39;{` \\\r\n`expected_template=&#39;{`\r\n\r\n[learn more form here][1]\r\n\r\n\r\n  [1]: https://stackoverflow.com/questions/56201393/passing-variables-containing-spaces-to-curl-data-field",
                "title": "using a pipe symbol in a jq command throws an error"
            },
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1719187259,
                "creation_date": 1719187259,
                "answer_id": 78660118,
                "question_id": 78660079,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "When shell scripting in sh, bash and similar shells, you can&#39;t put spaces around the = during assignment.  If you do, it tries to find a command equal to the name of the variable you&#39;re trying to assign.  You&#39;ll see this in the first two error messages that end with &quot;: command not found&quot;.\r\n\r\nThe next problem is that since the variables aren&#39;t assigned because of the first two errors, you&#39;re attempting to run &quot;jq &quot; | &quot; which jq can&#39;t parse.\r\n\r\nFinal note, I haven&#39;t used jq enough to encounter this problem, but with your command, it&#39;s still reading from stdin, so you don&#39;t get any output until you hit ctrl-d to signal end of file or redirect stdin.  &lt;/dev/null works in unix-like OS.",
                "title": "using a pipe symbol in a jq command throws an error"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1719187259,
        "creation_date": 1719185080,
        "last_edit_date": 1719185232,
        "question_id": 78660079,
        "body_markdown": "I am having a shell script file `validation-example.sh` , it has the followign content \r\n\r\n\r\n    expected_template = &#39;{\r\n      &quot;remoteIds&quot;: [\r\n        {\r\n          &quot;remoteId&quot;: &quot;&quot;,\r\n          &quot;requestsReceived&quot;: 1\r\n        },\r\n        {\r\n          &quot;remoteId&quot;: &quot;&quot;,\r\n          &quot;requestsReceived&quot;: 1\r\n        },\r\n        {\r\n          &quot;remoteId&quot;: &quot;&quot;,\r\n          &quot;requestsReceived&quot;: 1\r\n        },\r\n        {\r\n          &quot;remoteId&quot;: &quot;&quot;,\r\n          &quot;requestsReceived&quot;: 1\r\n        }\r\n      ]\r\n    }&#39;\r\n    \r\n    actual_json = &#39;{\r\n      &quot;remoteIds&quot;: [\r\n        {\r\n          &quot;remoteId&quot;: &quot;[fd00:10:244:1:0:0:0:12]--(http://fd00-10-244-1--12.test.pod:8080)&quot;,\r\n          &quot;requestsReceived&quot;: 1\r\n        },\r\n        {\r\n          &quot;remoteId&quot;: &quot;[fd00:10:244:1:0:0:0:12]--(http://fd00-10-244-1--12.test.pod:8081)&quot;,\r\n          &quot;requestsReceived&quot;: 1\r\n        },\r\n        {\r\n          &quot;remoteId&quot;: &quot;[fd00:10:244:1:0:0:0:12]--(http://fd00-10-244-1--12.test.pod:8082)&quot;,\r\n          &quot;requestsReceived&quot;: 1\r\n        },\r\n        {\r\n          &quot;remoteId&quot;: &quot;[fd00:10:244:1:0:0:0:12]--(http://fd00-10-244-1--12.test.pod:8083)&quot;,\r\n          &quot;requestsReceived&quot;: 1\r\n        }\r\n      ]\r\n    }&#39;\r\n    \r\n    validate_json() {\r\n        local data=&quot;$1&quot;\r\n        local template=&quot;$2&quot;\r\n        jq -e &quot;$data | $template&quot; &gt;/dev/null\r\n    }\r\n    \r\n    \r\n    if validate_json &quot;$actual_json&quot; &quot;$expected_template&quot;; then\r\n        echo &quot;The actual JSON matches the expected template.&quot;\r\n    else\r\n        echo &quot;The actual JSON does not match the expected template.&quot;\r\n    fi\r\n\r\nHowever when i run the file it is returning the following error\r\n\r\n    validation-example.sh: line 1: expected_template: command not found\r\n    validation-example.sh: line 22: actual_json: command not found\r\n    jq: error: syntax error, unexpected &#39;|&#39;, expecting $end (Unix shell quoting issues?) at &lt;top-level&gt;, line 1:\r\n     |  \r\n    jq: 1 compile error\r\n    The actual JSON does not match the expected template.\r\n\r\nany help please\r\nthanks\r\n\r\n\r\n ",
        "link": "https://stackoverflow.com/questions/78660079/using-a-pipe-symbol-in-a-jq-command-throws-an-error",
        "title": "using a pipe symbol in a jq command throws an error"
    },
    {
        "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": 1,
                "creation_date": 1719224009,
                "post_id": 78661739,
                "comment_id": 138685813,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1719227759,
                "post_id": 78661739,
                "comment_id": 138686287,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 4,
                "creation_date": 1719228273,
                "post_id": 78661739,
                "comment_id": 138686360,
                "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": 1719505617,
                "post_id": 78661739,
                "comment_id": 138716654,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "is_answered": false,
        "answer_count": 0,
        "score": 0,
        "last_activity_date": 1719224394,
        "creation_date": 1719223496,
        "question_id": 78661739,
        "body_markdown": "Is there a way to use `map()` in a conditional manner ?\r\n\r\nMy problem is that I am using `jq` against Github repos.\r\n\r\nSome repos (e.g. https://api.github.com/repos/containerd/nerdctl/releases) use `prerelease` flag and therefore I can use `map(select(.prerelease==false))|first`\r\n\r\nOther repos (e.g. https://api.github.com/repos/slsa-framework/slsa-verifier/releases) do not and therefore `map(select(.prerelease==false))` has no effect.\r\n\r\nTherefore I need a way to conditionally check for the existence of `.prerelease` and if present apply `map()`.",
        "link": "https://stackoverflow.com/questions/78661739/conditional-map-in-jq",
        "title": "Conditional map in jq"
    },
    {
        "tags": [
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 5301,
                    "reputation": 94077,
                    "user_id": 8454,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/2NlHs.png?s=256",
                    "display_name": "Andy Lester",
                    "link": "https://stackoverflow.com/users/8454/andy-lester"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1719498220,
                "post_id": 78678234,
                "comment_id": 138715498,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 20205621,
                    "reputation": 959,
                    "user_id": 14820140,
                    "user_type": "registered",
                    "profile_image": "https://lh5.googleusercontent.com/-Gm5T3JLO_H4/AAAAAAAAAAI/AAAAAAAAAAA/AMZuucm5IvoBYdEJ_8z-uOON4iIIufxB3Q/s96-c/s256-rj/photo.jpg",
                    "display_name": "Starbucks Admin",
                    "link": "https://stackoverflow.com/users/14820140/starbucks-admin"
                },
                "reply_to_user": {
                    "account_id": 5301,
                    "reputation": 94077,
                    "user_id": 8454,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/2NlHs.png?s=256",
                    "display_name": "Andy Lester",
                    "link": "https://stackoverflow.com/users/8454/andy-lester"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1719498417,
                "post_id": 78678234,
                "comment_id": 138715534,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 3,
                "creation_date": 1719499486,
                "post_id": 78678234,
                "comment_id": 138715697,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 20205621,
                    "reputation": 959,
                    "user_id": 14820140,
                    "user_type": "registered",
                    "profile_image": "https://lh5.googleusercontent.com/-Gm5T3JLO_H4/AAAAAAAAAAI/AAAAAAAAAAA/AMZuucm5IvoBYdEJ_8z-uOON4iIIufxB3Q/s96-c/s256-rj/photo.jpg",
                    "display_name": "Starbucks Admin",
                    "link": "https://stackoverflow.com/users/14820140/starbucks-admin"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1719499838,
                "post_id": 78678234,
                "comment_id": 138715744,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 4879,
                    "reputation": 248190,
                    "user_id": 7552,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/b60298053f87465641c1b1192338c8cd?s=256&d=identicon&r=PG",
                    "display_name": "glenn jackman",
                    "link": "https://stackoverflow.com/users/7552/glenn-jackman"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1719505188,
                "post_id": 78678234,
                "comment_id": 138716588,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "is_answered": false,
        "answer_count": 0,
        "score": 0,
        "last_activity_date": 1719498063,
        "creation_date": 1719498063,
        "question_id": 78678234,
        "body_markdown": "I am having a sample shell script file. In my script file I have a json data in a variable and also i have a file containing json . \r\nI want to compare the contents of the file against the variable using jq.\r\n\r\nThe following is my script file \r\n\r\n    RESPONSE=&#39;{remoteIds:[{remoteId:[fd00:10:244:3:0:0:0:14]--(http://fd00-10-244-3--14.scctest.pod:8080),requestsReceived:1},{remoteId:[fd00:10:244:3:0:0:0:14]--(http://fd00-10-244-3--14.scctest.pod:8081),requestsReceived:1},{remoteId:[fd00:10:244:3:0:0:0:14]--(http://fd00-10-244-3--14.scctest.pod:8082),requestsReceived:1},{remoteId:[fd00:10:244:3:0:0:0:14]--(http://fd00-10-244-3--14.scctest.pod:8083),requestsReceived:1}]}&#39;\r\n        expected_response=&#39;/test/scripts/tests/local-policy/expectedTestResponse1.json&#39;\r\n        echo $RESPONSE\r\n        echo $expected_response\r\n    \r\n        # Compare JSON objects using jq\r\n        if jq --argjson var &quot;$RESPONSE&quot; -e &#39;. == $var&#39; &quot;$expected_response&quot; &gt; /dev/null 2&gt;&amp;1; then\r\n          echo 0  # JSON objects are equal\r\n        else\r\n          echo 1  # JSON objects are unequal\r\n          exit 1\r\n        fi\r\n\r\nThe content of the file expectedTestResponse1.json is below\r\n\r\n    {\r\n      &quot;remoteIds&quot;: [\r\n        {\r\n          &quot;remoteId&quot;: &quot;[fd00:10:244:3:0:0:0:14]--(http://fd00-10-244-3--14.scctest.pod:8080)&quot;,\r\n          &quot;requestsReceived&quot;: 1\r\n        },\r\n        {\r\n          &quot;remoteId&quot;: &quot;[fd00:10:244:3:0:0:0:14]--(http://fd00-10-244-3--14.scctest.pod:8081)&quot;,\r\n          &quot;requestsReceived&quot;: 1\r\n        },\r\n        {\r\n          &quot;remoteId&quot;: &quot;[fd00:10:244:3:0:0:0:14]--(http://fd00-10-244-3--14.scctest.pod:8082)&quot;,\r\n          &quot;requestsReceived&quot;: 1\r\n        },\r\n        {\r\n          &quot;remoteId&quot;: &quot;[fd00:10:244:3:0:0:0:14]--(http://fd00-10-244-3--14.scctest.pod:8083)&quot;,\r\n          &quot;requestsReceived&quot;: 1\r\n        }\r\n      ]\r\n    }\r\n\r\nwhen i execute the script my script fails and exits . any idea what is happening. I would expect to print `echo 0`\r\n\r\nthank you\r\n",
        "link": "https://stackoverflow.com/questions/78678234/comparing-json-object-fail-in-jq",
        "title": "comparing json object fail in jq"
    },
    {
        "tags": [
            "module",
            "include",
            "jq",
            "infinite"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1719547101,
                "last_edit_date": 1719547101,
                "creation_date": 1719546206,
                "answer_id": 78680580,
                "question_id": 78679886,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "1) The failure to detect circularity is a (well-known?) limitation (or bug); perhaps you would care to make an enhancement request for both the C and Go implementations?\r\n\r\n2) The syntax of include directives does not provide for conditionality.\r\n\r\nThere are also some discrepancies between the C and Go implementations.\r\nNotably: \r\n* if a-mod.jq defines `a` (e.g. `def a: &quot;a&quot;;`), and\r\n* if b-mod.jq includes `a-mod`, and\r\n* if b.jq includes `b-mod` and invokes `a`\r\n\r\nthen gojq handles the situation as expected, but the C implementation gives a compilation error (running b.jq yields &quot;a/0 is not defined&quot;).\r\n\r\n---\r\nIn summary: for now at least, \r\napart from making enhancement requests and filing bug reports, it seems best not to expect too much from the module system.\r\n\r\n",
                "title": "infinite include loop in jq. Two modules that need each other and one of them by a third"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1719553894,
        "creation_date": 1719523947,
        "last_edit_date": 1719553894,
        "question_id": 78679886,
        "body_markdown": "I have 2 modules that will convert code into strings, module1.jq and module2.jq\r\n\r\nmodule1 converts the code of obj1 that have this form\r\n{ &quot;code1&quot;:&quot;254&quot;, &quot;Object2s&quot;:[ {Object2}, {Object2} ] }\r\n\r\nmodule2 converts the code of obj2 that have this form\r\n{ &quot;code1&quot;:&quot;574&quot;, &quot;Object1s&quot;:[ {Object1}, {Object1} ] }\r\n\r\nAs you can see, both object include each other, so in module1 it will be a statement\r\ninclude &quot;module2&quot;;\r\nand in module2 there will be an statement\r\ninclude &quot;module1&quot;;\r\n\r\nwhen using either of the modules, you&#180;ll get an infinite loop.\r\n\r\nmodule3.jq\r\ninclude &quot;module1&quot;;\r\n\r\n\r\nHow can stop this from happening?\r\n\r\nAny help will be apreciated\r\n\r\nI try to define kind of variables unique for each module and go like\r\nIn module1.jq\r\n$module_module1 = 1;\r\nif $module_module2 == 0 then include &quot;module2&quot;;\r\n\r\nIn module2\r\n$module_module2 = 1;\r\nif $module_module1 == 0 then include &quot;module1&quot;;\r\n\r\nbut it did not work.",
        "link": "https://stackoverflow.com/questions/78679886/infinite-include-loop-in-jq-two-modules-that-need-each-other-and-one-of-them-by",
        "title": "infinite include loop in jq. Two modules that need each other and one of them by a third"
    },
    {
        "tags": [
            "arrays",
            "json",
            "multidimensional-array",
            "jq",
            "jsonschema"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1719845251,
                "creation_date": 1719845251,
                "answer_id": 78692874,
                "question_id": 78692692,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "There is a simple but generic &quot;structural schema inference engine&quot;\r\nat https://gist.github.com/pkoppstein/a5abb4ebef3b0f72a6ed (schema.jq).\r\nIt produces a schema very similar to the one you describe (see below),\r\nbut if that is not directly acceptable, you could either add a filter\r\nto convert it to the form you want, or tweak schema.jq itself.\r\n\r\nWith schema.jq in the pwd (&quot;.&quot;), and using your file as input.json:\r\n```\r\n&lt; input.json jq &#39;include &quot;schema&quot; {search: &quot;.&quot;}; schema&#39;\r\n```\r\nproduces:\r\n\r\n```\r\n{\r\n  &quot;objectSchema&quot;: {\r\n    &quot;fields&quot;: {\r\n      &quot;fieldArray&quot;: [\r\n        {\r\n          &quot;a&quot;: &quot;string&quot;,\r\n          &quot;c&quot;: &quot;string&quot;,\r\n          &quot;x&quot;: &quot;number&quot;,\r\n          &quot;y&quot;: &quot;string&quot;\r\n        }\r\n      ]\r\n    }\r\n  }\r\n}\r\n\r\n```\r\n---\r\n\r\nNotes:\r\n1) schema.jq is compatible with both gojq and jaq (the Go and Rust implementations of jq), but at the time of writing, jaq does does support the `include` statement.  You could however leave schema.jq untouched by writing something like:\r\n```\r\n&lt; input.json jaq -f &lt;(cat schema.jq; echo schema) \r\n```\r\n\r\n2. Disclaimer: schema.jq was written by yours truly.\r\n",
                "title": "How can I write a jq expression to convert nested array objects in JSON to a JSON schema?"
            },
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1719855025,
                "creation_date": 1719855025,
                "answer_id": 78693538,
                "question_id": 78692692,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Instead of `add`, you need to merge with `* operator`:\r\n\r\n```\r\njq &#39;\r\ndef convertToSchema:\r\n  if type == &quot;array&quot; then\r\n    if length == 0 then {&quot;type&quot;: &quot;array&quot;, &quot;items&quot;: {&quot;type&quot;: &quot;string&quot;}}\r\n    else {&quot;type&quot;: &quot;array&quot;, &quot;items&quot;:\r\n          (reduce map(convertToSchema)[] as $i ({}; . *= $i))}\r\n    end\r\n  elif type == &quot;object&quot; then {\r\n    &quot;type&quot;: &quot;object&quot;,\r\n    &quot;properties&quot;: map_values(convertToSchema)}\r\n  elif type == &quot;boolean&quot; then {&quot;type&quot;: &quot;boolean&quot;}\r\n  elif type == &quot;number&quot; then {&quot;type&quot;: &quot;number&quot;}\r\n  elif type == &quot;string&quot; then {&quot;type&quot;: &quot;string&quot;}\r\n  elif type == &quot;null&quot; then {&quot;type&quot;: &quot;string&quot;}\r\n  else {&quot;type&quot;: (type | tostring)} end;\r\n.objectSchema | convertToSchema\r\n&#39; input.json\r\n```\r\n\r\nOutput:\r\n\r\n```\r\n{\r\n  &quot;type&quot;: &quot;object&quot;,\r\n  &quot;properties&quot;: {\r\n    &quot;fields&quot;: {\r\n      &quot;type&quot;: &quot;object&quot;,\r\n      &quot;properties&quot;: {\r\n        &quot;fieldArray&quot;: {\r\n          &quot;type&quot;: &quot;array&quot;,\r\n          &quot;items&quot;: {\r\n            &quot;type&quot;: &quot;object&quot;,\r\n            &quot;properties&quot;: {\r\n              &quot;a&quot;: {\r\n                &quot;type&quot;: &quot;string&quot;\r\n              },\r\n              &quot;c&quot;: {\r\n                &quot;type&quot;: &quot;string&quot;\r\n              },\r\n              &quot;x&quot;: {\r\n                &quot;type&quot;: &quot;number&quot;\r\n              },\r\n              &quot;y&quot;: {\r\n                &quot;type&quot;: &quot;string&quot;\r\n              }\r\n            }\r\n          }\r\n        }\r\n      }\r\n    }\r\n  }\r\n}\r\n```\r\n",
                "title": "How can I write a jq expression to convert nested array objects in JSON to a JSON schema?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1719902544,
        "creation_date": 1719842896,
        "last_edit_date": 1719902544,
        "question_id": 78692692,
        "body_markdown": "I have a JSON structure like this:\r\n\r\n    {\r\n    &quot;objectSchema&quot;: {\r\n        &quot;fields&quot;: [\r\n            {\r\n                &quot;name&quot;: &quot;OBJECTID&quot;,\r\n                &quot;type&quot;: &quot;esriFieldTypeOID&quot;,\r\n                &quot;alias&quot;: &quot;OBJECTID&quot;,\r\n                &quot;domain&quot;: null,\r\n                &quot;editable&quot;: false,\r\n                &quot;nullable&quot;: false,\r\n                &quot;defaultValue&quot;: null,\r\n                &quot;modelName&quot;: &quot;OBJECTID&quot;\r\n            },\r\n            {\r\n                &quot;name&quot;: &quot;ENABLED&quot;,\r\n                &quot;type&quot;: &quot;esriFieldTypeSmallInteger&quot;,\r\n                &quot;alias&quot;: &quot;ENABLED&quot;,\r\n                &quot;domain&quot;: {\r\n                    &quot;type&quot;: &quot;codedValue&quot;,\r\n                    &quot;name&quot;: &quot;EnabledDomain&quot;,\r\n                    &quot;description&quot;: &quot;Geometric Network Enabled domain&quot;,\r\n                    &quot;codedValues&quot;: [\r\n                        {\r\n                            &quot;name&quot;: &quot;False&quot;,\r\n                            &quot;code&quot;: 0\r\n                        },\r\n                        {\r\n                            &quot;name&quot;: &quot;True&quot;,\r\n                            &quot;code&quot;: 1\r\n                        }\r\n                    ],\r\n                    &quot;mergePolicy&quot;: &quot;esriMPTDefaultValue&quot;,\r\n                    &quot;splitPolicy&quot;: &quot;esriSPTDefaultValue&quot;\r\n                },\r\n                &quot;editable&quot;: true,\r\n                &quot;nullable&quot;: true,\r\n                &quot;defaultValue&quot;: 1,\r\n                &quot;modelName&quot;: &quot;ENABLED&quot;\r\n            },\r\n            {\r\n                &quot;name&quot;: &quot;GLOBALID&quot;,\r\n                &quot;type&quot;: &quot;esriFieldTypeGlobalID&quot;,\r\n                &quot;alias&quot;: &quot;GLOBALID&quot;,\r\n                &quot;domain&quot;: null,\r\n                &quot;editable&quot;: false,\r\n                &quot;nullable&quot;: false,\r\n                &quot;length&quot;: 38,\r\n                &quot;defaultValue&quot;: null,\r\n                &quot;modelName&quot;: &quot;GLOBALID&quot;\r\n            }\r\n        ]\r\n       }\r\n       }\r\n\r\nMy current jq - \r\n\r\n    def convertToSchema: if type == &quot;array&quot; then if length == 0 then {&quot;type&quot;: &quot;array&quot;, &quot;items&quot;: {&quot;type&quot;: &quot;string&quot;}} else {&quot;type&quot;: &quot;array&quot;, &quot;items&quot;: (reduce map(convertToSchema)[] as $i ({}; . *= $i))} end elif type == &quot;object&quot; then {&quot;type&quot;: &quot;object&quot;, &quot;properties&quot;: map_values(convertToSchema)} elif type == &quot;boolean&quot; then {&quot;type&quot;: &quot;boolean&quot;} elif type == &quot;number&quot; then {&quot;type&quot;: &quot;number&quot;} elif type == &quot;string&quot; then {&quot;type&quot;: &quot;string&quot;} elif type == &quot;null&quot; then {&quot;type&quot;: &quot;string&quot;} else {&quot;type&quot;: (type | tostring)} end; .objectSchema | convertToSchema\r\n\r\n\r\nMy current output / converted JSON schema - \r\n\r\n    {\r\n    &quot;type&quot;: &quot;object&quot;,\r\n    &quot;properties&quot;: {\r\n    &quot;fields&quot;: {\r\n      &quot;type&quot;: &quot;array&quot;,\r\n      &quot;items&quot;: {\r\n        &quot;type&quot;: &quot;object&quot;,\r\n        &quot;properties&quot;: {\r\n          &quot;name&quot;: {\r\n            &quot;type&quot;: &quot;string&quot;\r\n          },\r\n          &quot;type&quot;: {\r\n            &quot;type&quot;: &quot;string&quot;\r\n          },\r\n          &quot;alias&quot;: {\r\n            &quot;type&quot;: &quot;string&quot;\r\n          },\r\n          &quot;domain&quot;: {\r\n            &quot;type&quot;: &quot;string&quot;,\r\n            &quot;properties&quot;: {\r\n              &quot;type&quot;: {\r\n                &quot;type&quot;: &quot;string&quot;\r\n              },\r\n              &quot;name&quot;: {\r\n                &quot;type&quot;: &quot;string&quot;\r\n              },\r\n              &quot;description&quot;: {\r\n                &quot;type&quot;: &quot;string&quot;\r\n              },\r\n              &quot;codedValues&quot;: {\r\n                &quot;type&quot;: &quot;array&quot;,\r\n                &quot;items&quot;: {\r\n                  &quot;type&quot;: &quot;object&quot;,\r\n                  &quot;properties&quot;: {\r\n                    &quot;name&quot;: {\r\n                      &quot;type&quot;: &quot;string&quot;\r\n                    },\r\n                    &quot;code&quot;: {\r\n                      &quot;type&quot;: &quot;number&quot;\r\n                    }\r\n                  }\r\n                }\r\n              },\r\n              &quot;mergePolicy&quot;: {\r\n                &quot;type&quot;: &quot;string&quot;\r\n              },\r\n              &quot;splitPolicy&quot;: {\r\n                &quot;type&quot;: &quot;string&quot;\r\n              }\r\n            }\r\n          },\r\n          &quot;editable&quot;: {\r\n            &quot;type&quot;: &quot;boolean&quot;\r\n          },\r\n          &quot;nullable&quot;: {\r\n            &quot;type&quot;: &quot;boolean&quot;\r\n          },\r\n          &quot;defaultValue&quot;: {\r\n            &quot;type&quot;: &quot;string&quot;\r\n          },\r\n          &quot;modelName&quot;: {\r\n            &quot;type&quot;: &quot;string&quot;\r\n          },\r\n          &quot;length&quot;: {\r\n            &quot;type&quot;: &quot;number&quot;\r\n          }\r\n        }\r\n      }\r\n    }\r\n    }\r\n    }\r\n\r\nHere &quot;domain&quot; field should be of &quot;type&quot;: &quot;object&quot;, but while converting it to schema in output I am getting it as &quot;type&quot;: &quot;string&quot;.\r\n\r\nPlease give me a proper jq expression that will handle above situations in all JSON nested object cases and ensure that each item in the array is considered and merged properly before applying the convertToSchema function and  create a combined schema that includes all unique properties from all items in the array.\r\n\r\nProviding JQPlay link with proper solution will be more helpful.\r\n",
        "link": "https://stackoverflow.com/questions/78692692/how-can-i-write-a-jq-expression-to-convert-nested-array-objects-in-json-to-a-jso",
        "title": "How can I write a jq expression to convert nested array objects in JSON to a JSON schema?"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1719951787,
                "creation_date": 1719951787,
                "answer_id": 78699109,
                "question_id": 78699051,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You&#39;re looking for something like this:\r\n```\r\nmap(select(.status.&quot;+@state&quot; == &quot;up&quot;) | {\r\n  address: .address.&quot;+@addr&quot;,\r\n  port: .ports.port[] | select(.state.&quot;+@state&quot; == &quot;open&quot;) .&quot;+@portid&quot;\r\n})\r\n```\r\nThis doesn&#39;t need `--null-input`.",
                "title": "Flatten and filter multi-dimension JSON with JQ"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1720046979,
                "creation_date": 1720046979,
                "answer_id": 78704460,
                "question_id": 78699051,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Since you know how to filter and rename keys, I&#39;m going to address the first part of your question: **How do I flatten the port to one object per port?**\r\n\r\n\r\n```sh\r\njq &#39;map(.address+.ports.port[])&#39; test.json\r\n```\r\n\r\nOutput:\r\n\r\n```json\r\n[\r\n  {\r\n    &quot;+@addr&quot;: &quot;10.10.10.1&quot;,\r\n    &quot;+@addrtype&quot;: &quot;ipv4&quot;,\r\n    &quot;+@protocol&quot;: &quot;tcp&quot;,\r\n    &quot;+@portid&quot;: &quot;80&quot;,\r\n    &quot;state&quot;: {\r\n      &quot;+@state&quot;: &quot;open&quot;\r\n    }\r\n  },\r\n  {\r\n    &quot;+@addr&quot;: &quot;10.10.10.1&quot;,\r\n    &quot;+@addrtype&quot;: &quot;ipv4&quot;,\r\n    &quot;+@protocol&quot;: &quot;tcp&quot;,\r\n    &quot;+@portid&quot;: &quot;443&quot;,\r\n    &quot;state&quot;: {\r\n      &quot;+@state&quot;: &quot;closed&quot;\r\n    }\r\n  },\r\n  {\r\n    &quot;+@addr&quot;: &quot;10.10.10.2&quot;,\r\n    &quot;+@addrtype&quot;: &quot;ipv4&quot;,\r\n    &quot;+@protocol&quot;: &quot;tcp&quot;,\r\n    &quot;+@portid&quot;: &quot;21&quot;,\r\n    &quot;state&quot;: {\r\n      &quot;+@state&quot;: &quot;closed&quot;\r\n    }\r\n  },\r\n  {\r\n    &quot;+@addr&quot;: &quot;10.10.10.2&quot;,\r\n    &quot;+@addrtype&quot;: &quot;ipv4&quot;,\r\n    &quot;+@protocol&quot;: &quot;tcp&quot;,\r\n    &quot;+@portid&quot;: &quot;22&quot;,\r\n    &quot;state&quot;: {\r\n      &quot;+@state&quot;: &quot;closed&quot;\r\n    }\r\n  },\r\n  {\r\n    &quot;+@addr&quot;: &quot;10.10.10.3&quot;,\r\n    &quot;+@addrtype&quot;: &quot;ipv4&quot;,\r\n    &quot;+@protocol&quot;: &quot;tcp&quot;,\r\n    &quot;+@portid&quot;: &quot;21&quot;,\r\n    &quot;state&quot;: {\r\n      &quot;+@state&quot;: &quot;closed&quot;\r\n    }\r\n  },\r\n  {\r\n    &quot;+@addr&quot;: &quot;10.10.10.3&quot;,\r\n    &quot;+@addrtype&quot;: &quot;ipv4&quot;,\r\n    &quot;+@protocol&quot;: &quot;tcp&quot;,\r\n    &quot;+@portid&quot;: &quot;22&quot;,\r\n    &quot;state&quot;: {\r\n      &quot;+@state&quot;: &quot;closed&quot;\r\n    }\r\n  },\r\n  {\r\n    &quot;+@addr&quot;: &quot;10.10.10.4&quot;,\r\n    &quot;+@addrtype&quot;: &quot;ipv4&quot;,\r\n    &quot;+@protocol&quot;: &quot;tcp&quot;,\r\n    &quot;+@portid&quot;: &quot;21&quot;,\r\n    &quot;state&quot;: {\r\n      &quot;+@state&quot;: &quot;open&quot;\r\n    }\r\n  },\r\n  {\r\n    &quot;+@addr&quot;: &quot;10.10.10.4&quot;,\r\n    &quot;+@addrtype&quot;: &quot;ipv4&quot;,\r\n    &quot;+@protocol&quot;: &quot;tcp&quot;,\r\n    &quot;+@portid&quot;: &quot;22&quot;,\r\n    &quot;state&quot;: {\r\n      &quot;+@state&quot;: &quot;open&quot;\r\n    }\r\n  }\r\n]\r\n```",
                "title": "Flatten and filter multi-dimension JSON with JQ"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1720046979,
        "creation_date": 1719950653,
        "question_id": 78699051,
        "body_markdown": "I have the following JSON `test.json`:\r\n```\r\n[\r\n  {\r\n    &quot;status&quot;: {\r\n      &quot;+@state&quot;: &quot;up&quot;\r\n    },\r\n    &quot;address&quot;: {\r\n      &quot;+@addr&quot;: &quot;10.10.10.1&quot;,\r\n      &quot;+@addrtype&quot;: &quot;ipv4&quot;\r\n    },\r\n    &quot;ports&quot;: {\r\n      &quot;port&quot;: [\r\n        {\r\n          &quot;+@protocol&quot;: &quot;tcp&quot;,\r\n          &quot;+@portid&quot;: &quot;80&quot;,\r\n          &quot;state&quot;: {\r\n            &quot;+@state&quot;: &quot;open&quot;\r\n          }\r\n        },\r\n        {\r\n          &quot;+@protocol&quot;: &quot;tcp&quot;,\r\n          &quot;+@portid&quot;: &quot;443&quot;,\r\n          &quot;state&quot;: {\r\n            &quot;+@state&quot;: &quot;closed&quot;\r\n          }\r\n        }\r\n      ]\r\n    }\r\n  },\r\n  {\r\n    &quot;status&quot;: {\r\n      &quot;+@state&quot;: &quot;down&quot;\r\n    },\r\n    &quot;address&quot;: {\r\n      &quot;+@addr&quot;: &quot;10.10.10.2&quot;,\r\n      &quot;+@addrtype&quot;: &quot;ipv4&quot;\r\n    },\r\n    &quot;ports&quot;: {\r\n      &quot;port&quot;: [\r\n        {\r\n          &quot;+@protocol&quot;: &quot;tcp&quot;,\r\n          &quot;+@portid&quot;: &quot;21&quot;,\r\n          &quot;state&quot;: {\r\n            &quot;+@state&quot;: &quot;closed&quot;\r\n          }\r\n        },\r\n        {\r\n          &quot;+@protocol&quot;: &quot;tcp&quot;,\r\n          &quot;+@portid&quot;: &quot;22&quot;,\r\n          &quot;state&quot;: {\r\n            &quot;+@state&quot;: &quot;closed&quot;\r\n          }\r\n        }\r\n      ]\r\n    }\r\n  },\r\n  {\r\n    &quot;status&quot;: {\r\n      &quot;+@state&quot;: &quot;up&quot;\r\n    },\r\n    &quot;address&quot;: {\r\n      &quot;+@addr&quot;: &quot;10.10.10.3&quot;,\r\n      &quot;+@addrtype&quot;: &quot;ipv4&quot;\r\n    },\r\n    &quot;ports&quot;: {\r\n      &quot;port&quot;: [\r\n        {\r\n          &quot;+@protocol&quot;: &quot;tcp&quot;,\r\n          &quot;+@portid&quot;: &quot;21&quot;,\r\n          &quot;state&quot;: {\r\n            &quot;+@state&quot;: &quot;closed&quot;\r\n          }\r\n        },\r\n        {\r\n          &quot;+@protocol&quot;: &quot;tcp&quot;,\r\n          &quot;+@portid&quot;: &quot;22&quot;,\r\n          &quot;state&quot;: {\r\n            &quot;+@state&quot;: &quot;closed&quot;\r\n          }\r\n        }\r\n      ]\r\n    }\r\n  },\r\n  {\r\n    &quot;status&quot;: {\r\n      &quot;+@state&quot;: &quot;up&quot;\r\n    },\r\n    &quot;address&quot;: {\r\n      &quot;+@addr&quot;: &quot;10.10.10.4&quot;,\r\n      &quot;+@addrtype&quot;: &quot;ipv4&quot;\r\n    },\r\n    &quot;ports&quot;: {\r\n      &quot;port&quot;: [\r\n        {\r\n          &quot;+@protocol&quot;: &quot;tcp&quot;,\r\n          &quot;+@portid&quot;: &quot;21&quot;,\r\n          &quot;state&quot;: {\r\n            &quot;+@state&quot;: &quot;open&quot;\r\n          }\r\n        },\r\n        {\r\n          &quot;+@protocol&quot;: &quot;tcp&quot;,\r\n          &quot;+@portid&quot;: &quot;22&quot;,\r\n          &quot;state&quot;: {\r\n            &quot;+@state&quot;: &quot;open&quot;\r\n          }\r\n        }\r\n      ]\r\n    }\r\n  }\r\n]\r\n```\r\n\r\nRunning `jq --null-input &#39;[ inputs | .[] | select( .status.&quot;+@state&quot; == &quot;up&quot; and .ports.port[].state.&quot;+@state&quot; == &quot;open&quot; ) | { address: .address.&quot;+@addr&quot;, port: .ports.port } ]&#39; test.json` gets me the following:\r\n```\r\n[\r\n  {\r\n    &quot;address&quot;: &quot;10.10.10.1&quot;,\r\n    &quot;port&quot;: [\r\n      {\r\n        &quot;+@protocol&quot;: &quot;tcp&quot;,\r\n        &quot;+@portid&quot;: &quot;80&quot;,\r\n        &quot;state&quot;: {\r\n          &quot;+@state&quot;: &quot;open&quot;\r\n        }\r\n      },\r\n      {\r\n        &quot;+@protocol&quot;: &quot;tcp&quot;,\r\n        &quot;+@portid&quot;: &quot;443&quot;,\r\n        &quot;state&quot;: {\r\n          &quot;+@state&quot;: &quot;closed&quot;\r\n        }\r\n      }\r\n    ]\r\n  },\r\n  {\r\n    &quot;address&quot;: &quot;10.10.10.4&quot;,\r\n    &quot;port&quot;: [\r\n      {\r\n        &quot;+@protocol&quot;: &quot;tcp&quot;,\r\n        &quot;+@portid&quot;: &quot;21&quot;,\r\n        &quot;state&quot;: {\r\n          &quot;+@state&quot;: &quot;open&quot;\r\n        }\r\n      },\r\n      {\r\n        &quot;+@protocol&quot;: &quot;tcp&quot;,\r\n        &quot;+@portid&quot;: &quot;22&quot;,\r\n        &quot;state&quot;: {\r\n          &quot;+@state&quot;: &quot;open&quot;\r\n        }\r\n      }\r\n    ]\r\n  },\r\n  {\r\n    &quot;address&quot;: &quot;10.10.10.4&quot;,\r\n    &quot;port&quot;: [\r\n      {\r\n        &quot;+@protocol&quot;: &quot;tcp&quot;,\r\n        &quot;+@portid&quot;: &quot;21&quot;,\r\n        &quot;state&quot;: {\r\n          &quot;+@state&quot;: &quot;open&quot;\r\n        }\r\n      },\r\n      {\r\n        &quot;+@protocol&quot;: &quot;tcp&quot;,\r\n        &quot;+@portid&quot;: &quot;22&quot;,\r\n        &quot;state&quot;: {\r\n          &quot;+@state&quot;: &quot;open&quot;\r\n        }\r\n      }\r\n    ]\r\n  }\r\n]\r\n```\r\nHow do I flatten the `port` to one object per port, with the `address` and filter where the port state == &quot;open&quot;? For example, I would like the output to be:\r\n```\r\n[\r\n  {\r\n    &quot;address&quot;: &quot;10.10.10.1&quot;,\r\n    &quot;port&quot;: &quot;80&quot;\r\n  },\r\n  {\r\n    &quot;address&quot;: &quot;10.10.10.4&quot;,\r\n    &quot;port&quot;: &quot;21&quot;\r\n  },\r\n  {\r\n    &quot;address&quot;: &quot;10.10.10.4&quot;,\r\n    &quot;port&quot;: &quot;22&quot;\r\n  }\r\n]\r\n```",
        "link": "https://stackoverflow.com/questions/78699051/flatten-and-filter-multi-dimension-json-with-jq",
        "title": "Flatten and filter multi-dimension JSON with JQ"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1719968268,
                "creation_date": 1719968268,
                "answer_id": 78699711,
                "question_id": 78699675,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can convert to an array of objects with `key` and `value` keys, then use [`from_entries`][1]:\r\n\r\n```jq\r\nmap({key: .name, value: .id}) | from_entries\r\n```\r\n\r\n\r\n  [1]: https://jqlang.github.io/jq/manual/#to_entries-from_entries-with_entries",
                "title": "How to map array of object to object key-value pairs in JQ?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1719980434,
        "creation_date": 1719966953,
        "question_id": 78699675,
        "body_markdown": "Using JQ how do I convert array of objects to key-value pair object?\r\n\r\nGiven the JSON:\r\n```\r\n[\r\n  {\r\n    &quot;name&quot;: &quot;foo&quot;,\r\n    &quot;id&quot;: &quot;123&quot;\r\n  },\r\n  {\r\n    &quot;name&quot;: &quot;bar&quot;,\r\n    &quot;id&quot;: &quot;456&quot;\r\n  }\r\n]\r\n```\r\n\r\nDesired output:\r\n```\r\n{\r\n  &quot;foo&quot;: &quot;123&quot;,\r\n  &quot;bar&quot;: &quot;456&quot;\r\n}\r\n```",
        "link": "https://stackoverflow.com/questions/78699675/how-to-map-array-of-object-to-object-key-value-pairs-in-jq",
        "title": "How to map array of object to object key-value pairs in JQ?"
    },
    {
        "tags": [
            "github-actions",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 3597514,
                    "reputation": 122820,
                    "user_id": 3001761,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/feZwC.jpg?s=256",
                    "display_name": "jonrsharpe",
                    "link": "https://stackoverflow.com/users/3001761/jonrsharpe"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1720076792,
                "post_id": 78705115,
                "comment_id": 138764574,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1929684,
                    "reputation": 881,
                    "user_id": 1739369,
                    "user_type": "registered",
                    "accept_rate": 40,
                    "profile_image": "https://www.gravatar.com/avatar/1721913f6713c5772c3d34692d97ac6d?s=256&d=identicon&r=PG",
                    "display_name": "JonTroncoso",
                    "link": "https://stackoverflow.com/users/1739369/jontroncoso"
                },
                "reply_to_user": {
                    "account_id": 3597514,
                    "reputation": 122820,
                    "user_id": 3001761,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/feZwC.jpg?s=256",
                    "display_name": "jonrsharpe",
                    "link": "https://stackoverflow.com/users/3001761/jonrsharpe"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1720079110,
                "post_id": 78705115,
                "comment_id": 138764877,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 3597514,
                    "reputation": 122820,
                    "user_id": 3001761,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/feZwC.jpg?s=256",
                    "display_name": "jonrsharpe",
                    "link": "https://stackoverflow.com/users/3001761/jonrsharpe"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1720079405,
                "post_id": 78705115,
                "comment_id": 138764913,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1929684,
                    "reputation": 881,
                    "user_id": 1739369,
                    "user_type": "registered",
                    "accept_rate": 40,
                    "profile_image": "https://www.gravatar.com/avatar/1721913f6713c5772c3d34692d97ac6d?s=256&d=identicon&r=PG",
                    "display_name": "JonTroncoso",
                    "link": "https://stackoverflow.com/users/1739369/jontroncoso"
                },
                "reply_to_user": {
                    "account_id": 3597514,
                    "reputation": 122820,
                    "user_id": 3001761,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/feZwC.jpg?s=256",
                    "display_name": "jonrsharpe",
                    "link": "https://stackoverflow.com/users/3001761/jonrsharpe"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1720079668,
                "post_id": 78705115,
                "comment_id": 138764935,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 3597514,
                    "reputation": 122820,
                    "user_id": 3001761,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/feZwC.jpg?s=256",
                    "display_name": "jonrsharpe",
                    "link": "https://stackoverflow.com/users/3001761/jonrsharpe"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1720079934,
                "post_id": 78705115,
                "comment_id": 138764971,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1929684,
                    "reputation": 881,
                    "user_id": 1739369,
                    "user_type": "registered",
                    "accept_rate": 40,
                    "profile_image": "https://www.gravatar.com/avatar/1721913f6713c5772c3d34692d97ac6d?s=256&d=identicon&r=PG",
                    "display_name": "JonTroncoso",
                    "link": "https://stackoverflow.com/users/1739369/jontroncoso"
                },
                "reply_to_user": {
                    "account_id": 3597514,
                    "reputation": 122820,
                    "user_id": 3001761,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/feZwC.jpg?s=256",
                    "display_name": "jonrsharpe",
                    "link": "https://stackoverflow.com/users/3001761/jonrsharpe"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1720080076,
                "post_id": 78705115,
                "comment_id": 138764994,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 3597514,
                    "reputation": 122820,
                    "user_id": 3001761,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/feZwC.jpg?s=256",
                    "display_name": "jonrsharpe",
                    "link": "https://stackoverflow.com/users/3001761/jonrsharpe"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1720080152,
                "post_id": 78705115,
                "comment_id": 138765007,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1721154173,
                "last_edit_date": 1721154173,
                "creation_date": 1720079593,
                "answer_id": 78705742,
                "question_id": 78705115,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I had to use `jq` and a GitHub run but:\r\n\r\n```lang-yaml\r\njobs:\r\n  # JOB to run change detection\r\n  changes:\r\n    runs-on: ubuntu-latest\r\n    # Required permissions\r\n    permissions:\r\n      pull-requests: read\r\n    outputs:\r\n      # Expose matched filters as job &#39;packages&#39; output variable\r\n      changed-packages: ${{ steps.filter.outputs.changes }}\r\n      UNCHANGED-packages: ${{ steps.get-unchanged.outputs.unchanged }}\r\n    steps:\r\n    - uses: dorny/paths-filter@v3\r\n      id: filter\r\n      with:\r\n        filters: |\r\n          package1: src/package1\r\n          package2: src/package2\r\n    # &#128071; &#129668; This is where the magic happens &#129412;&#128071;\r\n    - id: unchanged\r\n      run: |\r\n        set -eux\r\n        UNCHANGED=$(echo &#39;${{ toJson(steps.filter.outputs) }}&#39; | jq -c &#39;. | to_entries | map(select(.value | contains(&quot;false&quot;)) | .key)&#39;)\r\n        ALL=$(echo &#39;${{ toJson(steps.filter.outputs) }}&#39; | jq -c &#39;. | to_entries | map(select(.value | contains(&quot;false&quot;) or contains(&quot;true&quot;)) | .key)&#39;)\r\n        echo &quot;unchanged=$UNCHANGED&quot; &gt;&gt; &quot;$GITHUB_OUTPUT&quot;\r\n        echo &quot;all=$ALL&quot; &gt;&gt; &quot;$GITHUB_OUTPUT&quot;\r\n\r\n\r\n  # JOB to build and test each of modified packages\r\n  changed-packages:\r\n    needs: changes\r\n    strategy:\r\n      matrix:\r\n        # Parse JSON array containing names of all filters matching any of changed files\r\n        # e.g. [&#39;package1&#39;, &#39;package2&#39;] if both package folders contains changes\r\n        package: ${{ fromJSON(needs.changes.outputs.changed-packages) }}\r\n    runs-on: ubuntu-latest\r\n    steps:\r\n      - uses: actions/checkout@v4\r\n      - ...\r\n    \r\n  # JOB to approve folders that have NOT changed\r\n  UNCHANGED-packages:\r\n    needs: changes\r\n    runs-on: ubuntu-latest\r\n    strategy:\r\n      fail-fast: true\r\n      matrix:\r\n        project: ${{ fromJSON(needs.changes.outputs.UNCHANGED-packages) }}\r\n    steps:\r\n    - run: echo &quot;No changes for ${{matrix.project}}&quot;\r\n\r\n```",
                "title": "How do I reference a step&#39;s &quot;with:&quot; property in workflow YAML?"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1721154173,
        "creation_date": 1720069827,
        "last_edit_date": 1720082748,
        "question_id": 78705115,
        "body_markdown": "I&#39;m using `dorny/paths-filter` to detect changes. The problem is I want to run a success job for each of the unchanged filters. This way I can enforce waiting for _all_ jobs in GitHub&#39;s rules. \r\n\r\nMy workflow looks like this:\r\n\r\n```lang-yaml\r\njobs:\r\n  # JOB to run change detection\r\n  changes:\r\n    runs-on: ubuntu-latest\r\n    # Required permissions\r\n    permissions:\r\n      pull-requests: read\r\n    outputs:\r\n      # Expose matched filters as job &#39;packages&#39; output variable\r\n      changed-packages: ${{ steps.filter.outputs.changes }}\r\n      UNCHANGED-packages: ${{ steps.filter.with.doesnt.exist.&#128545;  }}\r\n    steps:\r\n    - uses: dorny/paths-filter@v3\r\n      id: filter\r\n      with:\r\n        filters: |\r\n          package1: src/package1\r\n          package2: src/package2\r\n\r\n  # JOB to build and test each of modified packages\r\n  build:\r\n    needs: changes\r\n    strategy:\r\n      matrix:\r\n        # Parse JSON array containing names of all filters matching any of changed files\r\n        # e.g. [&#39;package1&#39;, &#39;package2&#39;] if both package folders contains changes\r\n        package: ${{ fromJSON(needs.changes.outputs.changed-packages) }}\r\n    runs-on: ubuntu-latest\r\n    steps:\r\n      - uses: actions/checkout@v4\r\n      - ...\r\n    \r\n  # JOB to approve folders that have NOT changed\r\n  approve:\r\n    needs: changes\r\n    strategy:\r\n      matrix:\r\n        # Parse JSON array containing names of all filters matching any of UNCHANGED files\r\n        package: ${{ fromJSON(needs.changes.outputs.UNCHANGED-packages) }}\r\n    runs-on: ubuntu-latest\r\n    steps:\r\n      - run: success()&#129335;&#127995;‍♂️&#129335;&#127995;‍♂️\r\n\r\n```\r\n\r\nI was thinking maybe I can use some combination of `setOutput`, `toJson()`, `getInput()`, maybe `jq`? \r\n\r\nCan I somehow get the object keys for the &quot;with&quot; property? Unfortunately, when I log the `toJson(steps)` I get:\r\n```json\r\n  {\r\n    &quot;filter&quot;: {\r\n      &quot;outputs&quot;: {\r\n        &quot;package1&quot;: &quot;false&quot;,\r\n        &quot;package1_count&quot;: &quot;0&quot;,\r\n        &quot;package2&quot;: &quot;true&quot;,\r\n        &quot;package2_count&quot;: &quot;3&quot;,\r\n        &quot;changes&quot;: &quot;[\\&quot;package2\\&quot;]&quot;\r\n      },\r\n      &quot;outcome&quot;: &quot;success&quot;,\r\n      &quot;conclusion&quot;: &quot;success&quot;\r\n    }\r\n  }\r\n```\r\n\r\nSo I don&#39;t know what to do. Is there a better library than `dorny/paths-filter` to accomplish?",
        "link": "https://stackoverflow.com/questions/78705115/how-do-i-reference-a-steps-with-property-in-workflow-yaml",
        "title": "How do I reference a step&#39;s &quot;with:&quot; property in workflow YAML?"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1720086746,
                "last_edit_date": 1720086746,
                "creation_date": 1720086089,
                "answer_id": 78706303,
                "question_id": 78706219,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You&#39;re looking for something like this:\r\n```\r\n.quadrants as $l | .entries[].quadrant |= . as $e | $l | index($e)\r\n```",
                "title": "Replace a field with the index of values in an array in JQ"
            },
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1720091987,
                "creation_date": 1720091987,
                "answer_id": 78706806,
                "question_id": 78706219,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can also use double brackets to find the index:\r\n```sh\r\n.quadrants as $q | .entries[].quadrant |= $q[[.]][]\r\n```\r\n[Demo](https://jqplay.org/s/Gmy0a6TYhSGtiRj)\r\n\r\nIf items in the quadrants array could occur multiple times, use `first($q[[.]][])` instead.\r\n\r\nFor large inputs with many, potentially expensive searches, you could create a lookup `INDEX` beforehand, and then efficiently just query that:\r\n```sh\r\n(.quadrants | to_entries | INDEX(.value)) as $i | .entries[].quadrant |= $i[.].key\r\n```\r\n[Demo](https://jqplay.org/s/IYuFBQ_71bAqkez)",
                "title": "Replace a field with the index of values in an array in JQ"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1720093909,
        "creation_date": 1720085182,
        "last_edit_date": 1720093909,
        "question_id": 78706219,
        "body_markdown": "Given the following JSON file:\r\n\r\n```json\r\n{\r\n  &quot;quadrants&quot;: [\r\n    &quot;Languages + Frameworks&quot;,\r\n    &quot;Tools&quot;,\r\n    &quot;Platforms&quot;,\r\n    &quot;Techniques&quot;\r\n  ],\r\n  &quot;entries&quot;: [\r\n    {\r\n      &quot;quadrant&quot;: &quot;Languages + Frameworks&quot;\r\n    },\r\n    {\r\n      &quot;quadrant&quot;: &quot;Platforms&quot;\r\n    },\r\n    {\r\n      &quot;quadrant&quot;: &quot;Languages + Frameworks&quot;\r\n    }\r\n  ]\r\n}\r\n```\r\n\r\nHow can the quadrant field of each entry be replaced with the index of the corresponding value in quadrants?\r\n\r\nExpected output:\r\n\r\n```json\r\n{\r\n  &quot;quadrants&quot;: [\r\n    &quot;Languages + Frameworks&quot;,\r\n    &quot;Tools&quot;,\r\n    &quot;Platforms&quot;,\r\n    &quot;Techniques&quot;\r\n  ],\r\n  &quot;entries&quot;: [\r\n    {\r\n      &quot;quadrant&quot;: 0\r\n    },\r\n    {\r\n      &quot;quadrant&quot;: 2\r\n    },\r\n    {\r\n      &quot;quadrant&quot;: 0\r\n    }\r\n  ]\r\n}\r\n```\r\n\r\nI tried the following jq script but get `null` for each quadrant.\r\n\r\n```sh\r\njq &#39;\r\n  .entries |= map(\r\n    .quadrant = (.quadrant as $q | (.quadrants | index($q)))\r\n  )\r\n&#39; &quot;$1&quot;\r\n```",
        "link": "https://stackoverflow.com/questions/78706219/replace-a-field-with-the-index-of-values-in-an-array-in-jq",
        "title": "Replace a field with the index of values in an array in JQ"
    },
    {
        "tags": [
            "amazon-web-services",
            "jq",
            "export-to-csv",
            "aws-cli"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1720100637,
                "post_id": 78707429,
                "comment_id": 138767791,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 3756735,
                    "reputation": 555,
                    "user_id": 3122932,
                    "user_type": "registered",
                    "accept_rate": 35,
                    "profile_image": "https://www.gravatar.com/avatar/6ea646c8a00d8e4f8093ff17e7b543a1?s=256&d=identicon&r=PG",
                    "display_name": "Jhosman",
                    "link": "https://stackoverflow.com/users/3122932/jhosman"
                },
                "reply_to_user": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1720100946,
                "post_id": 78707429,
                "comment_id": 138767847,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1720101119,
                "post_id": 78707429,
                "comment_id": 138767862,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 3756735,
                    "reputation": 555,
                    "user_id": 3122932,
                    "user_type": "registered",
                    "accept_rate": 35,
                    "profile_image": "https://www.gravatar.com/avatar/6ea646c8a00d8e4f8093ff17e7b543a1?s=256&d=identicon&r=PG",
                    "display_name": "Jhosman",
                    "link": "https://stackoverflow.com/users/3122932/jhosman"
                },
                "reply_to_user": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1720101406,
                "post_id": 78707429,
                "comment_id": 138767899,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1720101731,
                "post_id": 78707429,
                "comment_id": 138767958,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 3756735,
                    "reputation": 555,
                    "user_id": 3122932,
                    "user_type": "registered",
                    "accept_rate": 35,
                    "profile_image": "https://www.gravatar.com/avatar/6ea646c8a00d8e4f8093ff17e7b543a1?s=256&d=identicon&r=PG",
                    "display_name": "Jhosman",
                    "link": "https://stackoverflow.com/users/3122932/jhosman"
                },
                "reply_to_user": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1720102856,
                "post_id": 78707429,
                "comment_id": 138768112,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 3756735,
                    "reputation": 555,
                    "user_id": 3122932,
                    "user_type": "registered",
                    "accept_rate": 35,
                    "profile_image": "https://www.gravatar.com/avatar/6ea646c8a00d8e4f8093ff17e7b543a1?s=256&d=identicon&r=PG",
                    "display_name": "Jhosman",
                    "link": "https://stackoverflow.com/users/3122932/jhosman"
                },
                "reply_to_user": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1720104182,
                "post_id": 78707429,
                "comment_id": 138768284,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "is_answered": false,
        "answer_count": 0,
        "score": 0,
        "last_activity_date": 1720127186,
        "creation_date": 1720100269,
        "last_edit_date": 1720127186,
        "question_id": 78707429,
        "body_markdown": "I have a problem generating the list of my resources in AWS, and later converting them into CSV using the JQ command, exactly this is the command I am running from the AWS CLI\r\n\r\n    aws configservice select-resource-config --expression &quot;\r\n    SELECT\r\n      accountId,\r\n      awsRegion,\r\n      resourceType,\r\n      configuration.instanceType,\r\n      configuration.dBInstanceClass,\r\n      arn,\r\n      configuration.description,\r\n      configuration.role,\r\n      configuration.volumeType,\r\n      configuration.size,\r\n      configuration.platform,\r\n      configuration.engineVersion,\r\n      configuration.architecture,\r\n      configuration.runtime,\r\n      configuration.vpcId,\r\n      configuration.subnetId,\r\n      configuration.dNSName,\r\n      configuration.publicIpAddress,\r\n      configuration.publicDnsName,\r\n      configuration.privateIpAddress,\r\n      configuration.privateDnsName,\r\n      configuration.securityGroups,\r\n      configuration.status\r\n    &quot; --output json |  \\\r\n    jq -r &#39;[&quot;ID Cuenta&quot;, &quot;Region AWS&quot;, &quot;Tipo Recurso&quot;, &quot;Tipo Instancia EC2&quot;, &quot;Tipo DB RDS&quot;, &quot;ARN&quot;, &quot;Descipcion&quot;, &quot;Rol&quot;, &quot;Tipo Volumen&quot;, &quot;Tama&#241;o&quot;, &quot;Plataforma&quot;, &quot;Engine Version&quot;, &quot;Arquitectura&quot;, &quot;Runtime&quot;, &quot;VPC&quot;, &quot;Subnet ID&quot;, &quot;DNS&quot;, &quot;IP P&#250;blica&quot;, &quot;DNS P&#250;blico&quot;, &quot;IP Privada&quot;, &quot;DNS Privado&quot;, &quot;Security Groups&quot;, &quot;Estado&quot;], (.Results[] | fromjson | [.accountId, .awsRegion, .resourceType, .configuration.instanceType, .configuration.dBInstanceClass, .arn, .configuration.description, .configuration.role, .configuration.volumeType, .configuration.size, .configuration.platform, .configuration.engineVersion, .configuration.architecture, .configuration.runtime, .configuration.vpcId, .configuration.subnetId, .configuration.dNSName, .configuration.publicIpAddress, .configuration.publicDnsName, .configuration.privateIpAddress, .configuration.privateDnsName, .configuration.securityGroups, .configuration.status]) | @csv&#39; &gt; data.csv &amp;&amp;\r\n    iconv -f UTF-8 data.csv -o data.csv\r\n\r\nThe export command works correctly, but the problem occurs when converting from JSON to CSV, and it occurs only with some AWS accounts or resources, an error is generated in the conversion and the CSV generation process fails and stops , this is the output in the shell\r\n\r\n    Bus error (core dumped)\r\n\r\nor\r\n\r\n    jq: error (at &lt;stdin&gt;:623): array ([{&quot;value&quot;:&quot;...) is not valid in a csv row\r\n\r\nIn this last case in particular, the conversion process with the JQ command was stopped, checking the first export was generated correctly and the line where the exception was generated contains this (comparing CSV file with JSON file), line not processed (not appears in CSV file):\r\n\r\n```\r\n&quot;{\\&quot;accountId\\&quot;:\\&quot;ID_ACCOUNT\\&quot;,\\&quot;awsRegion\\&quot;:\\&quot;us-east-1\\&quot;,\\&quot;configuration\\&quot;:{\\&quot;vpcId\\&quot;:\\&quot;vpc-XXXXXX_ID\\&quot;,\\&quot;securityGroups\\&quot;:[{\\&quot;value\\&quot;:\\&quot;sg-XXXXX_ID\\&quot;},{\\&quot;value\\&quot;:\\&quot;sg-YYYY_UD\\&quot;}],\\&quot;dNSName\\&quot;:\\&quot;awseb-AWSEB-XXXXXXX.us-east-1.elb.amazonaws.com\\&quot;},\\&quot;arn\\&quot;:\\&quot;arn:aws:elasticloadbalancing:us-east-1:XXXX_ID:loadbalancer/app/awseb-AWSEB-XXXXXXX/YYYYY\\&quot;,\\&quot;resourceType\\&quot;:\\&quot;AWS::ElasticLoadBalancingV2::LoadBalancer\\&quot;}&quot;,\r\n```\r\n\r\nThe question is, how could I fix this so that JQ processes the line generated by AWS configservice\r\n\r\nOr alternatively, how could I skip this line to avoid and continue processing the file (I have more than 50 AWS accounts and doing it manually continuously is not optional)\r\n\r\nReferral documentation: https://repost.aws/es/articles/ARQz1QqJx0R7ioSz3nI3noeg/returning-aws-config-aggregator-results-as-csv ",
        "link": "https://stackoverflow.com/questions/78707429/json-conversion-error-from-aws-configservice-query",
        "title": "JSON conversion error from aws configservice query"
    },
    {
        "tags": [
            "json",
            "bash",
            "curl",
            "nested",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 2792262,
                    "reputation": 187127,
                    "user_id": 2402272,
                    "user_type": "registered",
                    "accept_rate": 85,
                    "profile_image": "https://www.gravatar.com/avatar/1182b1d5518a596d4e8cfe0567a65c4d?s=256&d=identicon&r=PG",
                    "display_name": "John Bollinger",
                    "link": "https://stackoverflow.com/users/2402272/john-bollinger"
                },
                "edited": false,
                "score": 4,
                "creation_date": 1720711295,
                "post_id": 78736348,
                "comment_id": 138820253,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2792262,
                    "reputation": 187127,
                    "user_id": 2402272,
                    "user_type": "registered",
                    "accept_rate": 85,
                    "profile_image": "https://www.gravatar.com/avatar/1182b1d5518a596d4e8cfe0567a65c4d?s=256&d=identicon&r=PG",
                    "display_name": "John Bollinger",
                    "link": "https://stackoverflow.com/users/2402272/john-bollinger"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1720711433,
                "post_id": 78736348,
                "comment_id": 138820278,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 8526894,
                    "reputation": 13,
                    "user_id": 6392062,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f7e5170bc10a43e5f40a1fcd11d79ae8?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "RKGupta",
                    "link": "https://stackoverflow.com/users/6392062/rkgupta"
                },
                "reply_to_user": {
                    "account_id": 2792262,
                    "reputation": 187127,
                    "user_id": 2402272,
                    "user_type": "registered",
                    "accept_rate": 85,
                    "profile_image": "https://www.gravatar.com/avatar/1182b1d5518a596d4e8cfe0567a65c4d?s=256&d=identicon&r=PG",
                    "display_name": "John Bollinger",
                    "link": "https://stackoverflow.com/users/2402272/john-bollinger"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1720711609,
                "post_id": 78736348,
                "comment_id": 138820313,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2792262,
                    "reputation": 187127,
                    "user_id": 2402272,
                    "user_type": "registered",
                    "accept_rate": 85,
                    "profile_image": "https://www.gravatar.com/avatar/1182b1d5518a596d4e8cfe0567a65c4d?s=256&d=identicon&r=PG",
                    "display_name": "John Bollinger",
                    "link": "https://stackoverflow.com/users/2402272/john-bollinger"
                },
                "edited": false,
                "score": 5,
                "creation_date": 1720711933,
                "post_id": 78736348,
                "comment_id": 138820377,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 13789219,
                    "reputation": 53538,
                    "user_id": 9952196,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/cd1a3f93172eb89e221c98e35e6e22b3?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Shawn",
                    "link": "https://stackoverflow.com/users/9952196/shawn"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1720712616,
                "post_id": 78736348,
                "comment_id": 138820480,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 32384,
                    "reputation": 127026,
                    "user_id": 89817,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/df253c3b6533949ea94f31f328f3e769?s=256&d=identicon&r=PG",
                    "display_name": "Gordon Davisson",
                    "link": "https://stackoverflow.com/users/89817/gordon-davisson"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1720712735,
                "post_id": 78736348,
                "comment_id": 138820503,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 8526894,
                    "reputation": 13,
                    "user_id": 6392062,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f7e5170bc10a43e5f40a1fcd11d79ae8?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "RKGupta",
                    "link": "https://stackoverflow.com/users/6392062/rkgupta"
                },
                "reply_to_user": {
                    "account_id": 13789219,
                    "reputation": 53538,
                    "user_id": 9952196,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/cd1a3f93172eb89e221c98e35e6e22b3?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Shawn",
                    "link": "https://stackoverflow.com/users/9952196/shawn"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1720712954,
                "post_id": 78736348,
                "comment_id": 138820545,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1143565,
                    "reputation": 535973,
                    "user_id": 1126841,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/fa05233b2357f8d11c22ef4cfc7bb85c?s=256&d=identicon&r=PG",
                    "display_name": "chepner",
                    "link": "https://stackoverflow.com/users/1126841/chepner"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1720714324,
                "post_id": 78736348,
                "comment_id": 138820728,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1720716040,
                "creation_date": 1720716040,
                "answer_id": 78736761,
                "question_id": 78736348,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "As I mentioned in comments, the best approach would be to fix the API (or get its provider to fix it) so that it delivers well-formed JSON.  There is every reason to demand this, for an API that promises JSON responses is buggy if it delivers invalid JSON under any circumstances.\r\n\r\nAlternatively, if you can control the data, then the best workaround would be to reformulate the regex in the API&#39;s database to an equivalent one that does not use backslash (`\\`) characters.  This should get you API responses that do not require client-side correction.\r\n\r\nIf neither of those is viable, then the best long-term approach would be to dump your unreasonable API provider in favor of a better one, but in the short term, there are client-side workarounds.\r\n\r\n&gt; I would like to\r\n&gt; \r\n&gt;  1. Either replace the single backslash with a double backslash before storing this json in a file OR\r\n&gt;  2. Delete the format field.\r\n&gt; \r\n&gt; Tried something like this:\r\n&gt; \r\n&gt;     SPECIAL_SERVICES_RESPONSE=$(curl -s -X GET -H &quot;Authorization: Bearer ${BEARER_TOKEN}&quot; &quot;${SPECIAL_SERVICES_URL}&quot; | jq &#39;[.[].inputParameterRules[] | del(.format)]&#39;)\r\n\r\nSince the problem to be solved is that the file is not valid JSON, it stands to reason that you cannot solve it via a mechanism that involves parsing the file as JSON.\r\n\r\nYou *can* filter it with `sed`.  The issue here is distinguishing between data that need fixed and data that don&#39;t, especially if there is hope that the API provider will evantually fix the issue on their side.\r\n\r\nHere are some alternatives you could consider:\r\n\r\n - This `sed` command will dumbly double every backslash in the input:\r\n   ```\r\n   sed &#39;s/\\\\/\\\\\\\\/g&#39;\r\n   ```\r\n   This will fix the specific malformation presented in the question, but it will *break* any JSON-ly correct backslash usage elsewhere in the file.  And if the API provider ever gets their stuff together, it will start breaking the correct JSON they then emit.\r\n\r\n - This one is a bit more targeted.  It will double every backslash in any line that matches `/&quot;format&quot;:/`\r\n   ```\r\n   sed &#39;/&quot;format&quot;:/ s/\\\\/\\\\\\\\/g&#39;\r\n   ```\r\n   The targeting reduces the likelihood that erstwhile valid data elsewhere in the file are corrupted, but also avoids fixing such data if they are in fact invalid.\r\n\r\n - This one will add one backslash at the end of any run of an odd number of backslashes that is bounded by non-backslash characters:\r\n   ```\r\n   sed -E &#39;s/([^\\\\](\\\\\\\\)*)\\\\([^\\\\])/\\1\\\\\\\\\\3/g&#39;\r\n   ```\r\n   That will fix your current malformation and not break when the API provider fixes your particular issue, but it might break JSON-ly correct backslash usage elsewhere.\r\n\r\n - Of course, you can combine the last two:\r\n   ```\r\n   sed -E &#39;/&quot;format&quot;:/ s/([^\\\\](\\\\\\\\)*)\\\\([^\\\\])/\\1\\\\\\\\\\3/g&#39;\r\n   ```\r\n   That gives you a fairly narrowly targeted approach that will not necessarily break when the API provider fixes the issue.\r\n\r\nThe overarching theme here is that if you can&#39;t rely on the API provider to emit correct data in the first place, then the best you can do is *heuristically* correct whatever they do emit, and that path is strewn with traps and pitfalls.  You have to be concerned both about &quot;fixing&quot; data that were correct and valid in the first place and about failing to recognize or fix incorrect data.",
                "title": "Replace single backslash with double backslash so that json becomes parseable"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1720814656,
                "last_edit_date": 1720814656,
                "creation_date": 1720780971,
                "answer_id": 78739917,
                "question_id": 78736348,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "It turns out that halaxa&#39;s &quot;JSON Machine&quot; (https://github.com/halaxa/json-machine)\r\nis very lenient in accepting &quot;strings&quot;\r\nwhen reading JSON, so one JSON-aware approach would be to use JSON Machine.\r\nFor simplicity, the following uses the &quot;jm&quot; script (https://github.com/pkoppstein/jm)\r\nthat uses JSON Machine under the hood.\r\n\r\nSince your post indicates you&#39;re particularly interested in the &quot;inputParameterRules&quot;,\r\nI&#39;ll focus on that in the following.\r\n\r\nIn brief, the following line produces the output (valid JSON) shown below:\r\n\r\n```\r\njm  --pointer /-/inputParameterRules input.pseudojson \r\n```\r\n\r\nOutput:\r\n```\r\n{&quot;name&quot;:&quot;PHONE_NUMBER&quot;,&quot;brandedName&quot;:&quot;Appointment Phone Number&quot;,&quot;required&quot;:true,&quot;format&quot;:&quot;^d{10,15}$&quot;,&quot;description&quot;:&quot;A valid 10 to 15 digit phone number including area code and optional extension&quot;}\r\n{&quot;name&quot;:&quot;SIGNATURE_RELEASE_NUMBER&quot;,&quot;description&quot;:&quot;A valid signature release number&quot;}\r\n```\r\n\r\nSince this is a stream of valid JSON objects, you can now use jq.",
                "title": "Replace single backslash with double backslash so that json becomes parseable"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1720814656,
        "creation_date": 1720710455,
        "last_edit_date": 1720712816,
        "question_id": 78736348,
        "body_markdown": "I am using `cURL` inside `bash` to fetch json data from remote API. Also using `jq` to parse and loop through the json array to perform additional operations. The response looks like this:\r\n\r\n``` lang-js\r\n[\r\n     {\r\n        &quot;services&quot;: [\r\n            &quot;HOM&quot;\r\n        ],\r\n        &quot;specialServiceId&quot;: &quot;APPOINTMENT&quot;,\r\n        &quot;brandedName&quot;: &quot;Appointment Home Delivery&#174;&quot;,\r\n        &quot;incompatibleSpecialServices&quot;: [\r\n            &quot;DATE&quot;,\r\n            &quot;EVENING&quot;\r\n        ],\r\n        &quot;inputParameterRules&quot;: [\r\n            {\r\n                &quot;name&quot;: &quot;PHONE_NUMBER&quot;,\r\n                &quot;brandedName&quot;: &quot;Appointment Phone Number&quot;,\r\n                &quot;required&quot;: true,\r\n                &quot;format&quot;:&quot;^\\d{10,15}$&quot;,\r\n                &quot;description&quot;: &quot;A valid 10 to 15 digit phone number including area code and optional extension&quot;\r\n            }\r\n        ]\r\n    },\r\n    {\r\n        &quot;services&quot;: [\r\n            &quot;NDA_AM_EH&quot;,\r\n            &quot;2DA&quot;\r\n        ],\r\n        &quot;specialServiceId&quot;: &quot;NO_SIG&quot;,\r\n        &quot;brandedName&quot;: &quot;No Signature Required&quot;,\r\n        &quot;categoryId&quot;: &quot;DEL_CON&quot;,\r\n        &quot;incompatibleSpecialServices&quot;: [\r\n            &quot;SIG&quot;,\r\n            &quot;DIRECT_SIG&quot;\r\n        ],\r\n        &quot;inputParameterRules&quot;: [\r\n            {\r\n                &quot;name&quot;: &quot;SIGNATURE_RELEASE_NUMBER&quot;,\r\n                &quot;description&quot;: &quot;A valid signature release number&quot;\r\n            }\r\n        ],\r\n        &quot;specialServiceLevel&quot;: &quot;ALLPKG&quot;\r\n    },\r\n  {...},\r\n  {...}\r\n] \r\n```\r\n\r\n\r\nAs you can see the `format` field inside inputParameterRules for PHONE_NUMBER contains a single backslash which makes this JSON un-parseable.\r\n\r\nI would like to \r\n1. Either replace the single backslash with a double backslash before storing this json in a file OR\r\n2. Delete the format field.\r\n\r\n\r\n\r\n\r\nTried something like this:\r\n``` lang-js\r\n SPECIAL_SERVICES_RESPONSE=$(curl -s -X GET -H &quot;Authorization: Bearer ${BEARER_TOKEN}&quot; &quot;${SPECIAL_SERVICES_URL}&quot; | jq &#39;[.[].inputParameterRules[] | del(.format)]&#39;)\r\n```\r\n\r\nBut it produces no results.\r\n\r\nThanks",
        "link": "https://stackoverflow.com/questions/78736348/replace-single-backslash-with-double-backslash-so-that-json-becomes-parseable",
        "title": "Replace single backslash with double backslash so that json becomes parseable"
    },
    {
        "tags": [
            "postgresql",
            "jq",
            "plpgsql",
            "postgresql-copy"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 892239,
                    "reputation": 25308,
                    "user_id": 930271,
                    "user_type": "registered",
                    "accept_rate": 50,
                    "profile_image": "https://www.gravatar.com/avatar/84cf3d99c3573d3fd40cbe37c107f3bd?s=256&d=identicon&r=PG",
                    "display_name": "Francisco Puga",
                    "link": "https://stackoverflow.com/users/930271/francisco-puga"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1720770729,
                "post_id": 78739142,
                "comment_id": 138825432,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 892239,
                    "reputation": 25308,
                    "user_id": 930271,
                    "user_type": "registered",
                    "accept_rate": 50,
                    "profile_image": "https://www.gravatar.com/avatar/84cf3d99c3573d3fd40cbe37c107f3bd?s=256&d=identicon&r=PG",
                    "display_name": "Francisco Puga",
                    "link": "https://stackoverflow.com/users/930271/francisco-puga"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1720771154,
                "post_id": 78739142,
                "comment_id": 138825478,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1720775733,
                "last_edit_date": 1720775733,
                "creation_date": 1720774788,
                "answer_id": 78739453,
                "question_id": 78739142,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You&#39;re getting the error because [`COPY`][1] expects one value per line, while `jq` pretty-prints by default, splitting the single json structure into multiple lines. As already [pointed out][2] by [@Francisco Puga][3], you can disable that:\r\n&gt;`--compact-output / -c:`\r\n&gt;\r\n&gt;By default, jq pretty-prints JSON output. Using this option will result in more compact output by instead putting each JSON object on a single line.\r\n\r\nOtherwise, this\r\n```\r\n&#39;{&quot;key1&quot;: &quot;val1&quot;, &quot;key2&quot;: &quot;val2&quot;}&#39;\r\n```\r\nGets turned by `jq` into this\r\n```\r\n{\r\n    &quot;key1&quot;: &quot;val1&quot;,\r\n    &quot;key2&quot;: &quot;val2&quot;\r\n}\r\n```\r\nAnd due to the line-separation thing, `copy` thinks you&#39;re trying to do something this:\r\n```\r\ninsert into tmp(json_tmp)values \r\n (&#39;{&#39;)\r\n,(&#39;&quot;key1&quot;: &quot;val1&quot;,&#39;)\r\n,(&#39;&quot;key2&quot;: &quot;val2&quot;&#39;)\r\n,(&#39;}&#39;);\r\n```\r\nHence, the error complaining about the single opening curly bracket. It seems to work fine if you enable compaction:\r\n```pgsql\r\nCREATE OR REPLACE FUNCTION json_func(IN json_in JSONB, OUT json_out JSONB)\r\nLANGUAGE plpgsql\r\nAS $code_block$\r\nBEGIN\r\nCREATE TEMPORARY TABLE tmp (json_tmp JSONB);\r\nEXECUTE format($dynsql$ COPY tmp FROM PROGRAM $bash$echo %1$L |jq -c . $bash$ \r\n               $dynsql$, json_in);\r\nSELECT json_tmp FROM tmp INTO json_out;\r\nDROP TABLE tmp;\r\nEND;\r\n$code_block$;\r\n```\r\n***\r\nIf that&#39;s an attempt to pretty-print, Postgres offers a built-in [`jsonb_pretty()`][4]:  \r\n[&lt;sub&gt;demo at db&lt;&gt;fiddle&lt;/sub&gt;][5]\r\n\r\n``` \r\nselect jsonb_pretty(&#39;{&quot;abc&quot;:123}&#39;);\r\n```\r\n\r\n| jsonb\\_pretty |\r\n|:-------------|\r\n| {&lt;br&gt;    &quot;abc&quot;: 123&lt;br&gt;} |\r\n\r\nIf it&#39;s for validation, In version 16+ you can check that with [`&#39;abc&#39; IS JSON`][6] or [`pg_input_is_valid(&#39;abc&#39;,&#39;jsonb&#39;)`][7]:\r\n```pgsql\r\nselect &#39;abc&#39; is json;                          --false\r\nselect pg_input_is_valid(&#39;abc&#39;,&#39;json&#39;);        --false\r\nselect &#39;{&quot;abc&quot;:123}&#39; is json;                  --true\r\nselect pg_input_is_valid(&#39;{&quot;abc&quot;:123}&#39;,&#39;json&#39;);--true\r\n```\r\n\r\n\r\n  [1]: https://www.postgresql.org/docs/current/sql-copy.html\r\n  [2]: https://stackoverflow.com/questions/78739142/how-do-i-pass-json-to-a-postgres-copy-tmp-from-program-command/78739453#comment138825478_78739142\r\n  [3]: https://stackoverflow.com/users/930271/francisco-puga\r\n  [4]: https://www.postgresql.org/docs/current/functions-json.html#id-1.5.8.22.8.13.2.2.23.1.1.1\r\n  [5]: https://dbfiddle.uk/qg0jZARj\r\n  [6]: https://www.postgresql.org/docs/current/functions-json.html#FUNCTIONS-SQLJSON-MISC\r\n  [7]: https://www.postgresql.org/docs/current/functions-info.html#FUNCTIONS-INFO-VALIDITY",
                "title": "How do I pass JSON to a Postgres COPY tmp FROM PROGRAM command"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1720775733,
        "creation_date": 1720770191,
        "last_edit_date": 1720775185,
        "question_id": 78739142,
        "body_markdown": "I&#39;m trying to use Postgres (PL/pgSQL) to communicate with a shell script that expects JSON data. A simplified example of what I&#39;m trying to do is\r\n\r\n```plpgsql\r\nCREATE OR REPLACE FUNCTION json_func(IN json_in JSONB, OUT json_out JSONB)\r\nLANGUAGE plpgsql\r\nAS $code_block$\r\nBEGIN\r\nCREATE TEMPORARY TABLE tmp (json_tmp JSONB);\r\nEXECUTE format($bash$ COPY tmp FROM PROGRAM &#39;echo &#39;&#39;%s&#39;&#39; | jq . &#39; $bash$, json_in);\r\nSELECT json_tmp FROM tmp INTO json_out;\r\nDROP TABLE tmp;\r\nEND;\r\n$code_block$;\r\n```\r\n\r\nWhen I run\r\n\r\n```sql\r\nSELECT json_func(&#39;{&quot;key1&quot;: &quot;val1&quot;, &quot;key2&quot;: &quot;val2&quot;}&#39;::JSONB);\r\n```\r\n\r\nI get\r\n\r\n```\r\nERROR:  invalid input syntax for type json\r\nDETAIL:  The input string ended unexpectedly.\r\nCONTEXT:  JSON data, line 1: {\r\nCOPY tmp, line 1, column json_tmp: &quot;{&quot;\r\nSQL statement &quot; COPY tmp FROM PROGRAM &#39;echo &#39;&#39;{&quot;key1&quot;: &quot;val1&quot;, &quot;key2&quot;: &quot;val2&quot;}&#39;&#39; | jq . &#39; &quot;\r\nPL/pgSQL function json_func(jsonb) line 4 at EXECUTE\r\n```\r\n\r\nI&#39;ve tried various ways of escaping the single quotes needed to surround the JSON input, but no luck.",
        "link": "https://stackoverflow.com/questions/78739142/how-do-i-pass-json-to-a-postgres-copy-tmp-from-program-command",
        "title": "How do I pass JSON to a Postgres COPY tmp FROM PROGRAM command"
    },
    {
        "tags": [
            "json",
            "amazon-web-services",
            "jq",
            "amazon-kinesis-firehose"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 39208,
                    "reputation": 267964,
                    "user_id": 112968,
                    "user_type": "registered",
                    "accept_rate": 68,
                    "profile_image": "https://i.sstatic.net/zHTaT.png?s=256",
                    "display_name": "knittl",
                    "link": "https://stackoverflow.com/users/112968/knittl"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1721113805,
                "post_id": 78752594,
                "comment_id": 138849654,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2646455,
                    "reputation": 1269,
                    "user_id": 2289031,
                    "user_type": "registered",
                    "accept_rate": 36,
                    "profile_image": "https://www.gravatar.com/avatar/baa8f3e03569a10871e8335b18f55d5a?s=256&d=identicon&r=PG",
                    "display_name": "Abhi",
                    "link": "https://stackoverflow.com/users/2289031/abhi"
                },
                "reply_to_user": {
                    "account_id": 39208,
                    "reputation": 267964,
                    "user_id": 112968,
                    "user_type": "registered",
                    "accept_rate": 68,
                    "profile_image": "https://i.sstatic.net/zHTaT.png?s=256",
                    "display_name": "knittl",
                    "link": "https://stackoverflow.com/users/112968/knittl"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1721145430,
                "post_id": 78752594,
                "comment_id": 138853990,
                "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": 1721148554,
                "post_id": 78752594,
                "comment_id": 138854388,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "is_answered": false,
        "answer_count": 0,
        "score": 0,
        "last_activity_date": 1721101154,
        "creation_date": 1721101154,
        "question_id": 78752594,
        "body_markdown": "0\r\nHello,\r\n\r\nI have a json stream coming into my aws firehose that can contain either metrics or report key-value pairs based on the data source. They look like this -\r\n\r\nmetrics stream\r\n\r\n&gt; { &quot;metric&quot;: { &quot;k1&quot; : &quot;v1&quot;, &quot;k2&quot; : &quot;v2&quot;, ... } }\r\n\r\nreport stream\r\n\r\n&gt; { &quot;report&quot;: { &quot;k1&quot; : &quot;v1&quot;, &quot;k2&quot; : &quot;v2&quot;, ... } }\r\n\r\nI am trying to use JQ expressions to check if the json has(&quot;metric&quot;)/has(&quot;report&quot;) and then derive the values from the blob. or eg,\r\n\r\n    if has(&quot;metric&quot;) then &quot;metric&quot; else &quot;report&quot; end\r\n\r\nThis seemed valid syntax from the online JQ Playground(ref). However, it fails when it is defined as a Dynamic partitioning Key in the firehose. I want to read different keys from the json to define the output of the stream. For eg, both Keys - K1, K2 are important to be read and they are dependent on being able to parse if the parent key is metric/report.\r\n\r\nIn this stream, metirc/report form the 1st level partition key, followed by the K1 value. I am using below JQ syntax to derive K1,\r\n\r\n    if has(&quot;metric&quot;) then .metric.k1 else .report.k1 end\r\n\r\nError message -\r\n\r\n&gt; JQ Subprocess failed due to: jq: error: syntax error, unexpected if\r\n&gt; (Unix shell quoting issues?) at &lt;top-level&gt;, line 2: {dataType:if\r\n&gt; has(&quot;metric&quot;) then &quot;metric&quot; else &quot;report&quot; end} jq: 1 compile error\r\n&gt; \r\n&gt; Error code: DynamicPartitioning.MetadataExtractionFailed\r\n\r\nWhat&#39;s the mistake with JQ expression here. It seems pretty normal here but I am unable to get the right expression to verify the metric or report key.",
        "link": "https://stackoverflow.com/questions/78752594/jq-parsing-a-json-stream-input-amazon-firehose",
        "title": "JQ Parsing a json stream input - Amazon Firehose"
    },
    {
        "tags": [
            "json",
            "parsing",
            "amazon-s3",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1721145477,
                "creation_date": 1721145477,
                "answer_id": 78755587,
                "question_id": 78755559,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Quick / manual solution:\r\n\r\nIf you `split` on both `//` and `/` you can use `$foo[0]` to get the bucket, use `$foo[-1]` for the key (last index) and `join` the rest (`1:-1`) to get the prefix.\r\n\r\n\r\n\r\n```\r\nsplit(&quot;//&quot;)[1] | split(&quot;/&quot;) | {\r\n    bucket: .[0],\r\n    prefix: .[-1],\r\n    key: .[1:-1] | join(&quot;/&quot;)\r\n}\r\n```\r\n\r\n[Demo](https://jqplay.org/s/uOmD34v1SrFHw9T)",
                "title": "JQ extract parent folder"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1721192165,
                "creation_date": 1721192165,
                "answer_id": 78757699,
                "question_id": 78755559,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Using regex capturing should do the trick while addressing any concerns regarding the use of `split`; e.g. with your input\r\n```\r\ncapture(&quot;^[^:]*://(?&lt;bucket&gt;[^/]+)/(?&lt;prefix&gt;.*)/(?&lt;key&gt;[^/]+)$&quot;)\r\n```\r\nproduces valid JSON:\r\n```\r\n{\r\n  &quot;bucket&quot;: &quot;bucket&quot;,\r\n  &quot;prefix&quot;: &quot;folder1/folder2/folder3&quot;,\r\n  &quot;key&quot;: &quot;key.txt&quot;\r\n}\r\n```",
                "title": "JQ extract parent folder"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": -1,
        "last_activity_date": 1721192165,
        "creation_date": 1721144953,
        "last_edit_date": 1721191654,
        "question_id": 78755559,
        "body_markdown": "I have an s3 route and I have to split it in bucket, prefix and key using JQ.\r\n\r\n    &quot;s3://bucket/folder1/folder2/folder3/key.txt&quot; -&gt;\r\n    \r\n    {\r\n      bucket: bucket,\r\n      prefix: folder1/folder2/folder3,\r\n      key: key.txt\r\n    }",
        "link": "https://stackoverflow.com/questions/78755559/jq-extract-parent-folder",
        "title": "JQ extract parent folder"
    },
    {
        "tags": [
            "shell",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 10015983,
                    "reputation": 144648,
                    "user_id": 9072753,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/EPmGy.jpg?s=256",
                    "display_name": "KamilCuk",
                    "link": "https://stackoverflow.com/users/9072753/kamilcuk"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1721228651,
                "post_id": 78760238,
                "comment_id": 138862563,
                "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": 1721230328,
                "post_id": 78760238,
                "comment_id": 138862819,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": false,
                "score": 4,
                "last_activity_date": 1721229748,
                "creation_date": 1721229748,
                "answer_id": 78760336,
                "question_id": 78760238,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Don&#39;t store the command in a variable; define a function.\r\n\r\n    CMD () {\r\n         jq --arg k $key &#39;.[$k]&#39; /tmp/test.json\r\n    }\r\n\r\nand call the function later:\r\n\r\n    $ key=foo\r\n    $ CMD\r\n    &quot;val1&quot;\r\n\r\nRather than having `CMD` rely on a global variable `key` to be defined, consider parameterizing the function.\r\n\r\n    CMD () {\r\n        jq --arg k &quot;$1&quot; &#39;.[$k]&#39; /tmp/test.json\r\n    }\r\n\r\n    $ CMD foo\r\n    &quot;val1&quot;\r\n    $ CMD bar\r\n    &quot;val2&quot;",
                "title": "Pass bash variable to jq filter and echo the whole command to another variable"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1721237517,
                "last_edit_date": 1721237517,
                "creation_date": 1721237185,
                "answer_id": 78760854,
                "question_id": 78760238,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If you want to print the exact command before execution, and for some reason `set -x` isn&#39;t suitable, you can do this with an array (without creating security vulnerabilities as with `eval`):\r\n\r\n```\r\n## Define your command as an array\r\nmyCmd=( jq --arg k &quot;$k&quot; &#39;.[$k]&#39; /tmp/test.json )\r\n\r\n## Create a string that, if it were eval&#39;d, would be equivalent to that command\r\n# bash 3.2+ version\r\nprintf -v myCmd_q &#39;%q &#39; &quot;${myCmd[@]}&quot; # use this OR the below\r\n# bash 5.0+ version\r\nmyCmd_q=${myCmd[*]@Q}                 # use this OR the above\r\n\r\n## Write that string to the user\r\nprintf &#39;About to run: %s\\n&#39; &quot;$myCmd_q&quot; &gt;&amp;2\r\n\r\n## Actually run the command\r\n&quot;${myCmd[@]}&quot; # identical behavior to &#39;&#39;eval &quot;$myCmd_q&quot;&#39;&#39;\r\n```\r\n\r\nNote that after using either `printf &#39;%q &#39; &quot;${array[@]}&quot;` or `&quot;${array[*]@Q}&quot;` to generate an eval-safe string, you _do_ have a string that&#39;s `eval`-safe -- you _could_ use `eval` without otherwise-inherent security problems at that point; but since you also still have the array that the string was built from, it&#39;s easier (and less likely to raise security-scanner flags) to just execute that array directly.\r\n\r\nThe use of `printf` instead of `echo` is for robustness, reliability, and portability reasons, as explained in detail in [Why is printf better than echo?](https://unix.stackexchange.com/questions/65803/why-is-printf-better-than-echo) over on our sister site [UNIX &amp; Linux](https://unix.stackexchange.com/).",
                "title": "Pass bash variable to jq filter and echo the whole command to another variable"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": -1,
                "last_activity_date": 1721244558,
                "creation_date": 1721244558,
                "answer_id": 78761297,
                "question_id": 78760238,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s a simpler way to achieve what you&#39;re trying to do:\r\n\r\n* Read test.json with jq instead of passing from cat\r\n* Use builtin env instead of `--arg k $key`\r\n* `.[foo]` is wrong - use `.foo` or `.[&quot;foo&quot;]` instead\r\n\r\n```console\r\n$ CMD=&quot;$(key=foo jq -r &#39;&quot;jq \\&quot;.\\(env.key)\\&quot; \\(input_filename)&quot;&#39; test.json)&quot;\r\n\r\n$ echo $CMD\r\njq &quot;.foo&quot; test.json\r\n\r\n$ eval &quot;$CMD&quot;\r\n&quot;val1&quot;\r\n```\r\n\r\nSame as above but with notes\r\n\r\n```sh\r\n# how to use jq&#39;s env: \r\n#   1) export key (export key=foo)\r\n#   2) prepend command with variable (key=foo jq &#39;...&#39;) \r\n\r\nexport key=foo\r\n\r\n# output: jq &quot;.foo&quot; test.json&#39;\r\njq -r &#39;&quot;jq \\&quot;.\\(env.key)\\&quot; \\(input_filename)&quot;&#39; test.json\r\n\r\n# sets CMD to &#39;jq &quot;.foo&quot; test.json&#39;\r\nCMD=&quot;$(jq -r &#39;&quot;jq \\&quot;.\\(env.key)\\&quot; \\(input_filename)&quot;&#39; test.json)&quot;\r\n\r\n# output: &quot;val1&quot;\r\neval &quot;$CMD&quot;\r\n```",
                "title": "Pass bash variable to jq filter and echo the whole command to another variable"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 0,
        "last_activity_date": 1721244558,
        "creation_date": 1721228502,
        "last_edit_date": 1721229369,
        "question_id": 78760238,
        "body_markdown": "I have a sample json like this `/tmp/test.json`\r\n```\r\n{\r\n    &quot;foo&quot; : &quot;val1&quot;,\r\n    &quot;bar&quot; : &quot;val2&quot;\r\n}\r\n```\r\n\r\nSetting the key in a variable\r\n```\r\nkey=foo\r\ncat /tmp/test.json | jq --arg k $key &#39;.[$k]&#39;\r\n\r\n# Output is fine\r\n&quot;val1&quot;\r\n```\r\n\r\nNow if I want to store the whole command into a variable `CMD` so that I can `echo &quot;$CMD` and `eval &quot;$CMD&quot;` later:\r\n```\r\nCMD=`echo cat /tmp/test.json | jq --arg k $key &#39;.[$k]&#39;`\r\n\r\n# Error outout\r\njq: parse error: Invalid numeric literal at line 1, column 4\r\n```\r\n\r\nHow do I escape these special chars?",
        "link": "https://stackoverflow.com/questions/78760238/pass-bash-variable-to-jq-filter-and-echo-the-whole-command-to-another-variable",
        "title": "Pass bash variable to jq filter and echo the whole command to another variable"
    },
    {
        "tags": [
            "bash",
            "timestamp",
            "jq",
            "utc",
            "bosh"
        ],
        "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": 1721396974,
                "post_id": 78769725,
                "comment_id": 138878463,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1721398090,
                "post_id": 78769725,
                "comment_id": 138878612,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1721422816,
                "creation_date": 1721422816,
                "answer_id": 78771204,
                "question_id": 78769725,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The &quot;UTC&quot; specification in the given example does create some complications.\r\n\r\nWith gojq, you can get away with using %Z:\r\n```\r\n$ gojq -R &#39;strptime(&quot;%a %b %d %H:%M:%S %Z %Y&quot;)&#39; &lt;&lt;&lt; &quot;Fri Jul 16 17:34:44 UTC 2024&quot;\r\n```\r\nBut this fails using jq.\r\n\r\nIf all the human-readable strings use UTC in the same way, you could simply\r\nreplace %Z with UTC:\r\n```\r\nstrptime(&quot;%a %b %d %H:%M:%S UTC %Y&quot;)\r\n```\r\nIf that&#39;s not the case, then one of many possibilities would be to use sub/2 in conjunction\r\nwith %Z, e.g.\r\n```\r\njq -R &#39;sub(&quot;UTC&quot;;&quot;GMT&quot;) | strptime(&quot;%a %b %d %H:%M:%S %Z %Y&quot;)&#39; &lt;&lt;&lt; &quot;Fri Jul 16 17:34:44 UTC 2024&quot;\r\n```\r\n",
                "title": "Convert human readable time to epoch inline with jq for time comparison"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1721679483,
                "creation_date": 1721679483,
                "answer_id": 78780633,
                "question_id": 78769725,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can save this file as `bosh.jq` and run it using  \r\n`bosh is --vitals --json | jq -r -f bosh.jq`:\r\n\r\n```jq\r\n# define function\r\ndef convert_time($str): $str|strptime(&quot;%a %b %d %T UTC %Y&quot;)|mktime;\r\n\r\n# set variable or (can also be set using --arg)\r\n&quot;Fri Jul 16 17:34:44 UTC 2024&quot; as $epoch\r\n\r\n| .Tables[].Rows[] \r\n| select(convert_time(.vm_created_at) &lt; convert_time($epoch)).instance_name\r\n```\r\n\r\nCommand you provided to get list of VM creation dates\r\n\r\n```console\r\n$ bosh is --vitals --json | jq -r &#39;.Tables[].Rows[].vm_created_at&#39; \r\n\r\nFri Jul 15 17:34:44 UTC 2024\r\nFri Jul 17 17:34:44 UTC 2024\r\n```\r\n\r\nCommand to find VMS recreated before an already captured epoch timestamp\r\n\r\n```console\r\n$ bosh is --vitals --json | jq -r \\\r\n  --arg epoch &quot;Fri Jul 16 17:34:44 UTC 2024&quot; &#39;\r\n    def convert_time($str): $str|strptime(&quot;%a %b %d %T UTC %Y&quot;)|mktime; \r\n    .Tables[].Rows[] \r\n    | select(convert_time(.vm_created_at) &lt; convert_time($epoch)).instance_name\r\n  &#39;\r\n\r\nBox 1\r\n```\r\n\r\n---\r\n\r\nI&#39;m assuming the output for `bosh is --vitals --json` is similar to:\r\n\r\n```json\r\n{                                        \r\n  &quot;Tables&quot;: [                                                        \r\n    {&quot;Rows&quot;: [{ &quot;vm_created_at&quot;: &quot;Fri Jul 15 17:34:44 UTC 2024&quot;, &quot;instance_name&quot;: &quot;Box 1&quot; }]},\r\n    {&quot;Rows&quot;: [{ &quot;vm_created_at&quot;: &quot;Fri Jul 17 17:34:44 UTC 2024&quot;, &quot;instance_name&quot;: &quot;Box 2&quot; }]}\r\n  ]        \r\n}\r\n```",
                "title": "Convert human readable time to epoch inline with jq for time comparison"
            }
        ],
        "is_answered": false,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1721679483,
        "creation_date": 1721396770,
        "last_edit_date": 1721461643,
        "question_id": 78769725,
        "body_markdown": "I am writing a bash script to compare VM creation date to an epoch time gathered in a previous step to see what VMs were recreated before a certain date. These are bosh vms which gives human readable time. Example: Fri Jul 16 17:34:44 UTC 2024\r\n\r\nTo get a list of vm creation dates, my bosh command looks like this:\r\n\r\n    bosh is --vitals --json | jq -r &#39;.Tables[].Rows[].vm_created_at&#39;\r\n    \r\nWhat I need is something like this:\r\n\r\n    bosh is --vitals --json | jq -r &#39;.Tables[].Rows[] | select( .vm_created_at(somehow convert to epoch) &lt; $epoch_from_previous_step).instance_name&#39;\r\n\r\nI&#39;m not sure if that is doable in that command. Or do I have to pull each one out and convert...tough to wrap my head around it.  There&#39;s anywhere from 75 to 450 VMs in the foundations I am running this against, and I need to find the VMs recreated before an already captured epoch time stamp. Thanks!\r\n\r\n",
        "link": "https://stackoverflow.com/questions/78769725/convert-human-readable-time-to-epoch-inline-with-jq-for-time-comparison",
        "title": "Convert human readable time to epoch inline with jq for time comparison"
    },
    {
        "tags": [
            "json",
            "select",
            "jq",
            "contains",
            "del"
        ],
        "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": 1721638426,
                "post_id": 78777302,
                "comment_id": 138892749,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1721638608,
                "creation_date": 1721638608,
                "answer_id": 78777773,
                "question_id": 78777302,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "&gt; I just want to remove those values from list. And if images list is empty (same will apply to initImages) then I want to remove whole object from output.\r\n\r\nFor the `select` condition inside `del`, use `any` on all items instead of separate disjunctions with `or`. To delete the entire object in case of an empty array, a simple `select` will suffice, which defines what to keep. Here, I&#39;ve also included `any` as you probably want to keep objects if either one of the arrays in `images` and `initImages` is non-empty (i.e. only delete if both are empty).\r\n\r\nNote that all items in your sample input unfortunately do contain either `&quot;istio&quot;` or `&quot;azurecr.io&quot;`, so eventually both objects will be removed. If you update your sample data to better exemplify the different cases, I&#39;ll also adapt this response to it.\r\n\r\n```sh\r\n[&quot;istio&quot;, &quot;registry.k8s&quot;, &quot;mcr.microsoft.com&quot;, &quot;azurecr.io&quot;] as $excludedImages\r\n| del(.images[], .initImages[] | select(any(.; contains($excludedImages[]))))\r\n| select(any(.images, .initImages; . != []))\r\n```\r\n[Demo](https://jqplay.org/s/sV_ovV2-ChloIm9)",
                "title": "jq filter to remove field value if contains element from list"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1721638608,
        "creation_date": 1721631489,
        "question_id": 78777302,
        "body_markdown": "This is somewhat similar to this: https://stackoverflow.com/questions/26701538/jq-how-to-filter-an-array-of-objects-based-on-values-in-an-inner-array but extended\r\n\r\nI have a list of values I want to filter out but it is not 1:1 match. It&#39;s contained match.\r\n\r\n\r\nHaving such input (from file or from pipe):\r\n```\r\n{\r\n  &quot;namespace&quot;: &quot;namespace1&quot;,\r\n  &quot;name&quot;: &quot;some-pod1&quot;,\r\n  &quot;images&quot;: [\r\n    &quot;acr1.azurecr.io/some_project/some_project_image@sha256:xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx&quot;,\r\n    &quot;docker.io/istio/proxyv2@sha256:57621adeb78e67c52e34ec1676d1ae898b252134838d60298c7446d0964551cc&quot;\r\n  ],\r\n  &quot;initImages&quot;: [\r\n    &quot;docker.io/istio/proxyv2@sha256:57621adeb78e67c52e34ec1676d1ae898b252134838d60298c7446d0964551cc&quot;\r\n  ]\r\n}\r\n{\r\n  &quot;namespace&quot;: &quot;namespace1&quot;,\r\n  &quot;name&quot;: &quot;some-pod2&quot;,\r\n  &quot;images&quot;: [\r\n    &quot;acr1.azurecr.io/some_project/some_project_image@sha256:xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx&quot;,\r\n    &quot;docker.io/istio/proxyv2@sha256:57621adeb78e67c52e34ec1676d1ae898b252134838d60298c7446d0964551cc&quot;\r\n  ],\r\n  &quot;initImages&quot;: [\r\n    &quot;docker.io/istio/proxyv2@sha256:57621adeb78e67c52e34ec1676d1ae898b252134838d60298c7446d0964551cc&quot;\r\n  ]\r\n}\r\n```\r\nand such query\r\n```\r\njq -r &#39;.[] as $pods | [&quot;kube-system&quot;, &quot;kube-public&quot;, &quot;gatekeeper-system&quot;, &quot;istio-system&quot;, &quot;istio-operator&quot;] as $excludedNamespaces | [&quot;istio&quot;, &quot;registry.k8s&quot;, &quot;mcr.microsoft.com&quot;, &quot;azurecr.io&quot;] as $excludedImages | $pods | select((.initImages[] | contains(&quot;docker.io&quot;)) or (.images[] | contains(&quot;docker.io&quot;))) | select(.namespace as $in | $excludedNamespaces | index($in) | not) | del(.images | select(contains($excludedImages))) &#39; pods.json\r\n```\r\nI need to do something like:\r\n```\r\ndel(.images | select(contains(&quot;istio&quot;) or select(contains(&quot;registry.k8s&quot;) or ...))\r\n```\r\nSince I have already $excludedImages list I want to process it and if I would require to change it then I can do this in one place. I tried as above by passing whole list to contains fuction but it doesn&#39;t work as expected. I always see &quot;istio&quot; images in the output.\r\n\r\nI just want to remove those values from list. And if images list is empty (same will apply to initImages) then I want to remove whole object from output.\r\n\r\nThe thing is that docker enabled some throttling on the docker hub and I want to find pods which are still not migrated to our own registry rather than docker hub directly. But there are some images which are excluded from throttling like for example istio. It can be pulled directly from docker hub. And that&#39;s the whole idea.\r\n\r\nSo I prepared lists of namespaces to exclude and images to exclude. Namespaces are 1:1 match so there&#39;s no issue but images... they contain those hashes so they will always change and I cannot provide it directly.\r\n\r\nYour help will be pretty much appreciated.",
        "link": "https://stackoverflow.com/questions/78777302/jq-filter-to-remove-field-value-if-contains-element-from-list",
        "title": "jq filter to remove field value if contains element from list"
    },
    {
        "tags": [
            "bash",
            "kubernetes",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 12394743,
                    "reputation": 7421,
                    "user_id": 12607443,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/0a01593ffab5a11f0d29d1ee09120801?s=256&d=identicon&r=PG",
                    "display_name": "Ivan",
                    "link": "https://stackoverflow.com/users/12607443/ivan"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1721714540,
                "post_id": 78781574,
                "comment_id": 138899650,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 13863020,
                    "reputation": 163362,
                    "user_id": 10008173,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/bc86d913c15f3b126673faa654e9668c?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "David Maze",
                    "link": "https://stackoverflow.com/users/10008173/david-maze"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1721731337,
                "post_id": 78781574,
                "comment_id": 138901706,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 26344013,
                    "reputation": 95,
                    "user_id": 20002689,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/bc1d272a2931e224ab72889ec39a4748?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "生きがい",
                    "link": "https://stackoverflow.com/users/20002689/%e7%94%9f%e3%81%8d%e3%81%8c%e3%81%84"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1721733557,
                "post_id": 78781574,
                "comment_id": 138901995,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1721718021,
                "creation_date": 1721718021,
                "answer_id": 78781993,
                "question_id": 78781574,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Try to use kubectl get pod -o json and then with jq filter you can filter the kind of the owner. The response from `kubectl get pod -o json` will be like,\r\n\r\n    {\r\n    &quot;metadata&quot;: {\r\n            &quot;ownerReferences&quot;: [\r\n                {\r\n                    &quot;apiVersion&quot;: &quot;apps/v1&quot;,\r\n                    &quot;blockOwnerDeletion&quot;: true,\r\n                    &quot;controller&quot;: true,\r\n                    &quot;kind&quot;: &quot;StatefulSet&quot;,\r\n                    &quot;name&quot;: &quot;&quot;,\r\n                    &quot;uid&quot;: &quot;&quot;\r\n                }\r\n            ]\r\n        }\r\n    }\r\n\r\nwith JQ,\r\n\r\n`kubectl get pod &lt;podname&gt; -o json | jq &#39;.metadata.ownerReferences[]?.kind&#39;`\r\n\r\nThis will give us the kind whether it&#39;s up by deployment or statefulset or pod, we can check this kind in if block before deleting the pod to ensure as,\r\n\r\n    echo &quot;active pods: ${active_pods_array[@]}&quot;\r\n          for pod in &quot;${active_pods_array[@]}&quot;; do\r\n            \r\n            if [[! kubectl get pod &quot;$pod&quot; -o json | jq &#39;.metadata.ownerReferences[]?.kind&#39; =~ ^(&quot;Statefulset&quot;|&quot;Deployment&quot;)$ ]]; \r\n            then\r\n              kubectl delete pod &quot;$pod&quot;\r\n            fi\r\n          done\r\n\r\nThis is just idea, I&#39;m not sure about the scripting.",
                "title": "Delete Pod without restarting other resources/object"
            },
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1722347846,
                "creation_date": 1722347846,
                "answer_id": 78812141,
                "question_id": 78781574,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Found a way to filter out the ```&quot;null&quot;``` which is needed to be deleted exclusive only for the Pod that have ```&quot;owner_kind&quot;``` using the commands below.\r\n\r\nFix on my script:\r\n```\r\nactive_pods=$(kubectl get pods -o json | jq &#39;.items[] | select( .metadata.ownerReferences[0].kind == null )&#39; | jq &#39;.metadata.name&#39; --raw-output)\r\n```\r\n\r\nTest from my terminal:\r\n```\r\n~ $ kubectl get pods -o json | jq &#39;.items[] | select( .metadata.ownerReferences[0].kind == null )&#39; | jq &#39;.metadata.name&#39; --raw-output\r\nhttp-client-test\r\nmytestcurl\r\n```\r\n\r\nList that show ```&quot;Replicaset&quot;``` and ```&quot;Null&quot;```:\r\n```\r\n~ $ kubectl get pods -o json | jq &#39;.items[] | {name: (.metadata.name), owner_kind: .metadata.ownerReferences[0].kind,}&#39;\r\n{\r\n  &quot;name&quot;: &quot;logging-event-7a8gl478e4-7pms9&quot;,\r\n  &quot;owner_kind&quot;: &quot;ReplicaSet&quot;\r\n}\r\n{\r\n  &quot;name&quot;: &quot;my-workspace-92757a9w8p-ghedk&quot;,\r\n  &quot;owner_kind&quot;: &quot;ReplicaSet&quot;\r\n}\r\n{\r\n  &quot;name&quot;: &quot;my-web-page-347817pt37-7wu1a&quot;,\r\n  &quot;owner_kind&quot;: &quot;ReplicaSet&quot;\r\n}\r\n{\r\n  &quot;name&quot;: &quot;hello-world-8i64337229-4yd37&quot;,\r\n  &quot;owner_kind&quot;: &quot;ReplicaSet&quot;\r\n}\r\n{\r\n  &quot;name&quot;: &quot;http-client-test&quot;,\r\n  &quot;owner_kind&quot;: null\r\n}\r\n{\r\n  &quot;name&quot;: &quot;mysql8demo-7425681afg-krdlh&quot;,\r\n  &quot;owner_kind&quot;: &quot;StatefulSet&quot;\r\n}\r\n{\r\n  &quot;name&quot;: &quot;postgres16demo-4p25jr3g9k-2piex&quot;,\r\n  &quot;owner_kind&quot;: &quot;StatefulSet&quot;\r\n}\r\n{\r\n  &quot;name&quot;: &quot;mytestcurl&quot;,\r\n  &quot;owner_kind&quot;: null\r\n}\r\n{\r\n  &quot;name&quot;: &quot;mytestdemo-9449873a4c-at5kg&quot;,\r\n  &quot;owner_kind&quot;: &quot;ReplicaSet&quot;\r\n}\r\n```",
                "title": "Delete Pod without restarting other resources/object"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1722347846,
        "creation_date": 1721709288,
        "last_edit_date": 1721721013,
        "question_id": 78781574,
        "body_markdown": "I currently have this bash script that do cleanup obsolete resources for deployment, services, and configmaps. when I try to add the ```kubectl delete pod``` on the script, then it will delete all the remaining pods, but the problem is for a certain scenario wherein I will cleanup only the pods that do not have or without the object like the deployment, services, and configmaps it will also restart the pods due to the ```kubectl delete pod``` and I do not want the other pods or resources also to restart but only delete the specific pod that have only an object pod, then for the other pod that have the object of deployment, services, and configmaps should not be restarted.\r\n\r\nHere&#39;s the script:\r\n```\r\n      active_pods=$(kubectl get pods -o jsonpath=&#39;{range .items[*]}{.metadata.name}{&quot;\\n&quot;}{end}&#39;)\r\n      active_deployments=$(kubectl get deployments -o jsonpath=&#39;{range .items[*]}{.metadata.name}{&quot;\\n&quot;}{end}&#39;)\r\n      active_services=$(kubectl get services -o jsonpath=&#39;{range .items[*]}{.metadata.name}{&quot;\\n&quot;}{end}&#39;)\r\n      active_configmaps=$(kubectl get configmap -o jsonpath=&#39;{range .items[*]}{.metadata.name}{&quot;\\n&quot;}{end}&#39;)\r\n\r\n      readarray -t active_pods_array &lt;&lt;&lt;&quot;$active_pods&quot;\r\n      readarray -t active_deployments_array &lt;&lt;&lt;&quot;$active_deployments&quot;\r\n      readarray -t active_services_array &lt;&lt;&lt;&quot;$active_services&quot;\r\n      readarray -t active_configmaps_array &lt;&lt;&lt;&quot;$active_configmaps&quot;\r\n\r\n      echo &quot;active pods: ${active_pods_array[@]}&quot;\r\n      for pod in &quot;${active_pods_array[@]}&quot;; do\r\n        if ! grep -q &quot;pod/${pod} &quot; nonprod.txt &amp;&amp; [[ -n $pod ]] ; then\r\n          kubectl delete pod &quot;$pod&quot;\r\n        fi\r\n      done\r\n\r\n      echo &quot;active deployments: ${active_deployments_array[@]}&quot;\r\n      for deployment in &quot;${active_deployments_array[@]}&quot;; do\r\n        if ! grep -q &quot;deployment.apps/${deployment} &quot; nonprod.txt &amp;&amp; [[ -n $deployment ]] ; then\r\n          kubectl delete deployment &quot;$deployment&quot;\r\n        fi\r\n      done\r\n\r\n      echo &quot;active services: ${active_services_array[@]}&quot;\r\n      for service in &quot;${active_services_array[@]}&quot;; do\r\n        if ! grep -q &quot;service/${service} &quot; nonprod.txt &amp;&amp; [[ -n $service ]] &amp;&amp; [[ $service != &#39;kubernetes&#39; ]] ; then\r\n          kubectl delete service &quot;$service&quot;\r\n        fi\r\n      done\r\n\r\n      echo &quot;active configmap: ${active_configmaps_array[@]}&quot;\r\n      for configmap in &quot;${active_configmaps_array[@]}&quot;; do\r\n        if ! grep -q &quot;configmap/${configmap} &quot; nonprod.txt &amp;&amp; [[ -n $configmap ]] &amp;&amp; [[ ${configmap} != &quot;kube-root-ca.crt&quot; ]] ; then\r\n          kubectl delete configmap &quot;${configmap}&quot;\r\n        fi\r\n      done\r\n\r\n```\r\n\r\n```\r\n~ $ kubectl get pods\r\nNAME                                        READY   STATUS    RESTARTS      AGE\r\nlogging-event-7a8gl478e4-7pms9              1/1     Running   0             22m\r\nmy-workspace-92757a9w8p-ghedk               1/1     Running   0             25m\r\nmy-web-page-347817pt37-7wu1a                1/1     Running   0             21m\r\nhello-world-8i64337229-4yd37                1/1     Running   0             21m\r\nhttp-client-test                            1/1     Running   0             21m\r\nmysql8demo-7425681afg-krdlh                 1/1     Running   0             22m\r\npostgres16demo-4p25jr3g9k-2piex             1/1     Running   0             21m\r\nmytestcurl                                  1/1     Running   0             21m\r\nmytestdemo-9449873a4c-at5kg                 1/1     Running   0             22m\r\n```\r\n\r\n```\r\n~ $ kubectl get deployment\r\nNAME                       READY   UP-TO-DATE   AVAILABLE   AGE\r\nlogging-event              1/1     1            1           22m\r\nmy-workspace               1/1     1            1           25m\r\nmy-web-page                1/1     1            1           21m\r\nhello-world                1/1     1            1           21m\r\nmysql8demo                 1/1     1            1           22m\r\npostgres16demo             1/1     1            1           21m\r\nmytestdemo                 1/1     1            1           22m\r\n```\r\n\r\n```\r\n~ $ kubectl get service\r\nNAME                       TYPE        CLUSTER-IP     EXTERNAL-IP   PORT(S)    AGE\r\nlogging-event              ClusterIP   ##########     &lt;none&gt;        8080/TCP   22m\r\nmy-web-page                ClusterIP   ##########     &lt;none&gt;        80/TCP     21m\r\nhello-world                ClusterIP   ##########     &lt;none&gt;        80/TCP     21m\r\nkubernetes                 ClusterIP   ##########     &lt;none&gt;        443/TCP    31m\r\nmysql8demo                 ClusterIP   ##########     &lt;none&gt;        1433/TCP   22m\r\npostgres16demo             ClusterIP   ##########     &lt;none&gt;        5432/TCP   21m\r\nmytestdemo                 ClusterIP   ##########     &lt;none&gt;        8080/TCP   22m\r\n```\r\n\r\n```\r\n~ $ kubectl get configmap\r\nNAME                                                         DATA   AGE\r\nlogging-event                                                1      22m\r\nmy-workspace-scripts                                         1      26m\r\nhello-world-html                                             1      21m\r\nkube-root-ca.crt                                             1      31m\r\nmysql8demo-hook                                              1      22m\r\nmysql8demo-part-66772g4g2ba1fdd37d7273f2gs64b4a8-aa-cm       1      22m\r\npostgres16demo-hook                                          1      22m\r\npostgres16demo-part-9r54446g81dbr16836g4214g85189139-aa-cm   1      22m\r\nmytestdemo-mappings                                          3      22m\r\n```\r\n",
        "link": "https://stackoverflow.com/questions/78781574/delete-pod-without-restarting-other-resources-object",
        "title": "Delete Pod without restarting other resources/object"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1721833608,
                "last_edit_date": 1721833608,
                "creation_date": 1721808697,
                "answer_id": 78787096,
                "question_id": 78786855,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You&#39;re looking for something like this:\r\n``` none\r\n&quot;(?&lt;prefix&gt;.*)\\\\.(?&lt;order&gt;\\\\d+)$&quot; as $pat\r\n| to_entries\r\n| (map(select(.key | test($pat) | not)) | from_entries)\r\n+ (map({value} + (.key | capture($pat)))\r\n  | group_by(.prefix)\r\n  | map(sort_by(.order | tonumber) | {(.[0].prefix): map(.value) | add})\r\n  | add)",
                "title": "Using jq to group-concat fields by field name prefix"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1721809648,
                "last_edit_date": 1721809648,
                "creation_date": 1721808707,
                "answer_id": 78787097,
                "question_id": 78786855,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can slice by the position of the last dot `rindex(&quot;.&quot;)` to find the future key and the number parts, then `reduce` by the groups to iteratively construct the result object. The values can be constructed by sorting the number part converted `tonumber`.\r\n\r\n```sh\r\nreduce (to_entries | group_by(.key | .[:rindex(&quot;.&quot;)])[]) as $g ({};\r\n  ($g[0].key | rindex(&quot;.&quot;)) as $p | .[$g[0].key[:$p]] = if $p\r\n    then $g | sort_by(.key |= (.[$p+1:] | tonumber)) | map(.value) | add\r\n    else $g[0].value end\r\n)\r\n```\r\n```json\r\n{\r\n  &quot;a&quot;: &quot;...field_a...&quot;,\r\n  &quot;aa&quot;: &quot;first second.&quot;,\r\n  &quot;b&quot;: &quot;...field_b...&quot;,\r\n  &quot;bla.bla&quot;: &quot;aabb&quot;,\r\n  &quot;c&quot;: &quot;...field_c...&quot;\r\n}\r\n```\r\n[Demo](https://jqplay.org/s/0gmTfiAkVqfWJNT)",
                "title": "Using jq to group-concat fields by field name prefix"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1721833608,
        "creation_date": 1721805403,
        "last_edit_date": 1721809746,
        "question_id": 78786855,
        "body_markdown": "I have a json file like this, I woiuld like to have a `jq` based solution to transform this:\r\n\r\n```json\r\n{\r\n   ... fields1 ...\r\n   &quot;any&quot;: [], &quot;other&quot;: 1,\r\n   &quot;aa.2&quot;: &quot;second.&quot;, &quot;aa.1&quot;: &quot;first &quot;,\r\n   ... fields2 ...\r\n   &quot;bla.bla.0&quot;: &quot;aa&quot;, &quot;bla.bla.2&quot;: &quot;bb&quot;,\r\n   ... fields3 ...\r\n}\r\n```\r\n\r\nI want an output grouped by prefix before &quot;.\\&lt;number\\&gt;&quot; concatenated as string (values for those can be assumed to be strings). The order of the fields with &quot;.\\&lt;number\\&gt;&quot; ending is not necessarily ordered.\r\nfields1,2,3 are other fields need to be kept (the order of the fields in the output object do not have to be kept)\r\nThe fields with &quot;.\\&lt;number\\&gt;&quot; ending must be removed in the output, only the concatenated final value is to be kept.\r\n\r\n```\r\n{\r\n   ... fields1 ...\r\n   &quot;any&quot;: [], &quot;other&quot;: 1,\r\n   &quot;aa&quot;: &quot;first second.&quot;,\r\n   ... fields2 ...\r\n   &quot;bla.bla&quot;: &quot;aabb&quot;,\r\n   ... fields3 ...\r\n}\r\n```\r\n\r\nI tried to find a solution using the manual but I did not succeed.",
        "link": "https://stackoverflow.com/questions/78786855/using-jq-to-group-concat-fields-by-field-name-prefix",
        "title": "Using jq to group-concat fields by field name prefix"
    },
    {
        "tags": [
            "json",
            "jq",
            "variable-assignment"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1721851901,
                "last_edit_date": 1721851901,
                "creation_date": 1721851555,
                "answer_id": 78790363,
                "question_id": 78790080,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The left hand side of the equals sign must be a value in `.`. Make `$o` `.` and then do the assignment like so:\r\n``` none\r\n$o | .[$key] = 42\r\n```",
                "title": "jq: assigning to computed property of an object"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1721851858,
                "creation_date": 1721851858,
                "answer_id": 78790385,
                "question_id": 78790080,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If you want to change the context, first evaluate the variable into it, then update the context:\r\n```sh\r\njq -n --arg key foo &#39;{} as $o | $o | .[$key] = 42&#39;\r\n```\r\n[Demo](https://jqplay.org/s/cB0ocG3iGVGHg9f)\r\n\r\nIf you want to update the contents of a variable based on its old value, shadow it with a new one of the same name using the old one&#39;s reference in its body:\r\n```sh\r\njq -n --arg key foo &#39;{} as $o | ($o | .[$key] = 42) as $o | …&#39;\r\n```\r\n[Demo](https://jqplay.org/s/dskFJG3E0lGcpSS)\r\n\r\nNote: for the latter one, `…` cannot be empty.",
                "title": "jq: assigning to computed property of an object"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1721853539,
                "creation_date": 1721853539,
                "answer_id": 78790491,
                "question_id": 78790080,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Variables in jq are immutable, which is why your first two statments give errors.\r\n\r\nThe third statement succeeds because what changed is the current value of the pipe, not `$o`, you can see it with :\r\n\r\n```\r\n$ jq -n --arg key foo &#39;{} as $o | ($o | setpath([$key]; 42)) | $o, .&#39;\r\n{}\r\n{\r\n  &quot;foo&quot;: 42\r\n}\r\n```\r\n\r\nYou can simulate mutable variables with :\r\n\r\n```\r\n$ jq -n --arg key foo &#39;.o = {} | .o[$key] = 42 | .o&#39;\r\n{\r\n  &quot;foo&quot;: 42\r\n}\r\n```",
                "title": "jq: assigning to computed property of an object"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 1,
        "last_activity_date": 1721875436,
        "creation_date": 1721846991,
        "last_edit_date": 1721875436,
        "question_id": 78790080,
        "body_markdown": "I&#39;m trying to get `jq` to generate an object whose keys are computed.\r\n\r\nThis didn&#39;t work:\r\n\r\n\r\n```\r\n$ jq -n --arg key foo &#39;{} as $o | $o[$key] = 42&#39;\r\njq: error (at &lt;unknown&gt;): Invalid path expression near attempt to access element &quot;foo&quot; of {}\r\n```\r\n\r\nThis didn&#39;t, either:\r\n\r\n\r\n```\r\n$ jq -n --arg key foo &#39;{} as $o | ($o | .[$key]) = 42&#39;\r\njq: error (at &lt;unknown&gt;): Invalid path expression near attempt to access element &quot;foo&quot; of {}\r\n```\r\n\r\nBut this worked:\r\n\r\n```\r\n$ jq -n --arg key foo &#39;{} as $o | ($o | setpath([$key]; 42))&#39;\r\n{\r\n  &quot;foo&quot;: 42\r\n}\r\n```\r\n\r\nSo, my question is, is there an assignment syntax that can produce the same effect?\r\n",
        "link": "https://stackoverflow.com/questions/78790080/jq-assigning-to-computed-property-of-an-object",
        "title": "jq: assigning to computed property of an object"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 6014861,
                    "reputation": 20007,
                    "user_id": 7939871,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/1199ba5dde05e4083823a058c5ac6bed?s=256&d=identicon&r=PG",
                    "display_name": "L&#233;a Gris",
                    "link": "https://stackoverflow.com/users/7939871/l%c3%a9a-gris"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1721985456,
                "post_id": 78797043,
                "comment_id": 138926283,
                "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": 4,
                "creation_date": 1721986332,
                "post_id": 78797043,
                "comment_id": 138926395,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1938048,
                    "reputation": 207858,
                    "user_id": 1745001,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/99a3ebae89496eb16afe453aae97f5be?s=256&d=identicon&r=PG",
                    "display_name": "Ed Morton",
                    "link": "https://stackoverflow.com/users/1745001/ed-morton"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1721993477,
                "post_id": 78797043,
                "comment_id": 138927168,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 6014861,
                    "reputation": 20007,
                    "user_id": 7939871,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/1199ba5dde05e4083823a058c5ac6bed?s=256&d=identicon&r=PG",
                    "display_name": "L&#233;a Gris",
                    "link": "https://stackoverflow.com/users/7939871/l%c3%a9a-gris"
                },
                "reply_to_user": {
                    "account_id": 1938048,
                    "reputation": 207858,
                    "user_id": 1745001,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/99a3ebae89496eb16afe453aae97f5be?s=256&d=identicon&r=PG",
                    "display_name": "Ed Morton",
                    "link": "https://stackoverflow.com/users/1745001/ed-morton"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1721996864,
                "post_id": 78797043,
                "comment_id": 138927528,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1938048,
                    "reputation": 207858,
                    "user_id": 1745001,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/99a3ebae89496eb16afe453aae97f5be?s=256&d=identicon&r=PG",
                    "display_name": "Ed Morton",
                    "link": "https://stackoverflow.com/users/1745001/ed-morton"
                },
                "reply_to_user": {
                    "account_id": 6014861,
                    "reputation": 20007,
                    "user_id": 7939871,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/1199ba5dde05e4083823a058c5ac6bed?s=256&d=identicon&r=PG",
                    "display_name": "L&#233;a Gris",
                    "link": "https://stackoverflow.com/users/7939871/l%c3%a9a-gris"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1721997351,
                "post_id": 78797043,
                "comment_id": 138927572,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1938048,
                    "reputation": 207858,
                    "user_id": 1745001,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/99a3ebae89496eb16afe453aae97f5be?s=256&d=identicon&r=PG",
                    "display_name": "Ed Morton",
                    "link": "https://stackoverflow.com/users/1745001/ed-morton"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1721997530,
                "post_id": 78797043,
                "comment_id": 138927596,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "reply_to_user": {
                    "account_id": 6014861,
                    "reputation": 20007,
                    "user_id": 7939871,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/1199ba5dde05e4083823a058c5ac6bed?s=256&d=identicon&r=PG",
                    "display_name": "L&#233;a Gris",
                    "link": "https://stackoverflow.com/users/7939871/l%c3%a9a-gris"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1722025618,
                "post_id": 78797043,
                "comment_id": 138930781,
                "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": 1722026380,
                "post_id": 78797043,
                "comment_id": 138930837,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1722025436,
                "creation_date": 1722025436,
                "answer_id": 78799791,
                "question_id": 78797043,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "&gt; .nodes[$count] += {&quot;mac&quot;: $mac}&lt;p&gt;\r\n&gt; But in this variant adding list items doesn&#39;t work.\r\n\r\nThat&#39;s because when you use += for arrays, the RHS must be an array, like so:\r\n```\r\n .nodes[$count] += [{&quot;mac&quot;: $mac}]\r\n\r\n```\r\n\r\nBy the way, I suspect you could greatly simplify things by using jq to do all (or at least nearly all) the required manipulations, thus avoiding the bash/awk/grep messiness.",
                "title": "Сreating multilevel json with the jq utility in a bash script"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1722252641,
                "last_edit_date": 1722252641,
                "creation_date": 1722244988,
                "answer_id": 78806276,
                "question_id": 78797043,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "It was interesting to deep dive into _jq_ scripting, and here it is.\r\n\r\n\r\nThere is no clue as to what the input is and what the desired output is, so here are my assumptions:\r\n* Input data is lines starting with Unix timestamps or starting with `Station ` (nodes), and other ignored lines. \\\r\n  Simple input generator:\r\n  ```bash\r\n  for _i in {0..10}; do\r\n    case $_i in\r\n    1 | 7 | 8)\r\n      echo &quot;$(date +%s -d &quot;now - $((10 - $_i)) days&quot;) rest..&quot;;;\r\n    4)\r\n      echo &quot;other log line&quot;;;\r\n    *)\r\n      printf &quot;Station 14:88:00:00:00:%02X some   iface%d.12x rest...\\n&quot; &quot;$_i&quot; &quot;$_i&quot;;;\r\n    esac;\r\n  done &gt;./station.sample\r\n  ```\r\n* Output is a grouping of _stations/nodes_ (_&quot;mac&quot;_ and _&quot;iface&quot;_) by unix timestamps. \\\r\n  The result for test input above:\r\n  ```json\r\n  [\r\n    {\r\n      &quot;nodes&quot;: [\r\n        {&quot;mac&quot;: &quot;14:88:00:00:00:00&quot;, &quot;interface&quot;: &quot;iface0.12&quot;}\r\n      ]\r\n    }, {\r\n      &quot;timestamp&quot;: 1721465934, &quot;datetime&quot;: &quot;2024-07-20 08:58:54&quot;,\r\n      &quot;nodes&quot;: [\r\n        {&quot;mac&quot;: &quot;14:88:00:00:00:02&quot;, &quot;interface&quot;: &quot;iface2.12&quot;},\r\n        {&quot;mac&quot;: &quot;14:88:00:00:00:03&quot;, &quot;interface&quot;: &quot;iface3.12&quot;},\r\n        {&quot;mac&quot;: &quot;14:88:00:00:00:05&quot;, &quot;interface&quot;: &quot;iface5.12&quot;},\r\n        {&quot;mac&quot;: &quot;14:88:00:00:00:06&quot;, &quot;interface&quot;: &quot;iface6.12&quot;}\r\n      ]\r\n    }, {\r\n      &quot;timestamp&quot;: 1721984334, &quot;datetime&quot;: &quot;2024-07-26 08:58:54&quot;,\r\n      &quot;nodes&quot;: []\r\n    }, {\r\n      &quot;timestamp&quot;: 1722070734, &quot;datetime&quot;: &quot;2024-07-27 08:58:54&quot;,\r\n      &quot;nodes&quot;: [\r\n        {&quot;mac&quot;: &quot;14:88:00:00:00:09&quot;, &quot;interface&quot;: &quot;iface9.12&quot;},\r\n        {&quot;mac&quot;: &quot;14:88:00:00:00:0A&quot;, &quot;interface&quot;: &quot;iface10.12&quot;}\r\n      ]\r\n    }\r\n  ]\r\n  ```\r\n\r\nHere is **jq** filter, save this into `filter.jq`:\r\n```jq\r\n[\r\n  inputs |                     # read input file line by line without parsing, this requere -Rn flags\r\n  if test(&quot;^\\\\d{10}&quot;) then     # parse line with unix timestamps\r\n    .[0:10] | tonumber | {\r\n      timestamp: .,\r\n      # NOTE: there is a bug in &#39;strflocaltime()&#39; with &#39;%z&#39; formatter, use &#39;%Z&#39; instead, see https://github.com/jqlang/jq/issues/2429\r\n      datetime: strflocaltime(&quot;%Y-%m-%d %H:%M:%S&quot;),\r\n    }\r\n  elif test(&quot;^Station &quot;) then  # parse line with &quot;station&quot;\r\n    [splits(&quot;\\\\s+&quot;)] | {\r\n      mac: .[1],\r\n      interface: .[3][:-1],    # trim last character\r\n    }\r\n  else                         # other lines, skip them\r\n    empty\r\n  end\r\n] + [{timestamp: null}] |      # append empty object for complete last group in the following &#39;foreach&#39;\r\n[\r\n  foreach .[] as $_o (         # groupping timestamps and stations/nodes\r\n    [[], []];\r\n    if $_o | has(&quot;timestamp&quot;) then [[$_o], .[0]] else [(.[0] + [$_o]), []] end;\r\n    if ($_o | has(&quot;timestamp&quot;)) and (.[1] | length) &gt; 0 then\r\n      if .[1][0] | has(&quot;timestamp&quot;) then\r\n        .[1][0] + {nodes: .[1][1:]}\r\n      else\r\n        {nodes: .[1]}          # case without Unix timestamp (file beginning)\r\n      end\r\n    else\r\n      empty\r\n    end\r\n  )\r\n]\r\n```\r\nThis filter should be run with the `-Rn` flags, e.g.:\r\n```bash\r\njq -Rn -f ./filter.jq &lt;./station.sample\r\n```",
                "title": "Сreating multilevel json with the jq utility in a bash script"
            }
        ],
        "is_answered": false,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1722252641,
        "creation_date": 1721982923,
        "question_id": 78797043,
        "body_markdown": "I get the contents of a text file into an array and then sequentially get the elements of the array and try to add the elements to the json:\r\n\r\n```\r\n#!/bin/bash\r\n\r\nJSON=$(jq -n &#39;&#39;)\r\nreadarray -t array &lt; ./station.sample\r\ncount=0\r\n\r\nfor e in &quot;${array[@]}&quot;\r\ndo\r\n    if echo &quot;$e&quot; | grep -Eq &#39;^[0-9]{10}&#39; &gt;/dev/null\r\n      then\r\n        timestamp=$e\r\n        datetime=`date +&#39;%Y-%m-%d %H:%M:%S&#39; -d &quot;@$e&quot;`\r\n        JSON=$(echo $JSON | jq --arg timestamp &quot;${timestamp}&quot; &#39;. += $ARGS.named&#39;)\r\n        JSON=$(echo $JSON | jq --arg datetime &quot;${datetime}&quot; &#39;. += $ARGS.named&#39;)\r\n    fi\r\n\r\n    if echo &quot;$e&quot; | grep &#39;^Station &#39; &gt;/dev/null\r\n      then\r\n        NODE=$(jq -n &#39;&#39;)\r\n        mac=`echo &quot;$e&quot; | awk &#39;{ print $2 }&#39;`\r\n        interface=`echo &quot;$e&quot; | awk &#39;{ print $4 }&#39; | rev | cut -c2- | rev`\r\n\r\n        JSON=$(echo $JSON | jq --argjson nodes &quot;[]&quot; &#39;. += $ARGS.named&#39;)\r\n        JSON=$(echo $JSON | jq --arg mac &quot;${mac}&quot; --arg count &quot;${count}&quot; &#39;.nodes[0] += {&quot;mac&quot;: $mac}&#39;)\r\n\tJSON=$(echo $JSON | jq --arg interface &quot;${interface}&quot; &#39;.nodes[0] += {&quot;interface&quot;: $interface}&#39;)\r\n\r\n        count=$((count+1))\r\n    fi\r\ndone\r\n```\r\nAs a result, I get a json like this:\r\n```\r\n{\r\n  &quot;timestamp&quot;: &quot;1721396365&quot;,\r\n  &quot;datetime&quot;: &quot;2024-07-19 16:39:25&quot;,\r\n  &quot;nodes&quot;: [\r\n    {\r\n      &quot;mac&quot;: &quot;14:88:00:00:00:06&quot;\r\n    }\r\n  ]\r\n}\r\n```\r\nBut I need to add multiple objects to the list, so I set a count variable and want to use it to specify the index of the list:\r\n```\r\nJSON=$(echo $JSON | jq --arg mac &quot;${mac}&quot; --arg count &quot;${count}&quot; &#39;.nodes[$count] += {&quot;mac&quot;: $mac}&#39;)\r\n```\r\n\r\nBut in this variant adding list items doesn&#39;t work.\r\n\r\nHow can I dynamically specify the index of the list?\r\n\r\nI&#39;ve tried all the options that came to mind, but I haven&#39;t found a solution yet:\r\n```\r\n NODE=$(echo $NODE | jq --arg mac &quot;$mac&quot; &#39;. += $ARGS.named&#39;)\r\n NODE=$(echo $NODE | jq --arg interface &quot;${interface}&quot; &#39;. += $ARGS.named&#39;)\r\n JSON=$(echo $JSON | jq --argjson node &quot;${NODE}&quot; &#39;.nodes[.nodes | length] = $ARGS.named&#39;)\r\n```\r\nIt is necessary to use a variable to specify the index of the list.",
        "link": "https://stackoverflow.com/questions/78797043/%d0%a1reating-multilevel-json-with-the-jq-utility-in-a-bash-script",
        "title": "Сreating multilevel json with the jq utility in a bash script"
    },
    {
        "tags": [
            "json",
            "sorting",
            "google-chrome",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 5402400,
                    "reputation": 13,
                    "user_id": 4301884,
                    "user_type": "registered",
                    "profile_image": "https://lh6.googleusercontent.com/-edjI9B6KT_o/AAAAAAAAAAI/AAAAAAAAAEY/QfjTwW5VcLk/s256-rj/photo.jpg",
                    "display_name": "Philip Rhoades P",
                    "link": "https://stackoverflow.com/users/4301884/philip-rhoades-p"
                },
                "reply_to_user": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1722194001,
                "post_id": 78803512,
                "comment_id": 138939074,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1722163640,
                "last_edit_date": 1722163640,
                "creation_date": 1722163338,
                "answer_id": 78803541,
                "question_id": 78803512,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You&#39;re looking for something like this:\r\n``` sh\r\njq --arg window &#39;OpenAI&#39; &#39;(.tree[] | select(.raw_title == $window)) .tabs |= sort_by(.raw_url)&#39;\r\n```",
                "title": "Output from Chrome Window / Tab Manager extension: Selecting a Window and sorting its Tabs with jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1722219481,
        "creation_date": 1722162327,
        "last_edit_date": 1722219481,
        "question_id": 78803512,
        "body_markdown": "People,\r\n\r\nHere is the head of an exported file:\r\n\r\n```\r\n{\r\n  &quot;tabfern&quot;: 42,\r\n  &quot;version&quot;: 1,\r\n  &quot;tree&quot;: [\r\n    {\r\n      &quot;raw_title&quot;: &quot;OpenAI&quot;,\r\n      &quot;tabs&quot;: [\r\n        {\r\n          &quot;raw_title&quot;: &quot;OpenAI&quot;,\r\n          &quot;raw_url&quot;: &quot;https://openai.com/&quot;,\r\n          &quot;raw_favicon_url&quot;: &quot;https://openai.com/favicon.ico&quot;\r\n        },\r\n        {\r\n          &quot;raw_title&quot;: &quot;Quickstart tutorial - OpenAI API&quot;,\r\n          &quot;raw_url&quot;: &quot;https://platform.openai.com/docs/quickstart&quot;,\r\n          &quot;raw_favicon_url&quot;: &quot;https://platform.openai.com/favicon.svg&quot;\r\n        },\r\netc . . \r\n\r\n```\r\nand I want to use jq to select a particular window and sort the tabs within that window on the raw_url.\r\n\r\nI have found if I use the &quot;-S&quot; switch I can sort the 3 lines within each Tab for ALL the tabs but I haven&#39;t found an example anywhere about how to choose a specific window and sort its tabs.\r\n\r\nThis exercise will only be necessary very infrequently for the case where the number of tabs has grown too large and trying to sort the tabs within the extension kills the browser . .\r\n\r\nAny pointers appreciated!\r\n\r\nThanks,\r\nPhil.\r\n",
        "link": "https://stackoverflow.com/questions/78803512/output-from-chrome-window-tab-manager-extension-selecting-a-window-and-sortin",
        "title": "Output from Chrome Window / Tab Manager extension: Selecting a Window and sorting its Tabs with jq?"
    },
    {
        "tags": [
            "json",
            "jq",
            "ndjson"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1722266439,
                "last_edit_date": 1722266439,
                "creation_date": 1722251559,
                "answer_id": 78806749,
                "question_id": 78806477,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You were very close. Try:\r\n``` sh\r\njq -Rrc &#39;. as $line | try fromjson catch ($line + &quot;\\n&quot; | stderr | empty)&#39; input.log &gt;good.jsonl 2&gt;bad.txt\r\n```",
                "title": "Split valid and invalid JSONL records into two files using JQ"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1722928635,
        "creation_date": 1722247749,
        "last_edit_date": 1722928635,
        "question_id": 78806477,
        "body_markdown": "I frequently receive application logs from journald. The application itself logs with jsonlines, but sometimes I got invalid lines, if...:\r\n* something is written to stderr like `Listening for transport dt_socket at address: 5045` or something like `JProfiler &gt; ...`.  \r\n* systemd adds some logs itself like `Started my.service - Service Description`.\r\n* my log lines exceed the maximum journald line length, they are split up into multiple lines. \r\n\r\nLong story short, I want to do some preprocessing of the shared log files where in a first step I only keep valid jsonlines and put all other lines into a dedicated second file for later review and processing.\r\n\r\nMy first attempt was to pipe the logfile through a bash script with running `jq -e . &gt;/dev/null 2&gt;&amp;1 &lt;&lt;&lt; &quot;$1&quot;` on each line. That turned out to be way too slow as my log files usually are about 2GB in size. So I would like to have a solution where I call `jq` only once and let it process all the loglines which would be way faster than calling `jq` once for each line. \r\n\r\nI found the `try catch` syntax from `jq` but I don&#39;t get a fully working solution with regards to the file containing the non jsonlines messages. Here are my best attempts so far:\r\n\r\n```bash\r\ncat input.log | jq -c -r -R &#39;. as $line | try fromjson catch &quot;\\($line)\\n&quot; | stderr&#39; &gt; good.jsonl 2&gt; bad.txt\r\n```\r\n\r\nThis nicely keeps only good jsonlines, but it is horribly slow. Further,the &quot;bad.txt&quot; is all in one line and literally prints &quot;\\n&quot; as 2-char-string instead of newline character. Don&#39;t know why.\r\n\r\nI tried another formatting of that output string like so:\r\n```bash\r\ncat input.log | jq -c -r -R &#39;. as $line | try fromjson catch ($line+=&quot;\\n&quot; | $line | stderr) &#39; &gt; good.jsonl 2&gt; bad.txt\r\n```\r\n\r\nThat runs much faster and produces proper jsonl good.jsonl but results in an unusable bad.txt like:\r\n```\r\njq: error (at &lt;stdin&gt;:18126): Invalid path expression with result &quot;Started my.service ...\r\n```\r\nwhere it literally prints only the first few characters of my broken message and not the entire line, hence I can&#39;t reconstruct it. \r\n\r\nThe best solution I found so far is:\r\n```bash\r\ncat input.log | jq -c -r -R &#39;. as $line | if (fromjson) then . else $line | stderr end&#39; &gt; good.jsonl 2&gt; bad.txt\r\n```\r\nThis leaves my `good.json` with the JSONL as expected and produces a &quot;bad.txt&quot; like:\r\n```\r\njq: error (at &lt;stdin&gt;:18126): Invalid numeric literal at line 1, column 8 (while parsing &#39;Started my.service - Service Description.&#39;)\r\njq: error (at &lt;stdin&gt;:18127): Invalid numeric literal at line 1, column 10 (while parsing &#39;Listening for transport dt_socket at address: 5045&#39;)\r\n```\r\n\r\nIf I find no better solution, I&#39;ll go for the last one and post-edit the jq error message with some regex or similar to only keep the original line without the error details, but I wonder if I can somehow simply tell jq to directly output my original line without the error details? For me it looks like the `catch` clause has some issues with the jq string formatting options.. \r\n\r\nFYI: I am currently using jq 1.6 (installed on Ubuntu 22.04)\r\n\r\nHere is a short example input.log\r\n```\r\n{&quot;@timestamp&quot;:&quot;2024-07-26T11:00:01.843+02:00&quot;,&quot;message&quot;:&quot;Hello&quot;}\r\nStarted my.service - Service Description\r\nListening for transport dt_socket at address: 5045\r\n{&quot;@timestamp&quot;:&quot;2024-07-26T11:10:02.356+02:00&quot;,&quot;message&quot;:&quot;World&quot;}\r\n```",
        "link": "https://stackoverflow.com/questions/78806477/split-valid-and-invalid-jsonl-records-into-two-files-using-jq",
        "title": "Split valid and invalid JSONL records into two files using JQ"
    },
    {
        "tags": [
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1722273799,
                "post_id": 78808305,
                "comment_id": 138945410,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1733816487,
                "last_edit_date": 1733816487,
                "creation_date": 1733067363,
                "answer_id": 79241921,
                "question_id": 78808305,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Based on the fact that you have used the Russian letter &quot;и&quot;, it seems that you have two separate codes. Therefore, I have attempted to reproduce your issue in this way.\r\n```\r\necho &#39;{\r\n  &quot;interfaces&quot;:{\r\n    &quot;m-11s-0&quot;: {\r\n      &quot;peers&quot;: {\r\n        &quot;14:88:00:00:00:13&quot;:{\r\n          &quot;next_hop&quot;:&quot;14:88:00:00:00:85&quot;,\r\n          &quot;hop_count&quot;:&quot;3&quot;,\r\n          &quot;path_change_count&quot;:&quot;43&quot;,\r\n          &quot;metric&quot;:&quot;357&quot;\r\n        },\r\n        &quot;14:88:00:00:00:50&quot;:{\r\n          &quot;next_hop&quot;:&quot;14:88:00:00:00:85&quot;,\r\n          &quot;hop_count&quot;:&quot;2&quot;,\r\n          &quot;path_change_count&quot;:&quot;13&quot;,\r\n          &quot;metric&quot;:&quot;163&quot;\r\n        },\r\n        &quot;14:88:00:00:00:85&quot;:{\r\n          &quot;next_hop&quot;:&quot;14:88:00:00:00:85&quot;,\r\n          &quot;hop_count&quot;:&quot;1&quot;,\r\n          &quot;path_change_count&quot;:&quot;1&quot;,\r\n          &quot;metric&quot;:&quot;48&quot;\r\n        }\r\n      }\r\n    }\r\n  }\r\n}&#39; &gt; ~/tmp/test.txt\r\n\r\necho &#39;{ &quot;mac&quot;: &quot;14:88:00:00:00:50&quot;, &quot;key1&quot;: &quot;value1&quot;, &quot;key2&quot;: &quot;value2&quot; }&#39;  &gt;  ~/tmp/test1.txt\r\n\r\nmac=$(jq -r &#39;.mac&#39;  ~/tmp/test1.txt)\r\nfor (( n=0; n&lt;=1; n++ )); do\r\n    key=$(jq keys[$n]  ~/tmp/test1.txt)\r\n    value=$(jq -r &#39;.&#39;&quot;${key}&quot;&#39;&#39; ~/tmp/test1.txt)\r\n    cat &lt;&lt;&lt; $(jq --arg name ${value} &#39;.interfaces[&quot;m-11s-0&quot;].peers.&quot;&#39;&quot;$mac&quot;&#39;&quot; .&#39;&quot;${key}&quot;&#39; = $name&#39; ~/tmp/test.txt) &gt; ~/tmp/test.txt\r\ndone\r\ncat ~/tmp/test.txt\r\n```\r\nAnd I get what you wanted.",
                "title": "How to find and merge two json objects in a bash script using jq"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1733816487,
        "creation_date": 1722272989,
        "question_id": 78808305,
        "body_markdown": "I need to merge two json objects by key value in a bash script:\r\n\r\nIt is necessary to find by key (MAC address) the corresponding object (value) and add to its pairs the key: value pair of another object.\r\n\r\n\r\n```\r\n{&quot;mac&quot;: &quot;14:88:00:00:00:50&quot;, &quot;key1&quot;: &quot;value1&quot;, &quot;key2&quot;: &quot;value2&quot;}\r\nи\r\n{\r\n  &quot;interfaces&quot;:{\r\n    &quot;m-11s-0&quot;: {\r\n      &quot;peers&quot;: {\r\n        &quot;14:88:00:00:00:13&quot;:{\r\n          &quot;next_hop&quot;:&quot;14:88:00:00:00:85&quot;,\r\n          &quot;hop_count&quot;:&quot;3&quot;,\r\n          &quot;path_change_count&quot;:&quot;43&quot;,\r\n          &quot;metric&quot;:&quot;357&quot;\r\n        },\r\n        &quot;14:88:00:00:00:50&quot;:{\r\n          &quot;next_hop&quot;:&quot;14:88:00:00:00:85&quot;,\r\n          &quot;hop_count&quot;:&quot;2&quot;,\r\n          &quot;path_change_count&quot;:&quot;13&quot;,\r\n          &quot;metric&quot;:&quot;163&quot;\r\n        },\r\n        &quot;14:88:00:00:00:85&quot;:{\r\n          &quot;next_hop&quot;:&quot;14:88:00:00:00:85&quot;,\r\n          &quot;hop_count&quot;:&quot;1&quot;,\r\n          &quot;path_change_count&quot;:&quot;1&quot;,\r\n          &quot;metric&quot;:&quot;48&quot;\r\n        }\r\n      }\r\n    }\r\n  }\r\n}\r\n```\r\nFound the right object:\r\n```\r\nlogstatus_JSON=$(cat logstatus.sample)\r\n\r\necho &quot;$logstatus_JSON&quot; | jq -c &#39;.interfaces[&quot;m-11s-0&quot;].peers&#39; | jq -r &#39;to_entries[] | if &quot;\\(.key)&quot; == &quot;14:88:00:00:00:50&quot; then &quot;\\(.value)&quot; else &quot;zero&quot; end&#39;\r\n```\r\n\r\nThere is very little information in the jq documentation.\r\nPlease help me figure this out.\r\n\r\nBut I don&#39;t know how to combine two objects to get this result:\r\n\r\n```\r\n{\r\n  &quot;interfaces&quot;:{\r\n    &quot;m-11s-0&quot;: {\r\n      &quot;peers&quot;: {\r\n        &quot;14:88:00:00:00:13&quot;:{\r\n          &quot;next_hop&quot;:&quot;14:88:00:00:00:85&quot;,\r\n          &quot;hop_count&quot;:&quot;3&quot;,\r\n          &quot;path_change_count&quot;:&quot;43&quot;,\r\n          &quot;metric&quot;:&quot;357&quot;\r\n        },\r\n        &quot;14:88:00:00:00:50&quot;:{\r\n          &quot;next_hop&quot;:&quot;14:88:00:00:00:85&quot;,\r\n          &quot;hop_count&quot;:&quot;2&quot;,\r\n          &quot;path_change_count&quot;:&quot;13&quot;,\r\n          &quot;metric&quot;:&quot;163&quot;,\r\n          &quot;key1&quot;: &quot;value1&quot;,\r\n          &quot;key2&quot;: &quot;value2&quot;\r\n        },\r\n        &quot;14:88:00:00:00:85&quot;:{\r\n          &quot;next_hop&quot;:&quot;14:88:00:00:00:85&quot;,\r\n          &quot;hop_count&quot;:&quot;1&quot;,\r\n          &quot;path_change_count&quot;:&quot;1&quot;,\r\n          &quot;metric&quot;:&quot;48&quot;\r\n        }\r\n      }\r\n    }\r\n  }\r\n}\r\n```",
        "link": "https://stackoverflow.com/questions/78808305/how-to-find-and-merge-two-json-objects-in-a-bash-script-using-jq",
        "title": "How to find and merge two json objects in a bash script using jq"
    },
    {
        "tags": [
            "bash",
            "shell",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1722279050,
                "post_id": 78808557,
                "comment_id": 138945886,
                "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": 1722279136,
                "post_id": 78808557,
                "comment_id": 138945901,
                "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": 1722279368,
                "post_id": 78808557,
                "comment_id": 138945920,
                "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": 1722279483,
                "post_id": 78808557,
                "comment_id": 138945930,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 16657153,
                    "reputation": 325,
                    "user_id": 12038199,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/afe51bbc140e097b13e5cfcbd2268141?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "sloppy",
                    "link": "https://stackoverflow.com/users/12038199/sloppy"
                },
                "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": 1722279940,
                "post_id": 78808557,
                "comment_id": 138945982,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1722277792,
                "creation_date": 1722277792,
                "answer_id": 78808573,
                "question_id": 78808557,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "&gt; notice `definition&quot;:&quot;(with \\&quot;the\\&quot;` &lt;--- quotes are escaped\r\n\r\nUse `read -r`:\r\n```sh\r\nwhile read -r meaning; do …\r\n```\r\n\r\nSee `man bash` on `read`:\r\n```sh\r\n-r     Backslash does not act as an escape character.  The backslash\r\n       is considered to be part of the line.  In particular, a\r\n       backslash-newline pair may not then be used as a line\r\n       continuation.\r\n```",
                "title": "while loop removes quotes escapes making jq fail to parse json"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1722278986,
        "creation_date": 1722277482,
        "question_id": 78808557,
        "body_markdown": "`&quot;$response&quot;`:\r\n\r\n```\r\n[{&quot;word&quot;:&quot;world&quot;,&quot;phonetic&quot;:&quot;/wɝld/&quot;,&quot;phonetics&quot;:[{&quot;text&quot;:&quot;/wɝld/&quot;,&quot;audio&quot;:&quot;https://api.dictionaryapi.dev/media/pronunciations/en/world-ca.mp3&quot;,&quot;sourceUrl&quot;:&quot;https://commons.wikimedia.org/w/index.php?curid=238003&quot;,&quot;license&quot;:{&quot;name&quot;:&quot;BY-SA 3.0&quot;,&quot;url&quot;:&quot;https://creativecommons.org/licenses/by-sa/3.0&quot;}},{&quot;text&quot;:&quot;/wɵːld/&quot;,&quot;audio&quot;:&quot;&quot;},{&quot;text&quot;:&quot;/wɜːld/&quot;,&quot;audio&quot;:&quot;&quot;},{&quot;text&quot;:&quot;/wɝld/&quot;,&quot;audio&quot;:&quot;https://api.dictionaryapi.dev/media/pronunciations/en/world-us.mp3&quot;,&quot;sourceUrl&quot;:&quot;https://commons.wikimedia.org/w/index.php?curid=67249678&quot;,&quot;license&quot;:{&quot;name&quot;:&quot;BY-SA 4.0&quot;,&quot;url&quot;:&quot;https://creativecommons.org/licenses/by-sa/4.0&quot;}}],&quot;meanings&quot;:[{&quot;partOfSpeech&quot;:&quot;noun&quot;,&quot;definitions&quot;:[{&quot;definition&quot;:&quot;(with \\&quot;the\\&quot;) Human collective existence; existence in general.&quot;,&quot;synonyms&quot;:[],&quot;antonyms&quot;:[],&quot;example&quot;:&quot;There will always be lovers, till the world&#39;s end.&quot;},{&quot;definition&quot;:&quot;The Universe.&quot;,&quot;synonyms&quot;:[],&quot;antonyms&quot;:[]},{&quot;definition&quot;:&quot;(with \\&quot;the\\&quot;) The Earth.&quot;,&quot;synonyms&quot;:[],&quot;antonyms&quot;:[],&quot;example&quot;:&quot;People are dying of starvation all over the world.&quot;},{&quot;definition&quot;:&quot;A planet, especially one which is inhabited or inhabitable.&quot;,&quot;synonyms&quot;:[],&quot;antonyms&quot;:[],&quot;example&quot;:&quot;Our mission is to travel the galaxy and find new worlds.&quot;},{&quot;definition&quot;:&quot;A very large extent of country.&quot;,&quot;synonyms&quot;:[],&quot;antonyms&quot;:[]},{&quot;definition&quot;:&quot;(speculation) A realm, such as planet, containing one or multiple societies of beings, especially intelligent ones.&quot;,&quot;synonyms&quot;:[],&quot;antonyms&quot;:[],&quot;example&quot;:&quot;the world of Narnia; the Wizarding World of Harry Potter; a zombie world&quot;},{&quot;definition&quot;:&quot;An individual or group perspective or social setting.&quot;,&quot;synonyms&quot;:[],&quot;antonyms&quot;:[],&quot;example&quot;:&quot;In the world of boxing, good diet is all-important.&quot;},{&quot;definition&quot;:&quot;The part of an operating system distributed with the kernel, consisting of the shell and other programs.&quot;,&quot;synonyms&quot;:[],&quot;antonyms&quot;:[]},{&quot;definition&quot;:&quot;A subdivision of a game, consisting of a series of stages or levels that usually share a similar environment or theme.&quot;,&quot;synonyms&quot;:[],&quot;antonyms&quot;:[],&quot;example&quot;:&quot;Have you reached the boss at the end of the ice world?&quot;},{&quot;definition&quot;:&quot;The twenty-second trump or major arcana card of the tarot.&quot;,&quot;synonyms&quot;:[],&quot;antonyms&quot;:[]},{&quot;definition&quot;:&quot;A great amount.&quot;,&quot;synonyms&quot;:[],&quot;antonyms&quot;:[],&quot;example&quot;:&quot;Taking a break from work seems to have done her a world of good.&quot;},{&quot;definition&quot;:&quot;Age, era&quot;,&quot;synonyms&quot;:[],&quot;antonyms&quot;:[]}],&quot;synonyms&quot;:[&quot;planet&quot;,&quot;circle&quot;,&quot;Earth&quot;,&quot;Sol III&quot;,&quot;globe&quot;],&quot;antonyms&quot;:[]},{&quot;partOfSpeech&quot;:&quot;verb&quot;,&quot;definitions&quot;:[{&quot;definition&quot;:&quot;To consider or cause to be considered from a global perspective; to consider as a global whole, rather than making or focussing on national or other distinctions; compare globalise.&quot;,&quot;synonyms&quot;:[],&quot;antonyms&quot;:[]},{&quot;definition&quot;:&quot;To make real; to make worldly.&quot;,&quot;synonyms&quot;:[],&quot;antonyms&quot;:[]}],&quot;synonyms&quot;:[],&quot;antonyms&quot;:[]}],&quot;license&quot;:{&quot;name&quot;:&quot;CC BY-SA 3.0&quot;,&quot;url&quot;:&quot;https://creativecommons.org/licenses/by-sa/3.0&quot;},&quot;sourceUrls&quot;:[&quot;https://en.wiktionary.org/wiki/world&quot;]}]\r\n```\r\n\r\n^ notice `definition&quot;:&quot;(with \\&quot;the\\&quot;` &lt;--- quotes are escaped\r\n\r\n```bash\r\necho &quot;$response&quot; | jq -c &#39;.[].meanings[]&#39; | while read meaning; do\r\n  echo &quot;$meaning&quot;\r\n  echo &quot;$meaning&quot; | jq -r &#39;.&#39;\r\n  exit\r\ndone\r\n```\r\n\r\n^ returns:\r\n\r\n```\r\n{&quot;partOfSpeech&quot;:&quot;noun&quot;,&quot;definitions&quot;:[{&quot;definition&quot;:&quot;(with &quot;the&quot;) Human collective existence; existence in general.&quot;,&quot;synonyms&quot;:[],&quot;antonyms&quot;:[],&quot;example&quot;:&quot;There will always be lovers, till the world&#39;s end.&quot;},{&quot;definition&quot;:&quot;The Universe.&quot;,&quot;synonyms&quot;:[],&quot;antonyms&quot;:[]},{&quot;definition&quot;:&quot;(with &quot;the&quot;) The Earth.&quot;,&quot;synonyms&quot;:[],&quot;antonyms&quot;:[],&quot;example&quot;:&quot;People are dying of starvation all over the world.&quot;},{&quot;definition&quot;:&quot;A planet, especially one which is inhabited or inhabitable.&quot;,&quot;synonyms&quot;:[],&quot;antonyms&quot;:[],&quot;example&quot;:&quot;Our mission is to travel the galaxy and find new worlds.&quot;},{&quot;definition&quot;:&quot;A very large extent of country.&quot;,&quot;synonyms&quot;:[],&quot;antonyms&quot;:[]},{&quot;definition&quot;:&quot;(speculation) A realm, such as planet, containing one or multiple societies of beings, especially intelligent ones.&quot;,&quot;synonyms&quot;:[],&quot;antonyms&quot;:[],&quot;example&quot;:&quot;the world of Narnia; the Wizarding World of Harry Potter; a zombie world&quot;},{&quot;definition&quot;:&quot;An individual or group perspective or social setting.&quot;,&quot;synonyms&quot;:[],&quot;antonyms&quot;:[],&quot;example&quot;:&quot;In the world of boxing, good diet is all-important.&quot;},{&quot;definition&quot;:&quot;The part of an operating system distributed with the kernel, consisting of the shell and other programs.&quot;,&quot;synonyms&quot;:[],&quot;antonyms&quot;:[]},{&quot;definition&quot;:&quot;A subdivision of a game, consisting of a series of stages or levels that usually share a similar environment or theme.&quot;,&quot;synonyms&quot;:[],&quot;antonyms&quot;:[],&quot;example&quot;:&quot;Have you reached the boss at the end of the ice world?&quot;},{&quot;definition&quot;:&quot;The twenty-second trump or major arcana card of the tarot.&quot;,&quot;synonyms&quot;:[],&quot;antonyms&quot;:[]},{&quot;definition&quot;:&quot;A great amount.&quot;,&quot;synonyms&quot;:[],&quot;antonyms&quot;:[],&quot;example&quot;:&quot;Taking a break from work seems to have done her a world of good.&quot;},{&quot;definition&quot;:&quot;Age, era&quot;,&quot;synonyms&quot;:[],&quot;antonyms&quot;:[]}],&quot;synonyms&quot;:[&quot;planet&quot;,&quot;circle&quot;,&quot;Earth&quot;,&quot;Sol III&quot;,&quot;globe&quot;],&quot;antonyms&quot;:[]}\r\njq: parse error: Invalid literal at line 1, column 64\r\n```\r\n\r\nquotes escapes are gone and `jq` fails to parse.\r\n\r\nI have tried adding flags to echo (`-n` and `-e`) but that didn&#39;t help.",
        "link": "https://stackoverflow.com/questions/78808557/while-loop-removes-quotes-escapes-making-jq-fail-to-parse-json",
        "title": "while loop removes quotes escapes making jq fail to parse json"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1722308863,
                "post_id": 78809641,
                "comment_id": 138947693,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1722310143,
                "last_edit_date": 1722310143,
                "creation_date": 1722309660,
                "answer_id": 78809684,
                "question_id": 78809641,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Do it like so:\r\n``` sh\r\njq --arg long &quot;$long&quot; &#39;.module.home[].names[] += {$long}&#39; list.json &gt; list.json.new\r\nmv list.json.new list.json\r\n```",
                "title": "How to only update a specific object in json using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1722322491,
        "creation_date": 1722308192,
        "last_edit_date": 1722322491,
        "question_id": 78809641,
        "body_markdown": "I read a json from a file, manipulated one of the fields such as below and got the output on terminal\r\n\r\n```\r\ncat list.json | jq &quot;.module.home.[].names | map(.long=\\&quot;$long\\&quot;)&quot;\r\n```\r\n\r\nHowever, the original file i.e. `list.json` is still having old values. How do I update only this object back in the original file.\r\n\r\nSolutions such as [here]( https://stackoverflow.com/questions/36565295/jq-to-replace-text-directly-on-file-like-sed-i) replaces the whole content with the output of command. However, what I want to is only update a particular object such as `&quot;.module.home.[].names` in it, and leave the rest as it is.\r\n",
        "link": "https://stackoverflow.com/questions/78809641/how-to-only-update-a-specific-object-in-json-using-jq",
        "title": "How to only update a specific object in json using jq"
    },
    {
        "tags": [
            "docker",
            "jq",
            "deprecation-warning"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 39208,
                    "reputation": 267964,
                    "user_id": 112968,
                    "user_type": "registered",
                    "accept_rate": 68,
                    "profile_image": "https://i.sstatic.net/zHTaT.png?s=256",
                    "display_name": "knittl",
                    "link": "https://stackoverflow.com/users/112968/knittl"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1722601523,
                "post_id": 78819875,
                "comment_id": 138975143,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1722601642,
                "creation_date": 1722601642,
                "answer_id": 78825499,
                "question_id": 78819875,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The latest Docker images of jq can be found in the [GitHub container registry](https://github.com/jqlang/jq/pkgs/container/jq):\r\n\r\n```\r\ndocker pull ghcr.io/jqlang/jq:1.7.1\r\n```\r\n\r\nIt&#39;s linked directly from the project&#39;s [README file](https://github.com/jqlang/jq).",
                "title": "docker image pull stedolan/jq fails on deprecation"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1738120692,
                "creation_date": 1738120692,
                "answer_id": 79395658,
                "question_id": 78819875,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "    docker run -i quay.io/docwhat/jq &lt;sample-data/test.json &#39;.key_1 + .key_2&#39;\r\n\r\ntry to use &#39;quay.io/docwhat&#39; image instead &#39;stedolan&#39;.",
                "title": "docker image pull stedolan/jq fails on deprecation"
            }
        ],
        "is_answered": false,
        "answer_count": 2,
        "score": -2,
        "last_activity_date": 1738120692,
        "creation_date": 1722500870,
        "question_id": 78819875,
        "body_markdown": "Error seen is:\r\n```\r\n+++ docker run --rm -i stedolan/jq &#39;.architectures.x86_64.artifacts.qemu.formats[&quot;qcow2.gz&quot;].disk.location&#39;\r\n+++ tr -d &#39;&quot;&#39;\r\nUnable to find image &#39;stedolan/jq:latest&#39; locally\r\nlatest: Pulling from stedolan/jq\r\ndocker: [DEPRECATION NOTICE] Docker Image Format v1 and Docker Image manifest version 2, schema 1 support is disabled by default and will be removed in an upcoming release. Suggest the author of docker.io/stedolan/jq:latest to upgrade the image to the OCI Format or Docker Image manifest v2, schema 2. More information at https://docs.docker.com/go/deprecated-image-specs/.\r\n```\r\n\r\nSee where it fails [here](https://github.com/RHsyseng/rhcos-slb/actions/runs/10194562591/job/28201419607#step:5:50). \r\n\r\nCan you please bump the Image manifest to v2?\r\n\r\ntrying to run the dockerized jq, expecting it to work :) ",
        "link": "https://stackoverflow.com/questions/78819875/docker-image-pull-stedolan-jq-fails-on-deprecation",
        "title": "docker image pull stedolan/jq fails on deprecation"
    },
    {
        "tags": [
            "json",
            "list",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1722541074,
                "post_id": 78822603,
                "comment_id": 138970556,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1722540873,
                "creation_date": 1722540873,
                "answer_id": 78822776,
                "question_id": 78822603,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Either retain the array by modifying its items using `map`, then `add` them to summarize the object:\r\n```sh\r\n.result | map({(.sys_name): .state_value}) | add\r\n```\r\n\r\nOr, simpler, `reduce` over the items, and successively build up the object:\r\n```sh\r\n.result | reduce .[] as $i ({}; .[$i.sys_name] = $i.state_value)\r\n```\r\n",
                "title": "Create one big object from a list of objects using jq"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1722601476,
                "creation_date": 1722601476,
                "answer_id": 78825487,
                "question_id": 78822603,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "[`from_entries`](https://jqlang.github.io/jq/manual/#to_entries-from_entries-with_entries) comes in handy in such use cases:\r\n\r\n```\r\n.result | map({key:.sys_name, value:.state_value}) | from_entries\r\n```",
                "title": "Create one big object from a list of objects using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1722601476,
        "creation_date": 1722537651,
        "last_edit_date": 1722542609,
        "question_id": 78822603,
        "body_markdown": "Okay so I have blob of data like so ... \r\n\r\n```\r\n[\r\n{\r\n  &quot;sys_replace_on_upgrade&quot;: &quot;false&quot;,\r\n  &quot;initial_state&quot;: &quot;false&quot;,\r\n  &quot;sys_mod_count&quot;: &quot;0&quot;,\r\n  &quot;sys_updated_on&quot;: &quot;2020-09-02 13:48:39&quot;,\r\n  &quot;sys_tags&quot;: &quot;&quot;,\r\n  &quot;state_label&quot;: &quot;Authorize&quot;,\r\n  &quot;sys_class_name&quot;: &quot;sttrm_state&quot;,\r\n  &quot;state_sequence&quot;: &quot;3&quot;,\r\n  &quot;sys_id&quot;: &quot;13fc0801c343101035ae3f52c1d3ae77&quot;,\r\n  &quot;sys_update_name&quot;: &quot;sttrm_state_13fc0801c343101035ae3f52c1d3ae77&quot;,\r\n  &quot;sys_updated_by&quot;: &quot;admin&quot;,\r\n  &quot;sys_created_on&quot;: &quot;2020-09-02 13:48:39&quot;,\r\n  &quot;sys_name&quot;: &quot;Authorize&quot;,\r\n  &quot;state_value&quot;: &quot;-3&quot;,\r\n  &quot;sys_customer_update&quot;: &quot;false&quot;,\r\n  &quot;sys_created_by&quot;: &quot;admin&quot;,\r\n  &quot;sys_policy&quot;: &quot;&quot;\r\n},\r\n...\r\n]\r\n```\r\n\r\nI run it through jq like so: \r\n\r\n```\r\njq &#39;.result[]|{(.sys_name) : .state_value}&#39; states.json\r\n{\r\n  &quot;Authorize&quot;: &quot;-3&quot;\r\n}\r\n{\r\n  &quot;New&quot;: &quot;-5&quot;\r\n}\r\n{\r\n  &quot;Closed&quot;: &quot;3&quot;\r\n}\r\n{\r\n  &quot;Review&quot;: &quot;0&quot;\r\n}\r\n...\r\n```\r\n\r\nWhat I really want is one big object like: \r\n\r\n```\r\n{\r\n  &quot;Authorize&quot;: &quot;-3&quot; ,\r\n  &quot;New&quot;: &quot;-5&quot;,\r\n  &quot;Closed&quot;: &quot;3&quot;,\r\n  &quot;Review&quot;: &quot;0&quot;, \r\n...\r\n}\r\n```\r\n\r\nI&#39;m close but I&#39;m missing something ... \r\n",
        "link": "https://stackoverflow.com/questions/78822603/create-one-big-object-from-a-list-of-objects-using-jq",
        "title": "Create one big object from a list of objects using jq"
    },
    {
        "tags": [
            "json",
            "merge",
            "ansible",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1722553624,
                "creation_date": 1722553624,
                "answer_id": 78823303,
                "question_id": 78823285,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "As [tag:jq] is tagged, you seem to be looking for a `JOIN`:\r\n```sh\r\njq &#39;[JOIN(input | INDEX(.name); .[]; .server; add)]&#39; simple.json master.json\r\n```\r\n```json\r\n[\r\n  {\r\n    &quot;playbook&quot;: &quot;simplerun.yml&quot;,\r\n    &quot;server&quot;: &quot;abc&quot;,\r\n    &quot;status&quot;: &quot;success&quot;,\r\n    &quot;name&quot;: &quot;abc&quot;,\r\n    &quot;fqdn&quot;: &quot;abc.com&quot;,\r\n    &quot;env&quot;: &quot;UAT&quot;,\r\n    &quot;ip_address&quot;: &quot;0.0.0.0&quot;,\r\n    &quot;owner&quot;: &quot;John Doe&quot;\r\n  },\r\n  {\r\n    &quot;playbook&quot;: &quot;simplerun.yml&quot;,\r\n    &quot;server&quot;: &quot;def&quot;,\r\n    &quot;status&quot;: &quot;success&quot;,\r\n    &quot;name&quot;: &quot;def&quot;,\r\n    &quot;fqdn&quot;: &quot;def.com&quot;,\r\n    &quot;env&quot;: &quot;PROD&quot;,\r\n    &quot;ip_address&quot;: &quot;0.0.0.1&quot;,\r\n    &quot;owner&quot;: &quot;Jane Doe&quot;\r\n  }\r\n]\r\n```\r\n[Demo](https://jqplay.org/s/wg6o19g0X12bEe4)\r\n\r\nIf you want the `name` field removed from the output, replace `add` with `add | del(.name)`.",
                "title": "merge 2 json arrays using ansible or jq"
            },
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1722586394,
                "last_edit_date": 1722586394,
                "creation_date": 1722575901,
                "answer_id": 78823866,
                "question_id": 78823285,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Read the files, for example\r\n\r\n```yaml\r\n  names: &quot;{{ lookup(&#39;file&#39;, &#39;names.yml&#39;) }}&quot;\r\n  pb_status: &quot;{{ lookup(&#39;file&#39;, &#39;pb_status.yml&#39;) }}&quot;\r\n```\r\ngives\r\n\r\n```yaml\r\n  names:\r\n  - env: UAT\r\n    fqdn: abc.com\r\n    ip_address: 0.0.0.0\r\n    name: abc\r\n    owner: John Doe\r\n  - env: PROD\r\n    fqdn: def.com\r\n    ip_address: 0.0.0.1\r\n    name: def\r\n    owner: Jane Doe\r\n\r\n  pb_status:\r\n  - playbook: simplerun.yml\r\n    server: abc\r\n    status: success\r\n  - playbook: simplerun.yml\r\n    server: def\r\n    status: success\r\n```\r\n\r\nThere are more options:\r\n\r\n1) Get the list of servers\r\n\r\n```yaml\r\n  servers: &quot;{{ pb_status | map(attribute=&#39;server&#39;) }}&quot;\r\n```\r\ngives\r\n\r\n```yaml\r\n  servers:\r\n  - abc\r\n  - def\r\n```\r\nSelect names in the servers&#39; list\r\n\r\n```yaml\r\n  names_sel: &quot;{{ names | selectattr(&#39;name&#39;, &#39;in&#39;, servers) }}&quot;\r\n```\r\ngives the same items here in testing, but there are a lot more items in production\r\n\r\n```yaml\r\n  names_sel:\r\n  - env: UAT\r\n    fqdn: abc.com\r\n    ip_address: 0.0.0.0\r\n    name: abc\r\n    owner: John Doe\r\n  - env: PROD\r\n    fqdn: def.com\r\n    ip_address: 0.0.0.1\r\n    name: def\r\n    owner: Jane Doe\r\n```\r\n\r\nRename the key *server* to *name* and merge the lists\r\n\r\n```yaml\r\n  target:\r\n      - {after: name, before: server}\r\n  result: &quot;{{ pb_status | community.general.replace_keys(target=target) |\r\n                community.general.lists_mergeby(names_sel, &#39;name&#39;) }}&quot;\r\n```\r\ngives what you want\r\n\r\n```yaml\r\n  result:\r\n  - env: UAT\r\n    fqdn: abc.com\r\n    ip_address: 0.0.0.0\r\n    name: abc\r\n    owner: John Doe\r\n    playbook: simplerun.yml\r\n    status: success\r\n  - env: PROD\r\n    fqdn: def.com\r\n    ip_address: 0.0.0.1\r\n    name: def\r\n    owner: Jane Doe\r\n    playbook: simplerun.yml\r\n    status: success\r\n```\r\n\r\n&lt;hr&gt;\r\n\r\n&lt;sup&gt;\r\n\r\nExample of a complete playbook for testing\r\n\r\n```yaml\r\n- hosts: localhost\r\n\r\n  vars:\r\n\r\n    names: &quot;{{ lookup(&#39;file&#39;, &#39;names.yml&#39;) }}&quot;\r\n    pb_status: &quot;{{ lookup(&#39;file&#39;, &#39;pb_status.yml&#39;) }}&quot;\r\n\r\n    servers: &quot;{{ pb_status | map(attribute=&#39;server&#39;) }}&quot;\r\n    names_sel: &quot;{{ names | selectattr(&#39;name&#39;, &#39;in&#39;, servers) }}&quot;\r\n    target:\r\n      - {after: name, before: server}\r\n    result: &quot;{{ pb_status | community.general.replace_keys(target=target) |\r\n                community.general.lists_mergeby(names_sel, &#39;name&#39;) }}&quot;\r\n\r\n  tasks:\r\n\r\n    - debug:\r\n        var: names\r\n    - debug:\r\n        var: pb_status\r\n    - debug:\r\n        var: servers\r\n    - debug:\r\n        var: names_sel\r\n    - debug:\r\n        var: result\r\n```\r\n\r\n&lt;/sup&gt;\r\n\r\n&lt;hr&gt;\r\n\r\n\r\n\r\n\r\n2) Group the status items and create a dictionary if there might be more status items for the same server \r\n\r\n```yaml\r\n  pb_status_group: &quot;{{ pb_status | groupby(&#39;server&#39;) | community.general.dict }}&quot;\r\n```\r\n\r\ngives\r\n\r\n```yaml\r\n  pb_status_group:\r\n    abc:\r\n    - playbook: simplerun.yml\r\n      server: abc\r\n      status: success\r\n    def:\r\n    - playbook: simplerun.yml\r\n      server: def\r\n      status: success\r\n```\r\n\r\nConvert the list of names to a dictionary too. It is expected that the names are unique\r\n\r\n```yaml\r\n  names_dict: &quot;{{ dict(names | json_query(&#39;[].[name, @]&#39;)) }}&quot;\r\n```\r\n\r\ngives\r\n\r\n```yaml\r\n  names_dict:\r\n    abc:\r\n      env: UAT\r\n      fqdn: abc.com\r\n      ip_address: 0.0.0.0\r\n      name: abc\r\n      owner: John Doe\r\n    def:\r\n      env: PROD\r\n      fqdn: def.com\r\n      ip_address: 0.0.0.1\r\n      name: def\r\n      owner: Jane Doe\r\n```\r\n\r\nAfter you have converted the lists to dictionaries the search will be more efficient. Select names\r\n\r\n```yaml\r\n  names_sel: &quot;{{ pb_status_group | map(&#39;extract&#39;, names_dict) }}&quot;\r\n```\r\n\r\ngives the same items here in testing, but there are a lot more items in production\r\n\r\n```yaml\r\n  names_sel:\r\n  - env: UAT\r\n    fqdn: abc.com\r\n    ip_address: 0.0.0.0\r\n    name: abc\r\n    owner: John Doe\r\n  - env: PROD\r\n    fqdn: def.com\r\n    ip_address: 0.0.0.1\r\n    name: def\r\n    owner: Jane Doe\r\n```\r\n\r\nConvert the dictionary pb_status_group to a list and merge the lists by *name*\r\n\r\n```yaml\r\n  result: &quot;{{ pb_status_group | dict2items(key_name=&#39;name&#39;, value_name=&#39;status&#39;) |\r\n              community.general.lists_mergeby(names_sel, &#39;name&#39;) }}&quot;\r\n```\r\ngives what want\r\n\r\n```yaml\r\n  result:\r\n  - env: UAT\r\n    fqdn: abc.com\r\n    ip_address: 0.0.0.0\r\n    name: abc\r\n    owner: John Doe\r\n    status:\r\n    - playbook: simplerun.yml\r\n      server: abc\r\n      status: success\r\n  - env: PROD\r\n    fqdn: def.com\r\n    ip_address: 0.0.0.1\r\n    name: def\r\n    owner: Jane Doe\r\n    status:\r\n    - playbook: simplerun.yml\r\n      server: def\r\n      status: success\r\n```\r\n\r\n&lt;hr&gt;\r\n\r\n&lt;sup&gt;\r\n\r\nExample of a complete playbook for testing\r\n\r\n```yaml\r\n- hosts: localhost\r\n\r\n  vars:\r\n\r\n    names: &quot;{{ lookup(&#39;file&#39;, &#39;names.yml&#39;) }}&quot;\r\n    pb_status: &quot;{{ lookup(&#39;file&#39;, &#39;pb_status.yml&#39;) }}&quot;\r\n\r\n    pb_status_group: &quot;{{ pb_status | groupby(&#39;server&#39;) | community.general.dict }}&quot;\r\n    names_dict: &quot;{{ dict(names | json_query(&#39;[].[name, @]&#39;)) }}&quot;\r\n    names_sel: &quot;{{ pb_status_group | map(&#39;extract&#39;, names_dict) }}&quot;\r\n    result: &quot;{{ pb_status_group | dict2items(key_name=&#39;name&#39;, value_name=&#39;status&#39;) |\r\n                community.general.lists_mergeby(names_sel, &#39;name&#39;) }}&quot;\r\n\r\n  tasks:\r\n\r\n    - debug:\r\n        var: names\r\n    - debug:\r\n        var: pb_status\r\n    - debug:\r\n        var: pb_status_group\r\n    - debug:\r\n        var: names_dict\r\n    - debug:\r\n        var: names_sel\r\n    - debug:\r\n        var: result\r\n```\r\n\r\n&lt;/sup&gt;\r\n",
                "title": "merge 2 json arrays using ansible or jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1722586394,
        "creation_date": 1722553079,
        "question_id": 78823285,
        "body_markdown": "So I have 2 json array files\r\none with some simple data (could be any number of servers):\r\n\r\n```\r\n    [\r\n    {\r\n    &quot;playbook&quot;: &quot;simplerun.yml&quot;,\r\n    &quot;server&quot;: &quot;abc&quot;,\r\n    &quot;status&quot;: &quot;success&quot;\r\n    },\r\n    {\r\n    &quot;playbook&quot;: &quot;simplerun.yml&quot;,\r\n    &quot;server&quot;: &quot;def&quot;,\r\n    &quot;status&quot;: &quot;success&quot;\r\n    }\r\n    etc\r\n    ]\r\n```\r\n\r\nand a master file (hundreds of thousands of servers) with enhanced data about the server (but is called Name)\r\n```\r\n    [\r\n    {\r\n    &quot;name&quot;: &quot;abc&quot;,\r\n    &quot;fqdn&quot;: &quot;abc.com&quot;,\r\n    &quot;env&quot;: &quot;UAT&quot;,\r\n    &quot;ip_address&quot;: &quot;0.0.0.0&quot;,\r\n    &quot;owner&quot;: &quot;John Doe&quot;\r\n    },\r\n    {\r\n    &quot;name&quot;: &quot;def&quot;,\r\n    &quot;fqdn&quot;: &quot;def.com&quot;,\r\n    &quot;env&quot;: &quot;PROD&quot;,\r\n    &quot;ip_address&quot;: &quot;0.0.0.1&quot;,\r\n    &quot;owner&quot;: &quot;Jane Doe&quot;\r\n    }\r\n    etc\r\n    ]\r\n```\r\n\r\nwhat I would like to have is \r\n```\r\n    [\r\n    {\r\n    &quot;playbook&quot;: &quot;simplerun.yml&quot;,\r\n    &quot;server&quot;: &quot;abc&quot;,\r\n    &quot;status&quot;: &quot;success&quot;,\r\n    &quot;fqdn&quot;: &quot;abc.com&quot;,\r\n    &quot;env&quot;: &quot;UAT&quot;,\r\n    &quot;ip_address&quot;: &quot;0.0.0.0&quot;,\r\n    &quot;owner&quot;: &quot;John Doe&quot;\r\n    },\r\n    {\r\n    &quot;playbook&quot;: &quot;simplerun.yml&quot;,\r\n    &quot;server&quot;: &quot;def&quot;,\r\n    &quot;status&quot;: &quot;success&quot;,\r\n    &quot;fqdn&quot;: &quot;def.com&quot;,\r\n    &quot;env&quot;: &quot;PROD&quot;,\r\n    &quot;ip_address&quot;: &quot;0.0.0.1&quot;,\r\n    &quot;owner&quot;: &quot;Jane Doe&quot;\r\n    }\r\n    ]\r\n```\r\n\r\nI know it must be simple, but \r\n\r\nAny help is greatly appreciated.\r\n\r\nI have tried combine\r\n\r\n```\r\n     - name: set fact\r\n       set_fact:\r\n         key1: &quot;server&quot;\r\n         key2: &quot;name&quot;\r\n     \r\n     - name: join data\r\n       set_fact:\r\n         joined_data: &gt;- \r\n           {{ jsonfile1 | map (&#39;combine&#39;,\r\n              jsonfile2 |selectattr (key2,&#39;eq&#39;, item[key1]|list|first|default ({}))\r\n           }}\r\n       loop: &quot;{{ jsonfile1 }}&quot;\r\n       loop_control:\r\n         loop_var: item\r\n```\r\nhowever that only produced the same values for all the entries in the simple data.\r\n",
        "link": "https://stackoverflow.com/questions/78823285/merge-2-json-arrays-using-ansible-or-jq",
        "title": "merge 2 json arrays using ansible or jq"
    },
    {
        "tags": [
            "arrays",
            "json",
            "csv",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 5,
                "creation_date": 1722554789,
                "post_id": 78823319,
                "comment_id": 138971560,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1641746,
                    "reputation": 2251,
                    "user_id": 1514042,
                    "user_type": "registered",
                    "accept_rate": 78,
                    "profile_image": "https://www.gravatar.com/avatar/cc8e6abfff2df766f765ada377bb20f4?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "JsCoder",
                    "link": "https://stackoverflow.com/users/1514042/jscoder"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1722555529,
                "post_id": 78823319,
                "comment_id": 138971592,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1722555705,
                "creation_date": 1722555705,
                "answer_id": 78823358,
                "question_id": 78823319,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Extract all raw `bar` as array and pipe to `@csv`:\r\n\r\n    jq -r &#39;[.foo.[].bar] | @csv&#39;\r\n\r\n---\r\n\r\n```\r\necho &#39;{&quot;foo&quot;: [\r\n      {\r\n        &quot;bar&quot;: &quot;baz&quot;\r\n      },\r\n      {\r\n        &quot;bar&quot;: &quot;baz&quot;\r\n      },\r\n      {\r\n        &quot;bar&quot;: &quot;baz&quot;\r\n      }\r\n    ]\r\n}&#39; | jq -r &#39;[.foo.[].bar] | @csv&#39;\r\n```\r\n\r\nOutput:\r\n\r\n    &quot;baz&quot;,&quot;baz&quot;,&quot;baz&quot;",
                "title": "Convert JSON array of key/value pairs into values with a comma seperator using jq"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1722635642,
        "creation_date": 1722554306,
        "last_edit_date": 1722635642,
        "question_id": 78823319,
        "body_markdown": "I have the following JSON. \r\n\r\n```\r\n{&quot;foo&quot;: [\r\n      {\r\n        &quot;bar&quot;: &quot;baz&quot;\r\n      },\r\n      {\r\n        &quot;bar&quot;: &quot;baz&quot;\r\n      },\r\n      {\r\n        &quot;bar&quot;: &quot;baz&quot;\r\n      }\r\n    ]\r\n}\r\n```\r\nI&#39;d like to convert this using jq into the following \r\n```text\r\n&quot;baz&quot;, &quot;baz&quot;, &quot;baz&quot;\r\n```\r\n\r\nHow do I do this using jq without any flags? \r\n\r\n`.foo.[].bar` using https://jqplay.org/ gets you to having them on separate lines with no comma between them, but I need them to have commas in between and be on the same line. \r\n```text\r\n&quot;baz&quot;\r\n&quot;baz&quot;\r\n&quot;baz&quot;\r\n```",
        "link": "https://stackoverflow.com/questions/78823319/convert-json-array-of-key-value-pairs-into-values-with-a-comma-seperator-using-j",
        "title": "Convert JSON array of key/value pairs into values with a comma seperator using jq"
    },
    {
        "tags": [
            "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": 1722623457,
                "post_id": 78826790,
                "comment_id": 138977717,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1722623889,
                "creation_date": 1722623889,
                "answer_id": 78826822,
                "question_id": 78826790,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If your JSON is saved as a file named &quot;file.json&quot;, you can get the output in the specified format using this command:\r\n\r\n    jq -r &#39;to_entries[] | .value[]&#39; file.json\r\n\r\nTo explain how this works:\r\n* `to_entries[]` converts the JSON object into an array of key-value pairs\r\n* `.value[]` iterates over each value array and prints each element on a new line\r\n* `-r` formats the output as raw text",
                "title": "How to merge arrays within JSON object"
            },
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1722637920,
                "creation_date": 1722637920,
                "answer_id": 78827424,
                "question_id": 78826790,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "To get all the second-level items, iterate two levels deep:\r\n```sh\r\njq -r &#39;.[][]&#39;\r\n```\r\n\r\nTo get all the leaf-level items, descend recursively, and filter for `scalars`:\r\n```sh\r\njq -r &#39;..|scalars&#39;\r\n```",
                "title": "How to merge arrays within JSON object"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": -1,
        "last_activity_date": 1722637920,
        "creation_date": 1722623293,
        "question_id": 78826790,
        "body_markdown": "Given a JSON object\r\n\r\n```\r\n{\r\n&quot;foo&quot;:[&quot;barfoo&quot;],\r\n&quot;bar&quot;:[&quot;foobar&quot;]\r\n}\r\n```\r\n\r\nI would like to merge both arrays, i.e. output:\r\n\r\n```\r\nbarfoo\r\nfoobar\r\n```\r\n\r\nObviously I can list either array using, e.g. `jq -r .foo[]` but I&#39;m not sure how to go about merging both.\r\n\r\nThe array names (`foo` / `bar`) are constants, they do not change.",
        "link": "https://stackoverflow.com/questions/78826790/how-to-merge-arrays-within-json-object",
        "title": "How to merge arrays within JSON object"
    },
    {
        "tags": [
            "regex",
            "jq",
            "owasp-dependency-track"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 1100252,
                    "reputation": 10774,
                    "user_id": 1092818,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/5b37561ab2aede6a2f839396733e999f?s=256&d=identicon&r=PG",
                    "display_name": "crizzis",
                    "link": "https://stackoverflow.com/users/1092818/crizzis"
                },
                "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": 1722874052,
                "post_id": 78834941,
                "comment_id": 138992776,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1100252,
                    "reputation": 10774,
                    "user_id": 1092818,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/5b37561ab2aede6a2f839396733e999f?s=256&d=identicon&r=PG",
                    "display_name": "crizzis",
                    "link": "https://stackoverflow.com/users/1092818/crizzis"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1722875293,
                "post_id": 78834941,
                "comment_id": 138992913,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1100252,
                    "reputation": 10774,
                    "user_id": 1092818,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/5b37561ab2aede6a2f839396733e999f?s=256&d=identicon&r=PG",
                    "display_name": "crizzis",
                    "link": "https://stackoverflow.com/users/1092818/crizzis"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1722875495,
                "post_id": 78834941,
                "comment_id": 138992940,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1722878847,
                "creation_date": 1722878847,
                "answer_id": 78835698,
                "question_id": 78834941,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You could use the approach exemplified by:\r\n```\r\ndef capture($s; $default): capture($s) // $default;\r\n\r\n.[]\r\n| select(.classifier | test(&quot;APPLICATION&quot;))\r\n| {\r\n      id: .name,\r\n      dep1: ((.directDependencies // &quot;&quot;) | capture([&quot;com\\\\.example\\\\.commons/dep1@(?&lt;version&gt;[0-9.]+)&quot;]; &quot;dep1 did not match&quot;)),\r\n      dep3: ((.directDependencies // &quot;&quot;) | capture([&quot;com\\\\.example\\\\.commons/dep3@(?&lt;version&gt;[0-9.]+)&quot;]; &quot;dep2 did not match&quot;)),\r\n      dep4: ((.directDependencies // &quot;&quot;) | capture([&quot;com\\\\.example\\\\.commons/dep4@(?&lt;version&gt;[0-9.]+)&quot;]; &quot;dep1 did not match&quot;))\r\n  }\r\n\r\n```",
                "title": "Print input element even when capture() fails to match expression"
            },
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1722900973,
                "last_edit_date": 1722900973,
                "creation_date": 1722900232,
                "answer_id": 78836732,
                "question_id": 78834941,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "As I understand the question, you want to only add successful matches to the result object. I would prefer using `scan` to find all matches, and then `reduce` over them to successively build up the result object, while including the dependency name in the regex (e.g. as `dep1|dep2|dep3|dep4`, or shorter `dep[1-4]`, or more generically `[^@]+`, which I&#39;ve used below).\r\n\r\n```sh\r\n.[] | select(.classifier/&quot; | &quot; | any(. == &quot;APPLICATION&quot;)) | reduce (\r\n  .directDependencies | scan(&quot;com\\\\.example\\\\.commons/(?&lt;dep&gt;[^@]+)@(?&lt;version&gt;[0-9.]+)&quot;)\r\n) as [$dep, $version] ({id: .name}; .[$dep] = {$version})\r\n```\r\n\r\nNote #1: This will always generate the `{id: .name}` part, even if no dependencies are added. To instead swallow these &quot;naked&quot; objects, start out the reduction with `null`, and filter eventually for non-null `values`:\r\n\r\n```sh\r\n.[] | select(.classifier/&quot; | &quot; | any(. == &quot;APPLICATION&quot;)) | {id: .name} + (reduce (\r\n  .directDependencies | scan(&quot;com\\\\.example\\\\.commons/(?&lt;dep&gt;[^@]+)@(?&lt;version&gt;[0-9.]+)&quot;)\r\n) as [$dep, $version] (null; .[$dep] = {$version}) | values)\r\n```\r\n\r\nNote #2: Your filter `select(.classifier==&quot;APPLICATION&quot;)` only matches objects where the value under `.classifier` is completely equal to the string `&quot;APPLICATION&quot;`, and thus wouldn&#39;t catch your sample input at all as it contains `{&quot;classifier&quot;: &quot;LIBRARY | APPLICATION&quot;}`. So instead, I used `/` to split that value at the substring `&quot; | &quot;`, and had it match if `any` (i.e. at least one) of the resulting parts was equal to that string.",
                "title": "Print input element even when capture() fails to match expression"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1722900973,
        "creation_date": 1722868185,
        "last_edit_date": 1722882615,
        "question_id": 78834941,
        "body_markdown": "I&#39;m trying to extract info on certain specific dependencies from the output of DTrack&#39;s `/v1/project` endpoint. \r\n\r\nThe API returns data in the format:\r\n\r\n```json\r\n[{\r\n    &quot;name&quot;: &quot;project name&quot;,\r\n    &quot;classifier&quot;: &quot;LIBRARY | APPLICATION&quot;,\r\n    &quot;directDependencies&quot;: &lt;escaped JSON string in which I need to search for &quot;com.example.commons/dep1@0.101.0&quot; and similar strings&gt;\r\n}, ...]\r\n```\r\n\r\nHere&#39;s what I got so far: \r\n\r\n```sh\r\njq &#39;.[] | select(.classifier==&quot;APPLICATION&quot;) | {\r\n      id: .name,\r\n      dep1: ((.directDependencies // &quot;&quot;) | capture([&quot;com\\\\.example\\\\.commons/dep1@(?&lt;version&gt;[0-9.]+)&quot;])),\r\n      dep2: ((.directDependencies // &quot;&quot;) | capture([&quot;com\\\\.example\\\\.commons/dep2@(?&lt;version&gt;[0-9.]+)&quot;])),\r\n      dep3: ((.directDependencies // &quot;&quot;) | capture([&quot;com\\\\.example\\\\.commons/dep3@(?&lt;version&gt;[0-9.]+)&quot;])),\r\n      dep4: ((.directDependencies // &quot;&quot;) | capture([&quot;com\\\\.example\\\\.commons/dep4@(?&lt;version&gt;[0-9.]+)&quot;]))\r\n    }&#39;\r\n```\r\n\r\nGenerated output looks fine: \r\n\r\n```json\r\n{\r\n  &quot;id&quot;: &quot;project1&quot;,\r\n  &quot;dep1&quot;: {\r\n    &quot;version&quot;: &quot;0.102.0&quot;\r\n  },\r\n  &quot;dep2&quot;: {\r\n    &quot;version&quot;: &quot;0.102.0&quot;\r\n  },\r\n  &quot;dep3&quot;: {\r\n    &quot;version&quot;: &quot;0.102.0&quot;\r\n  },\r\n  &quot;dep4&quot;: {\r\n    &quot;version&quot;: &quot;0.102.0&quot;\r\n  }\r\n}\r\n... // more elements\r\n```\r\n\r\nThe problem is, the output **only contains those of the input elements for which all four `capture`s matched something**. \r\n\r\nI would like the output to contain all the elements of the input list, **even if some of the `capture`s fail to match**. In other words, I would expect elements in the output like: \r\n\r\n```json\r\n{\r\n    &quot;id&quot;: &quot;project1&quot;,\r\n    &quot;dep1&quot;: { &quot;version&quot;: &quot;0.1.0&quot; },\r\n    // dep2 didn&#39;t match\r\n    // dep3 didn&#39;t match\r\n    &quot;dep4&quot;: { &quot;version&quot;: &quot;0.3.0&quot; }\r\n}\r\n```\r\n\r\nI couldn&#39;t find such an option in the docs. Any ideas how to solve this?",
        "link": "https://stackoverflow.com/questions/78834941/print-input-element-even-when-capture-fails-to-match-expression",
        "title": "Print input element even when capture() fails to match expression"
    },
    {
        "tags": [
            "arrays",
            "linux",
            "bash",
            "for-loop",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 5351266,
                    "reputation": 73064,
                    "user_id": 4265352,
                    "user_type": "registered",
                    "profile_image": "https://lh4.googleusercontent.com/-lzAUc5pYb24/AAAAAAAAAAI/AAAAAAAAAGQ/q3h7bZUnqrs/s256-rj/photo.jpg",
                    "display_name": "axiac",
                    "link": "https://stackoverflow.com/users/4265352/axiac"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1722953406,
                "post_id": 78839494,
                "comment_id": 139000293,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 5351266,
                    "reputation": 73064,
                    "user_id": 4265352,
                    "user_type": "registered",
                    "profile_image": "https://lh4.googleusercontent.com/-lzAUc5pYb24/AAAAAAAAAAI/AAAAAAAAAGQ/q3h7bZUnqrs/s256-rj/photo.jpg",
                    "display_name": "axiac",
                    "link": "https://stackoverflow.com/users/4265352/axiac"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1722953553,
                "post_id": 78839494,
                "comment_id": 139000316,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1722962691,
                "creation_date": 1722962691,
                "answer_id": 78840194,
                "question_id": 78839494,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Start with JSON arrays, not `bash` arrays, for your input data.\r\n\r\n    egress_ports=&#39;[80, 44]&#39;\r\n    egress_values=&#39;[&quot;test&quot;, &quot;test1&quot;]&#39;\r\n    egress_protocols=&#39;[&quot;http&quot;, &quot;https&quot;]&#39;\r\n\r\nThese will be passed as arguments to the `jq` filter directly, from which you will\r\n\r\n 1. Create a nested array `[[80, 443], [&quot;test&quot;, &quot;test1&quot;], [&quot;http&quot;, &quot;https&quot;]]`\r\n 2. Transpose this to `[[80, &quot;test&quot;, &quot;http&quot;], [443, &quot;test1&quot;, &quot;https&quot;]]`\r\n 3. Build an array of objects using each subarray as a separate object\r\n 4. Assign (or merge, with `|=`) this final array directly to `.environments.egress`.\r\n\r\n---\r\n\r\n    jq  --argjson ports &quot;$egress_ports&quot; \\\r\n       --argjson values &quot;$egress_values&quot; \\\r\n       --argjson protocols &quot;$egress_protocols&quot; \\\r\n       &#39;.environments.egress = ([$ports, $values, $protocols] | transpose |\r\n       map ({port: .[0], type: &quot;external&quot;, value: .[1], protocol: .[2]}))&#39; test.json",
                "title": "How to update json with variable array using bash script"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1723129513,
                "last_edit_date": 1723129513,
                "creation_date": 1723129136,
                "answer_id": 78849123,
                "question_id": 78839494,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If you do want to use actual bash arrays, you&#39;ll need to loop:\r\n```bash\r\nports=(80 443)\r\nvalues=(test test1)\r\nprotocols=(http https)\r\njson=$(&lt; test.json)\r\n\r\nfor i in &quot;${!ports[@]}&quot;; do\r\n    json=$(\r\n        echo &quot;$json&quot; \\\r\n        | jq --arg port &quot;${ports[i]}&quot; \\\r\n             --arg value &quot;${values[i]}&quot; \\\r\n             --arg protocol &quot;${protocols[i]}&quot; \\\r\n          &#39;.environments.egress += [\r\n            {$port, $value, $protocol, type: &quot;external&quot;}\r\n          ]&#39;\r\n    )\r\ndone\r\n```\r\nAfter this, the `json` variable contains\r\n```json\r\n{\r\n  &quot;environments&quot;: {\r\n    &quot;egress&quot;: [\r\n      {\r\n        &quot;port&quot;: &quot;80&quot;,\r\n        &quot;value&quot;: &quot;test&quot;,\r\n        &quot;protocol&quot;: &quot;http&quot;,\r\n        &quot;type&quot;: &quot;external&quot;\r\n      },\r\n      {\r\n        &quot;port&quot;: &quot;443&quot;,\r\n        &quot;value&quot;: &quot;test1&quot;,\r\n        &quot;protocol&quot;: &quot;https&quot;,\r\n        &quot;type&quot;: &quot;external&quot;\r\n      }\r\n    ]\r\n  }\r\n}\r\n```\r\n",
                "title": "How to update json with variable array using bash script"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1723129513,
        "creation_date": 1722953100,
        "last_edit_date": 1723036410,
        "question_id": 78839494,
        "body_markdown": "I have a json file test.json with below format:\r\n\r\n    {  \r\n       &quot;environments&quot;: \r\n                {\r\n                    &quot;egress&quot;: [\r\n                       \r\n                    ]\r\n                }\r\n    }\r\n\r\nI want to add objects under egress field with multiple variable values. I have written a bash script test.sh with below code snippet:\r\n\r\n    egress_port=&#39;[80,443]&#39;\r\n    egress_value=&#39;[test,test1]&#39;\r\n    egress_protocol=&#39;[http,https]&#39;\r\n    # IFS=&#39;,&#39;\r\n    \r\n    echo $egress_port\r\n    echo $egress_value\r\n    echo $egress_protocol\r\n    \r\n    cat test.json |\r\n    jq  --argjson port &quot;$egress_port&quot; \\\r\n       --argjson value &quot;$egress_value&quot; \\\r\n       --argjson protocol &quot;$egress_protocol&quot; \\\r\n       &#39;.environments.egress = ([$port, $value, $protocol] | transpose |\r\n       map ({port: .[0], type: &quot;external&quot;, value: .[1], protocol: .[2]}))&#39;\r\n\r\nI want json to be updated in below format:\r\n\r\n    {  \r\n       &quot;environments&quot;: \r\n                {\r\n                    &quot;egress&quot;: [\r\n                       {\r\n                        &quot;port&quot;: &quot;80&quot;, \r\n                        &quot;type&quot;: &quot;external&quot;, \r\n                        &quot;value&quot;: &quot;test&quot;, \r\n                        &quot;protocol&quot;: &quot;http&quot;\r\n                       },\r\n                       {\r\n                        &quot;port&quot;: &quot;443&quot;, \r\n                        &quot;type&quot;: &quot;external&quot;, \r\n                        &quot;value&quot;: &quot;test1&quot;, \r\n                        &quot;protocol&quot;: &quot;https&quot;\r\n                       }\r\n                    ]\r\n                }\r\n    }\r\n\r\nWhen i run it, it throws an error:\r\n\r\n    jq: invalid JSON text passed to --argjson\r\n\r\nCan someone help me here?\r\n",
        "link": "https://stackoverflow.com/questions/78839494/how-to-update-json-with-variable-array-using-bash-script",
        "title": "How to update json with variable array using bash script"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1723022425,
                "last_edit_date": 1723022425,
                "creation_date": 1723022091,
                "answer_id": 78842804,
                "question_id": 78842770,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Try saving the top level `.Schedules` to a variable like so:\r\n``` none\r\n.Schedules as $dflt\r\n| .Servers[].Schedules |= $dflt + .\r\n| {Servers}\r\n```",
                "title": "How to merge the values from the top-level property to each item in the array?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1723022425,
        "creation_date": 1723021437,
        "last_edit_date": 1723021638,
        "question_id": 78842770,
        "body_markdown": "Here&#39;s my sample JSON file:\r\n```lang-json\r\n{\r\n\t&quot;Schedules&quot;: {\r\n\t\t&quot;Days&quot;: [\r\n\t\t\t&quot;Monday&quot;,\r\n\t\t\t&quot;Tuesday&quot;,\r\n\t\t\t&quot;Wednesday&quot;,\r\n\t\t\t&quot;Thursday&quot;,\r\n\t\t\t&quot;Friday&quot;,\r\n\t\t\t&quot;Saturday&quot;,\r\n\t\t\t&quot;Sunday&quot;\r\n\t\t],\r\n\t\t&quot;Times&quot;: [&quot;8:00 AM&quot;, &quot;9:00 AM&quot;, &quot;10:00 AM&quot;]\r\n\t},\r\n\t&quot;Servers&quot;: [\r\n\t\t{\r\n\t\t\t&quot;Name&quot;: &quot;Test&quot;,\r\n\t\t\t&quot;Schedules&quot;: {\r\n\t\t\t\t&quot;Days&quot;: [\r\n\t\t\t\t\t&quot;Monday&quot;,\r\n\t\t\t\t\t&quot;Tuesday&quot;,\r\n\t\t\t\t\t&quot;Wednesday&quot;,\r\n\t\t\t\t\t&quot;Thursday&quot;,\r\n\t\t\t\t\t&quot;Friday&quot;\r\n\t\t\t\t],\r\n\t\t\t\t&quot;Times&quot;: [\r\n\t\t\t\t\t&quot;8:30 AM&quot;,\r\n\t\t\t\t\t&quot;1:30 PM&quot;,\r\n\t\t\t\t\t&quot;5:00 PM&quot;\r\n\t\t\t\t]\r\n\t\t\t}\r\n\t\t},\r\n\t\t{\r\n\t\t\t&quot;Name&quot;: &quot;Staging&quot;,\r\n\t\t\t&quot;Schedules&quot;: {\r\n\t\t\t\t&quot;Times&quot;: [\r\n\t\t\t\t\t&quot;5:00 PM&quot;\r\n\t\t\t\t]\r\n\t\t\t}\r\n\t\t}\r\n\t]\r\n}\r\n```\r\nThe top-level &quot;Schedules&quot; is meant as default value for each item in the &quot;Servers&quot; and can be overridden from each item in the &quot;Servers&quot;. To achieve this, I&#39;m thinking of copying the top-level &quot;Schedules&quot; and replace the values of the local &quot;Schedules&quot; and use the resulting value to replace the local &quot;Schedules&quot;. I tried this command:\r\n```lang-bash\r\njq &#39;.Servers |= map(. + {&quot;Schedules&quot;: .Schedules})&#39;\r\n```\r\nbut it seems .Schedules refers to the local &quot;Schedules&quot; instead of the top-level one.\r\n\r\nThis is what I&#39;m expecting for result:\r\n```lang-json\r\n[\r\n\t{\r\n\t\t&quot;Name&quot;: &quot;Test&quot;,\r\n\t\t&quot;Schedules&quot;: {\r\n\t\t\t&quot;Days&quot;: [\r\n\t\t\t\t&quot;Monday&quot;,\r\n\t\t\t\t&quot;Tuesday&quot;,\r\n\t\t\t\t&quot;Wednesday&quot;,\r\n\t\t\t\t&quot;Thursday&quot;,\r\n\t\t\t\t&quot;Friday&quot;\r\n\t\t\t],\r\n\t\t\t&quot;Times&quot;: [\r\n\t\t\t\t&quot;8:30 AM&quot;,\r\n\t\t\t\t&quot;1:30 PM&quot;,\r\n\t\t\t\t&quot;5:00 PM&quot;\r\n\t\t\t]\r\n\t\t}\r\n\t},\r\n\t{\r\n\t\t&quot;Name&quot;: &quot;Staging&quot;,\r\n\t\t&quot;Schedules&quot;: {\r\n\t\t\t&quot;Days&quot;: [\r\n\t\t\t\t&quot;Monday&quot;,\r\n\t\t\t\t&quot;Tuesday&quot;,\r\n\t\t\t\t&quot;Wednesday&quot;,\r\n\t\t\t\t&quot;Thursday&quot;,\r\n\t\t\t\t&quot;Friday&quot;,\r\n\t\t\t\t&quot;Saturday&quot;,\r\n\t\t\t\t&quot;Sunday&quot;\r\n\t\t\t],\r\n\t\t\t&quot;Times&quot;: [\r\n\t\t\t\t&quot;5:00 PM&quot;\r\n\t\t\t]\r\n\t\t}\r\n\t}\r\n]\r\n```",
        "link": "https://stackoverflow.com/questions/78842770/how-to-merge-the-values-from-the-top-level-property-to-each-item-in-the-array",
        "title": "How to merge the values from the top-level property to each item in the array?"
    },
    {
        "tags": [
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 3597514,
                    "reputation": 122820,
                    "user_id": 3001761,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/feZwC.jpg?s=256",
                    "display_name": "jonrsharpe",
                    "link": "https://stackoverflow.com/users/3001761/jonrsharpe"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1723226164,
                "post_id": 78854080,
                "comment_id": 139026583,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 341129,
                    "reputation": 39418,
                    "user_id": 671543,
                    "user_type": "registered",
                    "accept_rate": 55,
                    "profile_image": "https://www.gravatar.com/avatar/2145962377da9419f2446cd565f614ee?s=256&d=identicon&r=PG",
                    "display_name": "njzk2",
                    "link": "https://stackoverflow.com/users/671543/njzk2"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1723226422,
                "post_id": 78854080,
                "comment_id": 139026608,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1723226362,
                "last_edit_date": 1723226362,
                "creation_date": 1723226221,
                "answer_id": 78854097,
                "question_id": 78854080,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "To extract the list of URLs from the JSON data using jq, you can use the following command:\r\n\r\n    echo $JSON | jq -r &#39;.[] | select(.metricName == &quot;PopularPages&quot;) | .[].url&#39;\r\n\r\nExplanation:\r\n\r\n- `-r`: This flag outputs raw strings instead of JSON-encoded strings.\r\n- `.[]`: This selects each item in the array at the root level of your JSON.\r\n- `select(.metricName == &quot;PopularPages&quot;)`: This filters out the objects where the metricName is &quot;PopularPages&quot;.\r\n- `.[]`: This accesses the array of objects inside the &quot;PopularPages&quot; metric.\r\n- `.url`: This extracts the url field from each object in the array.\r\n\r\nThis command will return each URL on a new line, which matches the desired output format.\r\n\r\nIf your JSON is stored in a file rather than a variable, you can replace `echo $JSON |` with `jq -r &#39;...&#39; yourfile.json`.\r\n",
                "title": "How to extract a list of URLs from JSON using jq"
            },
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1723227101,
                "last_edit_date": 1723227101,
                "creation_date": 1723226565,
                "answer_id": 78854117,
                "question_id": 78854080,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You have selected the object with this part.\r\n```\r\n.[] | select(.metricName == &quot;PopularPages&quot;)\r\n```\r\n\r\nNow you need to drill down to the urls on that object\r\n```\r\n.[] | select(.metricName == &quot;PopularPages&quot;).information[].url\r\n```\r\n",
                "title": "How to extract a list of URLs from JSON using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": -2,
        "last_activity_date": 1724346153,
        "creation_date": 1723225925,
        "last_edit_date": 1724346153,
        "question_id": 78854080,
        "body_markdown": "[Microsoft Clarity](https://www.mslinn.com/blog/2022/03/31/clarity.html#pp) returns JSON. I am able to extract the following portion of JSON using JQ:\r\n\r\n```json\r\n$ echo $JSON | jq &#39;.[] | select(.metricName == &quot;PopularPages&quot;) | .[]&#39;\r\n&quot;PopularPages&quot;\r\n[\r\n  {\r\n    &quot;url&quot;: &quot;https://www.mslinn.com/blog/2023/09/14/boost.html&quot;,\r\n    &quot;visitsCount&quot;: &quot;8&quot;\r\n  },\r\n  {\r\n    &quot;url&quot;: &quot;https://www.mslinn.com/blog/2021/02/11/javascript-named-arguments.html&quot;,\r\n    &quot;visitsCount&quot;: &quot;8&quot;\r\n  },\r\n  {\r\n    &quot;url&quot;: &quot;https://www.mslinn.com/blog/2023/08/20/pytest.html&quot;,\r\n    &quot;visitsCount&quot;: &quot;7&quot;\r\n  },\r\n  {\r\n    &quot;url&quot;: &quot;https://www.mslinn.com/blog/2022/01/10/wsl-backup.html&quot;,\r\n    &quot;visitsCount&quot;: &quot;7&quot;\r\n  },\r\n  {\r\n    &quot;url&quot;: &quot;https://www.mslinn.com/av_studio/640-music21.html&quot;,\r\n    &quot;visitsCount&quot;: &quot;5&quot;\r\n  },\r\n  {\r\n    &quot;url&quot;: &quot;https://www.mslinn.com/llm/4000-wsl.html&quot;,\r\n    &quot;visitsCount&quot;: &quot;4&quot;\r\n  },\r\n  {\r\n    &quot;url&quot;: &quot;https://www.mslinn.com/blog/2021/04/28/buildah-podman.html&quot;,\r\n    &quot;visitsCount&quot;: &quot;4&quot;\r\n  },\r\n  {\r\n    &quot;url&quot;: &quot;https://www.mslinn.com/blog/2020/10/27/installing-a-new-ssh-key-on-awc-ec2-with-user-data.html&quot;,\r\n    &quot;visitsCount&quot;: &quot;3&quot;\r\n  },\r\n  {\r\n    &quot;url&quot;: &quot;https://www.mslinn.com/av_studio/570-ableton-push-standalone.html&quot;,\r\n    &quot;visitsCount&quot;: &quot;3&quot;\r\n  },\r\n  {\r\n    &quot;url&quot;: &quot;https://www.mslinn.com/git/600-partial-clone.html&quot;,\r\n    &quot;visitsCount&quot;: &quot;3&quot;\r\n  }\r\n]\r\n```\r\n\r\nHowever, I cannot figure out how to reduce the above JSON to a list of `url` values, one per line, like this:\r\n\r\n```\r\nhttps://www.mslinn.com/blog/2023/09/14/boost.html\r\nhttps://www.mslinn.com/blog/2021/02/11/javascript-named-arguments.html\r\nhttps://www.mslinn.com/blog/2023/08/20/pytest.html\r\nhttps://www.mslinn.com/blog/2022/01/10/wsl-backup.html\r\nhttps://www.mslinn.com/av_studio/640-music21.html\r\nhttps://www.mslinn.com/llm/4000-wsl.html\r\nhttps://www.mslinn.com/blog/2021/04/28/buildah-podman.html\r\nhttps://www.mslinn.com/blog/2020/10/27/installing-a-new-ssh-key-on-awc-ec2-with-user-data.html\r\nhttps://www.mslinn.com/av_studio/570-ableton-push-standalone.html\r\nhttps://www.mslinn.com/git/600-partial-clone.html\r\n```\r\n\r\nWhat incantation might yield the desired result?\r\n\r\nThe JSON comes back in a structure like this:\r\n\r\n```json\r\n[\r\n    ...\r\n    {\r\n        &quot;metricName&quot;: &quot;PopularPages&quot;,\r\n        &quot;information&quot;: [\r\n            {\r\n                &quot;url&quot;: &quot;https://www.mslinn.com/blog/2023/09/14/boost.html&quot;,\r\n                &quot;visitsCount&quot;: &quot;8&quot;\r\n            },\r\n            {\r\n                &quot;url&quot;: &quot;https://www.mslinn.com/blog/2021/02/11/javascript-named-arguments.html&quot;,\r\n                &quot;visitsCount&quot;: &quot;8&quot;\r\n            },\r\n            {\r\n                &quot;url&quot;: &quot;https://www.mslinn.com/blog/2023/08/20/pytest.html&quot;,\r\n                &quot;visitsCount&quot;: &quot;7&quot;\r\n            },\r\n            {\r\n                &quot;url&quot;: &quot;https://www.mslinn.com/blog/2022/01/10/wsl-backup.html&quot;,\r\n                &quot;visitsCount&quot;: &quot;7&quot;\r\n            },\r\n            {\r\n                &quot;url&quot;: &quot;https://www.mslinn.com/av_studio/640-music21.html&quot;,\r\n                &quot;visitsCount&quot;: &quot;5&quot;\r\n            },\r\n            {\r\n                &quot;url&quot;: &quot;https://www.mslinn.com/llm/4000-wsl.html&quot;,\r\n                &quot;visitsCount&quot;: &quot;4&quot;\r\n            },\r\n            {\r\n                &quot;url&quot;: &quot;https://www.mslinn.com/blog/2021/04/28/buildah-podman.html&quot;,\r\n                &quot;visitsCount&quot;: &quot;4&quot;\r\n            },\r\n            {\r\n                &quot;url&quot;: &quot;https://www.mslinn.com/blog/2020/10/27/installing-a-new-ssh-key-on-awc-ec2-with-user-data.html&quot;,\r\n                &quot;visitsCount&quot;: &quot;3&quot;\r\n            },\r\n            {\r\n                &quot;url&quot;: &quot;https://www.mslinn.com/av_studio/570-ableton-push-standalone.html&quot;,\r\n                &quot;visitsCount&quot;: &quot;3&quot;\r\n            },\r\n            {\r\n                &quot;url&quot;: &quot;https://www.mslinn.com/git/600-partial-clone.html&quot;,\r\n                &quot;visitsCount&quot;: &quot;3&quot;\r\n            }\r\n        ]\r\n    }\r\n]\r\n```",
        "link": "https://stackoverflow.com/questions/78854080/how-to-extract-a-list-of-urls-from-json-using-jq",
        "title": "How to extract a list of URLs from JSON using jq"
    },
    {
        "tags": [
            "json",
            "linux",
            "csv",
            "jq",
            "batch-processing"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 1613587,
                    "reputation": 786618,
                    "user_id": 1491895,
                    "user_type": "registered",
                    "accept_rate": 69,
                    "profile_image": "https://www.gravatar.com/avatar/82f9e178a16364bf561d0ed4da09a35d?s=256&d=identicon&r=PG",
                    "display_name": "Barmar",
                    "link": "https://stackoverflow.com/users/1491895/barmar"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1723475951,
                "post_id": 78861254,
                "comment_id": 139041464,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1486587,
                    "reputation": 15479,
                    "user_id": 1394729,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/B9Ri8.jpg?s=256",
                    "display_name": "tink",
                    "link": "https://stackoverflow.com/users/1394729/tink"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1723481971,
                "post_id": 78861254,
                "comment_id": 139042274,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 503246,
                    "reputation": 117,
                    "user_id": 6743186,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/2273e44496d6b5bed89fc2df80970813?s=256&d=identicon&r=PG",
                    "display_name": "Juhele",
                    "link": "https://stackoverflow.com/users/6743186/juhele"
                },
                "reply_to_user": {
                    "account_id": 1486587,
                    "reputation": 15479,
                    "user_id": 1394729,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/B9Ri8.jpg?s=256",
                    "display_name": "tink",
                    "link": "https://stackoverflow.com/users/1394729/tink"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1723485486,
                "post_id": 78861254,
                "comment_id": 139042595,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1613587,
                    "reputation": 786618,
                    "user_id": 1491895,
                    "user_type": "registered",
                    "accept_rate": 69,
                    "profile_image": "https://www.gravatar.com/avatar/82f9e178a16364bf561d0ed4da09a35d?s=256&d=identicon&r=PG",
                    "display_name": "Barmar",
                    "link": "https://stackoverflow.com/users/1491895/barmar"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1723497498,
                "post_id": 78861254,
                "comment_id": 139043768,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 503246,
                    "reputation": 117,
                    "user_id": 6743186,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/2273e44496d6b5bed89fc2df80970813?s=256&d=identicon&r=PG",
                    "display_name": "Juhele",
                    "link": "https://stackoverflow.com/users/6743186/juhele"
                },
                "reply_to_user": {
                    "account_id": 1613587,
                    "reputation": 786618,
                    "user_id": 1491895,
                    "user_type": "registered",
                    "accept_rate": 69,
                    "profile_image": "https://www.gravatar.com/avatar/82f9e178a16364bf561d0ed4da09a35d?s=256&d=identicon&r=PG",
                    "display_name": "Barmar",
                    "link": "https://stackoverflow.com/users/1491895/barmar"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1723543242,
                "post_id": 78861254,
                "comment_id": 139047065,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1613587,
                    "reputation": 786618,
                    "user_id": 1491895,
                    "user_type": "registered",
                    "accept_rate": 69,
                    "profile_image": "https://www.gravatar.com/avatar/82f9e178a16364bf561d0ed4da09a35d?s=256&d=identicon&r=PG",
                    "display_name": "Barmar",
                    "link": "https://stackoverflow.com/users/1491895/barmar"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1723565541,
                "post_id": 78861254,
                "comment_id": 139050148,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1723830622,
                "last_edit_date": 1723830622,
                "creation_date": 1723483263,
                "answer_id": 78862871,
                "question_id": 78861254,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "From your post it&#39;s quite unclear how many JSON files you have, how they correlate to the API link and what they contain, so I can&#39;t really produce a tested working example; you also mentioned the final goal of a single CSV? I&#39;d expect e.g. the following to work for you:\r\n\r\n    find . -maxdepth 1 -type f -name \\*.json -print0 | xargs -0 -I&quot;^&quot; jq -r &#39;[&quot;id&quot;, &quot;user_id&quot;, &quot;source url&quot;, &quot;status&quot;, &quot;submitted&quot;, &quot;measurements_count&quot;, &quot;approved&quot;, &quot;created_at&quot;, &quot;updated_at&quot;, &quot;name&quot;, &quot;description&quot;, &quot;lines_count&quot;, &quot;credits&quot;, &quot;height&quot;, &quot;orientation&quot;, &quot;cities&quot;, &quot;subtype&quot;, &quot;rejected&quot;], (.[] | [.id, .user_id, .source.url, .status, .submitted, .measurements_count, .approved, .created_at, .updated_at, .name, .description, .lines_count, .credits, .height, .orientation, .cities, .subtype, .rejected]) | @csv&#39; ^ &gt;&gt; data.csv",
                "title": "How to use jq in linux for multiple files?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -2,
        "last_activity_date": 1723830622,
        "creation_date": 1723459748,
        "last_edit_date": 1723816498,
        "question_id": 78861254,
        "body_markdown": "I am trying to convert [SAFECAST API JSON](https://api.safecast.org/en-US/bgeigie_imports?format=json&amp;order=created_at+desc) to a CSV suitable for spreadsheet programs like Excel etc. to prepare some data summaries etc. I have semi-manual WGET script to download several JSON files based on my filters.\r\n\r\nthe JSON files are now available from this shared folder:\r\nhttps://www.mediafire.com/folder/d0f4ztqv19xzl/SAFECAST_API_scripts\r\n\r\nI am able to convert single JSON to usable CSV using jq (Ubuntu linux):\r\n\r\n```\r\ncat bgeigie_imports_001.json |  jq -r &#39;[&quot;id&quot;, &quot;user_id&quot;, &quot;source url&quot;, &quot;status&quot;, &quot;submitted&quot;, &quot;measurements_count&quot;, &quot;approved&quot;, &quot;created_at&quot;, &quot;updated_at&quot;, &quot;name&quot;, &quot;description&quot;, &quot;lines_count&quot;, &quot;credits&quot;, &quot;height&quot;, &quot;orientation&quot;, &quot;cities&quot;, &quot;subtype&quot;, &quot;rejected&quot;], (.[] | [.id, .user_id, .source.url, .status, .submitted, .measurements_count, .approved, .created_at, .updated_at, .name, .description, .lines_count, .credits, .height, .orientation, .cities, .subtype, .rejected]) | @csv &#39; &gt; bgeigie_imports_001.csv\r\n```\r\n\r\nbut I am unable to make it work automatically and convert all json files in the folder ([this thread](https://stackoverflow.com/questions/38203286/batching-cat-command) did not help).\r\n\r\nany ideas? Loading the file names for input/output from a txt file might also help as I have a list from the wget script...\r\n\r\nappreciate any advice, unfortunately my skills are limited\r\n\r\nthanks\r\n\r\nPS: merging the json first using `jq -s &#39;.&#39; *.json &gt; All_data.json` produces somehow different file and the jq command above fails to work properly",
        "link": "https://stackoverflow.com/questions/78861254/how-to-use-jq-in-linux-for-multiple-files",
        "title": "How to use jq in linux for multiple files?"
    },
    {
        "tags": [
            "arrays",
            "json",
            "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": 4,
                "creation_date": 1723537464,
                "post_id": 78865154,
                "comment_id": 139046359,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 33111373,
                    "reputation": 1,
                    "user_id": 25668170,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/7606284a3383ada2b03167ee8bc2515d?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Michael Steed",
                    "link": "https://stackoverflow.com/users/25668170/michael-steed"
                },
                "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": 1723537870,
                "post_id": 78865154,
                "comment_id": 139046411,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 468289,
                    "reputation": 190915,
                    "user_id": 874188,
                    "user_type": "registered",
                    "accept_rate": 62,
                    "profile_image": "https://www.gravatar.com/avatar/091f411d57db5be8298e057a32e5ad72?s=256&d=identicon&r=PG",
                    "display_name": "tripleee",
                    "link": "https://stackoverflow.com/users/874188/tripleee"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1723537977,
                "post_id": 78865154,
                "comment_id": 139046425,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 33111373,
                    "reputation": 1,
                    "user_id": 25668170,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/7606284a3383ada2b03167ee8bc2515d?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Michael Steed",
                    "link": "https://stackoverflow.com/users/25668170/michael-steed"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1723538932,
                "post_id": 78865154,
                "comment_id": 139046534,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "is_answered": false,
        "answer_count": 0,
        "score": 0,
        "last_activity_date": 1723537593,
        "creation_date": 1723537234,
        "last_edit_date": 1723537593,
        "question_id": 78865154,
        "body_markdown": "When parsing a json response using jq run from cmd.exe on a Windows 10 machine, I always get either a null response or an error when trying to get a value present in the JSON. \r\n\r\nHere is the curl: \r\n\r\n    curl -X POST -H &quot;Content-Type: application/json&quot; -H &quot;Accept: application/json&quot; -H &quot;Accept-Encoding: gzip, deflate&quot; --compressed -d &quot;{\\&quot;upc\\&quot;: \\&quot;4002293401102\\&quot;}&quot; &quot;https://api.upcitemdb.com/prod/trial/lookup&quot; | jq &quot;.ean&quot;\r\n\r\nHere is the JSON response. For brevity, I shortened the full response as it&#39;s quite long. \r\n\r\n    {\r\n      &quot;code&quot;: &quot;OK&quot;,\r\n      &quot;total&quot;: 1,\r\n      &quot;offset&quot;: 0,\r\n      &quot;items&quot;: [\r\n        {\r\n          &quot;ean&quot;: &quot;4002293401102&quot;,\r\n          &quot;title&quot;: &quot;Wusthof Gourmet 3-Inch Serrated Paring Knife&quot;,\r\n          &quot;asin&quot;: &quot;B0000DJYE3&quot;,\r\n          &quot;elid&quot;: &quot;192088094351&quot;\r\n        }\r\n      ]\r\n    }\r\n\r\nHere is what I&#39;ve tried in jq to obtain the EAN value. In parenthesis I put abbreviated errors I receive.\r\n\r\n- jq &quot;.items.ean&quot; (I get: jq: error (at &lt;stdin&gt;:0): Cannot index array with string &quot;ean&quot;)\r\n- jq &quot;[items].ean&quot; (I get: curl: Failed writing body)\r\n- jq &quot;.[items].ean&quot; (I get: curl: Failed writing body)\r\n- jq &quot;[].items.ean&quot; (I get: jq: error (at &lt;stdin&gt;:0): Cannot index array with string &quot;items&quot;)\r\n- jq &quot;[].[items].ean&quot; (I get: curl: Failed writing body)\r\n- jq &quot;.items.[ean]&quot; (I get: curl: Failed writing body&quot;\r\n\r\nI&#39;m sure I&#39;m using the wrong syntax for jq. Any ideas what I&#39;m doing wrong? I just cannot seem to get the syntax of getting that value.",
        "link": "https://stackoverflow.com/questions/78865154/jq-returns-null-or-error-when-parsing-json-response",
        "title": "jq returns null or error when parsing json response"
    },
    {
        "tags": [
            "bash",
            "parsing",
            "ansible",
            "sonarqube",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 11829413,
                    "reputation": 15849,
                    "user_id": 8656552,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/BP640.png?s=256",
                    "display_name": "Paul Hodges",
                    "link": "https://stackoverflow.com/users/8656552/paul-hodges"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1723564806,
                "post_id": 78867172,
                "comment_id": 139050024,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1938048,
                    "reputation": 207858,
                    "user_id": 1745001,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/99a3ebae89496eb16afe453aae97f5be?s=256&d=identicon&r=PG",
                    "display_name": "Ed Morton",
                    "link": "https://stackoverflow.com/users/1745001/ed-morton"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1723566078,
                "post_id": 78867172,
                "comment_id": 139050235,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1723575558,
                "last_edit_date": 1723575558,
                "creation_date": 1723565528,
                "answer_id": 78867316,
                "question_id": 78867172,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The best way to handle this IMO is to switch your output plugin to yaml or json and parse the stats with a tool like `jq` or `yq`.\r\n\r\nDummy example\r\n\r\nGiven the following inventory:\r\n```yaml\r\nall:\r\n  vars:\r\n    ansible_connection: local\r\n  hosts:\r\n    test1:\r\n    test2:\r\n```\r\n\r\nAnd the following playbook:\r\n```yaml\r\n---\r\n- hosts: all\r\n  gather_facts: false\r\n  tasks:\r\n    - shell: echo toto\r\n```\r\n\r\nWhich you can execute forcing the output as json with:\r\n```bash\r\n$ ANSIBLE_STDOUT_CALLBACK=ansible.posix.json ansible-playbook -i inventory.yml example.yml\r\n```\r\nYou get the following raw result:\r\n```json\r\n{\r\n    &quot;custom_stats&quot;: {},\r\n    &quot;global_custom_stats&quot;: {},\r\n    &quot;plays&quot;: [\r\n        {\r\n            &quot;play&quot;: {\r\n                &quot;duration&quot;: {\r\n                    &quot;end&quot;: &quot;2024-08-13T16:08:58.760835Z&quot;,\r\n                    &quot;start&quot;: &quot;2024-08-13T16:08:58.451673Z&quot;\r\n                },\r\n                &quot;id&quot;: &quot;519e7ea9-39cf-1a01-4b04-000000000003&quot;,\r\n                &quot;name&quot;: &quot;all&quot;,\r\n                &quot;path&quot;: &quot;/tmp/example.yml:2&quot;\r\n            },\r\n            &quot;tasks&quot;: [\r\n                {\r\n                    &quot;hosts&quot;: {\r\n                        &quot;test1&quot;: {\r\n                            &quot;_ansible_no_log&quot;: null,\r\n                            &quot;action&quot;: &quot;shell&quot;,\r\n                            &quot;changed&quot;: true,\r\n                            &quot;cmd&quot;: &quot;echo toto&quot;,\r\n                            &quot;delta&quot;: &quot;0:00:00.005336&quot;,\r\n                            &quot;end&quot;: &quot;2024-08-13 18:08:58.703006&quot;,\r\n                            &quot;invocation&quot;: {\r\n                                &quot;module_args&quot;: {\r\n                                    &quot;_raw_params&quot;: &quot;echo toto&quot;,\r\n                                    &quot;_uses_shell&quot;: true,\r\n                                    &quot;argv&quot;: null,\r\n                                    &quot;chdir&quot;: null,\r\n                                    &quot;creates&quot;: null,\r\n                                    &quot;executable&quot;: null,\r\n                                    &quot;expand_argument_vars&quot;: true,\r\n                                    &quot;removes&quot;: null,\r\n                                    &quot;stdin&quot;: null,\r\n                                    &quot;stdin_add_newline&quot;: true,\r\n                                    &quot;strip_empty_ends&quot;: true\r\n                                }\r\n                            },\r\n                            &quot;msg&quot;: &quot;&quot;,\r\n                            &quot;rc&quot;: 0,\r\n                            &quot;start&quot;: &quot;2024-08-13 18:08:58.697670&quot;,\r\n                            &quot;stderr&quot;: &quot;&quot;,\r\n                            &quot;stderr_lines&quot;: [],\r\n                            &quot;stdout&quot;: &quot;toto&quot;,\r\n                            &quot;stdout_lines&quot;: [\r\n                                &quot;toto&quot;\r\n                            ]\r\n                        },\r\n                        &quot;test2&quot;: {\r\n                            &quot;_ansible_no_log&quot;: null,\r\n                            &quot;action&quot;: &quot;shell&quot;,\r\n                            &quot;changed&quot;: true,\r\n                            &quot;cmd&quot;: &quot;echo toto&quot;,\r\n                            &quot;delta&quot;: &quot;0:00:00.003842&quot;,\r\n                            &quot;end&quot;: &quot;2024-08-13 18:08:58.736638&quot;,\r\n                            &quot;invocation&quot;: {\r\n                                &quot;module_args&quot;: {\r\n                                    &quot;_raw_params&quot;: &quot;echo toto&quot;,\r\n                                    &quot;_uses_shell&quot;: true,\r\n                                    &quot;argv&quot;: null,\r\n                                    &quot;chdir&quot;: null,\r\n                                    &quot;creates&quot;: null,\r\n                                    &quot;executable&quot;: null,\r\n                                    &quot;expand_argument_vars&quot;: true,\r\n                                    &quot;removes&quot;: null,\r\n                                    &quot;stdin&quot;: null,\r\n                                    &quot;stdin_add_newline&quot;: true,\r\n                                    &quot;strip_empty_ends&quot;: true\r\n                                }\r\n                            },\r\n                            &quot;msg&quot;: &quot;&quot;,\r\n                            &quot;rc&quot;: 0,\r\n                            &quot;start&quot;: &quot;2024-08-13 18:08:58.732796&quot;,\r\n                            &quot;stderr&quot;: &quot;&quot;,\r\n                            &quot;stderr_lines&quot;: [],\r\n                            &quot;stdout&quot;: &quot;toto&quot;,\r\n                            &quot;stdout_lines&quot;: [\r\n                                &quot;toto&quot;\r\n                            ]\r\n                        }\r\n                    },\r\n                    &quot;task&quot;: {\r\n                        &quot;duration&quot;: {\r\n                            &quot;end&quot;: &quot;2024-08-13T16:08:58.760835Z&quot;,\r\n                            &quot;start&quot;: &quot;2024-08-13T16:08:58.458733Z&quot;\r\n                        },\r\n                        &quot;id&quot;: &quot;519e7ea9-39cf-1a01-4b04-000000000005&quot;,\r\n                        &quot;name&quot;: &quot;shell&quot;,\r\n                        &quot;path&quot;: &quot;/tmp/example.yml:5&quot;\r\n                    }\r\n                }\r\n            ]\r\n        }\r\n    ],\r\n    &quot;stats&quot;: {\r\n        &quot;test1&quot;: {\r\n            &quot;changed&quot;: 1,\r\n            &quot;failures&quot;: 0,\r\n            &quot;ignored&quot;: 0,\r\n            &quot;ok&quot;: 1,\r\n            &quot;rescued&quot;: 0,\r\n            &quot;skipped&quot;: 0,\r\n            &quot;unreachable&quot;: 0\r\n        },\r\n        &quot;test2&quot;: {\r\n            &quot;changed&quot;: 1,\r\n            &quot;failures&quot;: 0,\r\n            &quot;ignored&quot;: 0,\r\n            &quot;ok&quot;: 1,\r\n            &quot;rescued&quot;: 0,\r\n            &quot;skipped&quot;: 0,\r\n            &quot;unreachable&quot;: 0\r\n        }\r\n    }\r\n}\r\n\r\n```\r\n\r\nFrom there it is easy to e.g. extract the number of changes for each host and sum them up with `jq`:\r\n```bash\r\n$ ANSIBLE_STDOUT_CALLBACK=ansible.posix.json ansible-playbook -i inventory.yml example.yml \\\r\n| jq &#39;.stats | map(.changed) | add&#39;\r\n2\r\n```\r\n\r\nSince the entire output is json, you can check for whatever you want elsewhere.",
                "title": "Extract (parse) specific strings from a ansible playbook output - bash"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1723575558,
        "creation_date": 1723563669,
        "question_id": 78867172,
        "body_markdown": "I have the following output from a ansible playbook execution.\r\n\r\n```\r\nPLAY [SonarQube on-boarding] ***************************************************\r\n\r\nTASK [Create file directory] ***************************************************\r\nok: [localhost] =&gt; {&quot;changed&quot;: false, &quot;gid&quot;: 20, &quot;group&quot;: &quot;staff&quot;, &quot;mode&quot;: &quot;0777&quot;, &quot;owner&quot;: &quot;abc&quot;, &quot;path&quot;: &quot;./files&quot;, &quot;size&quot;: 96, &quot;state&quot;: &quot;directory&quot;, &quot;uid&quot;: 502}\r\n\r\nTASK [Create tenants permission structure] *************************************\r\nchanged: [localhost] =&gt; {&quot;changed&quot;: true, &quot;checksum&quot;: &quot;d2e330325702090ac3661b7abcf57d1023a758ea&quot;, &quot;dest&quot;: &quot;./files/tenants.yml&quot;, &quot;gid&quot;: 20, &quot;group&quot;: &quot;staff&quot;, &quot;md5sum&quot;: &quot;a0277b8826cd362e2782bf0d25b523fd&quot;, &quot;mode&quot;: &quot;0777&quot;, &quot;owner&quot;: &quot;abc&quot;, &quot;size&quot;: 867, &quot;src&quot;: &quot;/Users/abc/.ansible/tmp/ansible-tmp-1723558954.538402-6040-258956284992736/.source.yml&quot;, &quot;state&quot;: &quot;file&quot;, &quot;uid&quot;: 502}\r\n\r\nTASK [Dynamic load of variable containing tenant structure] ********************\r\nok: [localhost] =&gt; {&quot;ansible_facts&quot;: {&quot;temp_var&quot;: {&quot;tenant&quot;: [{&quot;groupName&quot;: &quot;r-docet-admin&quot;, &quot;name&quot;: &quot;docet&quot;, &quot;permission&quot;: [&quot;admin&quot;], &quot;status&quot;: &quot;present&quot;, &quot;target&quot;: &quot;admin&quot;}, {&quot;groupName&quot;: &quot;r-docet-user&quot;, &quot;name&quot;: &quot;docet&quot;, &quot;permission&quot;: [&quot;profileadmin&quot;, &quot;provisioning&quot;], &quot;status&quot;: &quot;present&quot;, &quot;target&quot;: &quot;user&quot;}, {&quot;groupName&quot;: &quot;r-test_team_b-admin&quot;, &quot;name&quot;: &quot;test_team_b&quot;, &quot;permission&quot;: [&quot;profileadmin&quot;, &quot;scan&quot;], &quot;status&quot;: &quot;present&quot;, &quot;target&quot;: &quot;admin&quot;}, {&quot;groupName&quot;: &quot;r-test_team_b-user&quot;, &quot;name&quot;: &quot;test_team_b&quot;, &quot;permission&quot;: [&quot;scan&quot;], &quot;status&quot;: &quot;present&quot;, &quot;target&quot;: &quot;user&quot;}, {&quot;groupName&quot;: &quot;r-test_team_a-admin&quot;, &quot;name&quot;: &quot;test_team_a&quot;, &quot;permission&quot;: [&quot;profileadmin&quot;, &quot;scan&quot;], &quot;status&quot;: &quot;present&quot;, &quot;target&quot;: &quot;admin&quot;}, {&quot;groupName&quot;: &quot;r-test_team_a-user&quot;, &quot;name&quot;: &quot;test_team_a&quot;, &quot;permission&quot;: [&quot;scan&quot;], &quot;status&quot;: &quot;present&quot;, &quot;target&quot;: &quot;user&quot;}]}}, &quot;ansible_included_var_files&quot;: [&quot;/Users/abc/git/ansible-play-sonarqube-onboard/files/tenants.yml&quot;], &quot;changed&quot;: false}\r\n\r\nTASK [Create file directory] ***************************************************\r\nskipping: [localhost] =&gt; {&quot;changed&quot;: false, &quot;false_condition&quot;: &quot;onboard_action == \\&quot;absent\\&quot;&quot;, &quot;skip_reason&quot;: &quot;Conditional result was False&quot;}\r\n\r\nTASK [Create tenants permission structure] *************************************\r\nskipping: [localhost] =&gt; {&quot;changed&quot;: false, &quot;false_condition&quot;: &quot;onboard_action == \\&quot;absent\\&quot;&quot;, &quot;skip_reason&quot;: &quot;Conditional result was False&quot;}\r\n\r\nTASK [Dynamic load of variable containing tenant structure] ********************\r\nskipping: [localhost] =&gt; {&quot;changed&quot;: false, &quot;false_condition&quot;: &quot;onboard_action == \\&quot;absent\\&quot;&quot;, &quot;skip_reason&quot;: &quot;Conditional result was False&quot;}\r\n\r\nTASK [sonarqube-onboard : Create Sonarqube Groups] *****************************\r\nok: [localhost] =&gt; (item={&#39;name&#39;: &#39;test_team_b&#39;, &#39;status&#39;: &#39;present&#39;, &#39;target&#39;: &#39;user&#39;, &#39;permission&#39;: [&#39;scan&#39;], &#39;groupName&#39;: &#39;r-test_team_b-user&#39;}) =&gt; {&quot;ansible_loop_var&quot;: &quot;item&quot;, &quot;changed&quot;: false, &quot;connection&quot;: &quot;close&quot;, &quot;content&quot;: &quot;{\\&quot;errors\\&quot;:[{\\&quot;msg\\&quot;:\\&quot;Group \\\\u0027r-test_team_b-user\\\\u0027 already exists\\&quot;}]}&quot;, &quot;content_type&quot;: &quot;application/json&quot;, &quot;date&quot;: &quot;Tue, 13 Aug 2024 14:22:43 GMT&quot;, &quot;elapsed&quot;: 0, &quot;item&quot;: {&quot;groupName&quot;: &quot;r-test_team_b-user&quot;, &quot;name&quot;: &quot;test_team_b&quot;, &quot;permission&quot;: [&quot;scan&quot;], &quot;status&quot;: &quot;present&quot;, &quot;target&quot;: &quot;user&quot;}, &quot;json&quot;: {&quot;errors&quot;: [{&quot;msg&quot;: &quot;Group &#39;r-test_team_b-user&#39; already exists&quot;}]}, &quot;msg&quot;: &quot;HTTP Error 400: &quot;, &quot;redirected&quot;: false, &quot;status&quot;: 400, &quot;strict_transport_security&quot;: &quot;max-age=31536000; includeSubDomains&quot;, &quot;transfer_encoding&quot;: &quot;chunked&quot;, &quot;url&quot;: &quot;https://sonarqube.luigi-lab.worldpay.io/api/user_groups/create&quot;, &quot;vary&quot;: &quot;accept-encoding&quot;}\r\nok: [localhost] =&gt; (item={&#39;name&#39;: &#39;test_team_a&#39;, &#39;status&#39;: &#39;present&#39;, &#39;target&#39;: &#39;admin&#39;, &#39;permission&#39;: [&#39;profileadmin&#39;, &#39;scan&#39;], &#39;groupName&#39;: &#39;r-test_team_a-admin&#39;}) =&gt; {&quot;ansible_loop_var&quot;: &quot;item&quot;, &quot;changed&quot;: false, &quot;connection&quot;: &quot;close&quot;, &quot;content&quot;: &quot;{\\&quot;errors\\&quot;:[{\\&quot;msg\\&quot;:\\&quot;Group \\\\u0027r-test_team_a-admin\\\\u0027 already exists\\&quot;}]}&quot;, &quot;content_type&quot;: &quot;application/json&quot;, &quot;date&quot;: &quot;Tue, 13 Aug 2024 14:22:46 GMT&quot;, &quot;elapsed&quot;: 0, &quot;item&quot;: {&quot;groupName&quot;: &quot;r-test_team_a-admin&quot;, &quot;name&quot;: &quot;test_team_a&quot;, &quot;permission&quot;: [&quot;profileadmin&quot;, &quot;scan&quot;], &quot;status&quot;: &quot;present&quot;, &quot;target&quot;: &quot;admin&quot;}, &quot;json&quot;: {&quot;errors&quot;: [{&quot;msg&quot;: &quot;Group &#39;r-test_team_a-admin&#39; already exists&quot;}]}, &quot;msg&quot;: &quot;HTTP Error 400: &quot;, &quot;redirected&quot;: false, &quot;status&quot;: 400, &quot;strict_transport_security&quot;: &quot;max-age=31536000; includeSubDomains&quot;, &quot;transfer_encoding&quot;: &quot;chunked&quot;, &quot;url&quot;: &quot;https://sonarqube.luigi-lab.worldpay.io/api/user_groups/create&quot;, &quot;vary&quot;: &quot;accept-encoding&quot;}\r\nok: [localhost] =&gt; (item={&#39;name&#39;: &#39;test_team_a&#39;, &#39;status&#39;: &#39;present&#39;, &#39;target&#39;: &#39;user&#39;, &#39;permission&#39;: [&#39;scan&#39;], &#39;groupName&#39;: &#39;r-test_team_a-user&#39;}) =&gt; {&quot;ansible_loop_var&quot;: &quot;item&quot;, &quot;changed&quot;: false, &quot;connection&quot;: &quot;close&quot;, &quot;content&quot;: &quot;{\\&quot;errors\\&quot;:[{\\&quot;msg\\&quot;:\\&quot;Group \\\\u0027r-test_team_a-user\\\\u0027 already exists\\&quot;}]}&quot;, &quot;content_type&quot;: &quot;application/json&quot;, &quot;date&quot;: &quot;Tue, 13 Aug 2024 14:22:47 GMT&quot;, &quot;elapsed&quot;: 0, &quot;item&quot;: {&quot;groupName&quot;: &quot;r-test_team_a-user&quot;, &quot;name&quot;: &quot;test_team_a&quot;, &quot;permission&quot;: [&quot;scan&quot;], &quot;status&quot;: &quot;present&quot;, &quot;target&quot;: &quot;user&quot;}, &quot;json&quot;: {&quot;errors&quot;: [{&quot;msg&quot;: &quot;Group &#39;r-test_team_a-user&#39; already exists&quot;}]}, &quot;msg&quot;: &quot;HTTP Error 400: &quot;, &quot;redirected&quot;: false, &quot;status&quot;: 400, &quot;strict_transport_security&quot;: &quot;max-age=31536000; includeSubDomains&quot;, &quot;transfer_encoding&quot;: &quot;chunked&quot;, &quot;url&quot;: &quot;https://sonarqube.luigi-lab.worldpay.io/api/user_groups/create&quot;, &quot;vary&quot;: &quot;accept-encoding&quot;}\r\n\r\nTASK [sonarqube-onboard : Assign Sonarqube Group Permissions] ******************\r\nok: [localhost] =&gt; (item=[{&#39;name&#39;: &#39;test_team_b&#39;, &#39;status&#39;: &#39;present&#39;, &#39;target&#39;: &#39;user&#39;, &#39;groupName&#39;: &#39;r-test_team_b-user&#39;}, &#39;scan&#39;]) =&gt; {&quot;ansible_loop_var&quot;: &quot;item&quot;, &quot;cache_control&quot;: &quot;no-cache, no-store, must-revalidate&quot;, &quot;changed&quot;: false, &quot;connection&quot;: &quot;close&quot;, &quot;content_security_policy&quot;: &quot;default-src &#39;self&#39;; base-uri &#39;none&#39;; connect-src &#39;self&#39; http: https:; img-src * data: blob:; object-src &#39;none&#39;; script-src &#39;self&#39;; style-src &#39;self&#39; &#39;unsafe-inline&#39;; worker-src &#39;none&#39;&quot;, &quot;cookies&quot;: {}, &quot;cookies_string&quot;: &quot;&quot;, &quot;cross_origin_embedder_policy&quot;: &quot;require-corp&quot;, &quot;cross_origin_opener_policy&quot;: &quot;same-origin&quot;, &quot;cross_origin_resource_policy&quot;: &quot;same-origin&quot;, &quot;date&quot;: &quot;Tue, 13 Aug 2024 14:22:58 GMT&quot;, &quot;elapsed&quot;: 0, &quot;item&quot;: [{&quot;groupName&quot;: &quot;r-test_team_b-user&quot;, &quot;name&quot;: &quot;test_team_b&quot;, &quot;status&quot;: &quot;present&quot;, &quot;target&quot;: &quot;user&quot;}, &quot;scan&quot;], &quot;msg&quot;: &quot;OK (unknown bytes)&quot;, &quot;redirected&quot;: false, &quot;status&quot;: 204, &quot;strict_transport_security&quot;: &quot;max-age=31536000; includeSubDomains&quot;, &quot;url&quot;: &quot;https://sonarqube.luigi-lab.worldpay.io/api/permissions/add_group&quot;, &quot;x_content_security_policy&quot;: &quot;default-src &#39;self&#39;; base-uri &#39;none&#39;; connect-src &#39;self&#39; http: https:; img-src * data: blob:; object-src &#39;none&#39;; script-src &#39;self&#39;; style-src &#39;self&#39; &#39;unsafe-inline&#39;; worker-src &#39;none&#39;&quot;, &quot;x_content_type_options&quot;: &quot;nosniff&quot;, &quot;x_frame_options&quot;: &quot;SAMEORIGIN&quot;, &quot;x_webkit_csp&quot;: &quot;default-src &#39;self&#39;; base-uri &#39;none&#39;; connect-src &#39;self&#39; http: https:; img-src * data: blob:; object-src &#39;none&#39;; script-src &#39;self&#39;; style-src &#39;self&#39; &#39;unsafe-inline&#39;; worker-src &#39;none&#39;&quot;, &quot;x_xss_protection&quot;: &quot;1; mode=block&quot;}\r\nok: [localhost] =&gt; (item=[{&#39;name&#39;: &#39;test_team_a&#39;, &#39;status&#39;: &#39;present&#39;, &#39;target&#39;: &#39;admin&#39;, &#39;groupName&#39;: &#39;r-test_team_a-admin&#39;}, &#39;profileadmin&#39;]) =&gt; {&quot;ansible_loop_var&quot;: &quot;item&quot;, &quot;cache_control&quot;: &quot;no-cache, no-store, must-revalidate&quot;, &quot;changed&quot;: false, &quot;connection&quot;: &quot;close&quot;, &quot;content_security_policy&quot;: &quot;default-src &#39;self&#39;; base-uri &#39;none&#39;; connect-src &#39;self&#39; http: https:; img-src * data: blob:; object-src &#39;none&#39;; script-src &#39;self&#39;; style-src &#39;self&#39; &#39;unsafe-inline&#39;; worker-src &#39;none&#39;&quot;, &quot;cookies&quot;: {}, &quot;cookies_string&quot;: &quot;&quot;, &quot;cross_origin_embedder_policy&quot;: &quot;require-corp&quot;, &quot;cross_origin_opener_policy&quot;: &quot;same-origin&quot;, &quot;cross_origin_resource_policy&quot;: &quot;same-origin&quot;, &quot;date&quot;: &quot;Tue, 13 Aug 2024 14:22:59 GMT&quot;, &quot;elapsed&quot;: 0, &quot;item&quot;: [{&quot;groupName&quot;: &quot;r-test_team_a-admin&quot;, &quot;name&quot;: &quot;test_team_a&quot;, &quot;status&quot;: &quot;present&quot;, &quot;target&quot;: &quot;admin&quot;}, &quot;profileadmin&quot;], &quot;msg&quot;: &quot;OK (unknown bytes)&quot;, &quot;redirected&quot;: false, &quot;status&quot;: 204, &quot;strict_transport_security&quot;: &quot;max-age=31536000; includeSubDomains&quot;, &quot;url&quot;: &quot;https://sonarqube.luigi-lab.worldpay.io/api/permissions/add_group&quot;, &quot;x_content_security_policy&quot;: &quot;default-src &#39;self&#39;; base-uri &#39;none&#39;; connect-src &#39;self&#39; http: https:; img-src * data: blob:; object-src &#39;none&#39;; script-src &#39;self&#39;; style-src &#39;self&#39; &#39;unsafe-inline&#39;; worker-src &#39;none&#39;&quot;, &quot;x_content_type_options&quot;: &quot;nosniff&quot;, &quot;x_frame_options&quot;: &quot;SAMEORIGIN&quot;, &quot;x_webkit_csp&quot;: &quot;default-src &#39;self&#39;; base-uri &#39;none&#39;; connect-src &#39;self&#39; http: https:; img-src * data: blob:; object-src &#39;none&#39;; script-src &#39;self&#39;; style-src &#39;self&#39; &#39;unsafe-inline&#39;; worker-src &#39;none&#39;&quot;, &quot;x_xss_protection&quot;: &quot;1; mode=block&quot;}\r\nok: [localhost] =&gt; (item=[{&#39;name&#39;: &#39;test_team_a&#39;, &#39;status&#39;: &#39;present&#39;, &#39;target&#39;: &#39;admin&#39;, &#39;groupName&#39;: &#39;r-test_team_a-admin&#39;}, &#39;scan&#39;]) =&gt; {&quot;ansible_loop_var&quot;: &quot;item&quot;, &quot;cache_control&quot;: &quot;no-cache, no-store, must-revalidate&quot;, &quot;changed&quot;: false, &quot;connection&quot;: &quot;close&quot;, &quot;content_security_policy&quot;: &quot;default-src &#39;self&#39;; base-uri &#39;none&#39;; connect-src &#39;self&#39; http: https:; img-src * data: blob:; object-src &#39;none&#39;; script-src &#39;self&#39;; style-src &#39;self&#39; &#39;unsafe-inline&#39;; worker-src &#39;none&#39;&quot;, &quot;cookies&quot;: {}, &quot;cookies_string&quot;: &quot;&quot;, &quot;cross_origin_embedder_policy&quot;: &quot;require-corp&quot;, &quot;cross_origin_opener_policy&quot;: &quot;same-origin&quot;, &quot;cross_origin_resource_policy&quot;: &quot;same-origin&quot;, &quot;date&quot;: &quot;Tue, 13 Aug 2024 14:23:01 GMT&quot;, &quot;elapsed&quot;: 0, &quot;item&quot;: [{&quot;groupName&quot;: &quot;r-test_team_a-admin&quot;, &quot;name&quot;: &quot;test_team_a&quot;, &quot;status&quot;: &quot;present&quot;, &quot;target&quot;: &quot;admin&quot;}, &quot;scan&quot;], &quot;msg&quot;: &quot;OK (unknown bytes)&quot;, &quot;redirected&quot;: false, &quot;status&quot;: 204, &quot;strict_transport_security&quot;: &quot;max-age=31536000; includeSubDomains&quot;, &quot;url&quot;: &quot;https://sonarqube.luigi-lab.worldpay.io/api/permissions/add_group&quot;, &quot;x_content_security_policy&quot;: &quot;default-src &#39;self&#39;; base-uri &#39;none&#39;; connect-src &#39;self&#39; http: https:; img-src * data: blob:; object-src &#39;none&#39;; script-src &#39;self&#39;; style-src &#39;self&#39; &#39;unsafe-inline&#39;; worker-src &#39;none&#39;&quot;, &quot;x_content_type_options&quot;: &quot;nosniff&quot;, &quot;x_frame_options&quot;: &quot;SAMEORIGIN&quot;, &quot;x_webkit_csp&quot;: &quot;default-src &#39;self&#39;; base-uri &#39;none&#39;; connect-src &#39;self&#39; http: https:; img-src * data: blob:; object-src &#39;none&#39;; script-src &#39;self&#39;; style-src &#39;self&#39; &#39;unsafe-inline&#39;; worker-src &#39;none&#39;&quot;, &quot;x_xss_protection&quot;: &quot;1; mode=block&quot;}\r\nok: [localhost] =&gt; (item=[{&#39;name&#39;: &#39;test_team_a&#39;, &#39;status&#39;: &#39;present&#39;, &#39;target&#39;: &#39;user&#39;, &#39;groupName&#39;: &#39;r-test_team_a-user&#39;}, &#39;scan&#39;]) =&gt; {&quot;ansible_loop_var&quot;: &quot;item&quot;, &quot;cache_control&quot;: &quot;no-cache, no-store, must-revalidate&quot;, &quot;changed&quot;: false, &quot;connection&quot;: &quot;close&quot;, &quot;content_security_policy&quot;: &quot;default-src &#39;self&#39;; base-uri &#39;none&#39;; connect-src &#39;self&#39; http: https:; img-src * data: blob:; object-src &#39;none&#39;; script-src &#39;self&#39;; style-src &#39;self&#39; &#39;unsafe-inline&#39;; worker-src &#39;none&#39;&quot;, &quot;cookies&quot;: {}, &quot;cookies_string&quot;: &quot;&quot;, &quot;cross_origin_embedder_policy&quot;: &quot;require-corp&quot;, &quot;cross_origin_opener_policy&quot;: &quot;same-origin&quot;, &quot;cross_origin_resource_policy&quot;: &quot;same-origin&quot;, &quot;date&quot;: &quot;Tue, 13 Aug 2024 14:23:02 GMT&quot;, &quot;elapsed&quot;: 0, &quot;item&quot;: [{&quot;groupName&quot;: &quot;r-test_team_a-user&quot;, &quot;name&quot;: &quot;test_team_a&quot;, &quot;status&quot;: &quot;present&quot;, &quot;target&quot;: &quot;user&quot;}, &quot;scan&quot;], &quot;msg&quot;: &quot;OK (unknown bytes)&quot;, &quot;redirected&quot;: false, &quot;status&quot;: 204, &quot;strict_transport_security&quot;: &quot;max-age=31536000; includeSubDomains&quot;, &quot;url&quot;: &quot;https://sonarqube.luigi-lab.worldpay.io/api/permissions/add_group&quot;, &quot;x_content_security_policy&quot;: &quot;default-src &#39;self&#39;; base-uri &#39;none&#39;; connect-src &#39;self&#39; http: https:; img-src * data: blob:; object-src &#39;none&#39;; script-src &#39;self&#39;; style-src &#39;self&#39; &#39;unsafe-inline&#39;; worker-src &#39;none&#39;&quot;, &quot;x_content_type_options&quot;: &quot;nosniff&quot;, &quot;x_frame_options&quot;: &quot;SAMEORIGIN&quot;, &quot;x_webkit_csp&quot;: &quot;default-src &#39;self&#39;; base-uri &#39;none&#39;; connect-src &#39;self&#39; http: https:; img-src * data: blob:; object-src &#39;none&#39;; script-src &#39;self&#39;; style-src &#39;self&#39; &#39;unsafe-inline&#39;; worker-src &#39;none&#39;&quot;, &quot;x_xss_protection&quot;: &quot;1; mode=block&quot;}\r\n\r\nPLAY RECAP *********************************************************************\r\nlocalhost                  : ok=6    changed=1    unreachable=0    failed=0    skipped=4    rescued=0    ignored=0   \r\n\r\n\r\n```\r\n\r\nI want to verify that changed = to more than 0 and under TASK [Create tenants permission structure] &quot;changed&quot; is defined as true.\r\n\r\nAlso under TASK [sonarqube-onboard : Create Sonarqube Groups], for all items with name test_team_b I want to verify &#39;status&#39; is defined as  &#39;present&#39;\r\n\r\nWhat would be the best way to achieve this?",
        "link": "https://stackoverflow.com/questions/78867172/extract-parse-specific-strings-from-a-ansible-playbook-output-bash",
        "title": "Extract (parse) specific strings from a ansible playbook output - bash"
    },
    {
        "tags": [
            "json",
            "jq",
            "coalesce"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1723568942,
                "last_edit_date": 1723568942,
                "creation_date": 1723568527,
                "answer_id": 78867516,
                "question_id": 78867476,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can use the [alternative operator](https://jqlang.github.io/jq/manual/#alternative-operator) `//`, which\r\n&gt; produces all the values of its left-hand side that are neither `false` nor `null`, or, if the left-hand side produces no values other than `false` or `null`, then `//` produces all the values of its right-hand side\r\n```sh\r\n.UNIT // .USER_UNIT // ._SYSTEMD_UNIT\r\n```\r\n\r\nYou can also add a constant fourth option as the last default, which is returned if all previous three fail. This can be anything, including the empty string `&quot;&quot;` for blank lines, or even `empty` to disregard these inputs entirely.",
                "title": "how to select Any of available fields with jq?"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1723570062,
                "creation_date": 1723570062,
                "answer_id": 78867611,
                "question_id": 78867476,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Another option is `--output-field`, but it has the side-effect that &quot;_For the former, the &quot;__CURSOR&quot;, &quot;__REALTIME_TIMESTAMP&quot;, &quot;__MONOTONIC_TIMESTAMP&quot;, and &quot;_BOOT_ID&quot; fields are always printed._&quot;\r\n\r\n```\r\njournalctl --output-fields=UNIT,USER_UNIT,SYSTEMD_UNIT  -o json | \r\n    jq &#39;del(.__CURSOR, ._BOOT_ID, .__MONOTONIC_TIMESTAMP, .__REALTIME_TIMESTAMP)&#39; | \r\n    grep -v &#39;{}&#39;\r\n```\r\n\r\nIn the end the `grep -v &#39;{}&#39;` is needed to delete the empty results.",
                "title": "how to select Any of available fields with jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1723576702,
        "creation_date": 1723568003,
        "last_edit_date": 1723576702,
        "question_id": 78867476,
        "body_markdown": "I&#39;m trying to filter some journald logs which might have some-what similar information in different keys.\r\n\r\n`journalctl -o json | head -n 1000  | jq &#39;.UNIT, .USER_UNIT, ._SYSTEMD_UNIT`\r\n\r\nThose 3 keys might have the unit name, depending on how the log entry was created (by the unit, by the system starting the unit, etc)... I don&#39;t care about this and just want to get the related-unit.\r\n\r\nHow can I extract something like `jq &#39;.UNIT OR .USER_UNIT OR ._SYSTEMD_UNIT` (`or` doesn&#39;t work as it is a boolean converter to be used in `select()`, and `|` tries to route to a function)\r\n\r\nI also cannot use `+` because when `.UNIT` key is present there will be something i don&#39;t want to collect in `._SYSTEMD_UNIT`.\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/78867476/how-to-select-any-of-available-fields-with-jq",
        "title": "how to select Any of available fields with jq?"
    },
    {
        "tags": [
            "arrays",
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1723626905,
                "creation_date": 1723626905,
                "answer_id": 78870089,
                "question_id": 78869984,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Solved:\r\n\r\n    b_names.Names as $names | a_names.Names | contains([$names[.counter]])\r\n\r\nIn order to work with 2 arrays at the same time you will need to initialize reference to both of them in separate pipes and only after that you can use functions.",
                "title": "Finding if each element of array 1 exists in array 2"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1723636819,
                "last_edit_date": 1723636819,
                "creation_date": 1723630356,
                "answer_id": 78870359,
                "question_id": 78869984,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "In the question, `a_names` is bound to the contents of the first file, whereas in practice the contents would more probably be bound to `$a_names`, so let&#39;s assume you invoke jq as follows:\r\n\r\n    jq -f program.jq a_names.json b_names.json\r\n\r\nIn this case, a suitable program would be:\r\n```\r\n. as $one\r\n| input as $two\r\n| all($one.Names[]; IN( $two.Names[] ))\r\n```\r\n\r\nHowever, you may also wish to consider the following:\r\n```\r\njq -n &#39;\r\n  def a_names: { &quot;Names&quot;: [&quot;a&quot;,&quot;b&quot;,&quot;c&quot;] } ;\r\n  def b_names: { &quot;Names&quot;: [&quot;b&quot;,&quot;c&quot;] } ;\r\n\r\n  all(a_names.Names[]; IN( b_names.Names[] ))\r\n&#39;\r\n```\r\n\r\nNumerous other variants are possible, but I&#39;d avoid `contains` in this case as its semantics is quite complex.\r\n  \r\n---\r\n\r\nIf the arrays are known to have distinct items in strictly increasing order, or if the overhead of sorting them can be justified, then you could use `subset/1` defined as:\r\n```\r\n# Determine if the input is a subset of s2\r\n# where it is assumed both satisfy (. == unique)\r\ndef subset($s2): \r\n  if length == 0 then true\r\n  else .[0] as $x\r\n  | ($s2 | bsearch($x) ) as $ix\r\n  | if $ix &lt; 0 then false\r\n    else .[1:] | subset($s2[$ix+1:])\r\n    end\r\n  end;\r\n```",
                "title": "Finding if each element of array 1 exists in array 2"
            }
        ],
        "is_answered": false,
        "answer_count": 2,
        "score": -1,
        "last_activity_date": 1723636819,
        "creation_date": 1723625828,
        "last_edit_date": 1723626137,
        "question_id": 78869984,
        "body_markdown": "I have 2 json files: a_names.json and b_names.json.\r\nFile a:\r\n```\r\n{\r\n&quot;Names&quot;: [&quot;a&quot;,&quot;b&quot;,&quot;c&quot;]\r\n}\r\n```\r\nFile b:\r\n```\r\n{\r\n&quot;Names&quot;: [&quot;b&quot;,&quot;c&quot;]\r\n}\r\n```\r\nWhat i tried to do was (say i have a loop with counter ascending from 0): \r\n`a_names.Names | contains([b_names.Names[.counter]])`\r\nAnd the output is an error: Cannot index string with string.\r\nHowever, next code provides a proper boolean output: \r\n`a_names.Names | contains([&quot;b&quot;])`\r\nMy colleague said it&#39;s happening due to me trying to refer to array 2 while being inside of the array 1, but we can&#39;t find a solution.\r\n\r\nP.S. - Same happens with any other &quot;search&quot; function, such as &quot;any&quot;,&quot;IN&quot;, etc...",
        "link": "https://stackoverflow.com/questions/78869984/finding-if-each-element-of-array-1-exists-in-array-2",
        "title": "Finding if each element of array 1 exists in array 2"
    },
    {
        "tags": [
            "json",
            "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": 0,
                "creation_date": 1723631500,
                "post_id": 78870424,
                "comment_id": 139055807,
                "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": 2,
                "creation_date": 1723631873,
                "post_id": 78870424,
                "comment_id": 139055858,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1723631948,
                "post_id": 78870424,
                "comment_id": 139055872,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1723632677,
                "post_id": 78870424,
                "comment_id": 139055949,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 12554128,
                    "reputation": 892,
                    "user_id": 9134545,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/940fe2d12e1ef4a5202f7cc99266baa9?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Fragan",
                    "link": "https://stackoverflow.com/users/9134545/fragan"
                },
                "reply_to_user": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1723632843,
                "post_id": 78870424,
                "comment_id": 139055970,
                "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": 1723633745,
                "post_id": 78870424,
                "comment_id": 139056064,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1723633786,
                "last_edit_date": 1723633786,
                "creation_date": 1723632482,
                "answer_id": 78870517,
                "question_id": 78870424,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You seem to be confusing syntax with values. The quotes are not part of the value; the value starts and ends with `[` and `]`, respectively (not `&quot;[` and `&quot;]`; the latter doesn&#39;t even make sense if the syntax quote was part of the value). To detect objects, you need to check for `{` and `}` prefix and suffix. You need to filter for string values, otherwise you cannot apply the `startswith` filter.\r\n\r\nNote that your values are not valid JSON. However, if you still want to continue, here&#39;s the full program:\r\n\r\n```\r\nmap_values(\r\n    if type == &quot;string&quot; and (startswith(&quot;[&quot;) and endswith(&quot;]&quot;) or startswith(&quot;{&quot;) and endswith(&quot;}&quot;)) then\r\n        gsub(&quot;&#39;&quot;; &quot;\\&quot;&quot;) | fromjson\r\n    else\r\n        .\r\n    end\r\n)\r\n```\r\n\r\nWhen used in a shell context:\r\n\r\n```\r\nparsed_json=$(printf &#39;%s\\n&#39; &quot;$json_string&quot; | jq &#39;map_values(\r\n    if type == &quot;string&quot; and (startswith(&quot;[&quot;) and endswith(&quot;]&quot;) or startswith(&quot;{&quot;) and endswith(&quot;}&quot;)) then\r\n        gsub(&quot;&#39;\\&#39;&#39;&quot;; &quot;\\&quot;&quot;) | fromjson\r\n    else\r\n        .\r\n    end\r\n)&#39;)\r\n```\r\n\r\nor\r\n\r\n```\r\nparsed_json=$(printf &#39;%s\\n&#39; &quot;$json_string&quot; | jq &quot;map_values(\r\n    if type == \\&quot;string\\&quot; and (startswith(\\&quot;[\\&quot;) and endswith(\\&quot;]\\&quot;) or startswith(\\&quot;{\\&quot;) and endswith(\\&quot;}\\&quot;)) then\r\n        gsub(\\&quot;&#39;\\&quot;; \\&quot;\\\\\\&quot;\\&quot;) | fromjson\r\n    else\r\n        .\r\n    end\r\n)&quot;)\r\n```\r\n",
                "title": "jq parse string array and string object"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -1,
        "last_activity_date": 1723633786,
        "creation_date": 1723631261,
        "question_id": 78870424,
        "body_markdown": "I have this json string:\r\n```\r\njson_string=&quot;{\\&quot;emailRecipients\\&quot;:\\&quot;[&#39;test@example.com&#39;, &#39;tes2t@example.com&#39;, &#39;test3@example.com&#39;]\\&quot;, \\&quot;anotherEmails\\&quot;:\\&quot;{&#39;test1&#39;: &#39;test1@example.com&#39;, &#39;test2&#39;: &#39;test2@example.com&#39;, &#39;test3&#39;: &#39;test3@example.com&#39;}\\&quot;, \\&quot;some_key\\&quot;: 3, \\&quot;another_key\\&quot;: \\&quot;some_value\\&quot;}&quot;\r\n```\r\n\r\nI&#39;m trying to use jq to parse the `emailRecipients` as a json array and `anotherEmails` as a json object.\r\n\r\nI&#39;m trying to make a command that can work with any key, not `emailRecipients` just and `anotherEmails`. I also need to keep keys-values that don&#39;t have json objects/arrays inside intact.\r\n\r\nSo I tried to do this:\r\n```\r\nparsed_json=$(echo &quot;$json_string&quot; | jq &#39;with_entries(\r\n    .value |= if startswith(&quot;\\&quot;[&quot;) and endswith(&quot;\\&quot;]&quot;) then\r\n        gsub(&quot;&#39;&#39;&quot;;&quot;\\&quot;&quot;) | fromjson\r\n    else\r\n        .\r\n    end\r\n)&#39;)\r\n```\r\n\r\nBut I don&#39;t know why the gsub isn&#39;t working. Any idea of what I&#39;m doing wrong ?\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/78870424/jq-parse-string-array-and-string-object",
        "title": "jq parse string array and string object"
    },
    {
        "tags": [
            "json",
            "key",
            "try-catch",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 5351266,
                    "reputation": 73064,
                    "user_id": 4265352,
                    "user_type": "registered",
                    "profile_image": "https://lh4.googleusercontent.com/-lzAUc5pYb24/AAAAAAAAAAI/AAAAAAAAAGQ/q3h7bZUnqrs/s256-rj/photo.jpg",
                    "display_name": "axiac",
                    "link": "https://stackoverflow.com/users/4265352/axiac"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1723635295,
                "post_id": 78870675,
                "comment_id": 139056200,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1723635926,
                "creation_date": 1723635926,
                "answer_id": 78870717,
                "question_id": 78870675,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can use the [error supression operator](https://jqlang.github.io/jq/manual/#error-suppression-optional-operator) `?` in combination with the [alternative operator](https://jqlang.github.io/jq/manual/#alternative-operator) `//`:\r\n```sh\r\nwith_entries(\r\n  select(.key | endswith(&quot;.json&quot;)) |= (.value |= fromjson)? // .key |= rtrimstr(&quot;.json&quot;)\r\n)\r\n```\r\n[Demo](https://jqplay.org/s/N05pbmp2BfaJ-ib)",
                "title": "How to assign field name in jq based on a try catch?"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1723810966,
                "creation_date": 1723810966,
                "answer_id": 78879132,
                "question_id": 78870675,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "It&#39;s not pretty but this does what you&#39;re asking\r\n\r\n```sh\r\n# {\r\n#   &quot;a.json&quot;: &quot;{\\&quot;x\\&quot;:42}&quot;,\r\n#   &quot;b.json&quot;: &quot;false&quot;,\r\n#   &quot;c.json&quot;: &quot;no JSON value&quot;,\r\n#   &quot;d&quot;: &quot;key mismatch&quot;\r\n# }\r\n\r\njq &#39;\r\nto_entries\r\n| map( .value as $v | .key as $k\r\n  | if (.key|test(&quot;json&quot;)) \r\n    then ( try {key,value: (.value|fromjson)} catch {key:($k|gsub(&quot;.json&quot;;&quot;&quot;)),value:$v} )  \r\n    else . end\r\n  )\r\n| from_entries&#39;\r\n```\r\n\r\nOutput:\r\n\r\n```json\r\n{\r\n  &quot;a.json&quot;: {\r\n    &quot;x&quot;: 42\r\n  },\r\n  &quot;b.json&quot;: false,\r\n  &quot;c&quot;: &quot;no JSON value&quot;,\r\n  &quot;d&quot;: &quot;key mismatch&quot;\r\n}\r\n```",
                "title": "How to assign field name in jq based on a try catch?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1723810966,
        "creation_date": 1723635145,
        "last_edit_date": 1723666782,
        "question_id": 78870675,
        "body_markdown": "I have a JSON object, some keys of which have names end in `.json`, like this:\r\n\r\n```json\r\n{\r\n    &quot;a.json&quot;: &quot;...&quot;,\r\n    ....\r\n}\r\n```\r\n\r\nThe `&quot;...&quot;` can be either a string which `fromjson` can decode, or something else.\r\n\r\nI want a `jq` filter which will, in the first case, replace the key&#39;s value by its `fromjson` equivalent, e.g. `&quot;{}&quot;` would become `{}`, resulting in:\r\n\r\n```json\r\n{\r\n    &quot;a.json&quot;: {},\r\n   ....\r\n}\r\n```\r\n\r\nOtherwise, the `.json` suffix should be removed from the key, so that if for example the value was `&quot;shh&quot;` the net result would be:\r\n\r\n```json\r\n{\r\n    &quot;a&quot;: &quot;shh&quot;,\r\n    ....\r\n}\r\n```\r\n\r\nAll keys ending with `.json` (like the `a.json` above) should be processed in this way.  Any other key-value pairs should be left unaltered. \r\n\r\nWhen:\r\n```json\r\nwith_entries(\r\n        select(.key|test(&quot;\\.json$&quot;)) as $root\r\n\t\t\t| $root.value = $root.value as $sub | ($sub|try fromjson catch $sub)\r\n)\r\n```\r\n\r\nThis works for the value, but I cannot find a way to chnge the `.key` in the `catch` block.",
        "link": "https://stackoverflow.com/questions/78870675/how-to-assign-field-name-in-jq-based-on-a-try-catch",
        "title": "How to assign field name in jq based on a try catch?"
    },
    {
        "tags": [
            "json",
            "shell",
            "jq",
            "whitelist"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1723693471,
                "creation_date": 1723693471,
                "answer_id": 78873575,
                "question_id": 78873556,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If the object containing the `tags` key lives inside another object&#39;s `default` key (as suggested by your example, although the quotes are missing), you have to include that in the path.\r\n\r\nThere, you can use `IN` [function](https://jqlang.github.io/jq/manual/#sql-style-operators) to test for the containedness of the item in question, which produces a boolean:\r\n```sh\r\nIN(.default.tags[]; &quot;v1.0.0&quot;)\r\n```\r\n\r\nAdditionally, the `--exit-status` (or `-e`) [flag](https://jqlang.github.io/jq/manual/#invoking-jq) can set the exit status dependin on the result.",
                "title": "How to check if there is an exact match in the jq list"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1723754375,
        "creation_date": 1723692930,
        "last_edit_date": 1723754375,
        "question_id": 78873556,
        "body_markdown": "I am trying to find a tag that matches a particular image repository in the Docker registry.\r\n```\r\ncurl -X GET http://my-registry-ip-address/v2/ancean-api/tags/list\\\r\n\r\nresult: {&quot;name&quot;:&quot;ancean-api&quot;,&quot;tags&quot;:[&quot;v1.0.0&quot;,&quot;v19.0.0&quot;,&quot;v11.1.1&quot;]}\r\n```\r\nHow do I check if the v1.0.0(example) tag exists in the json data output as a result above?\r\n\r\n---------------------------------------------------------\r\nI tried\r\n\r\n```\r\ncurl -X GET http://my-registry-ip-address/v2/ancean-api/tags/list | jq &#39;.tags | select(. == v1.0.19)&#39;\r\n```\r\n[jq document](https://jqlang.github.io/jq/manual/#select)\r\nThe jq document attempted to use select but failed.\r\nThe above command is successful regardless of which tag is used.\r\n\r\n```\r\ncurl -X GET http://my-registry-ip-address/v2/ancean-api/tags/list | jq &#39;.tags | .[]&#39; | grep &quot;v1.0.0&quot;\r\n```\r\nI tried to use it with grep but failed.\r\n\r\n---------------------\r\n\r\nProblem Solved\r\n--------------\r\n\r\n\r\nThrough pms&#39;s answer, I solved the problem with the `IN` function.\r\n```\r\ncurl -X GET http://my-registry-ip-address/v2/ancean-api/tags/list | jq IN&#39;(.tags[]; &quot;v1.0.0&quot;)&#39;\r\n```\r\nUsing `IN`, I was able to get the bool value back when there was a specific value in the json data.\r\n[![enter image description here][1]][1]\r\n\r\n\r\n  [1]: https://i.sstatic.net/xVagOGLi.png",
        "link": "https://stackoverflow.com/questions/78873556/how-to-check-if-there-is-an-exact-match-in-the-jq-list",
        "title": "How to check if there is an exact match in the jq list"
    },
    {
        "tags": [
            "bash",
            "curl",
            "jq",
            "xargs"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1723697829,
                "post_id": 78873635,
                "comment_id": 139061642,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 3813614,
                    "reputation": 11350,
                    "user_id": 3163618,
                    "user_type": "registered",
                    "accept_rate": 82,
                    "profile_image": "https://www.gravatar.com/avatar/7baa9537384cb1b60aab8e624d2fde2b?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "qwr",
                    "link": "https://stackoverflow.com/users/3163618/qwr"
                },
                "reply_to_user": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1723698584,
                "post_id": 78873635,
                "comment_id": 139061689,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1723698769,
                "post_id": 78873635,
                "comment_id": 139061701,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 3813614,
                    "reputation": 11350,
                    "user_id": 3163618,
                    "user_type": "registered",
                    "accept_rate": 82,
                    "profile_image": "https://www.gravatar.com/avatar/7baa9537384cb1b60aab8e624d2fde2b?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "qwr",
                    "link": "https://stackoverflow.com/users/3163618/qwr"
                },
                "reply_to_user": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1723698812,
                "post_id": 78873635,
                "comment_id": 139061706,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1723699083,
                "post_id": 78873635,
                "comment_id": 139061721,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1938048,
                    "reputation": 207858,
                    "user_id": 1745001,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/99a3ebae89496eb16afe453aae97f5be?s=256&d=identicon&r=PG",
                    "display_name": "Ed Morton",
                    "link": "https://stackoverflow.com/users/1745001/ed-morton"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1723717246,
                "post_id": 78873635,
                "comment_id": 139063188,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1938048,
                    "reputation": 207858,
                    "user_id": 1745001,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/99a3ebae89496eb16afe453aae97f5be?s=256&d=identicon&r=PG",
                    "display_name": "Ed Morton",
                    "link": "https://stackoverflow.com/users/1745001/ed-morton"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1723717374,
                "post_id": 78873635,
                "comment_id": 139063199,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 3813614,
                    "reputation": 11350,
                    "user_id": 3163618,
                    "user_type": "registered",
                    "accept_rate": 82,
                    "profile_image": "https://www.gravatar.com/avatar/7baa9537384cb1b60aab8e624d2fde2b?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "qwr",
                    "link": "https://stackoverflow.com/users/3163618/qwr"
                },
                "reply_to_user": {
                    "account_id": 1938048,
                    "reputation": 207858,
                    "user_id": 1745001,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/99a3ebae89496eb16afe453aae97f5be?s=256&d=identicon&r=PG",
                    "display_name": "Ed Morton",
                    "link": "https://stackoverflow.com/users/1745001/ed-morton"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1723724631,
                "post_id": 78873635,
                "comment_id": 139063924,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1938048,
                    "reputation": 207858,
                    "user_id": 1745001,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/99a3ebae89496eb16afe453aae97f5be?s=256&d=identicon&r=PG",
                    "display_name": "Ed Morton",
                    "link": "https://stackoverflow.com/users/1745001/ed-morton"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1723724801,
                "post_id": 78873635,
                "comment_id": 139063943,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1723698843,
                "creation_date": 1723698843,
                "answer_id": 78873712,
                "question_id": 78873635,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You don&#39;t need a loop. This should  work:\r\n```\r\ncurl https://data.ninjakiwi.com/btd6/races |\r\njq -r &#39;.body[] | .leaderboard, .metadata | &quot;url = &quot;+., &quot;output = &quot;+((./&quot;/&quot;)[-3:] | join(&quot;/&quot;))+&quot;.json&quot;&#39; |\r\ncurl -Z -K - --create-dirs\r\n```",
                "title": "Curl list of links and save files according to URL hierarchy"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1723698843,
        "creation_date": 1723695855,
        "question_id": 78873635,
        "body_markdown": "From the first API call, a JSON response is returned which includes a bunch of links. I want to curl each link, and download the file to a location based on the last 3 path segments. \r\n\r\nFor example, if the URL is `https://data.ninjakiwi.com/btd6/races/The_Olympics_lzlqex8k/metadata`, then I want to download the file to `races/The_Olympics_lzlqex8k/metadata.json`.  Apparently `cut` cannot handle indexing from the end, so I&#39;ve hardcoded the number of slashes (including 2 in https://) to skip. I came up with an example command. Is there a more elegant way to write this? xargs has showed me this is probably possible without a loop and less subshell usage. \r\n\r\n    for url in $(curl https://data.ninjakiwi.com/btd6/races | jq -r &#39;.body [] | .leaderboard, .metadata&#39;); do         \r\n    echo $url; curl --create-dirs -o $(echo $url | cut -d/ -f5-).json $url; done\r\n",
        "link": "https://stackoverflow.com/questions/78873635/curl-list-of-links-and-save-files-according-to-url-hierarchy",
        "title": "Curl list of links and save files according to URL hierarchy"
    },
    {
        "tags": [
            "json",
            "stream",
            "jq",
            "hjson"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 1912742,
                    "reputation": 16377,
                    "user_id": 1726083,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/757452f7cd7ba2347c667ef9298ceadb?s=256&d=identicon&r=PG",
                    "display_name": "erik258",
                    "link": "https://stackoverflow.com/users/1726083/erik258"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1723838753,
                "post_id": 78880675,
                "comment_id": 139074213,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 202552,
                    "reputation": 12401,
                    "user_id": 449693,
                    "user_type": "registered",
                    "accept_rate": 58,
                    "profile_image": "https://www.gravatar.com/avatar/059e801224986097231a37e6042de92a?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Tony Ennis",
                    "link": "https://stackoverflow.com/users/449693/tony-ennis"
                },
                "reply_to_user": {
                    "account_id": 1912742,
                    "reputation": 16377,
                    "user_id": 1726083,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/757452f7cd7ba2347c667ef9298ceadb?s=256&d=identicon&r=PG",
                    "display_name": "erik258",
                    "link": "https://stackoverflow.com/users/1726083/erik258"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1723839002,
                "post_id": 78880675,
                "comment_id": 139074228,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1912742,
                    "reputation": 16377,
                    "user_id": 1726083,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/757452f7cd7ba2347c667ef9298ceadb?s=256&d=identicon&r=PG",
                    "display_name": "erik258",
                    "link": "https://stackoverflow.com/users/1726083/erik258"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1723839244,
                "post_id": 78880675,
                "comment_id": 139074253,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 202552,
                    "reputation": 12401,
                    "user_id": 449693,
                    "user_type": "registered",
                    "accept_rate": 58,
                    "profile_image": "https://www.gravatar.com/avatar/059e801224986097231a37e6042de92a?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Tony Ennis",
                    "link": "https://stackoverflow.com/users/449693/tony-ennis"
                },
                "reply_to_user": {
                    "account_id": 1912742,
                    "reputation": 16377,
                    "user_id": 1726083,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/757452f7cd7ba2347c667ef9298ceadb?s=256&d=identicon&r=PG",
                    "display_name": "erik258",
                    "link": "https://stackoverflow.com/users/1726083/erik258"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1723839549,
                "post_id": 78880675,
                "comment_id": 139074281,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1912742,
                    "reputation": 16377,
                    "user_id": 1726083,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/757452f7cd7ba2347c667ef9298ceadb?s=256&d=identicon&r=PG",
                    "display_name": "erik258",
                    "link": "https://stackoverflow.com/users/1726083/erik258"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1723840214,
                "post_id": 78880675,
                "comment_id": 139074340,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1912742,
                    "reputation": 16377,
                    "user_id": 1726083,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/757452f7cd7ba2347c667ef9298ceadb?s=256&d=identicon&r=PG",
                    "display_name": "erik258",
                    "link": "https://stackoverflow.com/users/1726083/erik258"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1723840293,
                "post_id": 78880675,
                "comment_id": 139074347,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 166270,
                    "reputation": 135171,
                    "user_id": 390278,
                    "user_type": "registered",
                    "accept_rate": 86,
                    "profile_image": "https://www.gravatar.com/avatar/84715fec547362389d02f5be0ed12814?s=256&d=identicon&r=PG",
                    "display_name": "Jeff Mercado",
                    "link": "https://stackoverflow.com/users/390278/jeff-mercado"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1723842832,
                "post_id": 78880675,
                "comment_id": 139074591,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 195407,
                    "reputation": 34327,
                    "user_id": 438273,
                    "user_type": "registered",
                    "accept_rate": 70,
                    "profile_image": "https://www.gravatar.com/avatar/88ad8bc15f1a9e787531e9b20340973a?s=256&d=identicon&r=PG",
                    "display_name": "jsejcksn",
                    "link": "https://stackoverflow.com/users/438273/jsejcksn"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1724091028,
                "post_id": 78880675,
                "comment_id": 139089726,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1723919045,
                "last_edit_date": 1723919045,
                "creation_date": 1723841821,
                "answer_id": 78880825,
                "question_id": 78880675,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "[Note: the following is a response to the original question, in which the input was described as a sequence of newline-delimited JSON-like records, with the suggestion that each record might be a valid hjson value that was not valid JSON.]\r\n\r\n\r\n&gt; I need to fix the format before I try to process the file.\r\n\r\nFirst, please notice that the proposed &quot;fix&quot; is at best incomplete, as in JSON, the keys must be JSON strings (i.e., with double-quotes).\r\n\r\n\r\nSecond, if your preferred tool requires you to have a single ginormous JSON file, then as others have suggested, the problem is with your preference in that regard.  Since you have indicated a willingness to use jq, please note that the C, Go and Rust implementations thereof all handle JSON streams very nicely, without any need to engage is slurpiness.\r\n\r\nThirdly, there are any number of approaches for converting a quasi-JSON stream such as you have described to a **stream of valid JSON entities**.\r\nI&#39;d focus my attention there.\r\n\r\n---\r\n\r\nUnfortunately the hjson CLI program does not handle streams, and it would probably be unwise to invoke the program zillions of times, so here&#39;s a simple Python program that could be used on new-line-delimited log files:\r\n\r\n```\r\nimport hjson\r\n\r\ndef process_json_line_by_line(stream):\r\n    for line in stream:\r\n        line = line.strip()  # Remove leading/trailing whitespace\r\n        if not line:\r\n            continue  # Skip empty lines\r\n        try:\r\n            # Parse the line as Hjson\r\n            obj = hjson.loads(line)\r\n            print(hjson.dumpsJSON(obj))\r\n        except hjson.HjsonDecodeError as e:\r\n            print(&quot;Failed to parse line:&quot;, line)\r\n            print(&quot;Error:&quot;, e)\r\n\r\nwith open(&#39;test.qjson&#39;, &#39;r&#39;) as file:\r\n    process_json_line_by_line(file)\r\n\r\n```\r\n\r\n---\r\n\r\nAs @pmf pointed out, once the stream of (hjson?) measurements has been converted to a JSON stream, you can use jq to convert that to a JSON array efficiently (i.e. without slurping) by:\r\n```\r\njq -r &#39;&quot;[&quot;, ., (inputs | &quot;,&quot;, .), &quot;]&quot;&#39;\r\n```",
                "title": "array of records without jq&#39;s &quot;slurp&quot;"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1723927315,
                "last_edit_date": 1723927315,
                "creation_date": 1723917960,
                "answer_id": 78882955,
                "question_id": 78880675,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "&gt; The files aren&#39;t valid json; they tend to be sequential json records without separators between them.\r\n\r\nSo long as the input consists of “sequential JSON records” (with or without whitespace between them), jq can handle it. To convert such input to ndjson (i.e. a stream of newline-delimited JSON records), you could simply use `jq .`, but in practice, you will probably want to have the ability to recover from errors, so your jq invocation will probably look something like\r\n\r\n    jq -Rn &#39;recurse(try (inputs|fromjson) catch .) | select(.)&#39;\r\n\r\nFor files which consist of hjson objects that are not JSON objects, then if the individual objects are newline-separated, then you could use the Python hjson package as explained elsewhere on this page. Otherwise, you will probably have a difficult choice: try some hackery (e.g. repairing the damage using sed); write your own parser; remonstrate with the customer; or abandon said customer.\r\n\r\n",
                "title": "array of records without jq&#39;s &quot;slurp&quot;"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1724175294,
                "last_edit_date": 1724175294,
                "creation_date": 1724174961,
                "answer_id": 78893742,
                "question_id": 78880675,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "As long as each document is guaranteed to be on its own line (i.e. a [JSONL](https://jsonlines.org/) file), this a shell-only solution to achieve what you want:\r\n\r\n```sh\r\nprintf &#39;[&#39;\r\nif read -r line; then\r\n   printf &#39;\\n%s&#39; &quot;$line&quot;\r\n   while read -r line; do\r\n      printf &#39;,\\n%s&#39; &quot;$line&quot;\r\n   done\r\nfi\r\nprintf &#39;\\n]\\n&#39;\r\n```\r\n\r\nIt reads from STDIN, so you could place the code in a file and use\r\n\r\n```sh\r\n./fix &lt;a.jsonl\r\n```\r\n\r\nOr you can inline it into an existing shell script using\r\n\r\n```sh\r\n{\r\n   # Place the code provided above here.\r\n} &lt;a.jsonl\r\n```\r\n\r\nFor example,\r\n\r\n```none\r\n$ cat a.jsonl\r\n{ &quot;a&quot;:1, &quot;b&quot;: 2 }\r\n{ &quot;a&quot;:2, &quot;b&quot;: 4 }\r\n{ &quot;a&quot;:3, &quot;b&quot;: 6 }\r\n\r\n$ {\r\n   printf &#39;[&#39;\r\n   if read -r line; then\r\n      printf &#39;\\n%s&#39; &quot;$line&quot;\r\n      while read -r line; do\r\n         printf &#39;,\\n%s&#39; &quot;$line&quot;\r\n      done\r\n   fi\r\n   printf &#39;\\n]\\n&#39;\r\n} &lt;a.jsonl\r\n[\r\n{ &quot;a&quot;:1, &quot;b&quot;: 2 },\r\n{ &quot;a&quot;:2, &quot;b&quot;: 4 },\r\n{ &quot;a&quot;:3, &quot;b&quot;: 6 }\r\n]\r\n```",
                "title": "array of records without jq&#39;s &quot;slurp&quot;"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1724371939,
                "last_edit_date": 1724371939,
                "creation_date": 1724255347,
                "answer_id": 78897897,
                "question_id": 78880675,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Alternative streaming methods using jq:\r\n\r\n```sh\r\n# METHOD #1: \r\n# Add comma after every line. \r\n# Requires an additional step to remove last comma and add brackets\r\njq --stream -Rr &#39;&quot;\\(.),&quot;&#39; file1.txt file2.txt\r\n\r\n# Skip comma on empty lines\r\n# if length &gt; 0 then &quot;\\(.),&quot; else &quot;&quot; end\r\n\r\n\r\n# METHOD #2:\r\n# Read each line and return an array of objects (or &quot;&quot; if there was an error)\r\n# I think this is your solution.\r\njq --stream -R &#39;[., inputs]|map(fromjson? // &quot;&quot;)&#39; file*.txt\r\n\r\n\r\n# METHOD #3: \r\n# A streamable json parser\r\njq --stream -c -R &#39;fromjson&#39; file*.txt\r\n\r\n```\r\n\r\nExample using #2\r\n\r\n```console\r\n$ cat file1.txt \r\n{ &quot;a&quot;:1, &quot;b&quot;: 2 }\r\n{ &quot;a&quot;:2, &quot;b&quot;: 4 }\r\n\r\n$ cat file2.txt \r\n{&quot;html&quot;: &quot;This is a sentence.&quot;}\r\n{&quot;html&quot;: &quot;This is another sentence.&quot;}\r\n\r\n$ cat file3.txt \r\n1\r\n2\r\n\r\n$ cat file4.txt\r\n{&quot;error&quot;: &quot;i am missing a bracket&quot;\r\n\r\n$ jq --stream -R &#39;[., inputs]|map(fromjson? // &quot;&quot;)&#39; file*.txt\r\n[\r\n  {&quot;a&quot;:1,&quot;b&quot;:2},\r\n  {&quot;a&quot;:2,&quot;b&quot;:4},\r\n  {&quot;html&quot;:&quot;This is a sentence.&quot;},\r\n  {&quot;html&quot;:&quot;This is another sentence.&quot;},\r\n  1,\r\n  2,\r\n  &quot;&quot;\r\n]\r\n```\r\n",
                "title": "array of records without jq&#39;s &quot;slurp&quot;"
            }
        ],
        "is_answered": true,
        "answer_count": 4,
        "score": 1,
        "last_activity_date": 1724371939,
        "creation_date": 1723838444,
        "last_edit_date": 1723934632,
        "question_id": 78880675,
        "body_markdown": "1. My customer is producing enormous json-like files, using automation. For this reason they can be enormous; tens of gigabytes or more; I cannot control these files in size or in content.\r\n\r\n2. The files aren&#39;t valid json; they tend to be sequential json records without separators between them.  They look sort of like this:\r\n\r\n    ```\r\n    { &quot;a&quot;:1, &quot;b&quot;: 2, ... }\r\n    { &quot;a&quot;:2, &quot;b&quot;: 4, ... }\r\n    { &quot;a&quot;:3, &quot;b&quot;: 6, ... }\r\n    ```\r\n\r\n3. Our software runs at customer site, autonomously, without my team being present after the initial setup.\r\n\r\n4. Customers have *many* files, and I have *many* customers. Custom coding is a last resort.\r\n\r\n5. I have `jq` in my environment. I would prefer to use what I already have.\r\n\r\nGiven the above set-up, I fear `jq -s` will load entire multi-gigabyte files into memory.\r\n\r\nI need to convert the above semi-json into something valid like:\r\n\r\n```\r\n[\r\n{ &#39;a&#39;:1, &#39;b&#39;: 2, ... },\r\n{ &#39;a&#39;:2, &#39;b&#39;: 4, ... },\r\n{ &#39;a&#39;:3, &#39;b&#39;: 6, ... }\r\n]\r\n```\r\n\r\nand I would like to stream the json while I make this conversion to reduce resource consumption.\r\n\r\nUsing `jq --slurp &quot;.&quot;`, the files are converted to the desired array-of-records.  However `slurp` pulls the entire file into memory and that&#39;s not ok.\r\n\r\nUsing `jq` what&#39;s an alternative &quot;streaming&quot; method?\r\n\r\n",
        "link": "https://stackoverflow.com/questions/78880675/array-of-records-without-jqs-slurp",
        "title": "array of records without jq&#39;s &quot;slurp&quot;"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1724207694,
                "creation_date": 1724207694,
                "answer_id": 78894938,
                "question_id": 78894931,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "```\r\nfile1.json\r\n\r\n{\r\n  &quot;field&quot;: &quot;@timestamp&quot;,\r\n  &quot;value&quot;: &quot;2024-08-20 23:00:13.426&quot;\r\n}\r\n\r\nfile2.json\r\n\r\n{\r\n  &quot;field&quot;: &quot;@message&quot;,\r\n  &quot;value&quot;: &quot;Started&quot;\r\n}\r\n\r\njq -s &#39;.[0].value as $timestamp | .[1].value as $message | {&quot;@timestamp&quot;: $timestamp, &quot;@message&quot;: $message}&#39; file1.json file2.json\r\n\r\n```\r\n\r\n[![enter image description here][1]][1]\r\n\r\n\r\n  [1]: https://i.sstatic.net/Lh99Rhmd.png",
                "title": "jq merge 2 rows to 1"
            },
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1724225134,
                "last_edit_date": 1724225134,
                "creation_date": 1724207821,
                "answer_id": 78894943,
                "question_id": 78894931,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can use the `from_entries` [function](https://jqlang.github.io/jq/manual/#to_entries-from_entries-with_entries), which does exactly what you want, but it requires the future key&#39;s name in a field called `key` or `name`. Thus, first transform the objects to meet this requirement (the `value` field can stay as-is):\r\n```sh\r\njq -s &#39;map({key: .field, value}) | from_entries&#39;\r\n```\r\n```json\r\n{\r\n  &quot;@timestamp&quot;: &quot;2024-08-20 23:00:13.426&quot;,\r\n  &quot;@message&quot;: &quot;Started&quot;\r\n}\r\n```\r\n[Demo](https://jqplay.org/s/sDtLlMlYtgwQugS)\r\n\r\n---\r\n\r\nIn the edited question, you want to apply `from_entries` to pairs of objects from the stream. `_nwise(2)` can bundle them into arrays of two. Also, to capture the output into an array, use brackets around the filter:\r\n```sh\r\njq -s &#39;map({key: .field, value}) | [_nwise(2) | from_entries]&#39;\r\n```\r\n```json\r\n[\r\n  {\r\n    &quot;@timestamp&quot;: &quot;2024-08-20 23:00:13.426&quot;,\r\n    &quot;@message&quot;: &quot;Started-1&quot;\r\n  },\r\n  {\r\n    &quot;@timestamp&quot;: &quot;2024-08-20 23:00:13.427&quot;,\r\n    &quot;@message&quot;: &quot;Started-2&quot;\r\n  }\r\n]\r\n```\r\n[Demo](https://jqplay.org/s/zn5xrvXc2OQqKds)",
                "title": "jq merge 2 rows to 1"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1724246971,
        "creation_date": 1724207331,
        "last_edit_date": 1724246971,
        "question_id": 78894931,
        "body_markdown": "```json\r\n{\r\n  &quot;field&quot;: &quot;@timestamp&quot;,\r\n  &quot;value&quot;: &quot;2024-08-20 23:00:13.426&quot;\r\n}\r\n{\r\n  &quot;field&quot;: &quot;@message&quot;,\r\n  &quot;value&quot;: &quot;Started-1&quot;\r\n}\r\n{\r\n  &quot;field&quot;: &quot;@timestamp&quot;,\r\n  &quot;value&quot;: &quot;2024-08-20 23:00:13.427&quot;\r\n}\r\n{\r\n  &quot;field&quot;: &quot;@message&quot;,\r\n  &quot;value&quot;: &quot;Started-2&quot;\r\n}\r\n```\r\n*Edited to show that the JSONs are repeating block*\r\n\r\nI have JSONs above which need to be merged as below. Please help\r\n```json\r\n[\r\n  {\r\n    &quot;@timestamp&quot;: &quot;2024-08-20 23:00:13.426&quot;,\r\n    &quot;@message&quot;: &quot;Started-1&quot;\r\n  },\r\n  {\r\n    &quot;@timestamp&quot;: &quot;2024-08-20 23:00:13.427&quot;,\r\n    &quot;@message&quot;: &quot;Started-2&quot;\r\n  }\r\n]\r\n```",
        "link": "https://stackoverflow.com/questions/78894931/jq-merge-2-rows-to-1",
        "title": "jq merge 2 rows to 1"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 10275035,
                    "reputation": 121775,
                    "user_id": 7582247,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/KPNHoVDG.png?s=256",
                    "display_name": "Ted Lyngmo",
                    "link": "https://stackoverflow.com/users/7582247/ted-lyngmo"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1724240364,
                "post_id": 78896672,
                "comment_id": 139102904,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1724241118,
                "last_edit_date": 1724241118,
                "creation_date": 1724240162,
                "answer_id": 78896726,
                "question_id": 78896672,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "There&#39;s only a `tostring/0` [function](https://jqlang.github.io/jq/manual/#tostring). Try `(.time | tostring)` instead.\r\n```sh\r\njq &#39;map(.id + &quot; &quot; + (.time | tostring))&#39; a.json\r\n```\r\n\r\nAlternatively, use [string interpolation](https://jqlang.github.io/jq/manual/#string-interpolation), which automatically converts to string:\r\n```sh\r\njq &#39;map(&quot;\\(.id) \\(.time)&quot;)&#39; a.json\r\n```",
                "title": "jq: error: tostring/1 is not defined at &lt;top-level&gt;, line 1:"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -1,
        "last_activity_date": 1724402689,
        "creation_date": 1724239357,
        "last_edit_date": 1724402689,
        "question_id": 78896672,
        "body_markdown": "I have a json array of objects in which I would like to create some string using some values. What I tried was:\r\n\r\n    cat a.json | jq &#39;map(.id+&quot; &quot;+tostring(.time))&#39;\r\n\r\nIt gives the error:\r\n\r\n    jq: error: tostring/1 is not defined at &lt;top-level&gt;, line 1:\r\n\r\nIf I omit the tostring, then the problem is of course that `time` is not a string but a number.\r\n\r\nIs there a way to do this? I could do a workaround using sed+tr, but it is inelegant.\r\n\r\n---\r\n\r\nEDIT: It was suggested to include some sample input. Behold!\r\n\r\n```\r\n[{\r\n    &quot;id&quot;: &quot;399&quot;,\r\n    &quot;time&quot;: 1705655705\r\n},\r\n{\r\n    &quot;id&quot;: &quot;409&quot;,\r\n    &quot;time&quot;: 1723587399\r\n}]\r\n```",
        "link": "https://stackoverflow.com/questions/78896672/jq-error-tostring-1-is-not-defined-at-top-level-line-1",
        "title": "jq: error: tostring/1 is not defined at &lt;top-level&gt;, line 1:"
    },
    {
        "tags": [
            "json",
            "jwt",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1724247522,
                "creation_date": 1724247522,
                "answer_id": 78897289,
                "question_id": 78897278,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If there is only one key, you can use the first item of the array provided by `keys`:\r\n```sh\r\njq -r &#39;.identity.userAssignedIdentities | keys[0]&#39;\r\n```\r\n[Demo](https://jqplay.org/s/TmU7cXt-zrE2p0g)\r\n\r\nIf there is more than one, use `[]` instead of `[0]` to iterate over all keys, which will also be sorted. Use `keys_unsorted[]` for an unsorted list.",
                "title": "How to filter only the object name using jq/jmespath?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1724248528,
        "creation_date": 1724247416,
        "last_edit_date": 1724248528,
        "question_id": 78897278,
        "body_markdown": "I have the following json:\r\n\r\n    {\r\n    &quot;hostNamesDisabled&quot;: false,\r\n    &quot;hostingEnvironmentProfile&quot;: null,\r\n    &quot;httpsOnly&quot;: true,\r\n    &quot;hyperV&quot;: false,\r\n    &quot;identity&quot;: {\r\n        &quot;principalId&quot;: null,\r\n        &quot;tenantId&quot;: null,\r\n        &quot;type&quot;: &quot;UserAssigned&quot;,\r\n        &quot;userAssignedIdentities&quot;: {\r\n            &quot;&lt;random_object_name&gt;&quot;: {\r\n                &quot;clientId&quot;: &quot;xxxx&quot;,\r\n                &quot;principalId&quot;: &quot;xxxx&quot;\r\n            }\r\n        }\r\n    },\r\n    &quot;inProgressOperationId&quot;: null,\r\n    &quot;isDefaultContainer&quot;: null\r\n}\r\n\r\nWith jq, I can easily filter keys like:\r\n\r\n    $ jq -r &#39;.httpsOnly&#39;\r\n    true\r\n\r\nor\r\n\r\n    $ jq -r &#39;.identity.principalId\r\n    null\r\n\r\nand retrieve their respective values, so that I could use them in a shell script as variables.\r\n\r\nQuestion is: how to filter the identity.userAssignedIdentities object to obtain **only the &lt;random_object_name&gt; name/content**, like so:\r\n\r\n    $ jq -r &#39;.identity.userAssignedIdentities.???&#39;\r\n    &lt;random_object_name&gt;\r\n\r\nbut not the remaining key-value pairs?\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/78897278/how-to-filter-only-the-object-name-using-jq-jmespath",
        "title": "How to filter only the object name using jq/jmespath?"
    },
    {
        "tags": [
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 3,
                "creation_date": 1724250534,
                "post_id": 78897526,
                "comment_id": 139104372,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 16515857,
                    "reputation": 31,
                    "user_id": 11933359,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/xVphJrVi.png?s=256",
                    "display_name": "awhisler",
                    "link": "https://stackoverflow.com/users/11933359/awhisler"
                },
                "reply_to_user": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1724250668,
                "post_id": 78897526,
                "comment_id": 139104395,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 6,
                "creation_date": 1724250751,
                "post_id": 78897526,
                "comment_id": 139104408,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 16515857,
                    "reputation": 31,
                    "user_id": 11933359,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/xVphJrVi.png?s=256",
                    "display_name": "awhisler",
                    "link": "https://stackoverflow.com/users/11933359/awhisler"
                },
                "reply_to_user": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1724250889,
                "post_id": 78897526,
                "comment_id": 139104425,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1912742,
                    "reputation": 16377,
                    "user_id": 1726083,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/757452f7cd7ba2347c667ef9298ceadb?s=256&d=identicon&r=PG",
                    "display_name": "erik258",
                    "link": "https://stackoverflow.com/users/1726083/erik258"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1724250891,
                "post_id": 78897526,
                "comment_id": 139104426,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1724251172,
                "post_id": 78897526,
                "comment_id": 139104484,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 16515857,
                    "reputation": 31,
                    "user_id": 11933359,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/xVphJrVi.png?s=256",
                    "display_name": "awhisler",
                    "link": "https://stackoverflow.com/users/11933359/awhisler"
                },
                "reply_to_user": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1724255734,
                "post_id": 78897526,
                "comment_id": 139105119,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1724255851,
                "post_id": 78897526,
                "comment_id": 139105142,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 16515857,
                    "reputation": 31,
                    "user_id": 11933359,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/xVphJrVi.png?s=256",
                    "display_name": "awhisler",
                    "link": "https://stackoverflow.com/users/11933359/awhisler"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1724258788,
                "post_id": 78897526,
                "comment_id": 139105515,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1724260513,
                "post_id": 78897526,
                "comment_id": 139105733,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 16515857,
                    "reputation": 31,
                    "user_id": 11933359,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/xVphJrVi.png?s=256",
                    "display_name": "awhisler",
                    "link": "https://stackoverflow.com/users/11933359/awhisler"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1724261271,
                "post_id": 78897526,
                "comment_id": 139105823,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1724261632,
                "post_id": 78897526,
                "comment_id": 139105870,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1724581206,
                "creation_date": 1724581206,
                "answer_id": 78910970,
                "question_id": 78897526,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I know there are a lot of comments with great snippets but wanted to answer the question for other readers&#39; convenience.\r\n\r\nThe question required to grab all the uploaded_at values, then sort, then determine which is the oldest\r\n\r\nTo get the oldest date:\r\n```\r\ncurl -s https://api-cloud.browserstack.com/app-automate/recent_apps | jq -r &#39;sort_by(.uploaded_at)[0].uploaded_at&#39;\r\n```\r\n\r\nTo get the relevant object of the oldest uploaded_at:\r\n```\r\ncurl -s https://api-cloud.browserstack.com/app-automate/recent_apps | jq -r &#39;sort_by(.uploaded_at)[0]&#39;\r\n```\r\n",
                "title": "Extract oldest entry from JSON"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1724599674,
        "creation_date": 1724250446,
        "last_edit_date": 1724599674,
        "question_id": 78897526,
        "body_markdown": "I&#39;m trying to get a `curl` response and be able to call it like an object. I&#39;ve been googling for a while and have seen a lot of answers around `jq`. I&#39;ve been trying to make that work but I can&#39;t seem to find the exact syntax. My ideal solution is that I grab all the `uploaded_at` values, then sort, then determine which is the oldest.\r\n\r\n\r\nThis is my `curl` command:\r\n```\r\nurl=&quot;https://api-cloud.browserstack.com/app-automate/recent_apps&quot;\r\ncurl -u &quot;xxx:xxx&quot; -X GET &quot;$url&quot;\r\n```\r\nIt returns something like:\r\n\r\n```\r\n[{&quot;app_name&quot;:&quot;FlyreelSample.ipa&quot;,&quot;app_version&quot;:&quot;1.1.0&quot;,&quot;app_url&quot;:&quot;bs://76867867&quot;,&quot;app_id&quot;:&quot;76867867&quot;,&quot;uploaded_at&quot;:&quot;2024-08-21 14:41:53 UTC&quot;},\r\n {&quot;app_name&quot;:&quot;FlyreelSample.ipa&quot;,&quot;app_version&quot;:&quot;1.1.0&quot;,&quot;app_url&quot;:&quot;bs://8567463&quot;,&quot;app_id&quot;:&quot;8567463&quot;,&quot;uploaded_at&quot;:&quot;2024-08-21 14:40:29 UTC&quot;},\r\n {&quot;app_name&quot;:&quot;app-stage-debug.apk&quot;,&quot;app_version&quot;:&quot;1.0&quot;,&quot;app_url&quot;:&quot;bs://834534534&quot;,&quot;app_id&quot;:&quot;834534534&quot;,&quot;uploaded_at&quot;:&quot;2024-08-12 15:00:34 UTC&quot;}\r\n]\r\n```\r\nI&#39;ve tried the following command:\r\n\r\n```\r\ncurl -u &quot;xxxx:xxxxx&quot; -X GET &quot;$url&quot; | jq -r &#39;.uploaded_at&#39;\r\n```\r\nAnd I get the following error:\r\n`jq: error (at &lt;stdin&gt;:0): Cannot index array with string &quot;uploaded_at&quot;`\r\n\r\nI also tried some `sed` and Awk solutions. Also tried putting it to a file but also didn&#39;t work. It never put the values into the file\r\n```\r\ncurl -u &quot;xxxx:xxxxx&quot; -X GET &quot;$url&quot; -d @test.txt\r\n```",
        "link": "https://stackoverflow.com/questions/78897526/extract-oldest-entry-from-json",
        "title": "Extract oldest entry from JSON"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1724329860,
                "post_id": 78901541,
                "comment_id": 139111472,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 7234913,
                    "reputation": 72,
                    "user_id": 7375377,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/Qy7Mp.jpg?s=256",
                    "display_name": "Tam&#225;s Horv&#225;th",
                    "link": "https://stackoverflow.com/users/7375377/tam%c3%a1s-horv%c3%a1th"
                },
                "reply_to_user": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1724330492,
                "post_id": 78901541,
                "comment_id": 139111576,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1724448721,
                "last_edit_date": 1724448721,
                "creation_date": 1724375448,
                "answer_id": 78904004,
                "question_id": 78901541,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Condense bottom-up by first recursively descending into each subordinate `.item` array, and then deleting and moving items from an already condensed `.item` arrays while going back up.\r\n\r\n`candidate(m)` succeeds if the context is an item of interest, i.e. it has no unknown keys and is a parent of exactly `m` child items. A missing `.item` key evaluates to `null` which conveniently also has a `length` of `0`. If the `.item` key is an array, `condense` is recursively applied to its items, from which all candidates with no child items are removed. Eventually, if the context is a candidate with exactly one child item, it is replaced with that child item.\r\n\r\n```sh\r\ndef candidate(m):\r\n  select([del(.item, .name, .description), .item | length] == [0,m]);\r\n\r\ndef condense:\r\n  .item |= (arrays | map(condense) | . - map(candidate(0)))\r\n  | candidate(1) = .item[0];\r\n\r\ncondense\r\n```\r\n```json\r\n{\r\n  &quot;name&quot;: &quot;objects&quot;,\r\n  &quot;description&quot;: &quot;root f&quot;,\r\n  &quot;item&quot;: [\r\n    {\r\n      &quot;name&quot;: &quot;external&quot;,\r\n      &quot;item&quot;: [\r\n        {\r\n          &quot;name&quot;: &quot;buuu&quot;,\r\n          &quot;keep1&quot;: {}\r\n        },\r\n        {\r\n          &quot;name&quot;: &quot;biii&quot;,\r\n          &quot;keep1&quot;: {}\r\n        }\r\n      ],\r\n      &quot;description&quot;: &quot;Whatever comment.&quot;\r\n    },\r\n    {\r\n      &quot;name&quot;: &quot;methods&quot;,\r\n      &quot;item&quot;: [\r\n        {\r\n          &quot;name&quot;: &quot;blaaa&quot;,\r\n          &quot;keep1&quot;: {}\r\n        },\r\n        {\r\n          &quot;name&quot;: &quot;whetever4&quot;,\r\n          &quot;beep1&quot;: {},\r\n          &quot;beep2&quot;: []\r\n        },\r\n        {\r\n          &quot;name&quot;: &quot;partner2&quot;,\r\n          &quot;item&quot;: [\r\n            {\r\n              &quot;name&quot;: &quot;operandx&quot;,\r\n              &quot;beep2&quot;: []\r\n            },\r\n            {\r\n              &quot;name&quot;: &quot;whatever3&quot;,\r\n              &quot;beep1&quot;: {},\r\n              &quot;beep2&quot;: []\r\n            }\r\n          ]\r\n        }\r\n      ]\r\n    }\r\n  ]\r\n}\r\n```\r\n[Demo](https://jqplay.org/s/EOSEkEeJ9BeBDQV)\r\n\r\nNote: In contrast to your expected output, this also condenses the paths `/` (the root), `/objects/afolder`, and `/objects/afolder/methods/partner1`, as they all have (per your rules) only one item and no other keys. To prevent this from happening to the root as a special case, start by processing the root&#39;s items directly, i.e. `.item[] |= condense` ([Demo](https://jqplay.org/s/LC6lJJinqyPESkx)).\r\n",
                "title": "Transform a tree-like json so that single &quot;item&quot; in a list is moved up (from leaf), empty items deleted - using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1724448721,
        "creation_date": 1724329312,
        "last_edit_date": 1724333341,
        "question_id": 78901541,
        "body_markdown": "I have a json that is like a tree of files or folders like this:\r\n\r\n```json\r\n{\r\n    &quot;item&quot;: [\r\n        {\r\n            &quot;name&quot;: &quot;objects&quot;,\r\n\t\t\t&quot;description&quot;: &quot;root f&quot;,\r\n            &quot;item&quot;: [\r\n                {\r\n                    &quot;name&quot;: &quot;external&quot;,\r\n                    &quot;item&quot;: [\r\n                        {\r\n                            &quot;name&quot;: &quot;buuu&quot;,\r\n\t\t\t\t\t\t\t&quot;keep1&quot;: {}\r\n                        },\r\n                        {\r\n                            &quot;name&quot;: &quot;biii&quot;,\r\n\t\t\t\t\t\t\t&quot;keep1&quot;: {}\r\n                        }\r\n                    ],\r\n                    &quot;description&quot;: &quot;Whatever comment.&quot;\r\n                },\r\n                {\r\n                    &quot;name&quot;: &quot;afolder&quot;,\r\n                    &quot;item&quot;: [\r\n                        {\r\n                            &quot;name&quot;: &quot;methods&quot;,\r\n                            &quot;item&quot;: [\r\n\t\t\t\t\t\t\t\t{\r\n\t\t\t\t\t\t\t\t\t&quot;name&quot;: &quot;blaaa&quot;,\r\n                                    &quot;keep1&quot;: {}\r\n\t\t\t\t\t\t\t\t},\r\n\t\t\t\t\t\t\t\t{\r\n\t\t\t\t\t\t\t\t\t&quot;name&quot;: &quot;empty&quot;,\r\n\t\t\t\t\t\t\t\t\t&quot;description&quot;: &quot;Whatever2.&quot;,\r\n\t\t\t\t\t\t\t\t\t&quot;item&quot;: []\r\n\t\t\t\t\t\t\t\t},\r\n                                {\r\n                                    &quot;name&quot;: &quot;partner1&quot;,\r\n                                    &quot;item&quot;: [\r\n                                        {\r\n                                            &quot;name&quot;: &quot;operand&quot;,\r\n                                            &quot;item&quot;: [\r\n                                                {\r\n                                                    &quot;name&quot;: &quot;whetever4&quot;,\r\n                                                    &quot;beep1&quot;: { },\r\n                                                    &quot;beep2&quot;: []\r\n                                                }\r\n                                            ]\r\n                                        }\r\n                                    ]\r\n                                },\r\n\t\t\t\t\t\t\t\t{\r\n\t\t\t\t\t\t\t\t\t&quot;name&quot;: &quot;empty2&quot;,\r\n\t\t\t\t\t\t\t\t\t&quot;description&quot;: &quot;Whatever3.&quot;\r\n\t\t\t\t\t\t\t\t},\r\n                                {\r\n                                    &quot;name&quot;: &quot;partner2&quot;,\r\n                                    &quot;item&quot;: [\r\n\t\t\t\t\t\t\t\t\t\t{\r\n                                            &quot;name&quot;: &quot;operandx&quot;,\r\n                                            &quot;beep2&quot;: []\r\n                                        },\r\n                                        {\r\n                                            &quot;name&quot;: &quot;operand2&quot;,\r\n                                            &quot;item&quot;: [\r\n                                                {\r\n                                                    &quot;name&quot;: &quot;whatever3&quot;,\r\n                                                    &quot;beep1&quot;: { },\r\n                                                    &quot;beep2&quot;: []\r\n                                                }\r\n                                            ]\r\n                                        }\r\n                                    ]\r\n                                }\r\n                            ]\r\n                        }\r\n                    ]\r\n                }\r\n            ]\r\n        }\r\n    ]\r\n}\r\n```\r\n\r\nThe tree is formed by `.item[]` (optional) arrays and `.name` (optionally `.description`) fields. If there are more fields then the item is not deletable!\r\n\r\nSo there are items like\r\n```\r\nobjects/   --&gt; with &quot;root f&quot; comment\r\n  external --&gt; is an item that could be deleted because has no extra fields \r\n  external/buu and external/bii  --&gt; Are non-deletable items, do not move them up to &quot;objects&quot; folder! As there are two items under &quot;exernal&quot;! You only move up single items in a folder!\r\nobjects/afolder\r\nobjects/afolder/methods\r\n  empty and empty2 are to be deleted items (leaf, and only name, description or item fields are there, and the items is practically empty.\r\nobjects/afolder/methods/partner1\r\n  operand  --&gt; is a folder to delete as you will move the &quot;operand/whetever4&quot; under objects/afolder/methods/partner1, and this &quot;operand&quot; will be empty!\r\nobjects/afolder/methods/partner2\r\n operand2 --&gt; must be deleted after the single leaf &quot;whatever3&quot; is moved under objects/afolder/methods/partner2 - next to &quot;operandx&quot; ideally\r\n```\r\n\r\nTherefore the `jq` filter must produce the reorganized json while\r\n- You cannot refer to fields like beep1, beep2, keep1, ... in the jq expression, any number of extra fields can be there in any object\r\n- You should only refer to the fields: item, name, description\r\n- keep the order of the fields the same\r\n- if you add the leaf item to the parent &quot;item&quot; array try to add it to the same location where the directory was present (in the example, whatever3 to the location of the deleted operand2)\r\n- You do not move leafs if there is more than one item in the same item array (you only move up leaf if it is a single item in the folder).\r\n\r\nSo the output must be like:\r\n\r\n```json\r\n{\r\n    &quot;item&quot;: [\r\n        {\r\n            &quot;name&quot;: &quot;objects&quot;,\r\n\t\t\t&quot;description&quot;: &quot;root f&quot;,\r\n            &quot;item&quot;: [\r\n                {\r\n                    &quot;name&quot;: &quot;external&quot;,\r\n                    &quot;item&quot;: [\r\n                        {\r\n                            &quot;name&quot;: &quot;buuu&quot;,\r\n\t\t\t\t\t\t\t&quot;keep1&quot;: {}\r\n                        },\r\n                        {\r\n                            &quot;name&quot;: &quot;biii&quot;,\r\n\t\t\t\t\t\t\t&quot;keep1&quot;: {}\r\n                        }\r\n                    ],\r\n                    &quot;description&quot;: &quot;Whatever comment.&quot;\r\n                },\r\n                {\r\n                    &quot;name&quot;: &quot;afolder&quot;,\r\n                    &quot;item&quot;: [\r\n                        {\r\n                            &quot;name&quot;: &quot;methods&quot;,\r\n                            &quot;item&quot;: [\r\n\t\t\t\t\t\t\t\t{\r\n\t\t\t\t\t\t\t\t\t&quot;name&quot;: &quot;blaaa&quot;,\r\n                                    &quot;keep1&quot;: {}\r\n\t\t\t\t\t\t\t\t},\r\n                                {\r\n                                    &quot;name&quot;: &quot;partner1&quot;,\r\n                                    &quot;item&quot;: [\r\n                                        {\r\n\t\t\t\t\t\t\t\t\t\t\t&quot;name&quot;: &quot;whetever4&quot;,\r\n\t\t\t\t\t\t\t\t\t\t\t&quot;beep1&quot;: { },\r\n\t\t\t\t\t\t\t\t\t\t\t&quot;beep2&quot;: []\r\n                                        }\r\n                                    ]\r\n                                },\r\n                                {\r\n                                    &quot;name&quot;: &quot;partner2&quot;,\r\n                                    &quot;item&quot;: [\r\n\t\t\t\t\t\t\t\t\t\t{\r\n                                            &quot;name&quot;: &quot;operandx&quot;,\r\n                                            &quot;beep2&quot;: []\r\n                                        },\r\n                                        {\r\n\t\t\t\t\t\t\t\t\t\t\t&quot;name&quot;: &quot;whatever3&quot;,\r\n\t\t\t\t\t\t\t\t\t\t\t&quot;beep1&quot;: { },\r\n\t\t\t\t\t\t\t\t\t\t\t&quot;beep2&quot;: []\r\n                                        }\r\n                                    ]\r\n                                }\r\n                            ]\r\n                        }\r\n                    ]\r\n                }\r\n            ]\r\n        }\r\n    ]\r\n}\r\n```",
        "link": "https://stackoverflow.com/questions/78901541/transform-a-tree-like-json-so-that-single-item-in-a-list-is-moved-up-from-lea",
        "title": "Transform a tree-like json so that single &quot;item&quot; in a list is moved up (from leaf), empty items deleted - using jq"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1724508743,
                "last_edit_date": 1724508743,
                "creation_date": 1724451121,
                "answer_id": 78907688,
                "question_id": 78907666,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "One way would be to use `to_entries` to get an array of indices and values, filter for the values and use the indices to remove from both arrays. Alternatively, as suggested by @oguz, use `path` to get the indices:\r\n```sh\r\ndel(.[].searchMetaData | select(.status == &quot;complete&quot;) | (\r\n  .rrStandard, .ccStandard\r\n)[\r\n  .rrStandard | to_entries[] | select(.value | startswith(&quot;XYZ&quot;) | not).key\r\n  # or:  .rrStandard | path(.[] | select(startswith(&quot;XYZ&quot;) | not))[]\r\n])\r\n```\r\n[Demo 1](https://jqplay.org/s/-ZCChCXzf1rK6zm)\r\n[Demo 2](https://jqplay.org/s/urPtqSyyW31IwyI)\r\n\r\nAnother way would be to `reduce` over the `keys` in one array, and delete from both arrays if there is a match. The iteration is in `reverse` order to not affect higher indices after lower ones have been deleted:\r\n```sh\r\n(.[].searchMetaData | select(.status == &quot;complete&quot;)) |= reduce (\r\n  .rrStandard | keys | reverse[]\r\n) as $i (.;\r\n  del((.rrStandard, .ccStandard)[\r\n    select(.rrStandard[$i] | startswith(&quot;XYZ&quot;) | not) | $i\r\n  ])\r\n)\r\n```\r\n[Demo](https://jqplay.org/s/6ASyf0j5Gsivps9)\r\n\r\nYet another way would be to coordinate both arrays and `transpose` them twice. After the first one, the elements line up, and those matching can be deleted in one go:\r\n```sh\r\n(.[].searchMetaData | select(.status == &quot;complete&quot;)) |= . + (\r\n  [.rrStandard, .ccStandard]\r\n  | transpose | map(select(first | startswith(&quot;XYZ&quot;)))\r\n  | transpose | {rrStandard: first, ccStandard: last}\r\n)\r\n```\r\n[Demo](https://jqplay.org/s/rI1xiv6WIeDuzJB)\r\n",
                "title": "Using JQ how to find/remove one element in json array and remove that same element index in other array"
            },
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1724469915,
                "creation_date": 1724469915,
                "answer_id": 78908062,
                "question_id": 78907666,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You&#39;re looking for something like this:\r\n``` none\r\n(.[].searchMetaData | select(.status == &quot;complete&quot;)) |=\r\n[.rrStandard | path (.[] | select(startswith(&quot;XYZ&quot;) | not))] as $p\r\n| (.rrStandard, .ccStandard) |= delpaths($p)\r\n```",
                "title": "Using JQ how to find/remove one element in json array and remove that same element index in other array"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1724508743,
        "creation_date": 1724450420,
        "question_id": 78907666,
        "body_markdown": "I have a json array of hundreds of objects and each object contains (among many other fields) two arrays like this and a status indicator:\r\n\r\n```\r\n&quot;searchMetaData&quot;: {&quot;rrStandard&quot;: [&quot;XYZ5.1&quot;,&quot;6.3&quot;],&quot;ccStandard&quot;: [&quot;46d45a68-a930&quot;,&quot;8cd1dc9a-d6a2&quot;],&quot;status&quot;: &quot;complete&quot;}\r\n```\r\n\r\nFor any object where status is &quot;complete&quot;, I want to look at the rrStandard array and remove any array elements that don&#39;t start with XYZ (ie, it would remove &quot;6.3&quot;).  But I also need to remove the corresponding element in the ccStandard array, but that array doesn&#39;t have patterns I can match on, so I think I would have to remove based on a corresponding index number.\r\n\r\nIs there a way with jq to remove the &quot;6.3&quot; from rrStandard, somehow remember what its index was (e.g. 1) and then remove the element at that same index (e.g. index 1) in the ccStandard array as well?\r\n\r\nIn the production case, these arrays will sometimes have more than just 2 values in the arrays, but the number of elements will match between the two.  So, it may be that I need to remove elements 1,2, and 3 across both arrays for example.\r\n\r\nI&#39;m new to jq and have (I think) figured out how to find and remove the &quot;6.3&quot; from rrStandard but from there I&#39;m lost.\r\n\r\nHere is what I have so far to simply find and delete the &quot;6.3&quot; from rrStandard:\r\n\r\n```\r\n.[].searchMetaData |= if(.status == &quot;complete&quot;) then (del(.rrStandard[] | select(startswith(&quot;XYZ&quot;) | not))) else . end\r\n```",
        "link": "https://stackoverflow.com/questions/78907666/using-jq-how-to-find-remove-one-element-in-json-array-and-remove-that-same-eleme",
        "title": "Using JQ how to find/remove one element in json array and remove that same element index in other array"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1724548622,
                "last_edit_date": 1724548622,
                "creation_date": 1724547972,
                "answer_id": 78910261,
                "question_id": 78910251,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The [update operation](https://jqlang.github.io/jq/manual/#update-assignment) `|=` is an assignment with the context of the LHS promoted to the RHS. With that, `.start`, `.size`, and `.end` can be resolved correctly.\r\n```sh\r\njq &#39;.partitiontable.partitions[] |= (.end = .start + .size)&#39;\r\n```\r\n```json\r\n{\r\n  &quot;partitiontable&quot;: {\r\n    &quot;label&quot;: &quot;gpt&quot;,\r\n    &quot;partitions&quot;: [\r\n      {\r\n        &quot;node&quot;: &quot;/dev/nvme0n1p1&quot;,\r\n        &quot;start&quot;: 2048,\r\n        &quot;size&quot;: 204801,\r\n        &quot;end&quot;: 206849\r\n      },\r\n      {\r\n        &quot;node&quot;: &quot;/dev/nvme0n1p2&quot;,\r\n        &quot;start&quot;: 208896,\r\n        &quot;size&quot;: 4097,\r\n        &quot;end&quot;: 212993\r\n      },\r\n      {\r\n        &quot;node&quot;: &quot;/dev/nvme0n1p3&quot;,\r\n        &quot;start&quot;: 243712,\r\n        &quot;size&quot;: 65501185,\r\n        &quot;end&quot;: 65744897\r\n      },\r\n      {\r\n        &quot;node&quot;: &quot;/dev/nvme0n1p4&quot;,\r\n        &quot;start&quot;: 65810432,\r\n        &quot;size&quot;: 3841118208,\r\n        &quot;end&quot;: 3906928640\r\n      }\r\n    ]\r\n  }\r\n}\r\n```\r\n[Demo](https://jqplay.org/s/GWD4I3XyuleFIRZ)",
                "title": "jq: Calculating a new property in local context nested within identity transform"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1724548622,
        "creation_date": 1724547524,
        "question_id": 78910251,
        "body_markdown": "Example JSON with many properties at various levels elided:\r\n\r\n    {\r\n      &quot;partitiontable&quot;: {\r\n        &quot;label&quot;: &quot;gpt&quot;,\r\n        &quot;partitions&quot;: [\r\n          {\r\n            &quot;node&quot;: &quot;/dev/nvme0n1p1&quot;,\r\n            &quot;start&quot;: 2048,\r\n            &quot;size&quot;: 204801\r\n          },\r\n          {\r\n            &quot;node&quot;: &quot;/dev/nvme0n1p2&quot;,\r\n            &quot;start&quot;: 208896,\r\n            &quot;size&quot;: 4097\r\n          },\r\n          {\r\n            &quot;node&quot;: &quot;/dev/nvme0n1p3&quot;,\r\n            &quot;start&quot;: 243712,\r\n            &quot;size&quot;: 65501185\r\n          },\r\n          {\r\n            &quot;node&quot;: &quot;/dev/nvme0n1p4&quot;,\r\n            &quot;start&quot;: 65810432,\r\n            &quot;size&quot;: 3841118208\r\n          }\r\n        ]\r\n      }\r\n    }\r\n\r\nwithin each element of the &#39;partitions&#39; array, I&#39;d like to perform the property-creation operation: .end = .start + .size resulting in a document such as:\r\n\r\n    {\r\n      &quot;partitiontable&quot;: {\r\n        &quot;label&quot;: &quot;gpt&quot;,\r\n        &quot;partitions&quot;: [\r\n          {\r\n            &quot;end&quot;: 206849,\r\n            &quot;node&quot;: &quot;/dev/nvme0n1p1&quot;,\r\n            &quot;start&quot;: 2048,\r\n            &quot;size&quot;: 204801\r\n          },\r\n          {\r\n            &quot;end&quot;: 212993,\r\n            &quot;node&quot;: &quot;/dev/nvme0n1p2&quot;,\r\n            &quot;start&quot;: 208896,\r\n            &quot;size&quot;: 4097\r\n          },\r\n          {\r\n            &quot;end&quot;: 65744897,\r\n            &quot;node&quot;: &quot;/dev/nvme0n1p3&quot;,\r\n            &quot;start&quot;: 243712,\r\n            &quot;size&quot;: 65501185\r\n          },\r\n          {\r\n            &quot;end&quot;: 3906928640,\r\n            &quot;node&quot;: &quot;/dev/nvme0n1p4&quot;,\r\n            &quot;start&quot;: 65810432,\r\n            &quot;size&quot;: 3841118208\r\n          }\r\n        ]\r\n      }\r\n    }\r\n\r\nThere could be many other properties within each object that I&#39;ll need to preserve (hopefully without explicit enumeration).\r\n\r\nI&#39;ve attempted straight-out .partitiontable.partitions[].end = .size + .start, but those &#39;end&#39; properties wind up null, I&#39;m presuming because there&#39;s no &#39;context&#39;.\r\nI&#39;ve also tried using the &#39;..&#39; operator to recurse, but I only get the local-scoping object as output. (jq &#39;.. | objects | select(.start) | .end = .start + .size&#39; results in the array objects but loses the outer document.)",
        "link": "https://stackoverflow.com/questions/78910251/jq-calculating-a-new-property-in-local-context-nested-within-identity-transform",
        "title": "jq: Calculating a new property in local context nested within identity transform"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1725272187,
                "last_edit_date": 1725272187,
                "creation_date": 1725270938,
                "answer_id": 78939877,
                "question_id": 78939784,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Convert all `.Identity` strings into numbers, and remove leading or trailing spaces from the `.message` fields (for clean spacing as in the desired output). Then iterate over the array and either append an item&#39;s message to the last message (with a re-included single space in between), or the item itself to the array, depending on the difference in their `.Identity` fields. Finally, remove all leftover `.Identity` fields.\r\n\r\n```sh\r\nmap(.Identity |= tonumber | .message |= (ltrimstr(&quot; &quot;) | rtrimstr(&quot; &quot;)))\r\n| reduce .[] as $i ([];\r\n    if last.Identity != $i.Identity - 1 then . += [$i] else\r\n      last.Identity += 1 | last.message += &quot; &quot; + $i.message\r\n    end\r\n  )\r\n| del(.[].Identity)\r\n```\r\n```json\r\n[\r\n  {\r\n    &quot;message&quot;: &quot;This is a car&quot;\r\n  },\r\n  {\r\n    &quot;message&quot;: &quot;My Job Is a Student&quot;\r\n  }\r\n]\r\n```\r\n[Demo](https://jqplay.org/s/_uBBjNgG7KtTSon)\r\n\r\nThis assumes that the input array is already sorted. If not, perform the sorting initially by starting with `map(.Identity |= tonumber | .message |= (…)) | sort_by(.Identity) | reduce …` instead.",
                "title": "How to add consecutive numbers of messages in jq command"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1726115063,
        "creation_date": 1725269544,
        "last_edit_date": 1726115063,
        "question_id": 78939784,
        "body_markdown": "I couldn&#39;t figure out how to do this, so I asked here.&lt;br&gt;\r\n\r\n```json\r\n[\r\n  {\r\n    &quot;message&quot; : &quot;This is&quot;,\r\n    &quot;Identity&quot; : &quot;1&quot;\r\n  },\r\n  {\r\n    &quot;message&quot; : &quot; a car&quot;,\r\n    &quot;Identity&quot; : &quot;2&quot;\r\n  },\r\n  {\r\n    &quot;message&quot; : &quot;My Job&quot;,\r\n    &quot;Identity&quot; : &quot;11&quot;\r\n  },\r\n  {\r\n    &quot;message&quot; : &quot;Is a &quot;,\r\n    &quot;Identity&quot; : &quot;12&quot;\r\n  },\r\n  {\r\n    &quot;message&quot; : &quot;Student&quot;,\r\n    &quot;Identity&quot; : &quot;13&quot;\r\n  }\r\n]\r\n\r\n\r\n```\r\n&lt;br&gt;\r\n1 and 2, 11 and 12 are made up of consecutive numbers.&lt;br&gt;\r\nI would like to group messages made up of consecutive numbers like this and add them starting from the smallest order.&lt;br&gt;\r\n\r\n```json\r\n[\r\n  {\r\n    &quot;message&quot; : &quot;This is a car&quot;\r\n  },\r\n  {\r\n    &quot;message&quot; : &quot;My Job Is a Student&quot;\r\n  }\r\n]\r\n```\r\n&lt;br&gt;\r\nI can&#39;t remember the mathematical formula, so I would appreciate if you could help me with the formula.\r\n\r\n&lt;br&gt;&lt;br&gt;&lt;br&gt;\r\n```\r\n# cat a.json\r\n{\r\n    &quot;events&quot;: [\r\n        {\r\n            &quot;message&quot;: &quot;# Time: 2024-09-11T17:42:56.069052Z\\n# User@Host: test_account[test_account] @  [127.0.0.1]  Id: 1760882\\n# Query_time: 1.090218  Lock_time: 0.000012 Rows_sent: 0  Rows_examined: 0 Thread_id: 1760883 Errno: 0 Killed: 0 Bytes_received: 0 Bytes_sent: 0 Read_first: 0 Read_last: 0 Read_key: 0 Read_next: 0 Read_prev: 0 Read_rnd: 0 Read_rnd_next: 0 Sort_merge_passes: 0 Sort_range_count: 0 Sort_rows: 0 Sort_scan_count: 0 Created_tmp_disk_tables: 0 Created_tmp_tables: 0 Start: 2024-09-11T17:42:54.978834Z End: 2024-09-11T17:42:56.069052Z\\nuse testdb;\\nSET timestamp=1726076574;&quot;, \r\n            &quot;eventId&quot;: &quot;38492793916066929644073647519700311240525639687799308288&quot;\r\n        }, \r\n        {\r\n            &quot;message&quot;: &quot;INSERT INTO test_table (c1, c2, c3) &quot;,\r\n            &quot;eventId&quot;: &quot;38492793916066929644073647519700311240525639687799308289&quot;\r\n        },\r\n        {\r\n            &quot;message&quot;: &quot;# Time: 2024-09-11T17:42:56.069052Z\\n# User@Host: test_account[test_account] @  [127.0.0.1]  Id: 1760883\\n# Query_time: 1.090218  Lock_time: 0.000012 Rows_sent: 0  Rows_examined: 0 Thread_id: 1760883 Errno: 0 Killed: 0 Bytes_received: 0 Bytes_sent: 0 Read_first: 0 Read_last: 0 Read_key: 0 Read_next: 0 Read_prev: 0 Read_rnd: 0 Read_rnd_next: 0 Sort_merge_passes: 0 Sort_range_count: 0 Sort_rows: 0 Sort_scan_count: 0 Created_tmp_disk_tables: 0 Created_tmp_tables: 0 Start: 2024-09-11T17:42:54.978834Z End: 2024-09-11T17:42:56.069052Z\\nuse testdb;\\nSET timestamp=1726076574;&quot;, \r\n            &quot;eventId&quot;: &quot;38492793916066929644073647519700311240525639687799308291&quot;\r\n        }, \r\n        {\r\n            &quot;message&quot;: &quot;INSERT INTO test_table (c1, c2, c3) &quot;,\r\n            &quot;eventId&quot;: &quot;38492793916066929644073647519700311240525639687799308292&quot;\r\n        },\r\n        {\r\n            &quot;message&quot;: &quot;# Time: 2024-09-11T17:42:56.069052Z\\n# User@Host: test_account[test_account] @  [127.0.0.1]  Id: 1760884\\n# Query_time: 1.090218  Lock_time: 0.000012 Rows_sent: 0  Rows_examined: 0 Thread_id: 1760883 Errno: 0 Killed: 0 Bytes_received: 0 Bytes_sent: 0 Read_first: 0 Read_last: 0 Read_key: 0 Read_next: 0 Read_prev: 0 Read_rnd: 0 Read_rnd_next: 0 Sort_merge_passes: 0 Sort_range_count: 0 Sort_rows: 0 Sort_scan_count: 0 Created_tmp_disk_tables: 0 Created_tmp_tables: 0 Start: 2024-09-11T17:42:54.978834Z End: 2024-09-11T17:42:56.069052Z\\nuse testdb;\\nSET timestamp=1726076574;&quot;, \r\n            &quot;eventId&quot;: &quot;38492793916066929644073647519700311240525639687799308293&quot;\r\n        }\r\n    ]\r\n}\r\n\r\n# cat b.json\r\n{\r\n    &quot;events&quot;: [\r\n        {\r\n            &quot;message&quot;: &quot;# Time: 2024-09-11T16:00:09.408435Z\\n# User@Host: test_account[test_account] @  [127.0.0.1]  Id: 5436754\\n# Query_time: 0.612487  Lock_time: 0.000003 Rows_sent: 1  Rows_examined: 130154 Thread_id: 5436754 Errno: 0 Killed: 0 Bytes_received: 0 Bytes_sent: 0 Read_first: 0 Read_last: 0 Read_key: 65078 Read_next: 130154 Read_prev: 0 Read_rnd: 0 Read_rnd_next: 0 Sort_merge_passes: 0 Sort_range_count: 0 Sort_rows: 0 Sort_scan_count: 0 Created_tmp_disk_tables: 0 Created_tmp_tables: 0 Start: 2024-09-11T16:00:08.795948Z End: 2024-09-11T16:00:09.408435Z\\nuse testdb;\\nSET timestamp=1726070408;\\nselect * from test_table;&quot;,\r\n            &quot;eventId&quot;: &quot;38492656394931242928022607514130903113177258647838851072&quot;\r\n        }, \r\n        {\r\n            &quot;message&quot;: &quot;# Time: 2024-09-11T16:00:09.408435Z\\n# User@Host: test_account[test_account] @  [127.0.0.1]  Id: 5436201\\n# Query_time: 0.610625  Lock_time: 0.000003 Rows_sent: 1  Rows_examined: 130154 Thread_id: 5436201 Errno: 0 Killed: 0 Bytes_received: 0 Bytes_sent: 0 Read_first: 0 Read_last: 0 Read_key: 65078 Read_next: 130154 Read_prev: 0 Read_rnd: 0 Read_rnd_next: 0 Sort_merge_passes: 0 Sort_range_count: 0 Sort_rows: 0 Sort_scan_count: 0 Created_tmp_disk_tables: 0 Created_tmp_tables: 0 Start: 2024-09-11T16:00:08.797810Z End: 2024-09-11T16:00:09.408435Z\\nSET timestamp=1726070408;\\nselect * from test_table;&quot;,\r\n            &quot;eventId&quot;: &quot;38492656394931242928022607514130903113177258647838851073&quot;\r\n        }, \r\n        {\r\n            &quot;message&quot;: &quot;# Time: 2024-09-11T16:00:12.461401Z\\n# User@Host: test_account[test_account] @  [127.0.0.1]  Id: 5436209\\n# Query_time: 0.528123  Lock_time: 0.000003 Rows_sent: 1  Rows_examined: 130156 Thread_id: 5436209 Errno: 0 Killed: 0 Bytes_received: 0 Bytes_sent: 0 Read_first: 0 Read_last: 0 Read_key: 65079 Read_next: 130156 Read_prev: 0 Read_rnd: 0 Read_rnd_next: 0 Sort_merge_passes: 0 Sort_range_count: 0 Sort_rows: 0 Sort_scan_count: 0 Created_tmp_disk_tables: 0 Created_tmp_tables: 0 Start: 2024-09-11T16:00:11.933278Z End: 2024-09-11T16:00:12.461401Z\\nSET timestamp=1726070411;\\nselect * from test_table;&quot;,\r\n            &quot;eventId&quot;: &quot;38492656463015418019136599965239450999572706325597061122&quot;\r\n\t    }\r\n    ]\r\n}\r\n```\r\n\r\n&lt;br&gt;\r\nThis is when I ran the script provided in the guide.&lt;br&gt;\r\nThe ending digits 88, 89 and 91, 92, and 93 of the eventId of a.json are consecutive.&lt;br&gt;\r\nSo I should get 2 results, but I get 3.\r\n\r\n```\r\n# cat c.sh\r\ncat a.json | /usr/local/bin/jq -r &#39;\r\n.events | map(.eventId |= tonumber) | sort_by(.eventId) | reduce .[1:][] as $i (.[:1];\r\n    if ((last.eventId + 1 != $i.eventId)) then . += [$i]\r\n    else last.eventId = last.eventID + 1 | last.message += &quot; &quot; + $i.message end\r\n)&#39;\r\n#) | del(.[].eventId)&#39; \r\n\r\necho &quot;==========================================================================================&quot;\r\necho &quot;==========================================================================================&quot;\r\necho &quot;==========================================================================================&quot;\r\n\r\ncat b.json | /usr/local/bin/jq -r &#39;\r\n.events | map(.eventId |= tonumber) | sort_by(.eventId) | reduce .[1:][] as $i (.[:1];\r\n    if ((last.eventId + 1 != $i.eventId)) then . += [$i]\r\n    else last.eventId = last.eventID + 1 | last.message += &quot; &quot; + $i.message end\r\n)&#39;\r\n#) | del(.[].eventId)&#39; \r\n\r\n\r\n# sh c.sh\r\n[\r\n  {\r\n    &quot;message&quot;: &quot;# Time: 2024-09-11T17:42:56.069052Z\\n# User@Host: test_account[test_account] @  [127.0.0.1]  Id: 1760882\\n# Query_time: 1.090218  Lock_time: 0.000012 Rows_sent: 0  Rows_examined: 0 Thread_id: 1760883 Errno: 0 Killed: 0 Bytes_received: 0 Bytes_sent: 0 Read_first: 0 Read_last: 0 Read_key: 0 Read_next: 0 Read_prev: 0 Read_rnd: 0 Read_rnd_next: 0 Sort_merge_passes: 0 Sort_range_count: 0 Sort_rows: 0 Sort_scan_count: 0 Created_tmp_disk_tables: 0 Created_tmp_tables: 0 Start: 2024-09-11T17:42:54.978834Z End: 2024-09-11T17:42:56.069052Z\\nuse testdb;\\nSET timestamp=1726076574; INSERT INTO test_table (c1, c2, c3) &quot;,\r\n    &quot;eventId&quot;: 1\r\n  },\r\n  {\r\n    &quot;message&quot;: &quot;# Time: 2024-09-11T17:42:56.069052Z\\n# User@Host: test_account[test_account] @  [127.0.0.1]  Id: 1760883\\n# Query_time: 1.090218  Lock_time: 0.000012 Rows_sent: 0  Rows_examined: 0 Thread_id: 1760883 Errno: 0 Killed: 0 Bytes_received: 0 Bytes_sent: 0 Read_first: 0 Read_last: 0 Read_key: 0 Read_next: 0 Read_prev: 0 Read_rnd: 0 Read_rnd_next: 0 Sort_merge_passes: 0 Sort_range_count: 0 Sort_rows: 0 Sort_scan_count: 0 Created_tmp_disk_tables: 0 Created_tmp_tables: 0 Start: 2024-09-11T17:42:54.978834Z End: 2024-09-11T17:42:56.069052Z\\nuse testdb;\\nSET timestamp=1726076574; INSERT INTO test_table (c1, c2, c3) &quot;,\r\n    &quot;eventId&quot;: 1\r\n  },\r\n  {\r\n    &quot;message&quot;: &quot;# Time: 2024-09-11T17:42:56.069052Z\\n# User@Host: test_account[test_account] @  [127.0.0.1]  Id: 1760884\\n# Query_time: 1.090218  Lock_time: 0.000012 Rows_sent: 0  Rows_examined: 0 Thread_id: 1760883 Errno: 0 Killed: 0 Bytes_received: 0 Bytes_sent: 0 Read_first: 0 Read_last: 0 Read_key: 0 Read_next: 0 Read_prev: 0 Read_rnd: 0 Read_rnd_next: 0 Sort_merge_passes: 0 Sort_range_count: 0 Sort_rows: 0 Sort_scan_count: 0 Created_tmp_disk_tables: 0 Created_tmp_tables: 0 Start: 2024-09-11T17:42:54.978834Z End: 2024-09-11T17:42:56.069052Z\\nuse testdb;\\nSET timestamp=1726076574;&quot;,\r\n    &quot;eventId&quot;: 38492793916066929644073647519700311240525639687799308293\r\n  }\r\n]\r\n==========================================================================================\r\n==========================================================================================\r\n==========================================================================================\r\n[\r\n  {\r\n    &quot;message&quot;: &quot;# Time: 2024-09-11T16:00:09.408435Z\\n# User@Host: test_account[test_account] @  [127.0.0.1]  Id: 5436754\\n# Query_time: 0.612487  Lock_time: 0.000003 Rows_sent: 1  Rows_examined: 130154 Thread_id: 5436754 Errno: 0 Killed: 0 Bytes_received: 0 Bytes_sent: 0 Read_first: 0 Read_last: 0 Read_key: 65078 Read_next: 130154 Read_prev: 0 Read_rnd: 0 Read_rnd_next: 0 Sort_merge_passes: 0 Sort_range_count: 0 Sort_rows: 0 Sort_scan_count: 0 Created_tmp_disk_tables: 0 Created_tmp_tables: 0 Start: 2024-09-11T16:00:08.795948Z End: 2024-09-11T16:00:09.408435Z\\nuse testdb;\\nSET timestamp=1726070408;\\nselect * from test_table; # Time: 2024-09-11T16:00:09.408435Z\\n# User@Host: test_account[test_account] @  [127.0.0.1]  Id: 5436201\\n# Query_time: 0.610625  Lock_time: 0.000003 Rows_sent: 1  Rows_examined: 130154 Thread_id: 5436201 Errno: 0 Killed: 0 Bytes_received: 0 Bytes_sent: 0 Read_first: 0 Read_last: 0 Read_key: 65078 Read_next: 130154 Read_prev: 0 Read_rnd: 0 Read_rnd_next: 0 Sort_merge_passes: 0 Sort_range_count: 0 Sort_rows: 0 Sort_scan_count: 0 Created_tmp_disk_tables: 0 Created_tmp_tables: 0 Start: 2024-09-11T16:00:08.797810Z End: 2024-09-11T16:00:09.408435Z\\nSET timestamp=1726070408;\\nselect * from test_table;&quot;,\r\n    &quot;eventId&quot;: 1\r\n  },\r\n  {\r\n    &quot;message&quot;: &quot;# Time: 2024-09-11T16:00:12.461401Z\\n# User@Host: test_account[test_account] @  [127.0.0.1]  Id: 5436209\\n# Query_time: 0.528123  Lock_time: 0.000003 Rows_sent: 1  Rows_examined: 130156 Thread_id: 5436209 Errno: 0 Killed: 0 Bytes_received: 0 Bytes_sent: 0 Read_first: 0 Read_last: 0 Read_key: 65079 Read_next: 130156 Read_prev: 0 Read_rnd: 0 Read_rnd_next: 0 Sort_merge_passes: 0 Sort_range_count: 0 Sort_rows: 0 Sort_scan_count: 0 Created_tmp_disk_tables: 0 Created_tmp_tables: 0 Start: 2024-09-11T16:00:11.933278Z End: 2024-09-11T16:00:12.461401Z\\nSET timestamp=1726070411;\\nselect * from test_table;&quot;,\r\n    &quot;eventId&quot;: 38492656463015418019136599965239450999572706325597061122\r\n  }\r\n]\r\n```\r\n\r\nSecond, it has continuous eventID values, but I tried to separate them when the message starts at # Time.&lt;br&gt;\r\na.json does not apply, but b.json produces the desired result.&lt;br&gt;\r\nFor this reason, version 1.7 does not seem to be able to calculate large numbers well.\r\n\r\n```\r\n# cat c.sh\r\n#!/bin/bash\r\ncat a.json | /usr/local/bin/jq -r &#39;\r\n.events | map(.eventId |= tonumber) | sort_by(.eventId) | reduce .[1:][] as $i (.[:1];\r\n    if ((last.eventId + 1 != $i.eventId) or (last.message | contains(&quot;Time&quot;))) then . += [$i]\r\n    else last.eventId = last.eventID + 1 | last.message += &quot; &quot; + $i.message end\r\n)&#39;\r\n#) | del(.[].eventId)&#39; \r\n\r\necho &quot;==========================================================================================&quot;\r\necho &quot;==========================================================================================&quot;\r\necho &quot;==========================================================================================&quot;\r\n\r\ncat b.json | /usr/local/bin/jq -r &#39;\r\n.events | map(.eventId |= tonumber) | sort_by(.eventId) | reduce .[1:][] as $i (.[:1];\r\n    if ((last.eventId + 1 != $i.eventId) or (last.message | contains(&quot;Time&quot;))) then . += [$i]\r\n    else last.eventId = last.eventID + 1 | last.message += &quot; &quot; + $i.message end\r\n)&#39;\r\n#) | del(.[].eventId)&#39; \r\n\r\n\r\n\r\n# sh c.sh\r\n[\r\n  {\r\n    &quot;message&quot;: &quot;# Time: 2024-09-11T17:42:56.069052Z\\n# User@Host: test_account[test_account] @  [127.0.0.1]  Id: 1760882\\n# Query_time: 1.090218  Lock_time: 0.000012 Rows_sent: 0  Rows_examined: 0 Thread_id: 1760883 Errno: 0 Killed: 0 Bytes_received: 0 Bytes_sent: 0 Read_first: 0 Read_last: 0 Read_key: 0 Read_next: 0 Read_prev: 0 Read_rnd: 0 Read_rnd_next: 0 Sort_merge_passes: 0 Sort_range_count: 0 Sort_rows: 0 Sort_scan_count: 0 Created_tmp_disk_tables: 0 Created_tmp_tables: 0 Start: 2024-09-11T17:42:54.978834Z End: 2024-09-11T17:42:56.069052Z\\nuse testdb;\\nSET timestamp=1726076574;&quot;,\r\n    &quot;eventId&quot;: 38492793916066929644073647519700311240525639687799308288\r\n  },\r\n  {\r\n    &quot;message&quot;: &quot;INSERT INTO test_table (c1, c2, c3)  # Time: 2024-09-11T17:42:56.069052Z\\n# User@Host: test_account[test_account] @  [127.0.0.1]  Id: 1760883\\n# Query_time: 1.090218  Lock_time: 0.000012 Rows_sent: 0  Rows_examined: 0 Thread_id: 1760883 Errno: 0 Killed: 0 Bytes_received: 0 Bytes_sent: 0 Read_first: 0 Read_last: 0 Read_key: 0 Read_next: 0 Read_prev: 0 Read_rnd: 0 Read_rnd_next: 0 Sort_merge_passes: 0 Sort_range_count: 0 Sort_rows: 0 Sort_scan_count: 0 Created_tmp_disk_tables: 0 Created_tmp_tables: 0 Start: 2024-09-11T17:42:54.978834Z End: 2024-09-11T17:42:56.069052Z\\nuse testdb;\\nSET timestamp=1726076574;&quot;,\r\n    &quot;eventId&quot;: 1\r\n  },\r\n  {\r\n    &quot;message&quot;: &quot;INSERT INTO test_table (c1, c2, c3)  # Time: 2024-09-11T17:42:56.069052Z\\n# User@Host: test_account[test_account] @  [127.0.0.1]  Id: 1760884\\n# Query_time: 1.090218  Lock_time: 0.000012 Rows_sent: 0  Rows_examined: 0 Thread_id: 1760883 Errno: 0 Killed: 0 Bytes_received: 0 Bytes_sent: 0 Read_first: 0 Read_last: 0 Read_key: 0 Read_next: 0 Read_prev: 0 Read_rnd: 0 Read_rnd_next: 0 Sort_merge_passes: 0 Sort_range_count: 0 Sort_rows: 0 Sort_scan_count: 0 Created_tmp_disk_tables: 0 Created_tmp_tables: 0 Start: 2024-09-11T17:42:54.978834Z End: 2024-09-11T17:42:56.069052Z\\nuse testdb;\\nSET timestamp=1726076574;&quot;,\r\n    &quot;eventId&quot;: 1\r\n  }\r\n]\r\n==========================================================================================\r\n==========================================================================================\r\n==========================================================================================\r\n[\r\n  {\r\n    &quot;message&quot;: &quot;# Time: 2024-09-11T16:00:09.408435Z\\n# User@Host: test_account[test_account] @  [127.0.0.1]  Id: 5436754\\n# Query_time: 0.612487  Lock_time: 0.000003 Rows_sent: 1  Rows_examined: 130154 Thread_id: 5436754 Errno: 0 Killed: 0 Bytes_received: 0 Bytes_sent: 0 Read_first: 0 Read_last: 0 Read_key: 65078 Read_next: 130154 Read_prev: 0 Read_rnd: 0 Read_rnd_next: 0 Sort_merge_passes: 0 Sort_range_count: 0 Sort_rows: 0 Sort_scan_count: 0 Created_tmp_disk_tables: 0 Created_tmp_tables: 0 Start: 2024-09-11T16:00:08.795948Z End: 2024-09-11T16:00:09.408435Z\\nuse testdb;\\nSET timestamp=1726070408;\\nselect * from test_table;&quot;,\r\n    &quot;eventId&quot;: 38492656394931242928022607514130903113177258647838851072\r\n  },\r\n  {\r\n    &quot;message&quot;: &quot;# Time: 2024-09-11T16:00:09.408435Z\\n# User@Host: test_account[test_account] @  [127.0.0.1]  Id: 5436201\\n# Query_time: 0.610625  Lock_time: 0.000003 Rows_sent: 1  Rows_examined: 130154 Thread_id: 5436201 Errno: 0 Killed: 0 Bytes_received: 0 Bytes_sent: 0 Read_first: 0 Read_last: 0 Read_key: 65078 Read_next: 130154 Read_prev: 0 Read_rnd: 0 Read_rnd_next: 0 Sort_merge_passes: 0 Sort_range_count: 0 Sort_rows: 0 Sort_scan_count: 0 Created_tmp_disk_tables: 0 Created_tmp_tables: 0 Start: 2024-09-11T16:00:08.797810Z End: 2024-09-11T16:00:09.408435Z\\nSET timestamp=1726070408;\\nselect * from test_table;&quot;,\r\n    &quot;eventId&quot;: 38492656394931242928022607514130903113177258647838851073\r\n  },\r\n  {\r\n    &quot;message&quot;: &quot;# Time: 2024-09-11T16:00:12.461401Z\\n# User@Host: test_account[test_account] @  [127.0.0.1]  Id: 5436209\\n# Query_time: 0.528123  Lock_time: 0.000003 Rows_sent: 1  Rows_examined: 130156 Thread_id: 5436209 Errno: 0 Killed: 0 Bytes_received: 0 Bytes_sent: 0 Read_first: 0 Read_last: 0 Read_key: 65079 Read_next: 130156 Read_prev: 0 Read_rnd: 0 Read_rnd_next: 0 Sort_merge_passes: 0 Sort_range_count: 0 Sort_rows: 0 Sort_scan_count: 0 Created_tmp_disk_tables: 0 Created_tmp_tables: 0 Start: 2024-09-11T16:00:11.933278Z End: 2024-09-11T16:00:12.461401Z\\nSET timestamp=1726070411;\\nselect * from test_table;&quot;,\r\n    &quot;eventId&quot;: 38492656463015418019136599965239450999572706325597061122\r\n  }\r\n]\r\n```\r\n\r\nHowever, when I saw it separated, it didn&#39;t seem like it would work, so I&#39;m continuing to test it. &lt;br&gt;\r\nThanks a lot for your help.\r\n\r\n\r\nIn conclusion, a consecutive number of eventIds are grouped. At this time, if the message field is # Time, a new field is created.",
        "link": "https://stackoverflow.com/questions/78939784/how-to-add-consecutive-numbers-of-messages-in-jq-command",
        "title": "How to add consecutive numbers of messages in jq command"
    },
    {
        "tags": [
            "json",
            "bash",
            "command-line",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1725471119,
                "last_edit_date": 1725471119,
                "creation_date": 1725407005,
                "answer_id": 78946383,
                "question_id": 78946376,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "`|` isn&#39;t &quot;ignoring&quot; anything. The problem seems to be that you&#39;re expecting jq&#39;s precedence to be different from what it is — `,` binds tighter than `|`.\r\n\r\n`(.menu[].menuitem[] | .value), .` produces the same four values as your first sample, followed by the top-level input (`.`), so that&#39;s five outputs.\r\n\r\nThen you pipe that into `{}`, which is a filter that discards its input and produces an empty object. Since it gets five inputs, it produces five empty objects.\r\n\r\nIf you want grouping different from the default, you can get it using parentheses, as you already figured out.\r\n\r\nOr, a simpler way to write the same filter would be `.menu[].menuitem[].value, {}`. There&#39;s no need to write `. | {}` at all.",
                "title": "Looks like jq pipe ignores commas and parenthesis"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -1,
        "last_activity_date": 1725471119,
        "creation_date": 1725406689,
        "last_edit_date": 1725423401,
        "question_id": 78946376,
        "body_markdown": "I&#39;m trying to understand the behavior of jq pipes when using parentheses and commas. Let&#39;s consider this JSON example:\r\n\r\n```json\r\n{\r\n  &quot;menu&quot;: [\r\n    {\r\n      &quot;id&quot;: &quot;file&quot;,\r\n      &quot;value&quot;: &quot;File&quot;,\r\n      &quot;menuitem&quot;: [\r\n        {\r\n          &quot;value&quot;: &quot;New&quot;,\r\n          &quot;onclick&quot;: &quot;CreateNewDoc()&quot;\r\n        },\r\n        {\r\n          &quot;value&quot;: &quot;Close&quot;,\r\n          &quot;onclick&quot;: &quot;CloseDoc()&quot;\r\n        }\r\n      ]\r\n    },\r\n    {\r\n      &quot;id&quot;: &quot;photo&quot;,\r\n      &quot;value&quot;: &quot;Photo&quot;,\r\n      &quot;menuitem&quot;: [\r\n        {\r\n          &quot;value&quot;: &quot;New&quot;,\r\n          &quot;onclick&quot;: &quot;CreateNewDoc()&quot;\r\n        },\r\n        {\r\n          &quot;value&quot;: &quot;Open&quot;,\r\n          &quot;onclick&quot;: &quot;OpenDoc()&quot;\r\n        }\r\n      ]\r\n    }\r\n  ]\r\n}\r\n```\r\n\r\nFirst, let&#39;s apply a simple filter:\r\n\r\n```bash\r\njq &#39;.menu[].menuitem[] | .value&#39;\r\n```\r\n\r\nOutput:\r\n\r\n```\r\n&quot;New&quot;\r\n&quot;Close&quot;\r\n&quot;New&quot;\r\n&quot;Open&quot;\r\n```\r\n\r\nThis output is as expected.\r\n\r\nNow, let&#39;s add a compound filter separated by a comma and group the first filter using parentheses:\r\n\r\n```bash\r\njq &#39;(.menu[].menuitem[] | .value), . | {}&#39;\r\n```\r\n\r\nOutput:\r\n\r\n```\r\n{}\r\n{}\r\n{}\r\n{}\r\n{}\r\n```\r\n\r\nIt looks like second pipe is working with output of first filters\r\n\r\nQuestion: why?\r\n\r\nAccording to the jq documentation:\r\n\r\n&gt; If two filters are separated by a comma, then the same input will be fed into both and the two filters&#39; output value streams will be concatenated in order: first, all of the outputs produced by the left expression, and then all of the outputs produced by the right.\r\n\r\nFollowing this logic, I would expect the output to be:\r\n\r\n```\r\n&quot;New&quot;    // output of first filter\r\n&quot;Close&quot;\r\n&quot;New&quot;\r\n&quot;Open&quot;\r\n{}       // output of second filter\r\n```\r\n\r\nHowever, this is not the case.\r\n\r\n**Corrected Filter**\r\n\r\nThe filter works as expected if we add parentheses to the second filter:\r\n\r\n```bash\r\njq &#39;(.menu[].menuitem[] | .value), (. | {})&#39;\r\n```\r\n\r\nOutput:\r\n\r\n```\r\n&quot;New&quot;\r\n&quot;Close&quot;\r\n&quot;New&quot;\r\n&quot;Open&quot;\r\n{}\r\n```\r\n\r\n**Main question**\r\n\r\nWhy does the pipe (`|`) operator seemingly ignore the parentheses and comma in the first compound filter? What is the logic behind this behavior?",
        "link": "https://stackoverflow.com/questions/78946376/looks-like-jq-pipe-ignores-commas-and-parenthesis",
        "title": "Looks like jq pipe ignores commas and parenthesis"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 1008660,
                    "reputation": 13846,
                    "user_id": 1021725,
                    "user_type": "registered",
                    "accept_rate": 75,
                    "profile_image": "https://www.gravatar.com/avatar/74b935010f9ac8bee2a8df5b1c6ee6cb?s=256&d=identicon&r=PG",
                    "display_name": "David Brossard",
                    "link": "https://stackoverflow.com/users/1021725/david-brossard"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1725468834,
                "post_id": 78949752,
                "comment_id": 139200071,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1725472162,
                "post_id": 78949752,
                "comment_id": 139200371,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1725469092,
                "last_edit_date": 1725469092,
                "creation_date": 1725469062,
                "answer_id": 78949788,
                "question_id": 78949752,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "use this\r\n \r\ncat /tmp/z.json | jq -r &#39;.[] | select(.displayName | test(&quot;^foo&quot;))&#39;\r\n\r\n== operator does not supported in regex pattern\r\n\r\nhope this work for you !!",
                "title": "Print data for an object based on value(variable) for a key in jq output"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1725472415,
        "creation_date": 1725468518,
        "last_edit_date": 1725468861,
        "question_id": 78949752,
        "body_markdown": "I have this JSON :\r\n\r\n```json\r\n[\r\n  {\r\n    &quot;id&quot;: &quot;1&quot;,\r\n    &quot;agent&quot;: &quot;23ef&quot;,\r\n    &quot;displayName&quot;: &quot;foo.com&quot;\r\n  },\r\n  {\r\n    &quot;id&quot;: &quot;2&quot;,\r\n    &quot;agent&quot;: &quot;23gh&quot;,\r\n    &quot;displayName&quot;: &quot;foo2.com&quot;\r\n  },\r\n  {\r\n    &quot;id&quot;: &quot;3&quot;,\r\n    &quot;agent&quot;: &quot;23gf&quot;,\r\n    &quot;displayName&quot;: &quot;boo.com&quot;\r\n  }\r\n]\r\n```\r\n\r\nWanted to get the dataset for all objects which have foo in their displayName.\r\n\r\nI am able to get when i pass the value as a string,\r\n```\r\n$ cat /tmp/z.json | jq -r &#39;.[] | select(.displayName==&quot;foo.com&quot;)&#39;  {   &quot;id&quot;: &quot;1&quot;,   &quot;agent&quot;: &quot;23ef&quot;,   &quot;displayName&quot;: &quot;foo.com&quot; }\r\n```\r\nBut not getting when i try a regex. Can somebody help?\r\n```\r\n$ cat /tmp/z.json | jq -r &#39;.[] | select(.displayName==&quot;foo*&quot;)&#39; \r\n```",
        "link": "https://stackoverflow.com/questions/78949752/print-data-for-an-object-based-on-valuevariable-for-a-key-in-jq-output",
        "title": "Print data for an object based on value(variable) for a key in jq output"
    },
    {
        "tags": [
            "json",
            "select",
            "boolean",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1725897307,
                "creation_date": 1725897307,
                "answer_id": 78966298,
                "question_id": 78966281,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "`select(.proxied == &quot;false&quot;)` checks for the string `&quot;false&quot;`, i.e. containing the characters `f`, `a`, `l`, `s`, and `e`.\r\n\r\nInstead, use the boolean value `false` (without quotes):\r\n```sh\r\n.result[] | select(.proxied == false)\r\n```\r\n[Demo](https://jqplay.org/s/k1Jm7fN7hYFtSyI)\r\n\r\nOr the `not` operator:\r\n```sh\r\n.result[] | select(.proxied | not)\r\n```\r\n[Demo](https://jqplay.org/s/w7yam6CAR87Ml5o)",
                "title": "jq select condition with nested field"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1725900707,
        "creation_date": 1725897148,
        "last_edit_date": 1725900707,
        "question_id": 78966281,
        "body_markdown": "I have the following json string below which I would like to select the proxied field.\r\n\r\nI&#39;ve used: \r\n`.result[] | select(.proxied==&quot;false&quot;)` but that results in &quot;no output&quot;\r\n\r\nIt seems to be how the field proxied is nested and I&#39;m struggling with the jq syntax with the nesting.\r\n\r\nAny help would be appreciated.\r\n\r\n```{\r\n  &quot;result&quot;: [\r\n    {\r\n      &quot;id&quot;: &quot;9360f71569e5072910db9cd35ddae&quot;,\r\n      &quot;zone_id&quot;: &quot;f658530765920e58bcc3a18fbefc38&quot;,\r\n      &quot;zone_name&quot;: &quot;123.com&quot;,\r\n      &quot;name&quot;: &quot;123.com&quot;,\r\n      &quot;type&quot;: &quot;A&quot;,\r\n      &quot;content&quot;: &quot;123.22.22.221&quot;,\r\n      &quot;proxiable&quot;: true,\r\n      &quot;proxied&quot;: true,\r\n      &quot;ttl&quot;: 1,\r\n      &quot;meta&quot;: {\r\n        &quot;auto_added&quot;: false,\r\n        &quot;managed_by_apps&quot;: false,\r\n        &quot;managed_by_argo_tunnel&quot;: false\r\n      },\r\n      &quot;comment&quot;: null,\r\n      &quot;tags&quot;: [],\r\n      &quot;created_on&quot;: &quot;2017-10-17T21:58:51.696247Z&quot;,\r\n      &quot;modified_on&quot;: &quot;2017-10-17T21:58:51.696247Z&quot;\r\n    },\r\n    {\r\n      &quot;id&quot;: &quot;e669bde5f1b4879d49d2147c5b8a0&quot;,\r\n      &quot;zone_id&quot;: &quot;f658530765920a9bcc3a18fbefc38&quot;,\r\n      &quot;zone_name&quot;: &quot;1234.com&quot;,\r\n      &quot;name&quot;: &quot;www.1234.com&quot;,\r\n      &quot;type&quot;: &quot;A&quot;,\r\n      &quot;content&quot;: &quot;123.202.202.105&quot;,\r\n      &quot;proxiable&quot;: true,\r\n      &quot;proxied&quot;: false,\r\n      &quot;ttl&quot;: 1,\r\n      &quot;meta&quot;: {\r\n        &quot;auto_added&quot;: false,\r\n        &quot;managed_by_apps&quot;: false,\r\n        &quot;managed_by_argo_tunnel&quot;: false\r\n      },\r\n      &quot;comment&quot;: null,\r\n      &quot;tags&quot;: [],\r\n      &quot;created_on&quot;: &quot;2017-10-17T21:58:51.715343Z&quot;,\r\n      &quot;modified_on&quot;: &quot;2017-10-17T21:58:51.715343Z&quot;\r\n    }\r\n  ],\r\n  &quot;success&quot;: true,\r\n  &quot;errors&quot;: [],\r\n  &quot;messages&quot;: [],\r\n  &quot;result_info&quot;: {\r\n    &quot;page&quot;: 1,\r\n    &quot;per_page&quot;: 100,\r\n    &quot;count&quot;: 2,\r\n    &quot;total_count&quot;: 2,\r\n    &quot;total_pages&quot;: 1\r\n  }\r\n}\r\n```\r\n",
        "link": "https://stackoverflow.com/questions/78966281/jq-select-condition-with-nested-field",
        "title": "jq select condition with nested field"
    },
    {
        "tags": [
            "php",
            "json",
            "jq",
            "config"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 7869117,
                    "reputation": 62566,
                    "user_id": 5947043,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/jUK37.png?s=256",
                    "display_name": "ADyson",
                    "link": "https://stackoverflow.com/users/5947043/adyson"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1725965226,
                "post_id": 78969066,
                "comment_id": 139235867,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 7869117,
                    "reputation": 62566,
                    "user_id": 5947043,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/jUK37.png?s=256",
                    "display_name": "ADyson",
                    "link": "https://stackoverflow.com/users/5947043/adyson"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1725965372,
                "post_id": 78969066,
                "comment_id": 139235882,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1725972532,
                "creation_date": 1725972532,
                "answer_id": 78969561,
                "question_id": 78969066,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Why export to another format, to then import it again, instead of manipulating the data directly in PHP? You already invoke the `php` CLI from the shell. Stay there, alter the parts you want to change, and then try replicating your original `return` code by exporting the value to valid PHP code.\r\n\r\n```sh\r\nphp -r &#39;\r\n  $in = include $argv[1]; $in[&quot;someobject&quot;][&quot;somefield&quot;] = &quot;othervalue&quot;;\r\n  $out = var_export($in,true); echo &quot;&lt;?php\\nreturn {$out};&quot;;\r\n&#39; sample.php &gt; sample2.php\r\n```\r\n\r\nSome notes:\r\n- For safety reasons, you might want to also perform some sanity checks before the export, e.g. employing functions like `is_resource`, etc.\r\n- For aesthetical reasons, you could replace `var_export` with a use of the [var_representation extension](https://www.php.net/manual/en/book.var_representation.php) to make the result look even more like your original\r\n- For interoperability reasons, you should consider storing your data as data (there are standard data processors for every data format), not as code",
                "title": "manipulate php config file"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -1,
        "last_activity_date": 1725972532,
        "creation_date": 1725964414,
        "question_id": 78969066,
        "body_markdown": "What&#39;s the correct way to automate manipulation of a php config file of this format?\r\n\r\n```\r\nsample.php:\r\n\r\n&lt;?php\r\nreturn [\r\n    &#39;someobject&#39; =&gt; [\r\n        &#39;somefield&#39; =&gt; &#39;somevalue&#39;\r\n    ]\r\n];\r\n```\r\n\r\nI was thinking of converting it to JSON (json_encode), manipulate the JSON and writing it back afterwards (json_decode). But the last step gives me a different data format.\r\n\r\n\r\n\r\n```\r\n# !/bin/bash\r\n\r\n# load data to json\r\nJSON=$(php -r &quot;echo json_encode(include &#39;sample.php&#39;);&quot;)\r\n# manipulate json with jq\r\nNEW_JSON=$(echo $JSON | jq -cr &#39;.someobject.somefield = &quot;othervalue&quot;&#39;)\r\n# write back\r\nphp -r &quot;var_dump(json_decode(&#39;$NEW_JSON&#39;, true));&quot; &gt; sample2.php\r\n```\r\n\r\nThe content I&#39;m getting from json_decode is:\r\n```\r\narray(1) {\r\n  [&quot;someobject&quot;]=&gt;\r\n  array(1) {\r\n    [&quot;somefield&quot;]=&gt;\r\n    string(10) &quot;othervalue&quot;\r\n  }\r\n}\r\n\r\n# or without true in json_decode\r\n\r\nobject(stdClass)#2 (1) {\r\n  [&quot;someobject&quot;]=&gt;\r\n  object(stdClass)#1 (1) {\r\n    [&quot;somefield&quot;]=&gt;\r\n    string(10) &quot;othervalue&quot;\r\n  }\r\n}\r\n```\r\n\r\nWhat&#39;s the correct way of manipulating this type of config files?",
        "link": "https://stackoverflow.com/questions/78969066/manipulate-php-config-file",
        "title": "manipulate php config file"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 906027,
                    "reputation": 2337,
                    "user_id": 940923,
                    "user_type": "registered",
                    "accept_rate": 62,
                    "profile_image": "https://www.gravatar.com/avatar/5f01d3f56cdcf95619c4f116baab8dbf?s=256&d=identicon&r=PG",
                    "display_name": "Alex",
                    "link": "https://stackoverflow.com/users/940923/alex"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1726083715,
                "post_id": 78975463,
                "comment_id": 139247935,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 5351266,
                    "reputation": 73064,
                    "user_id": 4265352,
                    "user_type": "registered",
                    "profile_image": "https://lh4.googleusercontent.com/-lzAUc5pYb24/AAAAAAAAAAI/AAAAAAAAAGQ/q3h7bZUnqrs/s256-rj/photo.jpg",
                    "display_name": "axiac",
                    "link": "https://stackoverflow.com/users/4265352/axiac"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1726084030,
                "post_id": 78975463,
                "comment_id": 139247967,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1726084111,
                "creation_date": 1726084111,
                "answer_id": 78975497,
                "question_id": 78975463,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The solution is simple. Instead of checking for equality, use the filters [`strings`](https://jqlang.github.io/jq/manual/#arrays-objects-iterables-booleans-numbers-normals-finites-strings-nulls-values-scalars) and [`contains()`](https://jqlang.github.io/jq/manual/#contains) to select and remove the values that contain `&quot;val&quot;` (together with their associated keys):\r\n\r\n```jq\r\ndel(.. | select(strings | contains(&quot;val&quot;)))\r\n```\r\n\r\nCheck it [online](https://jqplay.org/s/mjckh9S1AdOHkgi).",
                "title": "Delete all where DOES NOT contain"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1726084603,
                "creation_date": 1726084603,
                "answer_id": 78975523,
                "question_id": 78975463,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You were close. This should work:\r\n```\r\ndel(.. | strings | select(index(&quot;val&quot;) | not))\r\n```",
                "title": "Delete all where DOES NOT contain"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1726084603,
        "creation_date": 1726083363,
        "last_edit_date": 1726084131,
        "question_id": 78975463,
        "body_markdown": "I have this JSON file json1.json:\r\n\r\n    {\r\n        &quot;a&quot;:&quot;val1&quot;,\r\n        &quot;b&quot;:&quot;val2&quot;,\r\n        &quot;nest1&quot;: {\r\n            &quot;z&quot;: &quot;x&quot;,\r\n            &quot;test&quot;: &quot;containval&quot;\r\n        }\r\n    }\r\n\r\nI need to get a new json where elements whose values that contain val are removed, ANY property can have val, this gets me close:\r\n\r\n    jq &#39;del(.. | select(. == &quot;val1&quot;))&#39; .\\json1.json\r\n\r\nit produces this:\r\n\r\n    {\r\n      &quot;b&quot;: &quot;val2&quot;,\r\n      &quot;nest1&quot;: {\r\n        &quot;z&quot;: &quot;x&quot;,\r\n        &quot;test&quot;: &quot;containval&quot;\r\n      }\r\n    }\r\n\r\nExcept that it checks for values being EQUAL to val1, and I only need where the value DOES NOT CONTAIN &quot;val&quot;.\r\n\r\nDesired output:\r\n\r\n    {\r\n        &quot;a&quot;:&quot;val1&quot;,\r\n        &quot;b&quot;:&quot;val2&quot;,\r\n        &quot;nest1&quot;: {\r\n            &quot;test&quot;: &quot;containval&quot;\r\n        }\r\n    }\r\n\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/78975463/delete-all-where-does-not-contain",
        "title": "Delete all where DOES NOT contain"
    },
    {
        "tags": [
            "json",
            "bash",
            "shell",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1726130489,
                "post_id": 78977238,
                "comment_id": 139251120,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1143565,
                    "reputation": 535973,
                    "user_id": 1126841,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/fa05233b2357f8d11c22ef4cfc7bb85c?s=256&d=identicon&r=PG",
                    "display_name": "chepner",
                    "link": "https://stackoverflow.com/users/1126841/chepner"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1726233293,
                "post_id": 78977238,
                "comment_id": 139260279,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 34437024,
                    "reputation": 11,
                    "user_id": 26568108,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/c2876e7d5dd6192a202e9670973ec748?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "David Tayar",
                    "link": "https://stackoverflow.com/users/26568108/david-tayar"
                },
                "reply_to_user": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1726378648,
                "post_id": 78977238,
                "comment_id": 139268252,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1726130551,
                "creation_date": 1726130551,
                "answer_id": 78977260,
                "question_id": 78977238,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You don&#39;t need the `=`, it&#39;s just:\r\n```\r\njq &#39;. + [inputs]&#39; existing new\r\n```",
                "title": "How to append object into a list of objects (not array) using bash"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1726130551,
        "creation_date": 1726130252,
        "question_id": 78977238,
        "body_markdown": "To a list of objects [{..},{..}], I want to add a new object using bash.\r\nExample of my list:\r\n```\r\n[\r\n      {\r\n        &quot;name&quot; : &quot;server&quot;,\r\n        &quot;image&quot; : &quot;server:latest&quot;,\r\n        &quot;essential&quot; : true,\r\n        &quot;environment&quot; : concat(\r\n          [\r\n            {\r\n              &quot;name&quot; : &quot;TZ&quot;,\r\n              &quot;value&quot; : &quot;${var.env_timezone}&quot;\r\n            }\r\n          ],\r\n          [\r\n            for key, value in var.env_for_server:\r\n            {\r\n              &quot;name&quot; : key,\r\n              &quot;value&quot; : value\r\n            }\r\n          ]\r\n        ,\r\n        &quot;portMappings&quot; : [\r\n          {\r\n            &quot;hostPort&quot; : 3000,\r\n            &quot;protocol&quot; : &quot;tcp&quot;,\r\n            &quot;containerPort&quot; : 3000\r\n          }\r\n        ],\r\n      },\r\n      {\r\n        &quot;name&quot; : &quot;client&quot;,\r\n        &quot;image&quot; : &quot;client:latest&quot;\r\n      },\r\n      {\r\n        &quot;name&quot; : &quot;nginx_gateway&quot;,\r\n        &quot;image&quot; : &quot;nginx_gateway:latest&quot;,\r\n        &quot;essential&quot; : true,\r\n        &quot;portMappings&quot; : [\r\n          {\r\n            &quot;hostPort&quot; : 80,\r\n            &quot;protocol&quot; : &quot;tcp&quot;,\r\n            &quot;containerPort&quot; : 80\r\n          }\r\n        ]\r\n      }\r\n ]\r\n```\r\n\r\nTo this, adding:\r\n```\r\n{\r\n  &quot;name&quot;: &quot;sidecar&quot;,\r\n  &quot;image&quot;: &quot;sidecar:latest&quot;,\r\n  &quot;essential&quot;: true\r\n \r\n}\r\n```\r\nSo the result will be:\r\n```\r\n[\r\n      {\r\n        &quot;name&quot; : &quot;server&quot;,\r\n        &quot;image&quot; : &quot;server:latest&quot;,\r\n        &quot;essential&quot; : true,\r\n        &quot;environment&quot; : concat(\r\n          [\r\n            {\r\n              &quot;name&quot; : &quot;TZ&quot;,\r\n              &quot;value&quot; : &quot;${var.env_timezone}&quot;\r\n            }\r\n          ],\r\n          [\r\n            for key, value in var.env_for_server:\r\n            {\r\n              &quot;name&quot; : key,\r\n              &quot;value&quot; : value\r\n            }\r\n          ]\r\n        ,\r\n        &quot;portMappings&quot; : [\r\n          {\r\n            &quot;hostPort&quot; : 3000,\r\n            &quot;protocol&quot; : &quot;tcp&quot;,\r\n            &quot;containerPort&quot; : 3000\r\n          }\r\n        ],\r\n      },\r\n      {\r\n        &quot;name&quot; : &quot;client&quot;,\r\n        &quot;image&quot; : &quot;client:latest&quot;\r\n      },\r\n      {\r\n        &quot;name&quot; : &quot;nginx_gateway&quot;,\r\n        &quot;image&quot; : &quot;nginx_gateway:latest&quot;,\r\n        &quot;essential&quot; : true,\r\n        &quot;portMappings&quot; : [\r\n          {\r\n            &quot;hostPort&quot; : 80,\r\n            &quot;protocol&quot; : &quot;tcp&quot;,\r\n            &quot;containerPort&quot; : 80\r\n          }\r\n        ]\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;sidecar&quot;,\r\n        &quot;image&quot;: &quot;sidecar:latest&quot;,\r\n        &quot;essential&quot;: true\r\n \r\n      }\r\n ]\r\n```\r\n\r\nI&#39;m working on CI, so better to keep it one-two lines of code max.\r\nAlready tried some commands of jq, but nothing came out with merged, so trying my lucky in here.\r\n\r\nSomething like that when the files are respectively\r\n```\r\njq &#39;. += [input]&#39; existing_containers.json new_container.json &gt; updated_containers.json\r\n\r\n```\r\n",
        "link": "https://stackoverflow.com/questions/78977238/how-to-append-object-into-a-list-of-objects-not-array-using-bash",
        "title": "How to append object into a list of objects (not array) using bash"
    },
    {
        "tags": [
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 3,
                "creation_date": 1726245199,
                "post_id": 78982991,
                "comment_id": 139261795,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1143565,
                    "reputation": 535973,
                    "user_id": 1126841,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/fa05233b2357f8d11c22ef4cfc7bb85c?s=256&d=identicon&r=PG",
                    "display_name": "chepner",
                    "link": "https://stackoverflow.com/users/1126841/chepner"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1726245350,
                "post_id": 78982991,
                "comment_id": 139261812,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1912742,
                    "reputation": 16377,
                    "user_id": 1726083,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/757452f7cd7ba2347c667ef9298ceadb?s=256&d=identicon&r=PG",
                    "display_name": "erik258",
                    "link": "https://stackoverflow.com/users/1726083/erik258"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1726248628,
                "post_id": 78982991,
                "comment_id": 139262123,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1726249246,
                "post_id": 78982991,
                "comment_id": 139262181,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 16041999,
                    "reputation": 145,
                    "user_id": 11578204,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/TtqUf.jpg?s=256",
                    "display_name": "Sambit Swain",
                    "link": "https://stackoverflow.com/users/11578204/sambit-swain"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1726250200,
                "post_id": 78982991,
                "comment_id": 139262242,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 16041999,
                    "reputation": 145,
                    "user_id": 11578204,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/TtqUf.jpg?s=256",
                    "display_name": "Sambit Swain",
                    "link": "https://stackoverflow.com/users/11578204/sambit-swain"
                },
                "reply_to_user": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1726255557,
                "post_id": 78982991,
                "comment_id": 139262723,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1726408118,
                "last_edit_date": 1726408118,
                "creation_date": 1726258585,
                "answer_id": 78983630,
                "question_id": 78982991,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The problem you are having is caused by the way you have constructed the loop: `for item in ...` is simply inappropriate here. You don&#39;t want to iterate over the tokens.\r\n\r\n\r\nInstead, as pointed out by @pmf, you could use a loop along the following lines:\r\n```\r\n&lt; &quot;$filename&quot; jq -c &quot;.replacements[]&quot; | while read -r item ; do\r\n    printf &quot;%s\\n&quot; &quot;$item&quot;\r\ndone    \r\n```\r\n---\r\n\r\nYou might be better off without any shell loop at all; you might even be able to accomplish whatever it is you&#39;re trying to do using jq alone.  If you gave a bit more information about your high-level goals, that would probably help everyone.",
                "title": "jq command to iterate on JSON array with values having space"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": -2,
        "last_activity_date": 1726419278,
        "creation_date": 1726244832,
        "last_edit_date": 1726419278,
        "question_id": 78982991,
        "body_markdown": "Input filename is `project.json`, and its content is:\r\n```lang-json\r\n{\r\n  &quot;package&quot;: [\r\n    {\r\n      &quot;path&quot;: &quot;src&quot;,\r\n      &quot;default&quot;: true\r\n    }\r\n  ],\r\n  &quot;name&quot;: &quot;Sample&quot;,\r\n  &quot;replacements&quot;: [\r\n    {\r\n      &quot;filename&quot;: &quot;/src/main/filename.xml&quot;,\r\n      &quot;stringToReplace&quot;: &quot;SFP_VARIABLE_A&quot;,\r\n      &quot;replaceWith&quot;: &quot;SFP_VARIABLE_A&quot;\r\n    },\r\n    {\r\n      &quot;filename&quot;: &quot;/src/main/file name 1.xml&quot;,\r\n      &quot;stringToReplace&quot;: &quot;SECURE_VARIABLE_B&quot;,\r\n      &quot;replaceWith&quot;: &quot;SECURE_VARIABLE_B&quot;,\r\n      &quot;allowUnsetEnvVariable&quot;: true\r\n    },\r\n    {\r\n      &quot;filename&quot;: &quot;/src/main/file name 2.xml&quot;,\r\n      &quot;stringToReplace&quot;: &quot;SFP_VARIABLE_C&quot;,\r\n      &quot;replaceWith&quot;: &quot;SFP_VARIABLE_C&quot;\r\n    }\r\n  ],\r\n  &quot;namespace&quot;: &quot;&quot;,\r\n  &quot;sourceApiVersion&quot;: &quot;61.0&quot;\r\n}\r\n```\r\nThe requirement is to validate that value of field &quot;replaceWith&quot; should start either with &#39;SFP_&#39; or &#39;SECURE_&#39;, and none of objects in array &quot;replacements&quot; should have a field &quot;allowUnsetEnvVariable&quot;\r\n```lang-bash\r\nfilename=&quot;project.json&quot;\r\nif [[ ! -f &quot;$filename&quot; || ! -s &quot;$filename&quot; ]]; then return 1;fi\r\n\r\nfor item in $(cat $filename | jq -c &quot;.replacements[]&quot; ); do\r\n    echo $item\r\n\r\n    # USE ITEM FOR STRING REPLACEMENT AND VALIDATION\r\n    # replaceWithEnv=$(echo $item | jq -r &quot;.replaceWithEnv\\&quot;&quot;)\r\ndone\r\n```\r\nThe output I get trims the spaces in `&quot;/src/main/CO Target System.xml&quot;`:\r\n\r\n    item = {&quot;filename&quot;:&quot;/src/main/filename.xml&quot;,&quot;stringToReplace&quot;:&quot;SFP_VARIABLE_A&quot;,&quot;replaceWith&quot;:&quot;SFP_VARIABLE_A&quot;}\r\n    item = {&quot;filename&quot;:&quot;/src/main/file\r\n    jq: parse error: Unfinished string at EOF at line 2, column 0\r\n    jq: parse error: Unfinished string at EOF at line 2, column 0\r\n    item = name\r\n    jq: parse error: Invalid numeric literal at line 2, column 0\r\n    jq: parse error: Invalid numeric literal at line 2, column 0\r\n    item = 1.xml&quot;,&quot;stringToReplace&quot;:&quot;SECURE_VARIABLE_B&quot;,&quot;replaceWith&quot;:&quot;SECURE_VARIABLE_B&quot;,&quot;allowUnsetEnvVariable&quot;:true}\r\n    jq: parse error: Invalid numeric literal at line 1, column 6\r\n    jq: parse error: Invalid numeric literal at line 1, column 6\r\n    item = {&quot;filename&quot;:&quot;/src/main/file\r\n    jq: parse error: Unfinished string at EOF at line 2, column 0\r\n    jq: parse error: Unfinished string at EOF at line 2, column 0\r\n    item = name\r\n    jq: parse error: Invalid numeric literal at line 2, column 0\r\n    jq: parse error: Invalid numeric literal at line 2, column 0\r\n    item = 2.xml&quot;,&quot;stringToReplace&quot;:&quot;SFP_VARIABLE_C&quot;,&quot;replaceWith&quot;:&quot;SFP_VARIABLE_C&quot;}\r\n    jq: parse error: Invalid numeric literal at line 1, column 6\r\n    jq: parse error: Invalid numeric literal at line 1, column 6\r\n\r\n",
        "link": "https://stackoverflow.com/questions/78982991/jq-command-to-iterate-on-json-array-with-values-having-space",
        "title": "jq command to iterate on JSON array with values having space"
    },
    {
        "tags": [
            "arrays",
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": -1,
                    "reputation": 1,
                    "user_id": -1,
                    "user_type": "moderator",
                    "profile_image": "https://www.gravatar.com/avatar/a007be5a61f6aa8f3e85ae2fc18dd66e?s=256&d=identicon&r=PG",
                    "display_name": "Community",
                    "link": "https://stackoverflow.com/users/-1/community"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1726638937,
                "post_id": 78994166,
                "comment_id": 139286936,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1726646839,
                "last_edit_date": 1726646839,
                "creation_date": 1726578029,
                "answer_id": 78994180,
                "question_id": 78994166,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Collect the results you get into an array by wrapping your filter inside array brackets:\r\n```sh\r\njq -c &#39;[.[] | .Split.result]&#39;\r\n```\r\n[Demo](https://jqplay.org/s/2DC-1UTcUC8m3I-)\r\n\r\nNote that for filters of the form `[.[] | …]` there&#39;s a shorthand function `map(…)`, so this is equivalent to the above:\r\n```sh\r\njq -c &#39;map(.Split.result)&#39;\r\n```\r\n[Demo](https://jqplay.org/s/9HSuoRtg14G90mw)\r\n\r\nAlternatively, if you just wanted to collect all `scalars` into an array, traverse the document with `..` and collect the results as before:\r\n```sh\r\njq -c &#39;[..|scalars]&#39;\r\n```\r\n[Demo](https://jqplay.org/s/vo5s6Fg2YD3eejs)\r\n\r\nFor the given input, all of these produce (with the `-c` flag compacted into a single line):\r\n```json\r\n[&quot;first_image&quot;,&quot;second_image&quot;]\r\n```\r\n",
                "title": "How parse json value into array with jq"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": -2,
        "last_activity_date": 1726778035,
        "creation_date": 1726577859,
        "last_edit_date": 1726778035,
        "question_id": 78994166,
        "body_markdown": "I have this \r\n\r\n`{\r\n    &quot;1&quot;: {\r\n       &quot;Split&quot;: {\r\n\t\t\t&quot;result&quot;: &quot;first_image&quot;\r\n\t\t}\r\n\t},\r\n\t&quot;2&quot;: {\r\n\t\t&quot;Split&quot;: {\r\n\t\t\t&quot;result&quot;: &quot;second_image&quot;\r\n\t\t}\r\n\t}\r\n}`\r\n\r\n\r\n\r\n\r\nI tried .[].Split.result but it gives be below result;\r\n\r\n&quot;first_image&quot;\r\n&quot;second_image&quot;\r\n\r\nbut I want below output\r\n\r\nI want the below output\r\n\r\n[&quot;first_image&quot;,&quot;second_image&quot;]\r\n\r\n",
        "link": "https://stackoverflow.com/questions/78994166/how-parse-json-value-into-array-with-jq",
        "title": "How parse json value into array with jq"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 1613587,
                    "reputation": 786618,
                    "user_id": 1491895,
                    "user_type": "registered",
                    "accept_rate": 69,
                    "profile_image": "https://www.gravatar.com/avatar/82f9e178a16364bf561d0ed4da09a35d?s=256&d=identicon&r=PG",
                    "display_name": "Barmar",
                    "link": "https://stackoverflow.com/users/1491895/barmar"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1726865249,
                "post_id": 79008215,
                "comment_id": 139307837,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": false,
                "score": 4,
                "last_activity_date": 1726865187,
                "creation_date": 1726865187,
                "answer_id": 79008219,
                "question_id": 79008215,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "`SECRETS_INFO` is already a `jq` object; use `--argjson` instead of `--arg`.\r\n\r\n    $ jq -n --argjson value &quot;${SECRETS_INFO}&quot; &#39;{ secrets : [ $value ] }&#39;\r\n    {\r\n      &quot;secrets&quot;: [\r\n        {\r\n          &quot;name&quot;: &quot;testSecret&quot;,\r\n          &quot;vault-apikey&quot;: &quot;kv&quot;,\r\n          &quot;vault-value&quot;: &quot;sabrinaTest&quot;\r\n        }\r\n      ]\r\n    }\r\n\r\nOr, just pipe the object into `jq` as input.\r\n\r\n    echo &quot;$SECRETS_INFO&quot; | jq &#39;{ secrets : [.] }&#39;",
                "title": "How to remove double-quotes and \\ in jq output without making it single line in bash?"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": -1,
                "last_activity_date": 1726865708,
                "creation_date": 1726865708,
                "answer_id": 79008243,
                "question_id": 79008215,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Issue is the way you are handling `jq` to handle the formatting. You&#39;re splitting the JSON string into separate lines, but what you need is to parse and preserve it as an object. Here is a better approach\r\n\r\n 1. Use `jq` to create the desired JSON structure directly, without splitting it to two lines. \r\n2. Ensure that the output from the vault-secrets command is parsed as JSON.\r\n\r\n```bash\r\nTEST_SECRET_JSON=$(hcp vault-secrets secrets open testSecret --format=json)\r\n\r\n# Parse the necessary fields and construct the JSON structure\r\nSECRETS_INFO=$(echo $TEST_SECRET_JSON | jq -c &#39;{&quot;name&quot;: .name, &quot;vault-apikey&quot;: .type, &quot;vault-value&quot;: .static_version.value}&#39;)\r\n\r\n# Use jq to construct the final JSON\r\njq -n --argjson value &quot;$SECRETS_INFO&quot; &#39;{ secrets: [ [$value] ] }&#39; &gt;&gt; secret.json\r\n```",
                "title": "How to remove double-quotes and \\ in jq output without making it single line in bash?"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": -1,
                "last_activity_date": 1727025547,
                "last_edit_date": 1727025547,
                "creation_date": 1727024834,
                "answer_id": 79012166,
                "question_id": 79008215,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I have managed to achieve the desired result using &quot;awk&quot; .\r\n\r\n    awk -F &#39;\\\\&#39; &#39; n=0 ; /\\[/ {n=1} { if(!n){sub(/&quot;/,&quot;&quot;,$0) ; sub(/,$/,&quot;&quot;,$0) ; sub(/&quot;$/,&quot;&quot;,$0) } ; for (i=1;i&lt;=NF;i++) { printf &quot;%s&quot;,$i } printf &quot;\\n&quot; }&#39; jsonfile.txt\r\n\r\n&quot;jsonfile.txt&quot; - the file you are working on.\r\n\r\nResult - \r\n\r\n    {\r\n      &quot;secrets&quot;: [\r\n        [\r\n          {\r\n            &quot;name&quot;: &quot;testSecret&quot;,\r\n            &quot;vault-apikey&quot;: &quot;kv&quot;,\r\n            &quot;vault-value&quot;: &quot;sabrinaTest&quot;\r\n          }\r\n        ]\r\n      ]\r\n    }\r\n\r\n\r\nBest regards.\r\n",
                "title": "How to remove double-quotes and \\ in jq output without making it single line in bash?"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 0,
        "last_activity_date": 1727025547,
        "creation_date": 1726865018,
        "question_id": 79008215,
        "body_markdown": "I have the following json output \r\n\r\n```\r\n{\r\n  &quot;secrets&quot;: [\r\n    [\r\n      &quot;{&quot;,\r\n      &quot;  \\&quot;name\\&quot;: \\&quot;testSecret\\&quot;,&quot;,\r\n      &quot;  \\&quot;vault-apikey\\&quot;: \\&quot;kv\\&quot;,&quot;,\r\n      &quot;  \\&quot;vault-value\\&quot;: \\&quot;sabrinaTest\\&quot;&quot;,\r\n      &quot;}&quot;\r\n    ]\r\n  ]\r\n}\r\n```\r\n\r\nBut I need the output to be a little cleaner and look like this:\r\n```\r\n{\r\n  &quot;secrets&quot;: [\r\n    [\r\n        {\r\n           &quot;name&quot; : &quot;testSecret&quot;,\r\n           &quot;vault-apikey&quot; : &quot;kv&quot;,\r\n           &quot;vault-value&quot; : &quot;sabrinaTest&quot;\r\n        }\r\n    ]\r\n  ]\r\n}\r\n```\r\n\r\nThese are the commands that I&#39;m currently running to get this output:\r\n\r\n```\r\nTEST_SECRET_JSON=$(hcp vault-secrets secrets open testSecret --format=json)\r\n\r\nSECRETS_INFO=$(echo $TEST_SECRET_JSON | jq -r &#39;{&quot;name&quot;: .name, &quot;vault-apikey&quot;: .type, &quot;vault-value&quot;: .static_version.value}&#39;)\r\n\r\njq -n --arg value &quot;${SECRETS_INFO}&quot; &#39;{ secrets : [ $value | split(&quot;\\n&quot;) ] }&#39; &gt;&gt; secret.json\r\n```\r\n\r\nI have tried other variations, but none have produced the desired results.",
        "link": "https://stackoverflow.com/questions/79008215/how-to-remove-double-quotes-and-in-jq-output-without-making-it-single-line-in",
        "title": "How to remove double-quotes and \\ in jq output without making it single line in bash?"
    },
    {
        "tags": [
            "arrays",
            "json",
            "select",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1727278577,
                "post_id": 79023514,
                "comment_id": 139336151,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 25784590,
                    "reputation": 7,
                    "user_id": 26817105,
                    "user_type": "registered",
                    "profile_image": "https://lh3.googleusercontent.com/a-/AFdZucofDbXGJda94SHkB5qc3intNbjpA1t_ngJfpPAh=k-s256",
                    "display_name": "V1st",
                    "link": "https://stackoverflow.com/users/26817105/v1st"
                },
                "reply_to_user": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1727279609,
                "post_id": 79023514,
                "comment_id": 139336294,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 25784590,
                    "reputation": 7,
                    "user_id": 26817105,
                    "user_type": "registered",
                    "profile_image": "https://lh3.googleusercontent.com/a-/AFdZucofDbXGJda94SHkB5qc3intNbjpA1t_ngJfpPAh=k-s256",
                    "display_name": "V1st",
                    "link": "https://stackoverflow.com/users/26817105/v1st"
                },
                "reply_to_user": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1727280606,
                "post_id": 79023514,
                "comment_id": 139336413,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 25784590,
                    "reputation": 7,
                    "user_id": 26817105,
                    "user_type": "registered",
                    "profile_image": "https://lh3.googleusercontent.com/a-/AFdZucofDbXGJda94SHkB5qc3intNbjpA1t_ngJfpPAh=k-s256",
                    "display_name": "V1st",
                    "link": "https://stackoverflow.com/users/26817105/v1st"
                },
                "reply_to_user": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1727281142,
                "post_id": 79023514,
                "comment_id": 139336472,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1727288986,
                "creation_date": 1727288986,
                "answer_id": 79024336,
                "question_id": 79023514,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "&gt; ... .fields[] which have .field.id==&#39;status&#39; and .to.id==&quot;closed&quot;\r\n\r\nAssuming the sample data is translated to JSON (*), the following query, which corresponds to these requirements, would work:\r\n```\r\nselect(.[].fields[] | select(.field and .field.id==&quot;status&quot; and (.to.id == &quot;closed&quot;)))\r\n```\r\n\r\nThis is just one of several reasonable possibilities, but the key point is that since not all items in .fields[] have a key named &quot;field&quot;, you cannot write a query that assumes they do. \r\n\r\n---\r\n\r\n(*) [tag:hjson] will do the job. ",
                "title": "Proper use of select in select in jq"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1727290534,
        "creation_date": 1727275383,
        "last_edit_date": 1727290534,
        "question_id": 79023514,
        "body_markdown": "I have a file\r\n\r\n```\r\n[{\r\nkey: &#39;value&#39;,\r\nkey1:{\r\nkey:&#39;value&#39;\r\n},\r\nfields:[{\r\nto:{\r\nid:&#39;value&#39;\r\n},\r\nfield:{\r\nid:&#39;value&#39;,\r\nname:&#39;value&#39;\r\n}\r\n},\r\n{key:&#39;value&#39;}]\r\n}]\r\n```\r\nI need to find elements of initial array which have and array .fields[] which have .field.id==&#39;status&#39; and .to.id==&quot;closed&quot;\r\n\r\nI ve tried `[.changelog[] | select(.fields[]|select(.field.id==&quot;status&quot; and (.to.key==&quot;closed&quot; or .to.key==&quot;done&quot;)))]`\r\n\r\nA mistake &#39;cannot iterate over null&#39; apears. Apparently, i can use `.changelog[].fields` but i cant use `.changelog[].fields[]`",
        "link": "https://stackoverflow.com/questions/79023514/proper-use-of-select-in-select-in-jq",
        "title": "Proper use of select in select in jq"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1727470624,
                "post_id": 79032744,
                "comment_id": 139352955,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1727472437,
                "last_edit_date": 1727472437,
                "creation_date": 1727467338,
                "answer_id": 79032762,
                "question_id": 79032744,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I got the right answer:\r\n\r\n    sensors -j ftsteutates-i2c-0-73 | jq &#39;\r\n      .&quot;ftsteutates-i2c-0-73&quot;\r\n      | del(.&quot;Adapter&quot;)\r\n      | with_entries(.value |= \r\n          if type == &quot;object&quot; \r\n          then with_entries(select(.key\r\n                                   | endswith(&quot;_input&quot;)))\r\n          | .[] \r\n          else . end)&#39;\r\n\r\nThis command does the following:\r\n\r\n    with_entries(.value |= if type == &quot;object&quot; then with_entries(select(.key | endswith(&quot;_input&quot;))) | .[] else . end): \r\n\r\nIterates over each key-value pair, and if the value is an object, it selects the entries where the key ends with _input and then extracts the value.\r\n\r\nThis give me the desired output.\r\n\r\nhttps://jqplay.org/s/KLkFpP0Q2yN3f9j\r\n",
                "title": "Map Keys with value of Subkeys in jq"
            },
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1727476478,
                "last_edit_date": 1727476478,
                "creation_date": 1727469005,
                "answer_id": 79032827,
                "question_id": 79032744,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s another way using the [error suppression operator](https://jqlang.github.io/jq/manual/#error-suppression-optional-operator) `?` (with jq 1.7+):\r\n```sh\r\njq &#39;.&quot;ftsteutates-i2c-0-73&quot; | .[] |= (.[keys[] | select(endswith(&quot;_input&quot;))])?&#39;\r\n```\r\n[Demo](https://jqplay.org/s/YdXJEygLjFbzVAY)\r\n\r\nFor older versions, just add another [types filter](https://jqlang.github.io/jq/manual/#arrays-objects-iterables-booleans-numbers-normals-finites-strings-nulls-values-scalars) for `objects` (with jq 1.6+):\r\n```sh\r\njq &#39;.&quot;ftsteutates-i2c-0-73&quot; | .[] |= (objects | .[keys[] | select(endswith(&quot;_input&quot;))])&#39;\r\n```\r\n[Demo](https://jqplay.org/s/I3SQiaMQDJOgFtJ)\r\n\r\nNot recommended, but if the field ending with `_input` is always encoded as the first one, you could even shorten this with jq 1.7+ to:\r\n```sh\r\njq &#39;.&quot;ftsteutates-i2c-0-73&quot; | .[] |= .[]?&#39;   # or .[] |= objects[]\r\n```\r\n[Demo](https://jqplay.org/s/L97gQEYANRmmW7Y)\r\n\r\nResult (due to its type, the `Adapter` field was deleted implicitly):\r\n```json\r\n{\r\n  &quot;VCC 3.3V&quot;: 3.331,\r\n  &quot;3.3V AUX&quot;: 3.359,\r\n  &quot;V_IN (12V)&quot;: 12.012,\r\n  &quot;VBAT 3.0V&quot;: 2.692,\r\n  &quot;CPU&quot;: 51.000,\r\n  &quot;Chassis&quot;: 1200.000,\r\n  &quot;Ambient&quot;: 44.000,\r\n  &quot;Core&quot;: 54.000,\r\n  &quot;Memory&quot;: 42.000,\r\n  &quot;PCH&quot;: 54.000,\r\n  &quot;Graphics&quot;: 40.000\r\n}\r\n```\r\n\r\n---\r\n\r\n&gt; EDIT: I found, that the temp and fan values from CPU get joined, which need to be keeped.\r\n&gt; \r\n&gt; Maybe it is possible to match the part of the subkey name in/fan/temp and join it together in the output name\r\n\r\nYou&#39;d need to `--stream` the input [at invocation](https://jqlang.github.io/jq/manual/#invoking-jq) in order to process broken-down parts individually, before they are collapsed in a superordinate structure.\r\n\r\nHere&#39;s one way using just `from_entries` on a prepared array:\r\n```sh\r\njq --stream -n &#39;\r\n  [inputs | select(.[0][0] == &quot;ftsteutates-i2c-0-73&quot;) | {\r\n    key: &quot;\\(.[0][1])_\\(.[0][2] | strings | scan(&quot;^(.*)\\\\d+_input$&quot;)[0])&quot;, \r\n    value: .[1] | values\r\n  }] | from_entries\r\n&#39;\r\n```\r\n\r\nHere&#39;s another one using `reduce` to successively build up the output:\r\n```sh\r\njq --stream -n &#39;\r\n  reduce (inputs | select(has(1))) as [$path, $val]\r\n    (.; setpath($path | .[1:] |= [join(&quot;_&quot;)]; $val))\r\n  | .&quot;ftsteutates-i2c-0-73&quot;\r\n  | with_entries(.key = (.key | scan(&quot;^(.*)\\\\d+_input$&quot;)[0]))\r\n&#39;\r\n```\r\n\r\nResult:\r\n```json\r\n{\r\n  &quot;VCC 3.3V_in&quot;: 3.331,\r\n  &quot;3.3V AUX_in&quot;: 3.359,\r\n  &quot;V_IN (12V)_in&quot;: 12.012,\r\n  &quot;VBAT 3.0V_in&quot;: 2.692,\r\n  &quot;CPU_fan&quot;: 660.000,\r\n  &quot;Chassis_fan&quot;: 1200.000,\r\n  &quot;CPU_temp&quot;: 51.000,\r\n  &quot;Ambient_temp&quot;: 44.000,\r\n  &quot;Core_temp&quot;: 54.000,\r\n  &quot;Memory_temp&quot;: 42.000,\r\n  &quot;PCH_temp&quot;: 54.000,\r\n  &quot;Graphics_temp&quot;: 40.000\r\n}\r\n```",
                "title": "Map Keys with value of Subkeys in jq"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1727471584,
                "creation_date": 1727471584,
                "answer_id": 79032917,
                "question_id": 79032744,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "A simple solution using `jq`:\r\n\r\n```jq\r\n.[&quot;ftsteutates-i2c-0-73&quot;] | map_values(objects | .[(keys[] | select(endswith(&quot;_input&quot;)))])\r\n```\r\n\r\nHow it works:\r\n\r\n```jq\r\n.[&quot;ftsteutates-i2c-0-73&quot;].     # extract the interesting object\r\n| map_values(                  # process its values, preserve the keys association\r\n    objects                    # process only the values that are object (ignore &quot;Adapter&quot;)\r\n    | .[                              # extract only some properties of these objects\r\n        keys[] |                      # choose the keys...\r\n        select(endswith(&quot;_input&quot;))    # ...ending in &quot;_input&quot;\r\n      ]                               # yield the values of the chosen keys\r\n  )\r\n```\r\n\r\nSee it [online](https://jqplay.org/s/0r5jX70MWqVVmAo).\r\n\r\nh3. Remarks\r\n\r\n * if multiple keys ending in `_input` are present in an object, the value associated to the last one is returned;\r\n * the sample data contains the key `CPU` two times;&lt;br&gt;\r\n depending on the JSON implementation, this can be reported as invalid\r\n   JSON or one of the keys is ignored (usually the last occurrence\r\n   overwrites any previous occurrences); this is also how `jq` works.",
                "title": "Map Keys with value of Subkeys in jq"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 0,
        "last_activity_date": 1727476478,
        "creation_date": 1727466885,
        "last_edit_date": 1727471637,
        "question_id": 79032744,
        "body_markdown": "I try to reformat the output of the sensors command:\r\n\r\n```\r\nsensors -j ftsteutates-i2c-0-73\r\n{\r\n   &quot;ftsteutates-i2c-0-73&quot;:{\r\n      &quot;Adapter&quot;: &quot;SMBus I801 adapter at efa0&quot;,\r\n      &quot;VCC 3.3V&quot;:{\r\n         &quot;in0_input&quot;: 3.331\r\n      },\r\n      &quot;3.3V AUX&quot;:{\r\n         &quot;in1_input&quot;: 3.359\r\n      },\r\n      &quot;V_IN (12V)&quot;:{\r\n         &quot;in2_input&quot;: 12.012\r\n      },\r\n      &quot;VBAT 3.0V&quot;:{\r\n         &quot;in3_input&quot;: 2.692\r\n      },\r\n      &quot;CPU&quot;:{\r\n         &quot;fan1_input&quot;: 660.000,\r\n         &quot;fan1_alarm&quot;: 0.000,\r\n         &quot;fan1_fault&quot;: 0.000\r\n      },\r\n      &quot;Chassis&quot;:{\r\n         &quot;fan3_input&quot;: 1200.000,\r\n         &quot;fan3_alarm&quot;: 0.000,\r\n         &quot;fan3_fault&quot;: 0.000\r\n      },\r\n      &quot;CPU&quot;:{\r\n         &quot;temp1_input&quot;: 51.000,\r\n         &quot;temp1_alarm&quot;: 0.000,\r\n         &quot;temp1_fault&quot;: 0.000\r\n      },\r\n      &quot;Ambient&quot;:{\r\n         &quot;temp2_input&quot;: 44.000,\r\n         &quot;temp2_alarm&quot;: 0.000,\r\n         &quot;temp2_fault&quot;: 0.000\r\n      },\r\n      &quot;Core&quot;:{\r\n         &quot;temp3_input&quot;: 54.000,\r\n         &quot;temp3_alarm&quot;: 0.000,\r\n         &quot;temp3_fault&quot;: 0.000\r\n      },\r\n      &quot;Memory&quot;:{\r\n         &quot;temp4_input&quot;: 42.000,\r\n         &quot;temp4_alarm&quot;: 0.000,\r\n         &quot;temp4_fault&quot;: 0.000\r\n      },\r\n      &quot;PCH&quot;:{\r\n         &quot;temp5_input&quot;: 54.000,\r\n         &quot;temp5_alarm&quot;: 0.000,\r\n         &quot;temp5_fault&quot;: 0.000\r\n      },\r\n      &quot;Graphics&quot;:{\r\n         &quot;temp6_input&quot;: 40.000,\r\n         &quot;temp6_alarm&quot;: 0.000,\r\n         &quot;temp6_fault&quot;: 0.000\r\n      }\r\n   }\r\n}\r\n```\r\nWhat I am expecting is:\r\n\r\n```\r\nsensors -j ftsteutates-i2c-0-73 | jq &#39;.&quot;ftsteutates-i2c-0-73&quot; | del(.&quot;Adapter&quot;) | ???&#39; \r\n{\r\n  &quot;VCC 3.3V&quot;: 3.331,\r\n  &quot;3.3V AUX&quot;: 3.359,\r\n  &quot;V_IN (12V)&quot;: 12.012,\r\n  &quot;VBAT 3.0V&quot;: 2.692,\r\n  &quot;CPU&quot;: 51.000,\r\n  &quot;Chassis&quot;: 1200.000,\r\n  &quot;Ambient&quot;: 44.000,\r\n  &quot;Core&quot;: 54.000,\r\n  &quot;Memory&quot;: 42.000,\r\n  &quot;PCH&quot;: 54.000,\r\n  &quot;Graphics&quot;: 40.000\r\n}\r\n```\r\n\r\nBut I cant figure out how to Map the values of the subkeys and also delete the *_alarm and *_fault subkeys or select just the first subkey which is always the *_input key.\r\n\r\nEDIT:\r\nI found, that the temp and fan values from CPU get joined, which need to be keeped.\r\n\r\nMaybe it is possible to match the part of the subkey name in/fan/temp and join it together in the output name like:\r\n\r\n```\r\nsensors -j ftsteutates-i2c-0-73 | jq &#39;.&quot;ftsteutates-i2c-0-73&quot; | del(.&quot;Adapter&quot;) | ???&#39; \r\n{\r\n  &quot;VCC 3.3V_in&quot;: 3.331,\r\n  &quot;3.3V AUX_in&quot;: 3.359,\r\n  &quot;V_IN (12V)_in&quot;: 12.012,\r\n  &quot;VBAT 3.0V_in&quot;: 2.692,\r\n  &quot;CPU_fan&quot;: 51.000,\r\n  &quot;Chassis_fan&quot;: 1200.000,\r\n  &quot;Ambient_temp&quot;: 44.000,\r\n  &quot;Core_temp&quot;: 54.000,\r\n  &quot;Memory_temp&quot;: 42.000,\r\n  &quot;PCH_temp&quot;: 54.000,\r\n  &quot;Graphics_temp&quot;: 40.000\r\n}\r\n```\r\nSomehow like (dosnt work)\r\n\r\n    sensors -j ftsteutates-i2c-0-73 | jq &#39;.&quot;ftsteutates-i2c-0-73&quot; | del(.&quot;Adapter&quot;) | with_entries(.key |= gsub(&quot; &quot;; &quot;_&quot;) | .value |= with_entries(select(.key | endswith(&quot;_input&quot;)) | .key |= gsub(&quot;_input&quot;; &quot;_in&quot;) | .key |= gsub(&quot;temp&quot;; &quot;_temp&quot;) | .key |= gsub(&quot;fan&quot;; &quot;_fan&quot;))) | with_entries(.value |= if type == &quot;object&quot; then .[] else . end)&#39;\r\n\r\nor \r\n\r\n    sensors -j ftsteutates-i2c-0-73 | jq &#39;.&quot;ftsteutates-i2c-0-73&quot; | del(.&quot;Adapter&quot;) | with_entries(.value |= if type == &quot;object&quot; then with_entries(select(.key | endswith(&quot;_input&quot;)) | .key |= gsub(&quot;_input&quot;; &quot;_in&quot;) | .key |= gsub(&quot;temp&quot;; &quot;_temp&quot;) | .key |= gsub(&quot;fan&quot;; &quot;_fan&quot;)) else . end) | with_entries(.value |= if type == &quot;object&quot; then .[] else . end)&#39;",
        "link": "https://stackoverflow.com/questions/79032744/map-keys-with-value-of-subkeys-in-jq",
        "title": "Map Keys with value of Subkeys in jq"
    },
    {
        "tags": [
            "json",
            "select",
            "jq",
            "any"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1727472881,
                "creation_date": 1727472881,
                "answer_id": 79032974,
                "question_id": 79032951,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Use the `IN` [function](https://jqlang.github.io/jq/manual/#sql-style-operators) to test for items in a stream:\r\n```sh\r\n.[] |= select(IN(.location[]?; &quot;Munich&quot;, &quot;Paris&quot;))\r\n```\r\n```json\r\n{\r\n  &quot;BAR&quot;: {\r\n    &quot;name&quot;: &quot;Walt&quot;,\r\n    &quot;location&quot;: [\r\n      &quot;Stockholm&quot;,\r\n      &quot;Munich&quot;\r\n    ]\r\n  },\r\n  &quot;BAZ&quot;: {\r\n    &quot;name&quot;: &quot;Jack&quot;,\r\n    &quot;location&quot;: [\r\n      &quot;Munich&quot;,\r\n      &quot;Paris&quot;\r\n    ]\r\n  },\r\n  &quot;BUZ&quot;: {\r\n    &quot;name&quot;: &quot;John&quot;,\r\n    &quot;location&quot;: [\r\n      &quot;London&quot;,\r\n      &quot;Paris&quot;\r\n    ]\r\n  }\r\n}\r\n```\r\n[Demo](https://jqplay.org/s/ybXpaZ5oM342Wvi)\r\n\r\nNote that the outer symbols need to be object braces `{}`, not array brackets `[]`.",
                "title": "How to filter JSON containing any of possible values, using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -1,
        "last_activity_date": 1727702836,
        "creation_date": 1727472149,
        "last_edit_date": 1727702836,
        "question_id": 79032951,
        "body_markdown": "I have the following json fragment:\r\n\r\n    [\r\n        &quot;FOO&quot;: {\r\n            &quot;name&quot;: &quot;Donald&quot;,\r\n            &quot;location&quot;: [&quot;Stockholm&quot;,&quot;London&quot;]\r\n        },\r\n        &quot;BAR&quot;: {\r\n            &quot;name&quot;: &quot;Walt&quot;,\r\n            &quot;location&quot;:  [&quot;Stockholm&quot;,&quot;Munich&quot;]\r\n        },\r\n        &quot;BAZ&quot;: {\r\n            &quot;name&quot;: &quot;Jack&quot;,\r\n            &quot;location&quot;:  [&quot;Munich&quot;,&quot;Paris&quot;]\r\n        },\r\n        &quot;BUZ&quot;: {\r\n            &quot;name&quot;: &quot;John&quot;,\r\n            &quot;location&quot;: [&quot;London&quot;,&quot;Paris&quot;]\r\n        },\r\n        &quot;QUX&quot;: {\r\n            &quot;name&quot;: &quot;Mickey&quot;\r\n        }\r\n    ]\r\n\r\nHow would I use jq to filter to all the that have **any** of Munich or Paris--that is:\r\n\r\n    [\r\n        &quot;BAR&quot;: {\r\n            &quot;name&quot;: &quot;Walt&quot;,\r\n            &quot;location&quot;:  [&quot;Stockholm&quot;,&quot;Munich&quot;]\r\n        },\r\n        &quot;BAZ&quot;: {\r\n            &quot;name&quot;: &quot;Jack&quot;,\r\n            &quot;location&quot;:  [&quot;Munich&quot;,&quot;Paris&quot;]\r\n        },\r\n        &quot;BUZ&quot;: {\r\n            &quot;name&quot;: &quot;John&quot;,\r\n            &quot;location&quot;: [&quot;London&quot;,&quot;Paris&quot;]\r\n        }\r\n    ]\r\n\r\n(of course, also excluding those that have no location at all)\r\n\r\nIt seems like when I use `or`, I get duplicated output. ",
        "link": "https://stackoverflow.com/questions/79032951/how-to-filter-json-containing-any-of-possible-values-using-jq",
        "title": "How to filter JSON containing any of possible values, using jq"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1727680015,
                "post_id": 79038230,
                "comment_id": 139362755,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 14952797,
                    "reputation": 11,
                    "user_id": 10795226,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/552750096848e614285d7a7ec2a76245?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Alimdi",
                    "link": "https://stackoverflow.com/users/10795226/alimdi"
                },
                "reply_to_user": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1727680909,
                "post_id": 79038230,
                "comment_id": 139362862,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1727685974,
                "last_edit_date": 1727685974,
                "creation_date": 1727683475,
                "answer_id": 79038457,
                "question_id": 79038230,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Iterate with `reduce` over the paths from `paths(. == null)`, get the corresponding value in the second `input` using `getpath`, and set it using `setpath` or fall back to the current iteration value using `? // .`.\r\n\r\n```sh\r\njq &#39;input as $in |\r\n  reduce paths(. == null) as $p (.; setpath($p; $in | getpath($p))? // .)\r\n&#39; first.json second.json\r\n```\r\n```json\r\n{\r\n  &quot;A&quot;: {\r\n    &quot;A1&quot;: {\r\n      &quot;A11&quot;: &quot;valueA11&quot;,\r\n      &quot;A12&quot;: null\r\n    }\r\n  },\r\n  &quot;B&quot;: {\r\n    &quot;B1&quot;: {\r\n      &quot;B12&quot;: &quot;valueB12&quot;\r\n    },\r\n    &quot;B2&quot;: &quot;valueB2&quot;\r\n  },\r\n  &quot;C&quot;: {\r\n    &quot;C1&quot;: {\r\n      &quot;C11&quot;: null,\r\n      &quot;C12&quot;: null\r\n    },\r\n    &quot;C2&quot;: {\r\n      &quot;C21&quot;: {\r\n        &quot;C211&quot;: null\r\n      }\r\n    }\r\n  }\r\n}\r\n```\r\n[Demo](https://jqplay.org/s/vw-DctO-4A0w5m-)",
                "title": "With jq Intersection of 2 json objects"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1727685974,
        "creation_date": 1727679517,
        "last_edit_date": 1727680845,
        "question_id": 79038230,
        "body_markdown": "I have a first json structure.\r\nAll the values are always null.\r\n\r\n```\r\n{\r\n    &quot;A&quot;: {\r\n        &quot;A1&quot;: {\r\n            &quot;A11&quot;: null,\r\n            &quot;A12&quot;: null\r\n        }\r\n    },\r\n    &quot;B&quot;: {\r\n        &quot;B1&quot;: {\r\n            &quot;B12&quot;: null\r\n        },\r\n        &quot;B2&quot;: null\r\n    },\r\n    &quot;C&quot;: {\r\n        &quot;C1&quot;: {\r\n            &quot;C11&quot;: null,\r\n            &quot;C12&quot;: null\r\n        },\r\n        &quot;C2&quot; : {\r\n            &quot;C21&quot;: {\r\n                &quot;C211&quot;: null\r\n            }\r\n        }\r\n    }\r\n}\r\n```\r\n\r\nIn the second json structure, all the values are always strings.\r\n\r\n\r\n```\r\n{\r\n    &quot;A&quot;: {\r\n        &quot;A1&quot;: {\r\n            &quot;A11&quot;: &quot;valueA11&quot;,\r\n        }\r\n    },\r\n    &quot;B&quot;: {\r\n        &quot;B1&quot;: {\r\n            &quot;B12&quot;: &quot;valueB12&quot;,\r\n            &quot;B13&quot;: &quot;valueB13&quot;\r\n        },\r\n        &quot;B2&quot;: &quot;valueB2&quot;\r\n    },\r\n    &quot;C&quot;: &quot;valueC&quot;\r\n}\r\n```\r\n\r\nThe result would be :\r\n\r\n```\r\n{\r\n    &quot;A&quot;: {\r\n        &quot;A1&quot;: {\r\n            &quot;A11&quot;: &quot;valueA11&quot;,\r\n            &quot;A12&quot;: null\r\n        }\r\n    },\r\n    &quot;B&quot;: {\r\n        &quot;B1&quot;: {\r\n            &quot;B12&quot;: &quot;valueB12&quot;\r\n        },\r\n        &quot;B2&quot;: &quot;valueB2&quot;\r\n    },\r\n    &quot;C&quot;: {\r\n        &quot;C1&quot;: {\r\n            &quot;C11&quot;: null,\r\n            &quot;C12&quot;: null\r\n        },\r\n        &quot;C2&quot; : {\r\n            &quot;C21&quot;: {\r\n                &quot;C211&quot;: null\r\n            }\r\n        }\r\n    }\r\n}\r\n```\r\n\r\nHow do I fill the first json keys with values from the second if the keys exists in the second json, otherwise we keep the null values\r\n\r\nI&#39;ve tried with jq on bash but without success. I&#39;m ready to use whatever tool that makes the job.",
        "link": "https://stackoverflow.com/questions/79038230/with-jq-intersection-of-2-json-objects",
        "title": "With jq Intersection of 2 json objects"
    },
    {
        "tags": [
            "json",
            "indexing",
            "stream",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1727798968,
                "creation_date": 1727798968,
                "answer_id": 79043933,
                "question_id": 79043921,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If you slurp (`-s`) the file, you can use the `last` keyword:\r\n```\r\njq -s &#39;last&#39; todo.json\r\n```",
                "title": "Trying to get the last object from a JSON list"
            },
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1727800072,
                "last_edit_date": 1727800072,
                "creation_date": 1727799693,
                "answer_id": 79043969,
                "question_id": 79043921,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "&gt; [Is] there another way for larger input files ? \r\n\r\nYes!  In a way, the whole point of jq is that it can process streams like yours efficiently, even when those streams are not [tag:NDJSON].\r\n\r\nIn your case, just use the -n command-line option and the program:\r\n\r\n    last(inputs)\r\n\r\n——\r\n\r\nAs you noticed, the ostensibly similar program `last(.)`, by contrast, executes iteratively for each JSON input.\r\n\r\n",
                "title": "Trying to get the last object from a JSON list"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1727834037,
        "creation_date": 1727798699,
        "last_edit_date": 1727834037,
        "question_id": 79043921,
        "body_markdown": "I have the following JSON data :\r\n```json\r\n$ cat toto.json\r\n{\r\n  &quot;method&quot;: &quot;GET&quot;,\r\n  &quot;path&quot;: &quot;/users/sign_in&quot;,\r\n  &quot;status&quot;: 500,\r\n  &quot;exception.class&quot;: &quot;NoMethodError&quot;,\r\n  &quot;exception.message&quot;: &quot;undefined method `user_azure_activedirectory_v2_omniauth_authorize_path&#39; for #&lt;ActionDispatch::Routing::RoutesProxy:0x00007d6fe7cfd0d0 @scope=#&lt;SessionsController:0x00000000186758&gt;, @routes=#&lt;ActionDispatch::Routing::RouteSet:0x00007d701b857b28&gt;, @helpers=#&lt;Module:0x00007d701b6f38b8&gt;, @script_namer=nil&gt;&quot;\r\n}\r\n{\r\n  &quot;method&quot;: &quot;GET&quot;,\r\n  &quot;path&quot;: &quot;/users/sign_in&quot;,\r\n  &quot;status&quot;: 500,\r\n  &quot;exception.class&quot;: &quot;NoMethodError&quot;,\r\n  &quot;exception.message&quot;: &quot;undefined method `user_azure_activedirectory_v2_omniauth_authorize_path&#39; for #&lt;ActionDispatch::Routing::RoutesProxy:0x00007d6ffb16f3f8 @scope=#&lt;SessionsController:0x00000000186910&gt;, @routes=#&lt;ActionDispatch::Routing::RouteSet:0x00007d701b857b28&gt;, @helpers=#&lt;Module:0x00007d701b6f38b8&gt;, @script_namer=nil&gt;&quot;\r\n}\r\n{\r\n  &quot;method&quot;: &quot;GET&quot;,\r\n  &quot;path&quot;: &quot;/users/sign_in&quot;,\r\n  &quot;status&quot;: 500,\r\n  &quot;exception.class&quot;: &quot;NoMethodError&quot;,\r\n  &quot;exception.message&quot;: &quot;undefined method `user_azure_activedirectory_v2_omniauth_authorize_path&#39; for #&lt;ActionDispatch::Routing::RoutesProxy:0x00007d6fe7e3e930 @scope=#&lt;SessionsController:0x00000000186870&gt;, @routes=#&lt;ActionDispatch::Routing::RouteSet:0x00007d701b857b28&gt;, @helpers=#&lt;Module:0x00007d701b6f38b8&gt;, @script_namer=nil&gt;&quot;\r\n}\r\n{\r\n  &quot;method&quot;: &quot;GET&quot;,\r\n  &quot;path&quot;: &quot;/users/sign_in&quot;,\r\n  &quot;status&quot;: 500,\r\n  &quot;exception.class&quot;: &quot;NoMethodError&quot;,\r\n  &quot;exception.message&quot;: &quot;undefined method `user_azure_activedirectory_v2_omniauth_authorize_path&#39; for #&lt;ActionDispatch::Routing::RoutesProxy:0x00007d6ff9a45a10 @scope=#&lt;SessionsController:0x000000001869b0&gt;, @routes=#&lt;ActionDispatch::Routing::RouteSet:0x00007d701b857b28&gt;, @helpers=#&lt;Module:0x00007d701b6f38b8&gt;, @script_namer=nil&gt;&quot;\r\n}\r\n{\r\n  &quot;method&quot;: &quot;GET&quot;,\r\n  &quot;path&quot;: &quot;/users/sign_in&quot;,\r\n  &quot;status&quot;: 500,\r\n  &quot;exception.class&quot;: &quot;NoMethodError&quot;,\r\n  &quot;exception.message&quot;: &quot;undefined method `user_azure_activedirectory_v2_omniauth_authorize_path&#39; for #&lt;ActionDispatch::Routing::RoutesProxy:0x00007d6ffd3dbc48 @scope=#&lt;SessionsController:0x000000001867f8&gt;, @routes=#&lt;ActionDispatch::Routing::RouteSet:0x00007d701b857b28&gt;, @helpers=#&lt;Module:0x00007d701b6f38b8&gt;, @script_namer=nil&gt;&quot;\r\n}\r\n{\r\n  &quot;method&quot;: &quot;GET&quot;,\r\n  &quot;path&quot;: &quot;/users/sign_in&quot;,\r\n  &quot;status&quot;: 500,\r\n  &quot;exception.class&quot;: &quot;NoMethodError&quot;,\r\n  &quot;exception.message&quot;: &quot;undefined method `user_azure_activedirectory_v2_omniauth_authorize_path&#39; for #&lt;ActionDispatch::Routing::RoutesProxy:0x00007d6ff75fb880 @scope=#&lt;SessionsController:0x00000000186a50&gt;, @routes=#&lt;ActionDispatch::Routing::RouteSet:0x00007d701b857b28&gt;, @helpers=#&lt;Module:0x00007d701b6f38b8&gt;, @script_namer=nil&gt;&quot;\r\n}\r\n{\r\n  &quot;method&quot;: &quot;GET&quot;,\r\n  &quot;path&quot;: &quot;/users/sign_in&quot;,\r\n  &quot;status&quot;: 500,\r\n  &quot;exception.class&quot;: &quot;NoMethodError&quot;,\r\n  &quot;exception.message&quot;: &quot;undefined method `user_azure_activedirectory_v2_omniauth_authorize_path&#39; for #&lt;ActionDispatch::Routing::RoutesProxy:0x00007d6ff75ffe80 @scope=#&lt;SessionsController:0x00000000186a28&gt;, @routes=#&lt;ActionDispatch::Routing::RouteSet:0x00007d701b857b28&gt;, @helpers=#&lt;Module:0x00007d701b6f38b8&gt;, @script_namer=nil&gt;&quot;\r\n}\r\n{\r\n  &quot;method&quot;: &quot;GET&quot;,\r\n  &quot;path&quot;: &quot;/users/sign_in&quot;,\r\n  &quot;status&quot;: 500,\r\n  &quot;exception.class&quot;: &quot;NoMethodError&quot;,\r\n  &quot;exception.message&quot;: &quot;undefined method `user_azure_activedirectory_v2_omniauth_authorize_path&#39; for #&lt;ActionDispatch::Routing::RoutesProxy:0x00007d6ffb34a858 @scope=#&lt;SessionsController:0x00000000188530&gt;, @routes=#&lt;ActionDispatch::Routing::RouteSet:0x00007d701b857b28&gt;, @helpers=#&lt;Module:0x00007d701b6f38b8&gt;, @script_namer=nil&gt;&quot;\r\n}\r\n{\r\n  &quot;method&quot;: &quot;GET&quot;,\r\n  &quot;path&quot;: &quot;/users/sign_in&quot;,\r\n  &quot;status&quot;: 500,\r\n  &quot;exception.class&quot;: &quot;NoMethodError&quot;,\r\n  &quot;exception.message&quot;: &quot;undefined method `user_azure_activedirectory_v2_omniauth_authorize_path&#39; for #&lt;ActionDispatch::Routing::RoutesProxy:0x00007d6ff724b460 @scope=#&lt;SessionsController:0x00000000188670&gt;, @routes=#&lt;ActionDispatch::Routing::RouteSet:0x00007d701b857b28&gt;, @helpers=#&lt;Module:0x00007d701b6f38b8&gt;, @script_namer=nil&gt;&quot;\r\n}\r\n{\r\n  &quot;method&quot;: &quot;GET&quot;,\r\n  &quot;path&quot;: &quot;/users/sign_in&quot;,\r\n  &quot;status&quot;: 500,\r\n  &quot;exception.class&quot;: &quot;NoMethodError&quot;,\r\n  &quot;exception.message&quot;: &quot;undefined method `user_azure_activedirectory_v2_omniauth_authorize_path&#39; for #&lt;ActionDispatch::Routing::RoutesProxy:0x00007d6ff6b526e0 @scope=#&lt;SessionsController:0x000000001886e8&gt;, @routes=#&lt;ActionDispatch::Routing::RouteSet:0x00007d701b857b28&gt;, @helpers=#&lt;Module:0x00007d701b6f38b8&gt;, @script_namer=nil&gt;&quot;\r\n}\r\n{\r\n  &quot;method&quot;: &quot;GET&quot;,\r\n  &quot;path&quot;: &quot;/users/sign_in&quot;,\r\n  &quot;status&quot;: 500,\r\n  &quot;exception.class&quot;: &quot;NoMethodError&quot;,\r\n  &quot;exception.message&quot;: &quot;undefined method `user_azure_activedirectory_v2_omniauth_authorize_path&#39; for #&lt;ActionDispatch::Routing::RoutesProxy:0x00007d6fdda80500 @scope=#&lt;SessionsController:0x00000000188f08&gt;, @routes=#&lt;ActionDispatch::Routing::RouteSet:0x00007d701b857b28&gt;, @helpers=#&lt;Module:0x00007d701b6f38b8&gt;, @script_namer=nil&gt;&quot;\r\n}\r\n{\r\n  &quot;method&quot;: &quot;GET&quot;,\r\n  &quot;path&quot;: &quot;/users/sign_in&quot;,\r\n  &quot;status&quot;: 500,\r\n  &quot;exception.class&quot;: &quot;NoMethodError&quot;,\r\n  &quot;exception.message&quot;: &quot;undefined method `user_azure_activedirectory_v2_omniauth_authorize_path&#39; for #&lt;ActionDispatch::Routing::RoutesProxy:0x00007d6feb2ab010 @scope=#&lt;SessionsController:0x00000000188850&gt;, @routes=#&lt;ActionDispatch::Routing::RouteSet:0x00007d701b857b28&gt;, @helpers=#&lt;Module:0x00007d701b6f38b8&gt;, @script_namer=nil&gt;&quot;\r\n}\r\n{\r\n  &quot;method&quot;: &quot;GET&quot;,\r\n  &quot;path&quot;: &quot;/users/sign_in&quot;,\r\n  &quot;status&quot;: 500,\r\n  &quot;exception.class&quot;: &quot;NoMethodError&quot;,\r\n  &quot;exception.message&quot;: &quot;undefined method `user_azure_activedirectory_v2_omniauth_authorize_path&#39; for #&lt;ActionDispatch::Routing::RoutesProxy:0x00007d6fddc9b330 @scope=#&lt;SessionsController:0x00000000188fa8&gt;, @routes=#&lt;ActionDispatch::Routing::RouteSet:0x00007d701b857b28&gt;, @helpers=#&lt;Module:0x00007d701b6f38b8&gt;, @script_namer=nil&gt;&quot;\r\n}\r\n{\r\n  &quot;method&quot;: &quot;GET&quot;,\r\n  &quot;path&quot;: &quot;/users/sign_in&quot;,\r\n  &quot;status&quot;: 500,\r\n  &quot;exception.class&quot;: &quot;NoMethodError&quot;,\r\n  &quot;exception.message&quot;: &quot;undefined method `user_azure_activedirectory_v2_omniauth_authorize_path&#39; for #&lt;ActionDispatch::Routing::RoutesProxy:0x00007d6ff6740098 @scope=#&lt;SessionsController:0x00000000188b70&gt;, @routes=#&lt;ActionDispatch::Routing::RouteSet:0x00007d701b857b28&gt;, @helpers=#&lt;Module:0x00007d701b6f38b8&gt;, @script_namer=nil&gt;&quot;\r\n}\r\n{\r\n  &quot;method&quot;: &quot;GET&quot;,\r\n  &quot;path&quot;: &quot;/users/sign_in&quot;,\r\n  &quot;status&quot;: 500,\r\n  &quot;exception.class&quot;: &quot;NoMethodError&quot;,\r\n  &quot;exception.message&quot;: &quot;undefined method `user_azure_activedirectory_v2_omniauth_authorize_path&#39; for #&lt;ActionDispatch::Routing::RoutesProxy:0x00007d6ffb73f3f0 @scope=#&lt;SessionsController:0x00000000189138&gt;, @routes=#&lt;ActionDispatch::Routing::RouteSet:0x00007d701b857b28&gt;, @helpers=#&lt;Module:0x00007d701b6f38b8&gt;, @script_namer=nil&gt;&quot;\r\n}\r\n{\r\n  &quot;method&quot;: &quot;GET&quot;,\r\n  &quot;path&quot;: &quot;/users/sign_in&quot;,\r\n  &quot;status&quot;: 500,\r\n  &quot;exception.class&quot;: &quot;NoMethodError&quot;,\r\n  &quot;exception.message&quot;: &quot;undefined method `user_azure_activedirectory_v2_omniauth_authorize_path&#39; for #&lt;ActionDispatch::Routing::RoutesProxy:0x00007d6fe8b98d88 @scope=#&lt;SessionsController:0x00000000188990&gt;, @routes=#&lt;ActionDispatch::Routing::RouteSet:0x00007d701b857b28&gt;, @helpers=#&lt;Module:0x00007d701b6f38b8&gt;, @script_namer=nil&gt;&quot;\r\n}\r\n{\r\n  &quot;method&quot;: &quot;GET&quot;,\r\n  &quot;path&quot;: &quot;/users/sign_in&quot;,\r\n  &quot;status&quot;: 500,\r\n  &quot;exception.class&quot;: &quot;NoMethodError&quot;,\r\n  &quot;exception.message&quot;: &quot;undefined method `user_azure_activedirectory_v2_omniauth_authorize_path&#39; for #&lt;ActionDispatch::Routing::RoutesProxy:0x000076156685d378 @scope=#&lt;SessionsController:0x00000000186758&gt;, @routes=#&lt;ActionDispatch::Routing::RouteSet:0x000076159a35afe0&gt;, @helpers=#&lt;Module:0x000076159a1e8b30&gt;, @script_namer=nil&gt;&quot;\r\n}\r\n{\r\n  &quot;method&quot;: &quot;GET&quot;,\r\n  &quot;path&quot;: &quot;/users/sign_in&quot;,\r\n  &quot;status&quot;: 500,\r\n  &quot;exception.class&quot;: &quot;NoMethodError&quot;,\r\n  &quot;exception.message&quot;: &quot;undefined method `user_azure_activedirectory_v2_omniauth_authorize_path&#39; for #&lt;ActionDispatch::Routing::RoutesProxy:0x0000761566955ca8 @scope=#&lt;SessionsController:0x000000001867f8&gt;, @routes=#&lt;ActionDispatch::Routing::RouteSet:0x000076159a35afe0&gt;, @helpers=#&lt;Module:0x000076159a1e8b30&gt;, @script_namer=nil&gt;&quot;\r\n}\r\n{\r\n  &quot;method&quot;: &quot;GET&quot;,\r\n  &quot;path&quot;: &quot;/users/sign_in&quot;,\r\n  &quot;status&quot;: 500,\r\n  &quot;exception.class&quot;: &quot;NoMethodError&quot;,\r\n  &quot;exception.message&quot;: &quot;undefined method `user_azure_activedirectory_v2_omniauth_authorize_path&#39; for #&lt;ActionDispatch::Routing::RoutesProxy:0x000076155c824410 @scope=#&lt;SessionsController:0x00000000188dc8&gt;, @routes=#&lt;ActionDispatch::Routing::RouteSet:0x000076159a35afe0&gt;, @helpers=#&lt;Module:0x000076159a1e8b30&gt;, @script_namer=nil&gt;&quot;\r\n}\r\n```\r\n\r\nI tried this command `cat toto.js | jq &#39;[.][-1]&#39;` but it outputs the whole file.\r\n\r\nI also tried this command `cat toto.js | jq &#39;last(.)&#39;` but it also outputs the whole file.\r\n\r\nI expect only the last element :\r\n```json\r\n{\r\n  &quot;method&quot;: &quot;GET&quot;,\r\n  &quot;path&quot;: &quot;/users/sign_in&quot;,\r\n  &quot;status&quot;: 500,\r\n  &quot;exception.class&quot;: &quot;NoMethodError&quot;,\r\n  &quot;exception.message&quot;: &quot;undefined method `user_azure_activedirectory_v2_omniauth_authorize_path&#39; for #&lt;ActionDispatch::Routing::RoutesProxy:0x000076155c824410 @scope=#&lt;SessionsController:0x00000000188dc8&gt;, @routes=#&lt;ActionDispatch::Routing::RouteSet:0x000076159a35afe0&gt;, @helpers=#&lt;Module:0x000076159a1e8b30&gt;, @script_namer=nil&gt;&quot;\r\n}\r\n```",
        "link": "https://stackoverflow.com/questions/79043921/trying-to-get-the-last-object-from-a-json-list",
        "title": "Trying to get the last object from a JSON list"
    },
    {
        "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": 0,
                "creation_date": 1727804379,
                "post_id": 79044165,
                "comment_id": 139373955,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 468289,
                    "reputation": 190915,
                    "user_id": 874188,
                    "user_type": "registered",
                    "accept_rate": 62,
                    "profile_image": "https://www.gravatar.com/avatar/091f411d57db5be8298e057a32e5ad72?s=256&d=identicon&r=PG",
                    "display_name": "tripleee",
                    "link": "https://stackoverflow.com/users/874188/tripleee"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1727804494,
                "post_id": 79044165,
                "comment_id": 139373969,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2234211,
                    "reputation": 2512,
                    "user_id": 1971062,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d428207ceca6531a1611d3e4cb0699c4?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Solonl",
                    "link": "https://stackoverflow.com/users/1971062/solonl"
                },
                "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": 1727804601,
                "post_id": 79044165,
                "comment_id": 139373983,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 468289,
                    "reputation": 190915,
                    "user_id": 874188,
                    "user_type": "registered",
                    "accept_rate": 62,
                    "profile_image": "https://www.gravatar.com/avatar/091f411d57db5be8298e057a32e5ad72?s=256&d=identicon&r=PG",
                    "display_name": "tripleee",
                    "link": "https://stackoverflow.com/users/874188/tripleee"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1727804745,
                "post_id": 79044165,
                "comment_id": 139374000,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2234211,
                    "reputation": 2512,
                    "user_id": 1971062,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d428207ceca6531a1611d3e4cb0699c4?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Solonl",
                    "link": "https://stackoverflow.com/users/1971062/solonl"
                },
                "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": 1727804865,
                "post_id": 79044165,
                "comment_id": 139374012,
                "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": 1727805016,
                "post_id": 79044165,
                "comment_id": 139374026,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1450087,
                    "reputation": 12022,
                    "user_id": 1409374,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/97d424fe924f2139812a4a6de1ef6b79?s=256&d=identicon&r=PG",
                    "display_name": "rickhg12hs",
                    "link": "https://stackoverflow.com/users/1409374/rickhg12hs"
                },
                "reply_to_user": {
                    "account_id": 39208,
                    "reputation": 267964,
                    "user_id": 112968,
                    "user_type": "registered",
                    "accept_rate": 68,
                    "profile_image": "https://i.sstatic.net/zHTaT.png?s=256",
                    "display_name": "knittl",
                    "link": "https://stackoverflow.com/users/112968/knittl"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1727814032,
                "post_id": 79044165,
                "comment_id": 139374795,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 433754,
                    "reputation": 42708,
                    "user_id": 995714,
                    "user_type": "registered",
                    "accept_rate": 56,
                    "profile_image": "https://i.sstatic.net/w1393.jpg?s=256",
                    "display_name": "phuclv",
                    "link": "https://stackoverflow.com/users/995714/phuclv"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1727836601,
                "post_id": 79044165,
                "comment_id": 139375970,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2234211,
                    "reputation": 2512,
                    "user_id": 1971062,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d428207ceca6531a1611d3e4cb0699c4?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Solonl",
                    "link": "https://stackoverflow.com/users/1971062/solonl"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1727846410,
                "post_id": 79044165,
                "comment_id": 139376332,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2234211,
                    "reputation": 2512,
                    "user_id": 1971062,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d428207ceca6531a1611d3e4cb0699c4?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Solonl",
                    "link": "https://stackoverflow.com/users/1971062/solonl"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1727846482,
                "post_id": 79044165,
                "comment_id": 139376338,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2234211,
                    "reputation": 2512,
                    "user_id": 1971062,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d428207ceca6531a1611d3e4cb0699c4?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Solonl",
                    "link": "https://stackoverflow.com/users/1971062/solonl"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1727846600,
                "post_id": 79044165,
                "comment_id": 139376345,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2234211,
                    "reputation": 2512,
                    "user_id": 1971062,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d428207ceca6531a1611d3e4cb0699c4?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Solonl",
                    "link": "https://stackoverflow.com/users/1971062/solonl"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1727846768,
                "post_id": 79044165,
                "comment_id": 139376356,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1727814044,
                "creation_date": 1727814044,
                "answer_id": 79044635,
                "question_id": 79044165,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Try removing non-printable characters\r\n\r\n```\r\ncurl ... | tr -cd &#39;[:print:]&#39; | sed &#39;s/^data://&#39; | jq &#39;.summary&#39;\r\n```\r\n\r\nand you should get\r\n\r\n```\r\n&quot;Balans: 305.37&quot;\r\n&quot;Balans: 305.37&quot;\r\n...\r\n```\r\n",
                "title": "Jq fails and shows no output on SSE endpoint through curl"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1727852235,
                "last_edit_date": 1727852235,
                "creation_date": 1727819211,
                "answer_id": 79044830,
                "question_id": 79044165,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "A full `jq` solution:\r\n\r\n```sh\r\ncurl... | jq -Rs &#39;match(&quot;data:(.*)&quot;)|.captures[0].string|fromjson|.summary\r\n```\r\n\r\nIn details:\r\n- `jq --raw-input --slurp` handles input as raw string data and captures everything including newlines\r\n- `match(&quot;data:(.*)&quot;)` Regex match string starting with `data:` and captures `.*` everything ongoing after that.\r\n- `.captures[0].string` This contains the captured string that is expected to be raw JSON.\r\n- `fromjson|` Parses the raw JSON into actual JSON data\r\n. `.summary` outputs the summary entry from the root object\r\n",
                "title": "Jq fails and shows no output on SSE endpoint through curl"
            },
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1727859986,
                "creation_date": 1727859986,
                "answer_id": 79046063,
                "question_id": 79044165,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Using your NodeJS test server, this works for me:\r\n```sh\r\n$ node server.js &amp;\r\n[1] 691108\r\nListening on port 3000\r\n\r\n$ curl -N -H &quot;Accept:text/event-stream&quot; --silent http://localhost:3000/events \\\r\n&gt; | jq -R &#39;scan(&quot;^data:(.*)&quot;)[] | fromjson.summary&#39;\r\n&quot;Balans: 305.37&quot;\r\n&quot;Balans: 305.37&quot;\r\n&quot;Balans: 305.37&quot;\r\n&quot;Balans: 305.37&quot;\r\n^C\r\n```",
                "title": "Jq fails and shows no output on SSE endpoint through curl"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 0,
        "last_activity_date": 1727859986,
        "creation_date": 1727804052,
        "last_edit_date": 1727846698,
        "question_id": 79044165,
        "body_markdown": "## Working example with Jq\r\n\r\n```\r\necho &#39;data:{&quot;id&quot;:&quot;66fc29f995e5b148fe5c7f7d&quot;,&quot;summary&quot;:&quot;Balans: 305.37&quot;,&quot;level&quot;:&quot;info&quot;,&quot;date&quot;:&quot;2024-10-01T16:57:29.873+00:00&quot;}&#39; | sed &#39;s/data://g&#39; | jq &#39;.summary&#39;\r\n```\r\n\r\nEven with new line at the end\r\n\r\n```\r\necho &#39;data:{&quot;id&quot;:&quot;66fc29f995e5b148fe5c7f7d&quot;,&quot;summary&quot;:&quot;Balans: 305.37&quot;,&quot;level&quot;:&quot;info&quot;,&quot;date&quot;:&quot;2024-10-01T16:57:29.873+00:00&quot;}\r\n&#39; | sed &#39;s/data://g&#39;  | jq &#39;.summary&#39;\r\n```\r\n\r\n### Output (success)\r\n\r\n&quot;Balans: 305.37&quot;\r\n\r\n\r\n## Not working example with Curl (and SSE endpoint)\r\n\r\n```\r\ncurl -N --http2 -H &quot;Accept:text/event-stream&quot; --silent https://my_domain/stream/OyP1cEC3N7BTQrCsm3AHrTFAj5F5VKCH/notifications | sed &#39;s/data://g&#39; | jq &#39;.summary&#39;\r\n```\r\n\r\nThis shows no output! My question is: why is this not working? \r\nThe following line does however show an output:\r\n\r\n## Working example with Curl (and SSE endpoint), without jq at end\r\n\r\n```\r\nanon@galliumos:~/Bureaublad$ curl -N --http2 -H &quot;Accept:text/event-stream&quot; --silent https://my_domain/stream/OyP1cEC3N7BTQrCsm3AHrTFAj5F5VKCH/notifications | sed &#39;s/data://g&#39;\r\n{&quot;id&quot;:&quot;66fc310d95e5b148fe5c7f8d&quot;,&quot;summary&quot;:&quot;Balans: 305.37&quot;,&quot;level&quot;:&quot;info&quot;,&quot;date&quot;:&quot;2024-10-01T17:27:41.679+00:00&quot;}\r\n\r\n```\r\n\r\nThe response on my SSE endpoint looks like this, and is working:\r\n\r\n```\r\ndata:{&quot;id&quot;:&quot;66fc310d95e5b148fe5c7f8d&quot;,&quot;summary&quot;:&quot;Balans: 305.37&quot;,&quot;level&quot;:&quot;info&quot;,&quot;date&quot;:&quot;2024-10-01T17:27:41.679+00:00&quot;}\r\n\r\ndata:{&quot;id&quot;:&quot;66fc310d95e5b148fe5c7f8a&quot;,&quot;summary&quot;:&quot;Balans: 305.37&quot;,&quot;level&quot;:&quot;info&quot;,&quot;date&quot;:&quot;2024-10-01T17:27:41.679+00:00&quot;}\r\n\r\n... more records here ...\r\n\r\n```\r\n\r\n## Update with local SSE test server using NodeJS\r\n\r\n\r\nThis provides a sample SSE endpoint on localhost port 3000. \r\n\r\n1. Create a file named `server.js` and add the code\r\n2. Run server with: `node server.js`\r\n\r\n```js\r\nconst http = require(&#39;http&#39;);\r\nconst port = process.env.PORT || 3000;\r\n\r\nconst server = http.createServer((req, res) =&gt; {\r\n  // Server-sent events endpoint\r\n  if (req.url === &#39;/events&#39;) {\r\n    res.writeHead(200, {\r\n      &#39;Content-Type&#39;: &#39;text/event-stream&#39;,\r\n      &#39;Cache-Control&#39;: &#39;no-cache&#39;,\r\n      ...(req.httpVersionMajor === 1 &amp;&amp; { &#39;Connection&#39;: &#39;keep-alive&#39; })\r\n    });\r\n\r\n    const refreshRate = 1000; // in milliseconds\r\n    return setInterval(() =&gt; {\r\n      const data = &#39;{&quot;id&quot;:&quot;66fc310d95e5b148fe5c7f8d&quot;,&quot;summary&quot;:&quot;Balans: 305.37&quot;,&quot;level&quot;:&quot;info&quot;,&quot;date&quot;:&quot;2024-10-01T17:27:41.679+00:00&quot;}&#39;;\r\n      const message = `data:${data}\\n\\n`;\r\n      res.write(message);\r\n    }, refreshRate);\r\n  }\r\n\r\n  // Client side\r\n  res.writeHead(200, {&#39;Content-Type&#39;: &#39;text/html&#39;});\r\n  res.end(`\r\n    &lt;!DOCTYPE html&gt;\r\n    &lt;html lang=&quot;en&quot; dir=&quot;ltr&quot;&gt;\r\n      &lt;head&gt;\r\n        &lt;meta charset=&quot;utf-8&quot;&gt;\r\n        &lt;title&gt;SSE&lt;/title&gt;\r\n      &lt;/head&gt;\r\n      &lt;body&gt;\r\n        &lt;pre id=&quot;log&quot;&gt;&lt;/pre&gt;\r\n      &lt;/body&gt;\r\n      &lt;script&gt;\r\n        var eventSource = new EventSource(&#39;/events&#39;);\r\n        eventSource.onmessage = function(event) {\r\n          document.getElementById(&#39;log&#39;).innerHTML += event.data + &#39;&lt;br&gt;&#39;;\r\n        };\r\n      &lt;/script&gt;\r\n    &lt;/html&gt;\r\n  `);\r\n});\r\n\r\nserver.listen(port);\r\n\r\nserver.on(&#39;error&#39;, (err) =&gt; {\r\n  console.log(err);\r\n  process.exit(1);\r\n});\r\n\r\nserver.on(&#39;listening&#39;, () =&gt; {\r\n  console.log(`Listening on port ${port}`);\r\n});\r\n```\r\n\r\nGetting output:\r\n\r\n```\r\ncurl -N -H &quot;Accept:text/event-stream&quot; --silent http://localhost:3000/events\r\n```\r\n\r\n## Tests results\r\n\r\nI got no output/ results with: \r\n\r\n```\r\ncurl -N -H &quot;Accept:text/event-stream&quot; --silent http://localhost:3000/events | jq -Rs &#39;match(&quot;data:(.*)&quot;)|.captures[0].string|fromjson|.summary&#39;\r\n```\r\n\r\nand\r\n\r\n```\r\ncurl -N -H &quot;Accept:text/event-stream&quot; --silent http://localhost:3000/events | tr -cd &#39;[:print:]&#39; | sed &#39;s/^data://&#39; | jq &#39;.summary&#39;\r\n```\r\n\r\n## Update 2: Output of `hexdump -C` in combination with curl `--no-buffer`\r\n\r\n```\r\ncurl -N --http2 -H &quot;Accept:text/event-stream&quot; --silent --no-buffer  https://my_domain/stream/OyP1cEC3N7BTQrCsm3AHrTFAj5F5VKCH/notifications | hexdump -C\r\n```\r\n\r\nWill give the following output:\r\n\r\n```\r\n00000000  64 61 74 61 3a 7b 22 69  64 22 3a 22 36 36 66 63  |data:{&quot;id&quot;:&quot;66fc|\r\n00000010  64 38 39 65 39 35 65 35  62 31 34 38 66 65 35 63  |d89e95e5b148fe5c|\r\n00000020  37 66 64 32 22 2c 22 73  75 6d 6d 61 72 79 22 3a  |7fd2&quot;,&quot;summary&quot;:|\r\n00000030  22 55 6e 69 6e 76 6f 69  63 65 64 20 61 6d 6f 75  |&quot;Uninvoiced amou|\r\n00000040  6e 74 20 30 2e 33 39 22  2c 22 6c 65 76 65 6c 22  |nt 0.39&quot;,&quot;level&quot;|\r\n00000050  3a 22 69 6e 66 6f 22 2c  22 64 61 74 65 22 3a 22  |:&quot;info&quot;,&quot;date&quot;:&quot;|\r\n00000060  32 30 32 34 2d 31 30 2d  30 32 54 30 35 3a 32 32  |2024-10-02T05:22|\r\n00000070  3a 33 38 2e 38 37 37 2b  30 30 3a 30 30 22 7d 0a  |:38.877+00:00&quot;}.|\r\n```",
        "link": "https://stackoverflow.com/questions/79044165/jq-fails-and-shows-no-output-on-sse-endpoint-through-curl",
        "title": "Jq fails and shows no output on SSE endpoint through curl"
    },
    {
        "tags": [
            "json",
            "jq",
            "empty-list"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 22609322,
                    "reputation": 13,
                    "user_id": 16789750,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/4a7f5762aa60c9afca4bbca779c2cf95?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "chemxboy",
                    "link": "https://stackoverflow.com/users/16789750/chemxboy"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1727895203,
                "post_id": 79048103,
                "comment_id": 139381142,
                "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": 1727898467,
                "post_id": 79048103,
                "comment_id": 139381412,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 22609322,
                    "reputation": 13,
                    "user_id": 16789750,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/4a7f5762aa60c9afca4bbca779c2cf95?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "chemxboy",
                    "link": "https://stackoverflow.com/users/16789750/chemxboy"
                },
                "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": 1727983756,
                "post_id": 79048103,
                "comment_id": 139387939,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1727898077,
                "creation_date": 1727898077,
                "answer_id": 79048239,
                "question_id": 79048103,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If you fix the test and add parentheses, the code in your comment may do what you intend:\r\n\r\n```\r\n.results | .[] | {\r\n    id,\r\n    name: .general.name,\r\n    platform: .general.platform,\r\n    site: .general.site.name,\r\n    ea_site: (\r\n        .extensionAttributes.[] | select(.definitionId==&quot;57&quot;).values |\r\n        if ( . | length &gt; 0 ) then .[] else &quot;blank&quot; end\r\n    )\r\n}\r\n```\r\n\r\nNote that if the values array contains multiple elements, you&#39;ll get a copy of the object you are creating for each one.",
                "title": "Using if-then-else-end in jq to handle missing values"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1727900723,
                "creation_date": 1727900723,
                "answer_id": 79048365,
                "question_id": 79048103,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can use the more concise `//` operator: \r\n\r\n```\r\njq &#39;.results[] | {\r\n    id, name: .general.name, platform: .general.platform, site: .general.site.name,\r\n    ea_site: ((.extensionAttributes.[] | select(.definitionId==&quot;57&quot;).values.[]) // null)\r\n  }&#39; data.json\r\n```\r\n\r\n```\r\n# output\r\n{\r\n  &quot;id&quot;: &quot;3882&quot;,\r\n  &quot;name&quot;: &quot;Kresge-iMac-900&quot;,\r\n  &quot;platform&quot;: &quot;Mac&quot;,\r\n  &quot;site&quot;: &quot;Arts&quot;,\r\n  &quot;ea_site&quot;: &quot;Arts&quot;\r\n}\r\n{\r\n  &quot;id&quot;: &quot;3881&quot;,\r\n  &quot;name&quot;: &quot;c-loaner&quot;,\r\n  &quot;platform&quot;: &quot;Mac&quot;,\r\n  &quot;site&quot;: &quot;.Production&quot;,\r\n  &quot;ea_site&quot;: null\r\n}\r\n```",
                "title": "Using if-then-else-end in jq to handle missing values"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1727966804,
                "creation_date": 1727966804,
                "answer_id": 79051062,
                "question_id": 79048103,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "A simple way to use `if...then...else...end` here based on your own attempt is as follows:\r\n```\r\n.results\r\n| .[]\r\n| {id, name: .general.name, platform: .general.platform, site: .general.site.name,\r\n   ea_site:\r\n       ((.extensionAttributes[] | select(.definitionId==&quot;57&quot;).values) \r\n         | if . == [] then . else .[] end)\r\n       }\r\n   \r\n```\r\n\r\nPlease note that in jq terminology, the &quot;empty list&quot; is quite different from `empty`: the latter is both a keyword and a reference to the empty stream.  (For me, it was your reference to line 1218, in which the value is [], that clarified the intent of the question.)",
                "title": "Using if-then-else-end in jq to handle missing values"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 1,
        "last_activity_date": 1728005967,
        "creation_date": 1727894788,
        "last_edit_date": 1728005967,
        "question_id": 79048103,
        "body_markdown": "This is the command I use to pull the info I need:\r\n\r\n```\r\n.results | .[] | {id, name: .general.name, platform: .general.platform, site: .general.site.name, ea_site: .extensionAttributes.[] | select(.definitionId==&quot;57&quot;).values.[]}\r\n```\r\n\r\nWhen `.extensionAttributes.[] | select(.definitionId==&quot;57&quot;).values.[]`  is empty, jq does not display any associated items at all.\r\n\r\nWhat I&#39;d like to do is check if `.extensionAttributes.[] | select(.definitionId==&quot;57&quot;).values.[] &lt; 0` and return empty otherwise return the content. I&#39;m trying to use if-then-else-end, but can&#39;t seem to get the syntax correct.\r\n\r\nYou can find sample data in jqplay [here](https://jqplay.org/s/WEKS6x1W8qjVl43).\r\nLine 1218 in the json input has the empty value.\r\n\r\nDesired output:\r\n```\r\n{ &quot;id&quot;: &quot;3882&quot;, &quot;name&quot;: &quot;Kresge-iMac-900&quot;, &quot;platform&quot;: &quot;Mac&quot;, &quot;site&quot;: &quot;Arts&quot;, &quot;ea_site&quot;: &quot;Arts&quot;}\r\n{ &quot;id&quot;: &quot;3881&quot;, &quot;name&quot;: &quot;c-loaner&quot;, &quot;platform&quot;: &quot;Mac&quot;, &quot;site&quot;: &quot;.Production&quot;, &quot;ea_site&quot;: &quot;blank&quot;}\r\n```\r\n",
        "link": "https://stackoverflow.com/questions/79048103/using-if-then-else-end-in-jq-to-handle-missing-values",
        "title": "Using if-then-else-end in jq to handle missing values"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1728088840,
                "last_edit_date": 1728088840,
                "creation_date": 1728031639,
                "answer_id": 79053476,
                "question_id": 79053407,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Break up the document into a stream of key-value pairs using `tostream`, while discarding back-tracking items by `select`ing only ones having a value (at position `1`). Then, re-arrange the path arrays by splitting strings (not `numbers`) at colons. Eventually, re-construct the output object using `setpath`.\r\n```sh\r\nreduce (tostream | select(has(1))) as $i (null;\r\n  setpath($i[0] | map(numbers // splits(&quot;:&quot;)); $i[1])\r\n)\r\n```\r\n```json\r\n[\r\n  {\r\n    &quot;ExifTool&quot;: {\r\n      &quot;ExifTool&quot;: {\r\n        &quot;ExifTool&quot;: {\r\n          &quot;ExifToolVersion&quot;: 12.76\r\n        }\r\n      }\r\n    },\r\n    &quot;SourceFile&quot;: &quot;./_DSC5848.JPG&quot;,\r\n    &quot;File&quot;: {\r\n      &quot;System&quot;: {\r\n        &quot;Other&quot;: {\r\n          &quot;FileName&quot;: &quot;_DSC5848.JPG&quot;,\r\n          &quot;Directory&quot;: &quot;.&quot;,\r\n          &quot;FileSize&quot;: &quot;82 kB&quot;,\r\n          &quot;FilePermissions&quot;: &quot;-rw-r--r--&quot;\r\n        },\r\n        &quot;Time&quot;: {\r\n          &quot;FileModifyDate&quot;: &quot;2024:09:24 14:10:16-07:00&quot;,\r\n          &quot;FileAccessDate&quot;: &quot;2024:09:28 00:13:26-07:00&quot;,\r\n          &quot;FileInodeChangeDate&quot;: &quot;2024:09:25 23:26:20-07:00&quot;\r\n        }\r\n      }\r\n    },\r\n    &quot;EXIF&quot;: {\r\n      &quot;ExifIFD&quot;: {\r\n        &quot;Camera&quot;: {\r\n          &quot;ExposureProgram&quot;: &quot;Aperture-priority AE&quot;,\r\n          &quot;MaxApertureValue&quot;: 1.4,\r\n          &quot;Sharpness&quot;: &quot;Normal&quot;\r\n        },\r\n        &quot;Image&quot;: {\r\n          &quot;ExposureTime&quot;: &quot;1/50&quot;,\r\n          &quot;FNumber&quot;: 4.0,\r\n          &quot;ISO&quot;: 200\r\n        }\r\n      }\r\n    }\r\n  }\r\n]\r\n```\r\n[Demo](https://jqplay.org/s/CNNWfKyW3KO7rqS)",
                "title": "Can jq unroll a list of objects by arbitrary key name?"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1728072640,
                "last_edit_date": 1728072640,
                "creation_date": 1728039910,
                "answer_id": 79053972,
                "question_id": 79053407,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Using `unroll_keys` as defined below gives quite a lot of flexibility.  Note that common prefixes are dealt with properly:\r\n\r\n```\r\n{&quot;A:B&quot;: 0, &quot;A:C&quot;: 1} | unroll_keys #=&gt; {&quot;A&quot;:{&quot;B&quot;:0,&quot;C&quot;:1}}\r\n```\r\nTo unroll the keys of all objects, you could use `walk` as shown below.\r\n\r\n```\r\n# Assume the input is an object\r\ndef unroll_keys:\r\n  def unroll($key; $value):\r\n    ($key | split(&quot;:&quot;)) as $a\r\n    | setpath($a; $value);\r\n\r\n  . as $in\r\n  | reduce keys_unsorted[] as $k ({};\r\n       if $k|test(&quot;:&quot;)\r\n       then $in[$k] as $v\r\n       | unroll($k; $v)\r\n       else .[$k] = $in[$k]\r\n       end);\r\n\r\nwalk(if type == &quot;object&quot; then unroll_keys else . end)\r\n```",
                "title": "Can jq unroll a list of objects by arbitrary key name?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1728090455,
        "creation_date": 1728030667,
        "last_edit_date": 1728090455,
        "question_id": 79053407,
        "body_markdown": "I have a bit of a thorny JSON manipulation problem.  I have half a mind to just write a Python program to do it, but I’m wondering if a well-written `jq` query can solve it more elegantly — partly for a cleaner solution, and partly for pedagogic purposes.  (I’m a `jq` noob and would love to take this opportunity to learn.)\r\n\r\nI have the following JSON, printed from a tool whose output format I cannot modify:\r\n\r\n```json\r\n[\r\n  {\r\n    &quot;ExifTool:ExifTool:ExifTool&quot;: {\r\n      &quot;ExifToolVersion&quot;: 12.76\r\n    },\r\n    &quot;SourceFile&quot;: &quot;./_DSC5848.JPG&quot;,\r\n    &quot;File:System:Other&quot;: {\r\n      &quot;FileName&quot;: &quot;_DSC5848.JPG&quot;,\r\n      &quot;Directory&quot;: &quot;.&quot;,\r\n      &quot;FileSize&quot;: &quot;82 kB&quot;,\r\n      &quot;FilePermissions&quot;: &quot;-rw-r--r--&quot;\r\n    },\r\n    &quot;EXIF:ExifIFD:Camera&quot;: {\r\n      &quot;ExposureProgram&quot;: &quot;Aperture-priority AE&quot;,\r\n      &quot;MaxApertureValue&quot;: 1.4,\r\n      &quot;Sharpness&quot;: &quot;Normal&quot;\r\n    },\r\n    &quot;File:System:Time&quot;: {\r\n      &quot;FileModifyDate&quot;: &quot;2024:09:24 14:10:16-07:00&quot;,\r\n      &quot;FileAccessDate&quot;: &quot;2024:09:28 00:13:26-07:00&quot;,\r\n      &quot;FileInodeChangeDate&quot;: &quot;2024:09:25 23:26:20-07:00&quot;\r\n    },\r\n    &quot;EXIF:ExifIFD:Image&quot;: {\r\n      &quot;ExposureTime&quot;: &quot;1/50&quot;,\r\n      &quot;FNumber&quot;: 4.0,\r\n      &quot;ISO&quot;: 200\r\n    },\r\n    ... additional arbitrary colon-keys ...\r\n  },\r\n  { ... },\r\n  { ... },\r\n  { ... },\r\n  { ... }\r\n]\r\n```\r\n\r\nI need the keys containing colons (I’ll call them “colon-keys”) to be recursively “unrolled” such that `&quot;A:B:C&quot;: { ... }` becomes:\r\n\r\n```json\r\n&quot;A&quot;: {\r\n  &quot;B&quot;: {\r\n    &quot;C&quot;: { ... }\r\n  }\r\n}\r\n```\r\n\r\nColon-keys with identical prefixes would be merged.  For example, if there is also a colon-key `&quot;A:B:D&quot;: { ... }`, the above would become:\r\n\r\n```json\r\n&quot;A&quot;: {\r\n  &quot;B&quot;: {\r\n    &quot;C&quot;: { ... },\r\n    &quot;D&quot;: { ... }\r\n  }\r\n}\r\n```\r\n\r\nPreserving the order of keys isn’t crucial, though it’d be cool if possible. It’s not known in advance what the names of the colon-keys will be, so hard-coding them unfortunately isn’t an option.\r\n\r\n---\r\n\r\n**[Update about 12 hours after initial post to clarify how arrays behave]** The input may be an array of objects (as given in the example), or it may be a single object.\r\n\r\nIn addition, this unrolling should recursively descend into arrays, so the following input:\r\n\r\n```json\r\n{\r\n  &quot;A:B&quot;: [\r\n    {\r\n      &quot;C:D:E&quot;: { ... }\r\n    },\r\n    {\r\n      &quot;C:D:F&quot;: { ... }\r\n    }\r\n  ]\r\n}\r\n```\r\n\r\nWould produce the following output:\r\n\r\n```json\r\n{\r\n  &quot;A&quot;: {\r\n    &quot;B&quot;: [\r\n      {\r\n        &quot;C&quot;: {\r\n          &quot;D&quot;: {\r\n            &quot;E&quot;: { ... }\r\n          }\r\n        }\r\n      },\r\n      {\r\n        &quot;C&quot;: {\r\n          &quot;D&quot;: {\r\n            &quot;F&quot;: { ... }\r\n          }\r\n        }\r\n      }\r\n    ]\r\n  }\r\n}\r\n```\r\n\r\nAlso notice from the above that the unrolling should _not_ merge colon-keys across list elements; i.e., it should _not_ produce the following:\r\n\r\n```json\r\nIt should NOT produce this:\r\n\r\n{\r\n  &quot;A&quot;: {\r\n    &quot;B&quot;: [\r\n      {\r\n        &quot;C&quot;: {\r\n          &quot;D&quot;: {\r\n            &quot;E&quot;: { ... },\r\n            &quot;F&quot;: { ... }\r\n          }\r\n        }\r\n      }\r\n    ]\r\n  }\r\n}\r\n```\r\n\r\n---\r\n\r\nSo to circle back to the example from the beginning of this post, the output would look like:\r\n\r\n```json\r\n[\r\n  {\r\n    &quot;ExifTool&quot;: {\r\n      &quot;ExifTool&quot;: {\r\n        &quot;ExifTool&quot;: {\r\n          &quot;ExifToolVersion&quot;: 12.76\r\n        }\r\n      }\r\n    },\r\n    &quot;SourceFile&quot;: &quot;./_DSC5848.JPG&quot;,\r\n    &quot;File&quot;: {\r\n      &quot;System&quot;: {\r\n        &quot;Other&quot;: {\r\n          &quot;FileName&quot;: &quot;_DSC5848.JPG&quot;,\r\n          &quot;Directory&quot;: &quot;.&quot;,\r\n          &quot;FileSize&quot;: &quot;82 kB&quot;,\r\n          &quot;FilePermissions&quot;: &quot;-rw-r--r--&quot;\r\n        },\r\n        &quot;Time&quot;: {\r\n          &quot;FileModifyDate&quot;: &quot;2024:09:24 14:10:16-07:00&quot;,\r\n          &quot;FileAccessDate&quot;: &quot;2024:09:28 00:13:26-07:00&quot;,\r\n          &quot;FileInodeChangeDate&quot;: &quot;2024:09:25 23:26:20-07:00&quot;\r\n        }\r\n      }\r\n    },\r\n    &quot;EXIF&quot;: {\r\n      &quot;ExifIFD&quot;: {\r\n        &quot;Camera&quot;: {\r\n          &quot;ExposureProgram&quot;: &quot;Aperture-priority AE&quot;,\r\n          &quot;MaxApertureValue&quot;: 1.4,\r\n          &quot;Sharpness&quot;: &quot;Normal&quot;\r\n        },\r\n        &quot;Image&quot;: {\r\n          &quot;ExposureTime&quot;: &quot;1/50&quot;,\r\n          &quot;FNumber&quot;: 4.0,\r\n          &quot;ISO&quot;: 200\r\n        }\r\n      }\r\n    }\r\n  },\r\n  { ... },\r\n  { ... },\r\n  { ... },\r\n  { ... }\r\n]\r\n```\r\n\r\nIs this possible to do with a well-written `jq` query, or is my only option a hand-rolled program?\r\n\r\nBonus, would such a query be able to handle colon-keys of arbitrary length (`A:B`, `A:B:C`, `A:B:C:D`, etc.) and at arbitrary levels of the JSON (`&quot;A:B:C&quot;: { &quot;D:E&quot;: { ... } }`)?\r\n\r\n---\r\n\r\n**Update:** Solved: See @pmf’s solution, which is extremely elegant and very robust, as it’s able to handle arbitrarily-nested objects and lists in a very short query.",
        "link": "https://stackoverflow.com/questions/79053407/can-jq-unroll-a-list-of-objects-by-arbitrary-key-name",
        "title": "Can jq unroll a list of objects by arbitrary key name?"
    },
    {
        "tags": [
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 1613587,
                    "reputation": 786618,
                    "user_id": 1491895,
                    "user_type": "registered",
                    "accept_rate": 69,
                    "profile_image": "https://www.gravatar.com/avatar/82f9e178a16364bf561d0ed4da09a35d?s=256&d=identicon&r=PG",
                    "display_name": "Barmar",
                    "link": "https://stackoverflow.com/users/1491895/barmar"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1728070311,
                "post_id": 79055566,
                "comment_id": 139394291,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1020072,
                    "reputation": 243994,
                    "user_id": 1030675,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/957956ce51706d03f19a4dc85a767bb1?s=256&d=identicon&r=PG",
                    "display_name": "choroba",
                    "link": "https://stackoverflow.com/users/1030675/choroba"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1728070692,
                "post_id": 79055566,
                "comment_id": 139394319,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1728070876,
                "creation_date": 1728070876,
                "answer_id": 79055641,
                "question_id": 79055566,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "```\r\n$ echo &#39;[&quot;sha256:9&quot;, &quot;sha256:5&quot;, &quot;sha256:46&quot;]&#39; | jq &#39;map(&quot;X &quot; + .)&#39;\r\n[\r\n  &quot;X sha256:9&quot;,\r\n  &quot;X sha256:5&quot;,\r\n  &quot;X sha256:46&quot;\r\n]\r\n```\r\nNote that strings are delimited with double quotes, not single quotes.",
                "title": "How to join a string onto the output from an array"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1728091334,
                "creation_date": 1728091334,
                "answer_id": 79056162,
                "question_id": 79055566,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Just incase this was what you wanted to do ....\r\n\r\n```sh\r\njq -r &#39;.imageIds\r\n# removes latest\r\n| map(select(.imageTag != &quot;latest&quot;)\r\n# format command to run in bash\r\n| &quot;aws ecr start-image-scan --repository-name sample-repo --image-id imageDigest=\\(.imageDigest)&quot;)[]\r\n```\r\n\r\nOutput\r\n```\r\naws ecr start-image-scan --repository-name sample-repo --image-id imageDigest=sha256:9\r\naws ecr start-image-scan --repository-name sample-repo --image-id imageDigest=sha256:5\r\n```",
                "title": "How to join a string onto the output from an array"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": -1,
        "last_activity_date": 1728091334,
        "creation_date": 1728069312,
        "last_edit_date": 1728070933,
        "question_id": 79055566,
        "body_markdown": "Let&#39;s say this is my output from an aws-cli command.\r\n```lang-json\r\n{\r\n    &quot;imageIds&quot;: [\r\n        {\r\n            &quot;imageDigest&quot;: &quot;sha256:9&quot;\r\n        },\r\n        {\r\n            &quot;imageDigest&quot;: &quot;sha256:5&quot;\r\n        },\r\n        {\r\n            &quot;imageDigest&quot;: &quot;sha256:46&quot;,\r\n            &quot;imageTag&quot;: &quot;latest&quot;\r\n        }\r\n    ]\r\n}\r\n```\r\n\r\nUsing:\r\n```lang-bash\r\n--query=&quot;imageIds[?imageTag != &#39;latest&#39;].imageDigest&quot;\r\n```\r\n\r\nGives me `[&quot;sha256:9&quot;, &quot;sha256:5&quot;, &quot;sha256:46&quot;]`. \r\n\r\nHow do I join an additional string to that list, either using the query, jq or bash, so it looks like\r\n`[&quot;X sha256:9&quot;, &quot;X sha256:5&quot;, &quot;X sha256:46&quot;]`?\r\n",
        "link": "https://stackoverflow.com/questions/79055566/how-to-join-a-string-onto-the-output-from-an-array",
        "title": "How to join a string onto the output from an array"
    },
    {
        "tags": [
            "json",
            "linux",
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 6313442,
                    "reputation": 45115,
                    "user_id": 5625547,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/oqCND.jpg?s=256",
                    "display_name": "0stone0",
                    "link": "https://stackoverflow.com/users/5625547/0stone0"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1728383168,
                "post_id": 79065379,
                "comment_id": 139412494,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 32080355,
                    "reputation": 11,
                    "user_id": 24882879,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/2705df775531e3f15fbfea1ef5bbd31a?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "MacLeon",
                    "link": "https://stackoverflow.com/users/24882879/macleon"
                },
                "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": 1728392203,
                "post_id": 79065379,
                "comment_id": 139413565,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1728383867,
                "creation_date": 1728383867,
                "answer_id": 79065579,
                "question_id": 79065379,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "```bash\r\njq &#39;(.dependencies,.devDependencies) |=\r\n        with_entries(.value = if .key | startswith(&quot;@glen/&quot;)\r\n                              then  .value | split(&quot;-&quot;)[0]\r\n                              else .value\r\n                              end)\r\n   &#39; file.json\r\n```",
                "title": "Update package.json with jq"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": -3,
        "last_activity_date": 1728383867,
        "creation_date": 1728381099,
        "question_id": 79065379,
        "body_markdown": "I am working on a web application that utilizes in-house npm packages.\r\nThese packages have names that begin with the prefix **@glen/**\r\n\r\nThe assignment is parse and to modify the package.json file by removing the *-dev.3* and *-rc.0* tags specifically for the **@glen/** prefix.\r\n\r\nExample:\r\n&quot;@glen/manager&quot;: &quot;^3.0.0-rc.0&quot;, -&gt; &quot;@glen/manager&quot;: &quot;^3.0.0&quot;,\r\n\r\nI expect to use jq, but any other suggestion running on Linux is welcome!\r\n\r\nOriginal package.json:\r\n```\r\n\t{\r\n\t  &quot;name&quot;: &quot;@glen/web_trans&quot;,\r\n\t  &quot;version&quot;: &quot;1.0.0&quot;,\r\n\t  &quot;scripts&quot;: {\r\n\t\t&quot;build&quot;: &quot;nuxt build&quot;,\r\n\t\t&quot;dev&quot;: &quot;nuxt dev&quot;,\r\n\t\t&quot;generate&quot;: &quot;nuxt generate&quot;,\r\n\t\t&quot;prepare&quot;: &quot;husky install&quot;\r\n\t  },\r\n\t  &quot;devDependencies&quot;: {\r\n\t\t&quot;@glen/manager&quot;: &quot;^3.0.0-rc.0&quot;,\r\n\t\t&quot;@glen/handler&quot;: &quot;^1.3.6&quot;,\r\n\t\t&quot;@glen/extension&quot;: &quot;^3.3.0-dev.3&quot;,\r\n\t\t&quot;@nuxt/devtools&quot;: &quot;^1.0.0-beta.2&quot;,\r\n\t\t&quot;@nuxtjs/device&quot;: &quot;^3.1.1&quot;,\r\n\t\t&quot;@nuxtjs/i18n&quot;: &quot;^8.0.0-rc.5&quot;,\r\n\t\t&quot;eslint&quot;: &quot;^8.29.0&quot;,\r\n\t\t&quot;husky&quot;: &quot;^8.0.0&quot;,\r\n\t\t&quot;jsdom&quot;: &quot;^21.1.1&quot;,\r\n\t\t&quot;nuxt&quot;: &quot;3.7.4&quot;,\r\n\t\t&quot;vitest&quot;: &quot;^0.29.7&quot;\r\n\t  },\r\n\t  &quot;dependencies&quot;: {\r\n\t\t&quot;@glen/manager&quot;: &quot;^3.0.0-rc.0&quot;,\r\n\t\t&quot;@glen/handler&quot;: &quot;^1.3.6&quot;,\r\n\t\t&quot;@glen/extension&quot;: &quot;^3.3.0-dev.3&quot;,\r\n\t\t&quot;@pinia/nuxt&quot;: &quot;^0.4.6&quot;,\r\n\t\t&quot;@vee-validate/rules&quot;: &quot;^4.11.3&quot;,\r\n\t\t&quot;@vue/apollo-composable&quot;: &quot;^4.0.0-beta.1&quot;,\r\n\t\t&quot;@vue/eslint-config-typescript&quot;: &quot;^11.0.2&quot;,\r\n\t\t&quot;@vueuse/components&quot;: &quot;^9.6.0&quot;,\r\n\t\t&quot;@vueuse/core&quot;: &quot;^9.6.0&quot;,\r\n\t\t&quot;websocket&quot;: &quot;^1.0.34&quot;\r\n\t  },\r\n\t  &quot;extensionPack&quot;: [\r\n\t\t&quot;Vue.volar&quot;\r\n\t  ],\r\n\t  &quot;overrides&quot;: {\r\n\t\t&quot;vue&quot;: &quot;latest&quot;\r\n\t  }\r\n\t}\r\n```\r\n\r\n\r\nAfter update he must look like:\r\n```\r\n\t{\r\n\t  &quot;name&quot;: &quot;@glen/web_trans&quot;,\r\n\t  &quot;version&quot;: &quot;1.0.0&quot;,\r\n\t  &quot;scripts&quot;: {\r\n\t\t&quot;build&quot;: &quot;nuxt build&quot;,\r\n\t\t&quot;dev&quot;: &quot;nuxt dev&quot;,\r\n\t\t&quot;generate&quot;: &quot;nuxt generate&quot;,\r\n\t\t&quot;prepare&quot;: &quot;husky install&quot;\r\n\t  },\r\n\t  &quot;devDependencies&quot;: {\r\n\t\t&quot;@glen/manager&quot;: &quot;^3.0.0&quot;,\r\n\t\t&quot;@glen/handler&quot;: &quot;^1.3.6&quot;,\r\n\t\t&quot;@glen/extension&quot;: &quot;^3.3.0&quot;,\r\n\t\t&quot;@nuxt/devtools&quot;: &quot;^1.0.0-beta.2&quot;,\r\n\t\t&quot;@nuxtjs/device&quot;: &quot;^3.1.1&quot;,\r\n\t\t&quot;@nuxtjs/i18n&quot;: &quot;^8.0.0-rc.5&quot;,\r\n\t\t&quot;eslint&quot;: &quot;^8.29.0&quot;,\r\n\t\t&quot;husky&quot;: &quot;^8.0.0&quot;,\r\n\t\t&quot;jsdom&quot;: &quot;^21.1.1&quot;,\r\n\t\t&quot;nuxt&quot;: &quot;3.7.4&quot;,\r\n\t\t&quot;vitest&quot;: &quot;^0.29.7&quot;\r\n\t  },\r\n\t  &quot;dependencies&quot;: {\r\n\t\t&quot;@glen/manager&quot;: &quot;^3.0.0&quot;,\r\n\t\t&quot;@glen/handler&quot;: &quot;^1.3.6&quot;,\r\n\t\t&quot;@glen/extension&quot;: &quot;^3.3.0&quot;,\r\n\t\t&quot;@pinia/nuxt&quot;: &quot;^0.4.6&quot;,\r\n\t\t&quot;@vee-validate/rules&quot;: &quot;^4.11.3&quot;,\r\n\t\t&quot;@vue/apollo-composable&quot;: &quot;^4.0.0-beta.1&quot;,\r\n\t\t&quot;@vue/eslint-config-typescript&quot;: &quot;^11.0.2&quot;,\r\n\t\t&quot;@vueuse/components&quot;: &quot;^9.6.0&quot;,\r\n\t\t&quot;@vueuse/core&quot;: &quot;^9.6.0&quot;,\r\n\t\t&quot;websocket&quot;: &quot;^1.0.34&quot;\r\n\t  },\r\n\t  &quot;extensionPack&quot;: [\r\n\t\t&quot;Vue.volar&quot;\r\n\t  ],\r\n\t  &quot;overrides&quot;: {\r\n\t\t&quot;vue&quot;: &quot;latest&quot;\r\n\t  }\r\n\t}\r\n```",
        "link": "https://stackoverflow.com/questions/79065379/update-package-json-with-jq",
        "title": "Update package.json with jq"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1728508072,
                "last_edit_date": 1728508072,
                "creation_date": 1728420362,
                "answer_id": 79067741,
                "question_id": 79067704,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "With your attempt, `add` simply flat-merges all the matches, and since `.things` is an array, latter occurrences just overwrite the clashing former ones. Replace it with a custom merge, that takes the streamed `first` item (from `.places`), and adds to it a `.things` array containing the concatenated items from the other matching items (those from `.thingGroups`):\r\n```sh\r\n{places: [JOIN(INDEX(.thingGroups[]; .thingGroup); .places[]; .thingGroup[];\r\n  first + {things: [.[1:][].things[]]}\r\n)]}\r\n```\r\n[Demo](https://jqplay.org/s/Ms92WA7Q-9GFkow)\r\n\r\nAlternatively, perform the whole mapping yourself directly:\r\n```sh\r\nINDEX(.thingGroups[]; .thingGroup) as $thingGroups\r\n| {places: [.places[] | .things = [$thingGroups[.thingGroup[]].things[]]]}\r\n```\r\n[Demo](https://jqplay.org/s/thB69ANlid7swgX)\r\n\r\nOutput:\r\n```json\r\n{\r\n  &quot;places&quot;: [\r\n    {\r\n      &quot;location&quot;: &quot;wwc1&quot;,\r\n      &quot;thingGroup&quot;: [\r\n        &quot;bs-1&quot;\r\n      ],\r\n      &quot;things&quot;: [\r\n        &quot;bp&quot;,\r\n        &quot;ci&quot;,\r\n        &quot;cc&quot;\r\n      ]\r\n    },\r\n    {\r\n      &quot;location&quot;: &quot;wwc2&quot;,\r\n      &quot;thingGroup&quot;: [\r\n        &quot;bs-2&quot;\r\n      ],\r\n      &quot;things&quot;: [\r\n        &quot;ems&quot;,\r\n        &quot;erec&quot;,\r\n        &quot;exs&quot;\r\n      ]\r\n    },\r\n    {\r\n      &quot;location&quot;: &quot;wwc3&quot;,\r\n      &quot;thingGroup&quot;: [\r\n        &quot;bs-3&quot;,\r\n        &quot;rs&quot;\r\n      ],\r\n      &quot;things&quot;: [\r\n        &quot;ci&quot;,\r\n        &quot;co&quot;,\r\n        &quot;dq&quot;,\r\n        &quot;cust&quot;\r\n      ]\r\n    },\r\n    {\r\n      &quot;location&quot;: &quot;wwc4&quot;,\r\n      &quot;thingGroup&quot;: [\r\n        &quot;bs-4&quot;,\r\n        &quot;rs&quot;\r\n      ],\r\n      &quot;things&quot;: [\r\n        &quot;ems&quot;,\r\n        &quot;erec&quot;,\r\n        &quot;home&quot;,\r\n        &quot;cust&quot;\r\n      ]\r\n    },\r\n    {\r\n      &quot;location&quot;: &quot;wwp1&quot;,\r\n      &quot;thingGroup&quot;: [\r\n        &quot;refdoc-bs&quot;\r\n      ],\r\n      &quot;things&quot;: [\r\n        &quot;refdoc&quot;\r\n      ]\r\n    }\r\n  ]\r\n}\r\n```\r\n\r\n---\r\n&gt; **ADDENDUM**: the possibility of a ```place``` with no ```thingGroup``` (see wwc1) is possible.  These would need to simply be output as is.  Likewise, extraneous objects (see fStuff) could be present and should be untouched/preserved.\r\n\r\nRegarding `wwc1`, as you&#39;ve figured out, changing `.thingGroup[]` to `.thingGroup[]?` will (in both approaches) treat items in `.place` with no `.thingGroup` array present as if it had produced a key of `null`, for which the index lookup then fails. The `.things` array (then empty) is still produced due to how it is constructed. To remedy this, either update the merging with an appropriate condition using `if` or `select`, or just delete the key afterwards if the array happens to be empty (but take into account that there may be other causes for it to come out empty).\r\n\r\nAs for `fStuff`, the `{places: […]}` construct produces an object containing only the `.places` key. To retain the other keys, use `.places = […]` instead to just replace the old key with a newly generated one. Note that in this case, you&#39;d have to explicitly delete the `.thingGroups` key if it should not be also considered an &quot;extraneous object&quot; to be preserved.\r\n\r\n```sh\r\n.places = [JOIN(INDEX(.thingGroups[]; .thingGroup); .places[]; .thingGroup[]?;\r\n  first + if has(1) then {things: [.[1:][].things[]]} else {} end\r\n)] | del(.thingGroups)\r\n```\r\n[Demo](https://jqplay.org/s/O8qIUTiv0M8kKWa)\r\n\r\n```sh\r\nINDEX(.thingGroups[]; .thingGroup) as $thingGroups\r\n| .places |= map(select(.thingGroup).things = [$thingGroups[.thingGroup[]?].things[]])\r\n| del(.thingGroups)\r\n```\r\n[Demo](https://jqplay.org/s/ml-PdE6RRgKk9-f)\r\n\r\nOutput:\r\n```json\r\n{\r\n  &quot;places&quot;: [\r\n    {\r\n      &quot;location&quot;: &quot;wwc1&quot;,\r\n      &quot;someotherdata&quot;: &quot;asdf&quot;\r\n    },\r\n    {\r\n      &quot;location&quot;: &quot;wwc2&quot;,\r\n      &quot;thingGroup&quot;: [\r\n        &quot;bs-2&quot;\r\n      ],\r\n      &quot;things&quot;: [\r\n        &quot;ems&quot;,\r\n        &quot;erec&quot;,\r\n        &quot;exs&quot;\r\n      ]\r\n    },\r\n    {\r\n      &quot;location&quot;: &quot;wwc3&quot;,\r\n      &quot;thingGroup&quot;: [\r\n        &quot;bs-3&quot;,\r\n        &quot;rs&quot;\r\n      ],\r\n      &quot;things&quot;: [\r\n        &quot;ci&quot;,\r\n        &quot;co&quot;,\r\n        &quot;dq&quot;,\r\n        &quot;cust&quot;\r\n      ]\r\n    },\r\n    {\r\n      &quot;location&quot;: &quot;wwc4&quot;,\r\n      &quot;thingGroup&quot;: [\r\n        &quot;bs-4&quot;,\r\n        &quot;rs&quot;\r\n      ],\r\n      &quot;things&quot;: [\r\n        &quot;ems&quot;,\r\n        &quot;erec&quot;,\r\n        &quot;home&quot;,\r\n        &quot;cust&quot;\r\n      ]\r\n    },\r\n    {\r\n      &quot;location&quot;: &quot;wwp1&quot;,\r\n      &quot;thingGroup&quot;: [\r\n        &quot;refdoc-bs&quot;\r\n      ],\r\n      &quot;things&quot;: [\r\n        &quot;refdoc&quot;\r\n      ]\r\n    }\r\n  ],\r\n  &quot;fStuff&quot;: [\r\n    &quot;this&quot;,\r\n    &quot;is&quot;,\r\n    &quot;extra&quot;\r\n  ]\r\n}\r\n```",
                "title": "Consolidating JOIN match results as opposed to taking &quot;last matched&quot; only"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1728508072,
        "creation_date": 1728419294,
        "last_edit_date": 1728486650,
        "question_id": 79067704,
        "body_markdown": "Using jq I am executing this query\r\n\r\n`{places: [JOIN(INDEX(.thingGroups[]; .thingGroup); .places[]; .thingGroup[] // empty; add)]}`\r\n\r\nagainst this data\r\n\r\n```\r\n{\r\n\t&quot;places&quot;: [\r\n\t\t{\r\n\t\t\t&quot;location&quot;: &quot;wwc1&quot;,\r\n\t\t\t&quot;someotherdata&quot;: &quot;asdf&quot;\r\n\t\t},\r\n\t\t{\r\n\t\t\t&quot;location&quot;: &quot;wwc2&quot;,\r\n\t\t\t&quot;thingGroup&quot;: [\r\n\t\t\t\t&quot;bs-2&quot;\r\n\t\t\t]\r\n\t\t},\r\n\t\t{\r\n\t\t\t&quot;location&quot;: &quot;wwc3&quot;,\r\n\t\t\t&quot;thingGroup&quot;: [\r\n\t\t\t\t&quot;bs-3&quot;,\r\n\t\t\t\t&quot;rs&quot;\r\n\t\t\t]\r\n\t\t},\r\n\t\t{\r\n\t\t\t&quot;location&quot;: &quot;wwc4&quot;,\r\n\t\t\t&quot;thingGroup&quot;: [\r\n\t\t\t\t&quot;bs-4&quot;,\r\n\t\t\t\t&quot;rs&quot;\r\n\t\t\t]\r\n\t\t},\r\n\t\t{\r\n\t\t\t&quot;location&quot;: &quot;wwp1&quot;,\r\n\t\t\t&quot;thingGroup&quot;: [\r\n\t\t\t\t&quot;refdoc-bs&quot;\r\n\t\t\t]\r\n\t\t}\r\n\t],\r\n\t&quot;thingGroups&quot;: [\r\n\t\t{\r\n\t\t\t&quot;thingGroup&quot;: &quot;bs-1&quot;,\r\n\t\t\t&quot;things&quot;: [\r\n\t\t\t\t&quot;bp&quot;,\r\n\t\t\t\t&quot;ci&quot;,\r\n\t\t\t\t&quot;cc&quot;\r\n\t\t\t]\r\n\t\t},\r\n\t\t{\r\n\t\t\t&quot;thingGroup&quot;: &quot;bs-2&quot;,\r\n\t\t\t&quot;things&quot;: [\r\n\t\t\t\t&quot;ems&quot;,\r\n\t\t\t\t&quot;erec&quot;,\r\n\t\t\t\t&quot;exs&quot;\r\n\t\t\t]\r\n\t\t},\r\n\t\t{\r\n\t\t\t&quot;thingGroup&quot;: &quot;bs-3&quot;,\r\n\t\t\t&quot;things&quot;: [\r\n\t\t\t\t&quot;ci&quot;,\r\n\t\t\t\t&quot;co&quot;,\r\n\t\t\t\t&quot;dq&quot;\r\n\t\t\t]\r\n\t\t},\r\n\t\t{\r\n\t\t\t&quot;thingGroup&quot;: &quot;bs-4&quot;,\r\n\t\t\t&quot;things&quot;: [\r\n\t\t\t\t&quot;ems&quot;,\r\n\t\t\t\t&quot;erec&quot;,\r\n\t\t\t\t&quot;home&quot;\r\n\t\t\t]\r\n\t\t},\r\n\t\t{\r\n\t\t\t&quot;thingGroup&quot;: &quot;rs&quot;,\r\n\t\t\t&quot;things&quot;: [\r\n\t\t\t\t&quot;cust&quot;\r\n\t\t\t]\r\n\t\t},\r\n\t\t{\r\n\t\t\t&quot;thingGroup&quot;: &quot;refdoc-bs&quot;,\r\n\t\t\t&quot;things&quot;: [\r\n\t\t\t\t&quot;refdoc&quot;\r\n\t\t\t]\r\n\t\t}\r\n\t],\r\n    &quot;fStuff&quot;: [\r\n        &quot;this&quot;,\r\n        &quot;is&quot;,\r\n        &quot;extra&quot;\r\n    ]\r\n}\r\n```\r\n\r\nThe issue is locations &quot;wwc3&quot; and &quot;wwc4&quot; are only being matched to thingGroup &quot;rs&quot;. The desired output is to have the things array generated for these two locations be a combination of all thingGroups that match, not just the last one. Those elements should look like this:\r\n\r\n```\r\n{\r\n\t&quot;location&quot;: &quot;wwc3&quot;,\r\n\t&quot;thingGroup&quot;: [\r\n\t\t&quot;bs-3&quot;,\r\n\t\t&quot;rs&quot;\r\n\t],\r\n\t&quot;things&quot;: [\r\n\t\t&quot;ci&quot;,\r\n\t\t&quot;co&quot;,\r\n\t\t&quot;dq&quot;,\r\n\t\t&quot;cust&quot;\r\n\t]\r\n}, \r\n{\r\n\t&quot;location&quot;: &quot;wwc4&quot;,\r\n\t&quot;thingGroup&quot;: [\r\n\t\t&quot;bs-4&quot;,\r\n\t\t&quot;rs&quot;\r\n\t],\r\n\t&quot;things&quot;: [\r\n\t\t&quot;ems&quot;,\r\n\t\t&quot;erec&quot;,\r\n\t\t&quot;home&quot;,\r\n\t\t&quot;cust&quot;\r\n\t]\r\n}\r\n```\r\n\r\nI have tried using the in() and has() functions to no avail. I feel I am close but missing something obvious.  Any help is appreciated.\r\n\r\n**ADDENDUM**: the possibility of a ```place``` with no ```thingGroup``` (see wwc1) is possible.  These would need to simply be output as is.  Likewise, extraneous objects (see fStuff) could be present and should be untouched/preserved.  Apologies for the initial mock-up not capturing these scenarios.\r\n\r\n[Demo][1]\r\n\r\n\r\n  [1]: https://jqplay.org/s/jRz1iFvnKe2iVlg",
        "link": "https://stackoverflow.com/questions/79067704/consolidating-join-match-results-as-opposed-to-taking-last-matched-only",
        "title": "Consolidating JOIN match results as opposed to taking &quot;last matched&quot; only"
    },
    {
        "tags": [
            "json",
            "csv",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1728484976,
                "last_edit_date": 1728484976,
                "creation_date": 1728484619,
                "answer_id": 79070806,
                "question_id": 79070662,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "With `.[] as $value`, you iterate again (after `keys_unsorted[] as $key`) over all items. Replace it with `.[$key] as $value` to just go into the one iterated over the first time:\r\n```sh\r\n.prop1 as $prop1\r\n| .prop2 as $prop2\r\n| .arr[]\r\n  | .arrProp1 as $arrProp1\r\n  | .arrProp2 as $arrProp2\r\n  | .valuePerDay\r\n    | keys_unsorted[] as $key\r\n    | .[$key] as $value\r\n| [$prop1,$prop2,$arrProp1,$arrProp2,$key,$value] \r\n| @csv\r\n```\r\n[Demo](https://jqplay.org/s/WJBbsbLQXSBUMM1)\r\n\r\nHere&#39;s a similar approach with simplifications for the variable binding, and the use of `to_entries` to get an array of key-value pairs:\r\n```sh\r\n. as {$prop1, $prop2} | .arr[]\r\n| . as {$arrProp1, $arrProp2} | .valuePerDay | to_entries[]\r\n| [$prop1, $prop2, $arrProp1, $arrProp2, .key, .value] | @csv\r\n```\r\n[Demo](https://jqplay.org/s/QZpqEumBOSIr87H)\r\n\r\nAnd here&#39;s another one without using variables by successively concatenating the final array:\r\n```sh\r\n[.prop1, .prop2] + (.arr[] | [.arrProp1, .arrProp2] + (\r\n  .valuePerDay | to_entries[] | [.key, .value]\r\n)) | @csv\r\n```\r\n[Demo](https://jqplay.org/s/8OzXWZzEBeRTFRI)",
                "title": "Convert JSON to CSV, repeating parent value"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1728542415,
        "creation_date": 1728482670,
        "question_id": 79070662,
        "body_markdown": "There&#39;s a lot of discussion to convert JSON to CSV with jq, but can&#39;t find my situation.\r\n\r\n2 points really blocking me :\r\n   1. Get key and value of `valuePerDay` by row\r\n   2. Sort `valuePerDay` keys to unsure values always in the same position\r\n\r\nI assume this JSON give the `valuePerDay` always the same keys for each `arr`.\r\n\r\nI have this JSON :\r\n\r\n```json\r\n{\r\n  &quot;prop1&quot;: &quot;val1&quot;,\r\n  &quot;prop2&quot;: &quot;val2&quot;,\r\n  &quot;arr&quot;: [\r\n    {\r\n      &quot;arrProp1&quot;: &quot;arr1Prop1&quot;,\r\n      &quot;arrProp2&quot;: &quot;arr1Prop2&quot;,\r\n      &quot;valuePerDay&quot;: {\r\n        &quot;2024-01-01&quot;: 1,\r\n        &quot;2024-01-02&quot;: 2,\r\n        &quot;2024-01-03&quot;: 3\r\n      }\r\n    },\r\n    {\r\n      &quot;arrProp1&quot;: &quot;arr2Prop1&quot;,\r\n      &quot;arrProp2&quot;: &quot;arr2Prop2&quot;,\r\n      &quot;valuePerDay&quot;: {\r\n        &quot;2024-01-02&quot;: 22,\r\n        &quot;2024-01-01&quot;: 11,\r\n        &quot;2024-01-03&quot;: 33\r\n      }\r\n    },\r\n    {\r\n      &quot;arrProp1&quot;: &quot;arr3Prop1&quot;,\r\n      &quot;arrProp2&quot;: &quot;arr3Prop1&quot;,\r\n      &quot;valuePerDay&quot;: {\r\n        &quot;2024-01-03&quot;: 333,\r\n        &quot;2024-01-01&quot;: 111,\r\n        &quot;2024-01-02&quot;: 222\r\n      }\r\n    }\r\n  ]\r\n}\r\n```\r\n\r\nHere is my actual JQ, but values are multiply by keys\r\n\r\n```\r\n.prop1 as $prop1\r\n| .prop2 as $prop2\r\n| .arr[]\r\n  | .arrProp1 as $arrProp1\r\n  | .arrProp2 as $arrProp2\r\n  | .valuePerDay\r\n    | keys_unsorted[] as $key\r\n    | .[] as $value\r\n| [$prop1,$prop2,$arrProp1,$arrProp2,$key,$value] \r\n| @csv\r\n```\r\n\r\nWhich give me :\r\n```csv\r\n&quot;prop1&quot;,&quot;prop2&quot;,&quot;arrProp1&quot;,&quot;arrProp2&quot;,&quot;valuePerDay&quot;,&quot;value&quot;\r\n&quot;val1&quot;,&quot;val2&quot;,&quot;arr1Prop1&quot;,&quot;arr1Prop2&quot;,&quot;2024-01-01&quot;,1\r\n&quot;val1&quot;,&quot;val2&quot;,&quot;arr1Prop1&quot;,&quot;arr1Prop2&quot;,&quot;2024-01-01&quot;,2\r\n&quot;val1&quot;,&quot;val2&quot;,&quot;arr1Prop1&quot;,&quot;arr1Prop2&quot;,&quot;2024-01-01&quot;,3\r\n&quot;val1&quot;,&quot;val2&quot;,&quot;arr1Prop1&quot;,&quot;arr1Prop2&quot;,&quot;2024-01-02&quot;,1\r\n&quot;val1&quot;,&quot;val2&quot;,&quot;arr1Prop1&quot;,&quot;arr1Prop2&quot;,&quot;2024-01-02&quot;,2\r\n&quot;val1&quot;,&quot;val2&quot;,&quot;arr1Prop1&quot;,&quot;arr1Prop2&quot;,&quot;2024-01-02&quot;,3\r\n&quot;val1&quot;,&quot;val2&quot;,&quot;arr1Prop1&quot;,&quot;arr1Prop2&quot;,&quot;2024-01-03&quot;,1\r\n&quot;val1&quot;,&quot;val2&quot;,&quot;arr1Prop1&quot;,&quot;arr1Prop2&quot;,&quot;2024-01-03&quot;,2\r\n&quot;val1&quot;,&quot;val2&quot;,&quot;arr1Prop1&quot;,&quot;arr1Prop2&quot;,&quot;2024-01-03&quot;,3\r\n&quot;val1&quot;,&quot;val2&quot;,&quot;arr2Prop1&quot;,&quot;arr2Prop2&quot;,&quot;2024-01-01&quot;,11\r\n&quot;val1&quot;,&quot;val2&quot;,&quot;arr2Prop1&quot;,&quot;arr2Prop2&quot;,&quot;2024-01-01&quot;,22\r\n&quot;val1&quot;,&quot;val2&quot;,&quot;arr2Prop1&quot;,&quot;arr2Prop2&quot;,&quot;2024-01-01&quot;,33\r\n&quot;val1&quot;,&quot;val2&quot;,&quot;arr2Prop1&quot;,&quot;arr2Prop2&quot;,&quot;2024-01-02&quot;,11\r\n&quot;val1&quot;,&quot;val2&quot;,&quot;arr2Prop1&quot;,&quot;arr2Prop2&quot;,&quot;2024-01-02&quot;,22\r\n&quot;val1&quot;,&quot;val2&quot;,&quot;arr2Prop1&quot;,&quot;arr2Prop2&quot;,&quot;2024-01-02&quot;,11\r\n&quot;val1&quot;,&quot;val2&quot;,&quot;arr2Prop1&quot;,&quot;arr2Prop2&quot;,&quot;2024-01-03&quot;,33\r\n&quot;val1&quot;,&quot;val2&quot;,&quot;arr2Prop1&quot;,&quot;arr2Prop2&quot;,&quot;2024-01-03&quot;,22\r\n&quot;val1&quot;,&quot;val2&quot;,&quot;arr2Prop1&quot;,&quot;arr2Prop2&quot;,&quot;2024-01-03&quot;,33\r\n&quot;val1&quot;,&quot;val2&quot;,&quot;arr3Prop1&quot;,&quot;arr3Prop2&quot;,&quot;2024-01-01&quot;,111\r\n&quot;val1&quot;,&quot;val2&quot;,&quot;arr3Prop1&quot;,&quot;arr3Prop2&quot;,&quot;2024-01-01&quot;,222\r\n&quot;val1&quot;,&quot;val2&quot;,&quot;arr3Prop1&quot;,&quot;arr3Prop2&quot;,&quot;2024-01-01&quot;,333\r\n&quot;val1&quot;,&quot;val2&quot;,&quot;arr3Prop1&quot;,&quot;arr3Prop2&quot;,&quot;2024-01-02&quot;,111\r\n&quot;val1&quot;,&quot;val2&quot;,&quot;arr3Prop1&quot;,&quot;arr3Prop2&quot;,&quot;2024-01-02&quot;,222\r\n&quot;val1&quot;,&quot;val2&quot;,&quot;arr3Prop1&quot;,&quot;arr3Prop2&quot;,&quot;2024-01-02&quot;,333\r\n&quot;val1&quot;,&quot;val2&quot;,&quot;arr3Prop1&quot;,&quot;arr3Prop2&quot;,&quot;2024-01-03&quot;,111\r\n&quot;val1&quot;,&quot;val2&quot;,&quot;arr3Prop1&quot;,&quot;arr3Prop2&quot;,&quot;2024-01-03&quot;,222\r\n&quot;val1&quot;,&quot;val2&quot;,&quot;arr3Prop1&quot;,&quot;arr3Prop2&quot;,&quot;2024-01-03&quot;,333\r\n```\r\n\r\nAnd I want :\r\n\r\n```csv\r\n&quot;prop1&quot;,&quot;prop2&quot;,&quot;arrProp1&quot;,&quot;arrProp2&quot;,&quot;valuePerDay&quot;,&quot;value&quot;\r\n&quot;val1&quot;,&quot;val2&quot;,&quot;arr1Prop1&quot;,&quot;arr1Prop2&quot;,&quot;2024-01-01&quot;,1\r\n&quot;val1&quot;,&quot;val2&quot;,&quot;arr1Prop1&quot;,&quot;arr1Prop2&quot;,&quot;2024-01-02&quot;,2\r\n&quot;val1&quot;,&quot;val2&quot;,&quot;arr1Prop1&quot;,&quot;arr1Prop2&quot;,&quot;2024-01-03&quot;,3\r\n&quot;val1&quot;,&quot;val2&quot;,&quot;arr2Prop1&quot;,&quot;arr2Prop2&quot;,&quot;2024-01-01&quot;,11\r\n&quot;val1&quot;,&quot;val2&quot;,&quot;arr2Prop1&quot;,&quot;arr2Prop2&quot;,&quot;2024-01-02&quot;,22\r\n&quot;val1&quot;,&quot;val2&quot;,&quot;arr2Prop1&quot;,&quot;arr2Prop2&quot;,&quot;2024-01-03&quot;,33\r\n&quot;val1&quot;,&quot;val2&quot;,&quot;arr3Prop1&quot;,&quot;arr3Prop2&quot;,&quot;2024-01-01&quot;,111\r\n&quot;val1&quot;,&quot;val2&quot;,&quot;arr3Prop1&quot;,&quot;arr3Prop2&quot;,&quot;2024-01-02&quot;,222\r\n&quot;val1&quot;,&quot;val2&quot;,&quot;arr3Prop1&quot;,&quot;arr3Prop2&quot;,&quot;2024-01-03&quot;,333\r\n```",
        "link": "https://stackoverflow.com/questions/79070662/convert-json-to-csv-repeating-parent-value",
        "title": "Convert JSON to CSV, repeating parent value"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 374049,
                    "reputation": 15207,
                    "user_id": 724039,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/NsCwt.png?s=256",
                    "display_name": "Luuk",
                    "link": "https://stackoverflow.com/users/724039/luuk"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1728744350,
                "post_id": 79081229,
                "comment_id": 139441266,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1532295,
                    "reputation": 5759,
                    "user_id": 1661012,
                    "user_type": "registered",
                    "accept_rate": 87,
                    "profile_image": "https://www.gravatar.com/avatar/abc04c76810d98405fc0f27f96c6c5e5?s=256&d=identicon&r=PG",
                    "display_name": "user137369",
                    "link": "https://stackoverflow.com/users/1661012/user137369"
                },
                "reply_to_user": {
                    "account_id": 374049,
                    "reputation": 15207,
                    "user_id": 724039,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/NsCwt.png?s=256",
                    "display_name": "Luuk",
                    "link": "https://stackoverflow.com/users/724039/luuk"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1728745929,
                "post_id": 79081229,
                "comment_id": 139441344,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1728744615,
                "creation_date": 1728744615,
                "answer_id": 79081241,
                "question_id": 79081229,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You could iterate over a stream of path-value arrays using `tostream` and `reduce`, and successively build up the result object using `getpath`, `setpath` and simple addition. Initially non-existent paths evaluate to `null`, which for the addition acts as `0`.\r\n```sh\r\njq -n &#39;\r\n  reduce (inputs | tostream | select(has(1))) as [$p,$v]\r\n    (null; setpath($p; getpath($p) + $v))\r\n&#39; file1.json file2.json\r\n```\r\n```json\r\n{\r\n  &quot;xFruits&quot;: {\r\n    &quot;views&quot;: 179,\r\n    &quot;all&quot;: {\r\n      &quot;xApples&quot;: {\r\n        &quot;views&quot;: 30,\r\n        &quot;eats&quot;: 12,\r\n        &quot;discards&quot;: 22\r\n      }\r\n    }\r\n  },\r\n  &quot;xVegetables&quot;: {\r\n    &quot;views&quot;: 281,\r\n    &quot;all&quot;: {\r\n      &quot;xBeans&quot;: {\r\n        &quot;views&quot;: 41,\r\n        &quot;eats&quot;: 18,\r\n        &quot;discards&quot;: 27\r\n      },\r\n      &quot;xCarrots&quot;: {\r\n        &quot;views&quot;: 30,\r\n        &quot;eats&quot;: 12,\r\n        &quot;discards&quot;: 11\r\n      },\r\n      &quot;xSpinach&quot;: {\r\n        &quot;views&quot;: 30,\r\n        &quot;eats&quot;: 12,\r\n        &quot;discards&quot;: 11\r\n      }\r\n    }\r\n  }\r\n}\r\n```\r\n[Demo](https://jqplay.org/s/C8teXVkWlSxPtR1)",
                "title": "Merge two JSON files with jq, adding integers"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -1,
        "last_activity_date": 1728744615,
        "creation_date": 1728744162,
        "question_id": 79081229,
        "body_markdown": "I have two JSON files of the form:\r\n\r\n```json\r\n{\r\n    &quot;xFruits&quot;: {\r\n        &quot;views&quot;: 163,\r\n        &quot;all&quot;: {\r\n            &quot;xApples&quot;: {\r\n                &quot;views&quot;: 28,\r\n                &quot;eats&quot;: 10,\r\n                &quot;discards&quot;: 17\r\n            }\r\n        }\r\n    },\r\n    &quot;xVegetables&quot;: {\r\n        &quot;views&quot;: 134,\r\n        &quot;all&quot;: {\r\n            &quot;xBeans&quot;: {\r\n                &quot;views&quot;: 29,\r\n                &quot;eats&quot;: 11,\r\n                &quot;discards&quot;: 14\r\n            },\r\n            &quot;xCarrots&quot;: {\r\n                &quot;views&quot;: 30,\r\n                &quot;eats&quot;: 12,\r\n                &quot;discards&quot;: 11\r\n            },\r\n        }\r\n    },\r\n}\r\n```\r\n\r\nKeys starting with `x` change names and vary in number. The others are fixed. Most `x` keys exist in both files, but some may exist only in file 1 and others only in file 2.\r\n\r\nI want to use `jq` to merge both files *and* add numbers when have the same path. So if this is the second file:\r\n\r\n```json\r\n{\r\n    &quot;xFruits&quot;: {\r\n        &quot;views&quot;: 16,\r\n        &quot;all&quot;: {\r\n            &quot;xApples&quot;: {\r\n                &quot;views&quot;: 2,\r\n                &quot;eats&quot;: 2,\r\n                &quot;discards&quot;: 5\r\n            }\r\n        }\r\n    },\r\n    &quot;xVegetables&quot;: {\r\n        &quot;views&quot;: 147,\r\n        &quot;all&quot;: {\r\n            &quot;xBeans&quot;: {\r\n                &quot;views&quot;: 12,\r\n                &quot;eats&quot;: 7,\r\n                &quot;discards&quot;: 13\r\n            },\r\n            &quot;xSpinach&quot;: {\r\n                &quot;views&quot;: 30,\r\n                &quot;eats&quot;: 12,\r\n                &quot;discards&quot;: 11\r\n            },\r\n        }\r\n    },\r\n}\r\n```\r\n\r\nThe the mix of both would result in:\r\n\r\n```json\r\n{\r\n    &quot;xFruits&quot;: {\r\n        &quot;views&quot;: 179,\r\n        &quot;all&quot;: {\r\n            &quot;xApples&quot;: {\r\n                &quot;views&quot;: 30,\r\n                &quot;eats&quot;: 12,\r\n                &quot;discards&quot;: 22\r\n            }\r\n        }\r\n    },\r\n    &quot;xVegetables&quot;: {\r\n        &quot;views&quot;: 281,\r\n        &quot;all&quot;: {\r\n            &quot;xBeans&quot;: {\r\n                &quot;views&quot;: 41,\r\n                &quot;eats&quot;: 18,\r\n                &quot;discards&quot;: 27\r\n            },\r\n            &quot;xCarrots&quot;: {\r\n                &quot;views&quot;: 30,\r\n                &quot;eats&quot;: 12,\r\n                &quot;discards&quot;: 11\r\n            },\r\n            &quot;xSpinach&quot;: {\r\n                &quot;views&quot;: 30,\r\n                &quot;eats&quot;: 12,\r\n                &quot;discards&quot;: 11\r\n            },\r\n        }\r\n    },\r\n}\r\n```\r\n\r\nNote how `xCarrots` and `xSpinach` retained their original values because each only existed in one file, while all other values were added together.\r\n\r\nIs this something `jq` is capable of?",
        "link": "https://stackoverflow.com/questions/79081229/merge-two-json-files-with-jq-adding-integers",
        "title": "Merge two JSON files with jq, adding integers"
    },
    {
        "tags": [
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 1613587,
                    "reputation": 786618,
                    "user_id": 1491895,
                    "user_type": "registered",
                    "accept_rate": 69,
                    "profile_image": "https://www.gravatar.com/avatar/82f9e178a16364bf561d0ed4da09a35d?s=256&d=identicon&r=PG",
                    "display_name": "Barmar",
                    "link": "https://stackoverflow.com/users/1491895/barmar"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1728752550,
                "post_id": 79081495,
                "comment_id": 139441767,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1613587,
                    "reputation": 786618,
                    "user_id": 1491895,
                    "user_type": "registered",
                    "accept_rate": 69,
                    "profile_image": "https://www.gravatar.com/avatar/82f9e178a16364bf561d0ed4da09a35d?s=256&d=identicon&r=PG",
                    "display_name": "Barmar",
                    "link": "https://stackoverflow.com/users/1491895/barmar"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1728752643,
                "post_id": 79081495,
                "comment_id": 139441773,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1728754210,
                "post_id": 79081495,
                "comment_id": 139441854,
                "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": 2,
                "creation_date": 1728759701,
                "post_id": 79081495,
                "comment_id": 139442164,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 4663062,
                    "reputation": 89888,
                    "user_id": 3776858,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/Cagbk.jpg?s=256",
                    "display_name": "Cyrus",
                    "link": "https://stackoverflow.com/users/3776858/cyrus"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1728825044,
                "post_id": 79081495,
                "comment_id": 139444684,
                "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": 2,
                "creation_date": 1728900785,
                "post_id": 79081495,
                "comment_id": 139449443,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1728999762,
                "last_edit_date": 1728999762,
                "creation_date": 1728967386,
                "answer_id": 79088430,
                "question_id": 79081495,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "It is because the element `interfaces` in the output of `vnstat -d --json` does not have a `day` element. The following is a sample truncated output of this command. There are `day` elements inside the JSON, but none of them are direct children of `interfaces`. The way you have called it requires `day` to be a direct element of `interfaces[0]`.\r\n\r\nYou might have copied the code from somewhere else or generated it by AI which has used an older version of `vnstat` or maybe the AI was hallucinating.\r\n\r\nBy the way, you could have dug deeper into it to find out that the output of (echo &quot;$output&quot; | jq -r --compact-output &#39;.interfaces[0].day[]&#39;) is null.\r\n\r\n```\r\n{                                                      \r\n    &quot;vnstatversion&quot;: &quot;2.10&quot;,                           \r\n    &quot;jsonversion&quot;: &quot;2&quot;,                                \r\n    &quot;interfaces&quot;: [                                    \r\n        {                                              \r\n            &quot;name&quot;: &quot;eth0&quot;,                            \r\n            &quot;alias&quot;: &quot;&quot;,                               \r\n            &quot;created&quot;: {                               \r\n                &quot;date&quot;: {                              \r\n                    &quot;year&quot;: 2024,                      \r\n                    &quot;month&quot;: 4,                        \r\n                    &quot;day&quot;: 28                          \r\n                },                                     \r\n                &quot;timestamp&quot;: 1714303206                \r\n            },                                         \r\n            &quot;updated&quot;: {                               \r\n                &quot;date&quot;: {                              \r\n                    &quot;year&quot;: 2024,                      \r\n                    &quot;month&quot;: 10,                       \r\n                    &quot;day&quot;: 15                          \r\n                },                                     \r\n                &quot;time&quot;: {                              \r\n                    &quot;hour&quot;: 4,                         \r\n                    &quot;minute&quot;: 20                       \r\n                },                                     \r\n                &quot;timestamp&quot;: 1728966000                \r\n            },                                         \r\n            &quot;traffic&quot;: {                               \r\n                &quot;total&quot;: {                             \r\n                    &quot;rx&quot;: 721795234718,                \r\n                    &quot;tx&quot;: 720659482363                 \r\n                },                                     \r\n                &quot;fiveminute&quot;: [                        \r\n                    {                                  \r\n                        &quot;id&quot;: 96594,                   \r\n                        &quot;date&quot;: {                      \r\n                            &quot;year&quot;: 2024,              \r\n                            &quot;month&quot;: 10,               \r\n                            &quot;day&quot;: 13                  \r\n                        },                             \r\n                        &quot;time&quot;: {                      \r\n                            &quot;hour&quot;: 4,                 \r\n                            &quot;minute&quot;: 0                \r\n                        },                             \r\n                        &quot;timestamp&quot;: 1728792000,       \r\n                        &quot;rx&quot;: 435591,                  \r\n                        &quot;tx&quot;: 463409                   \r\n                    },                                 \r\n                    {                                  \r\n                        &quot;id&quot;: 96596,                   \r\n                        &quot;date&quot;: {                      \r\n                            &quot;year&quot;: 2024,              \r\n                            &quot;month&quot;: 10,               \r\n                            &quot;day&quot;: 13                  \r\n                        },                             \r\n                        &quot;time&quot;: {                      \r\n                            &quot;hour&quot;: 4,                 \r\n                            &quot;minute&quot;: 5                \r\n                        },                             \r\n                        &quot;timestamp&quot;: 1728792300,       \r\n                        &quot;rx&quot;: 695570,                  \r\n                        &quot;tx&quot;: 912465                   \r\n                    },                                 \r\n                    {                                  \r\n                        &quot;id&quot;: 96598,                   \r\n```",
                "title": "Check the amount of traffic on server, and then detects if the traffic has been decreased dramatically or not"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1728999762,
        "creation_date": 1728752368,
        "last_edit_date": 1728914109,
        "question_id": 79081495,
        "body_markdown": "I&#39;ve written a script in the bash  to connect to servers via SSH and check their traffic. If the traffic significantly decreases, the script will send an email to the address specified in the program.\r\n\r\n```\r\n#!/bin/bash  \r\n\r\n# Variables  \r\nserver_ip=&quot;IP address&quot;   # Replace with your server&#39;s IP address  \r\nusername=&quot;ubuntu&quot;   # Replace with your SSH username  \r\n\r\n# Function to fetch and calculate traffic data  \r\ncalculate_traffic() {\r\n    echo &quot;Connecting to $server_ip to fetch traffic data...&quot;  \r\n\r\n    # Running vnstat command and saving output  \r\n    output=$(ssh -o StrictHostKeyChecking=no &quot;${username}@${server_ip}&quot; vnstat -d --json)\r\n    # echo &quot;$output&quot;\r\n    if [[ $? -ne 0 ]]; then\r\n        echo &quot;Failed to connect to $server_ip or vnstat is not installed.&quot;  \r\n        return\r\n    fi\r\n\r\n    # Extract daily traffic data  \r\n    # traffic_data=($(echo &quot;$output&quot; | jq -r &#39;.interfaces[0].traffic | map(.day.rx + .day.tx) | .[]&#39;))     \r\n    traffic_data=($(echo &quot;$output&quot; | jq -r &#39;.interfaces[0].day[] | &quot;(.rx + .tx) bytes&quot;&#39;))\r\n    echo &quot;$traffic_data&quot;\r\n    #traffic_data=($(echo &quot;$output&quot; | jq &#39;.interfaces[].day[] | {date: .date, rx: .rx, tx: .tx}&#39; data.json))\r\n    # Validate that we have enough data  \r\n    if [[ ${#traffic_data[@]} -lt 10 ]]; then\r\n        echo &quot;Not enough data available for the past 10 days.&quot;  \r\n        return\r\n    fi\r\n\r\n    # Calculate new_traffic (average of the last 5 days)  \r\n    new_traffic=0\r\n    for i in {0..4}; do\r\n        new_traffic=$(echo &quot;$new_traffic + ${traffic_data[$i]}&quot; | bc)\r\n    done\r\n    new_traffic=$(echo &quot;$new_traffic / 5&quot; | bc -l)\r\n\r\n    # Calculate old_traffic (average of days 6-10)  \r\n    old_traffic=0\r\n    for i in {5..9}; do\r\n     old_traffic=$(echo &quot;$old_traffic + ${traffic_data[$i]}&quot; | bc)\r\n    done\r\n    old_traffic=$(echo &quot;$old_traffic / 5&quot; | bc -l)\r\n\r\n    echo &quot;Average traffic in the last 5 days: $new_traffic MB&quot;  \r\n    echo &quot;Average traffic in the 5 to 10 days ago: $old_traffic MB&quot;  \r\n\r\n    # Optionally, compare or take action based on traffic  \r\n}\r\n\r\n# Run the function to calculate traffic \r\n```\r\n\r\nThe SSH connection works fine, but the following code leads to an error.\r\n\r\n```none\r\njq: error (at &lt;stdin&gt;:1): Cannot iterate over null (null)\r\nNot enough data available for the past 10 days.\r\n```\r\n\r\n\r\nThe output is not empty. This is the result after running vnstat -d on the server.\r\n\r\n\r\n  \r\n\r\nand this is the output when I put the line \r\n```\r\n echo &quot;$traffic_data&quot;\r\n```\r\n\r\n\r\n\r\n\r\n            \r\n```\r\n {&quot;vnstatversion&quot;:&quot;2.12&quot;,&quot;jsonversion&quot;:&quot;2&quot;,&quot;interfaces&quot;:[{&quot;name&quot;:&quot;eth0&quot;,&quot;alias&quot;:&quot;&quot;,&quot;created&quot;:{&quot;date&quot;:{&quot;year&quot;:2024,&quot;month&quot;:10,&quot;day&quot;:13},&quot;timestamp&quot;:1728801752},&quot;updated&quot;:{&quot;date&quot;:{&quot;year&quot;:2024,&quot;month&quot;:10,&quot;day&quot;:13},&quot;time&quot;:{&quot;hour&quot;:9,&quot;minute&quot;:35},&quot;timestamp&quot;:1728812100},&quot;traffic&quot;:{&quot;total&quot;:{&quot;rx&quot;:1301247,&quot;tx&quot;:1443456},&quot;fiveminute&quot;:[{&quot;id&quot;:2,&quot;date&quot;:{&quot;year&quot;:2024,&quot;month&quot;:10,&quot;day&quot;:13},&quot;time&quot;:{&quot;hour&quot;:6,&quot;minute&quot;:40},&quot;timestamp&quot;:1728801600,&quot;rx&quot;:35241,&quot;tx&quot;:53433},{&quot;id&quot;:1,&quot;date&quot;:{&quot;year&quot;:2024,&quot;month&quot;:10,&quot;day&quot;:13},&quot;time&quot;:{&quot;hour&quot;:6,&quot;minute&quot;:45},&quot;timestamp&quot;:1728801900,&quot;rx&quot;:5604,&quot;tx&quot;:4450},{&quot;id&quot;:3,&quot;date&quot;:{&quot;year&quot;:2024,&quot;month&quot;:10,&quot;day&quot;:13},&quot;time&quot;:{&quot;hour&quot;:6,&quot;minute&quot;:50},&quot;timestamp&quot;:1728802200,&quot;rx&quot;:5737,&quot;tx&quot;:4531},{&quot;id&quot;:4,&quot;date&quot;:{&quot;year&quot;:2024,&quot;month&quot;:10,&quot;day&quot;:13},&quot;time&quot;:{&quot;hour&quot;:6,&quot;minute&quot;:55},&quot;timestamp&quot;:1728802500,&quot;rx&quot;:44158,&quot;tx&quot;:45048},{&quot;id&quot;:5,&quot;date&quot;:{&quot;year&quot;:2024,&quot;month&quot;:10,&quot;day&quot;:13},&quot;time&quot;:{&quot;hour&quot;:7,&quot;minute&quot;:0},&quot;timestamp&quot;:1728802800,&quot;rx&quot;:8273,&quot;tx&quot;:7747},{&quot;id&quot;:6,&quot;date&quot;:{&quot;year&quot;:2024,&quot;month&quot;:10,&quot;day&quot;:13},&quot;time&quot;:{&quot;hour&quot;:7,&quot;minute&quot;:5},&quot;timestamp&quot;:1728803100,&quot;rx&quot;:5234,&quot;tx&quot;:4260},{&quot;id&quot;:7,&quot;date&quot;:{&quot;year&quot;:2024,&quot;month&quot;:10,&quot;day&quot;:13},&quot;time&quot;:{&quot;hour&quot;:7,&quot;minute&quot;:10},&quot;timestamp&quot;:1728803400,&quot;rx&quot;:10659,&quot;tx&quot;:8577},{&quot;id&quot;:8,&quot;date&quot;:{&quot;year&quot;:2024,&quot;month&quot;:10,&quot;day&quot;:13},&quot;time&quot;:{&quot;hour&quot;:7,&quot;minute&quot;:15},&quot;timestamp&quot;:1728803700,&quot;rx&quot;:63903,&quot;tx&quot;:55183},{&quot;id&quot;:9,&quot;date&quot;:{&quot;year&quot;:2024,&quot;month&quot;:10,&quot;day&quot;:13},&quot;time&quot;:{&quot;hour&quot;:7,&quot;minute&quot;:20},&quot;timestamp&quot;:1728804000,&quot;rx&quot;:67698,&quot;tx&quot;:61890},{&quot;id&quot;:10,&quot;date&quot;:{&quot;year&quot;:2024,&quot;month&quot;:10,&quot;day&quot;:13},&quot;time&quot;:{&quot;hour&quot;:7,&quot;minute&quot;:25},&quot;timestamp&quot;:1728804300,&quot;rx&quot;:9286,&quot;tx&quot;:8401},{&quot;id&quot;:11,&quot;date&quot;:{&quot;year&quot;:2024,&quot;month&quot;:10,&quot;day&quot;:13},&quot;time&quot;:{&quot;hour&quot;:7,&quot;minute&quot;:30},&quot;timestamp&quot;:1728804600,&quot;rx&quot;:5533,&quot;tx&quot;:4165},{&quot;id&quot;:12,&quot;date&quot;:{&quot;year&quot;:2024,&quot;month&quot;:10,&quot;day&quot;:13},&quot;time&quot;:{&quot;hour&quot;:7,&quot;minute&quot;:35},&quot;timestamp&quot;:1728804900,&quot;rx&quot;:7187,&quot;tx&quot;:6073},{&quot;id&quot;:13,&quot;date&quot;:{&quot;year&quot;:2024,&quot;month&quot;:10,&quot;day&quot;:13},&quot;time&quot;:{&quot;hour&quot;:7,&quot;minute&quot;:40},&quot;timestamp&quot;:1728805200,&quot;rx&quot;:10659,&quot;tx&quot;:10097},{&quot;id&quot;:14,&quot;date&quot;:{&quot;year&quot;:2024,&quot;month&quot;:10,&quot;day&quot;:13},&quot;time&quot;:{&quot;hour&quot;:7,&quot;minute&quot;:45},&quot;timestamp&quot;:1728805500,&quot;rx&quot;:8103,&quot;tx&quot;:7595},{&quot;id&quot;:15,&quot;date&quot;:{&quot;year&quot;:2024,&quot;month&quot;:10,&quot;day&quot;:13},&quot;time&quot;:{&quot;hour&quot;:7,&quot;minute&quot;:50},&quot;timestamp&quot;:1728805800,&quot;rx&quot;:10720,&quot;tx&quot;:12586},{&quot;id&quot;:16,&quot;date&quot;:{&quot;year&quot;:2024,&quot;month&quot;:10,&quot;day&quot;:13},&quot;time&quot;:{&quot;hour&quot;:7,&quot;minute&quot;:55},&quot;timestamp&quot;:1728806100,&quot;rx&quot;:4151,&quot;tx&quot;:3119},{&quot;id&quot;:17,&quot;date&quot;:{&quot;year&quot;:2024,&quot;month&quot;:10,&quot;day&quot;:13},&quot;time&quot;:{&quot;hour&quot;:8,&quot;minute&quot;:0},&quot;timestamp&quot;:1728806400,&quot;rx&quot;:4650,&quot;tx&quot;:4004},{&quot;id&quot;:18,&quot;date&quot;:{&quot;year&quot;:2024,&quot;month&quot;:10,&quot;day&quot;:13},&quot;time&quot;:{&quot;hour&quot;:8,&quot;minute&quot;:5},&quot;timestamp&quot;:1728806700,&quot;rx&quot;:7248,&quot;tx&quot;:6828},{&quot;id&quot;:19,&quot;date&quot;:{&quot;year&quot;:2024,&quot;month&quot;:10,&quot;day&quot;:13},&quot;time&quot;:{&quot;hour&quot;:8,&quot;minute&quot;:10},&quot;timestamp&quot;:1728807000,&quot;rx&quot;:9530,&quot;tx&quot;:7368},{&quot;id&quot;:20,&quot;date&quot;:{&quot;year&quot;:2024,&quot;month&quot;:10,&quot;day&quot;:13},&quot;time&quot;:{&quot;hour&quot;:8,&quot;minute&quot;:15},&quot;timestamp&quot;:1728807300,&quot;rx&quot;:6675,&quot;tx&quot;:6095},{&quot;id&quot;:21,&quot;date&quot;:{&quot;year&quot;:2024,&quot;month&quot;:10,&quot;day&quot;:13},&quot;time&quot;:{&quot;hour&quot;:8,&quot;minute&quot;:20},&quot;timestamp&quot;:1728807600,&quot;rx&quot;:4623,&quot;tx&quot;:3447},{&quot;id&quot;:22,&quot;date&quot;:{&quot;year&quot;:2024,&quot;month&quot;:10,&quot;day&quot;:13},&quot;time&quot;:{&quot;hour&quot;:8,&quot;minute&quot;:25},&quot;timestamp&quot;:1728807900,&quot;rx&quot;:10352,&quot;tx&quot;:9920},{&quot;id&quot;:23,&quot;date&quot;:{&quot;year&quot;:2024,&quot;month&quot;:10,&quot;day&quot;:13},&quot;time&quot;:{&quot;hour&quot;:8,&quot;minute&quot;:30},&quot;timestamp&quot;:1728808200,&quot;rx&quot;:8638,&quot;tx&quot;:7432},{&quot;id&quot;:24,&quot;date&quot;:{&quot;year&quot;:2024,&quot;month&quot;:10,&quot;day&quot;:13},&quot;time&quot;:{&quot;hour&quot;:8,&quot;minute&quot;:35},&quot;timestamp&quot;:1728808500,&quot;rx&quot;:6395,&quot;tx&quot;:6085},{&quot;id&quot;:25,&quot;date&quot;:{&quot;year&quot;:2024,&quot;month&quot;:10,&quot;day&quot;:13},&quot;time&quot;:{&quot;hour&quot;:8,&quot;minute&quot;:40},&quot;timestamp&quot;:1728808800,&quot;rx&quot;:100639,&quot;tx&quot;:118300},{&quot;id&quot;:26,&quot;date&quot;:{&quot;year&quot;:2024,&quot;month&quot;:10,&quot;day&quot;:13},&quot;time&quot;:{&quot;hour&quot;:8,&quot;minute&quot;:45},&quot;timestamp&quot;:1728809100,&quot;rx&quot;:100824,&quot;tx&quot;:133866},{&quot;id&quot;:27,&quot;date&quot;:{&quot;year&quot;:2024,&quot;month&quot;:10,&quot;day&quot;:13},&quot;time&quot;:{&quot;hour&quot;:8,&quot;minute&quot;:50},&quot;timestamp&quot;:1728809400,&quot;rx&quot;:123621,&quot;tx&quot;:162497},{&quot;id&quot;:28,&quot;date&quot;:{&quot;year&quot;:2024,&quot;month&quot;:10,&quot;day&quot;:13},&quot;time&quot;:{&quot;hour&quot;:8,&quot;minute&quot;:55},&quot;timestamp&quot;:1728809700,&quot;rx&quot;:105350,&quot;tx&quot;:127156},{&quot;id&quot;:29,&quot;date&quot;:{&quot;year&quot;:2024,&quot;month&quot;:10,&quot;day&quot;:13},&quot;time&quot;:{&quot;hour&quot;:9,&quot;minute&quot;:0},&quot;timestamp&quot;:1728810000,&quot;rx&quot;:53538,&quot;tx&quot;:58412},{&quot;id&quot;:30,&quot;date&quot;:{&quot;year&quot;:2024,&quot;month&quot;:10,&quot;day&quot;:13},&quot;time&quot;:{&quot;hour&quot;:9,&quot;minute&quot;:5},&quot;timestamp&quot;:1728810300,&quot;rx&quot;:87424,&quot;tx&quot;:101574},{&quot;id&quot;:31,&quot;date&quot;:{&quot;year&quot;:2024,&quot;month&quot;:10,&quot;day&quot;:13},&quot;time&quot;:{&quot;hour&quot;:9,&quot;minute&quot;:10},&quot;timestamp&quot;:1728810600,&quot;rx&quot;:58102,&quot;tx&quot;:61288},{&quot;id&quot;:32,&quot;date&quot;:{&quot;year&quot;:2024,&quot;month&quot;:10,&quot;day&quot;:13},&quot;time&quot;:{&quot;hour&quot;:9,&quot;minute&quot;:15},&quot;timestamp&quot;:1728810900,&quot;rx&quot;:53089,&quot;tx&quot;:58081},{&quot;id&quot;:33,&quot;date&quot;:{&quot;year&quot;:2024,&quot;month&quot;:10,&quot;day&quot;:13},&quot;time&quot;:{&quot;hour&quot;:9,&quot;minute&quot;:20},&quot;timestamp&quot;:1728811200,&quot;rx&quot;:82041,&quot;tx&quot;:83978},{&quot;id&quot;:34,&quot;date&quot;:{&quot;year&quot;:2024,&quot;month&quot;:10,&quot;day&quot;:13},&quot;time&quot;:{&quot;hour&quot;:9,&quot;minute&quot;:25},&quot;timestamp&quot;:1728811500,&quot;rx&quot;:114346,&quot;tx&quot;:120850},{&quot;id&quot;:35,&quot;date&quot;:{&quot;year&quot;:2024,&quot;month&quot;:10,&quot;day&quot;:13},&quot;time&quot;:{&quot;hour&quot;:9,&quot;minute&quot;:30},&quot;timestamp&quot;:1728811800,&quot;rx&quot;:62016,&quot;tx&quot;:69120}],&quot;hour&quot;:[{&quot;id&quot;:1,&quot;date&quot;:{&quot;year&quot;:2024,&quot;month&quot;:10,&quot;day&quot;:13},&quot;time&quot;:{&quot;hour&quot;:6,&quot;minute&quot;:0},&quot;timestamp&quot;:1728799200,&quot;rx&quot;:90740,&quot;tx&quot;:107462},{&quot;id&quot;:2,&quot;date&quot;:{&quot;year&quot;:2024,&quot;month&quot;:10,&quot;day&quot;:13},&quot;time&quot;:{&quot;hour&quot;:7,&quot;minute&quot;:0},&quot;timestamp&quot;:1728802800,&quot;rx&quot;:211406,&quot;tx&quot;:189693},{&quot;id&quot;:3,&quot;date&quot;:{&quot;year&quot;:2024,&quot;month&quot;:10,&quot;day&quot;:13},&quot;time&quot;:{&quot;hour&quot;:8,&quot;minute&quot;:0},&quot;timestamp&quot;:1728806400,&quot;rx&quot;:488545,&quot;tx&quot;:592998},{&quot;id&quot;:4,&quot;date&quot;:{&quot;year&quot;:2024,&quot;month&quot;:10,&quot;day&quot;:13},&quot;time&quot;:{&quot;hour&quot;:9,&quot;minute&quot;:0},&quot;timestamp&quot;:1728810000,&quot;rx&quot;:510556,&quot;tx&quot;:553303}],&quot;day&quot;:[{&quot;id&quot;:1,&quot;date&quot;:{&quot;year&quot;:2024,&quot;month&quot;:10,&quot;day&quot;:13},&quot;timestamp&quot;:1728777600,&quot;rx&quot;:1301247,&quot;tx&quot;:1443456}],&quot;month&quot;:[{&quot;id&quot;:1,&quot;date&quot;:{&quot;year&quot;:2024,&quot;month&quot;:10},&quot;timestamp&quot;:1727740800,&quot;rx&quot;:1301247,&quot;tx&quot;:1443456}],&quot;year&quot;:[{&quot;id&quot;:1,&quot;date&quot;:{&quot;year&quot;:2024},&quot;timestamp&quot;:1704067200,&quot;rx&quot;:1301247,&quot;tx&quot;:1443456}],&quot;top&quot;:[{&quot;id&quot;:1,&quot;date&quot;:{&quot;year&quot;:2024,&quot;month&quot;:10,&quot;day&quot;:13},&quot;timestamp&quot;:1728777600,&quot;rx&quot;:1301247,&quot;tx&quot;:1443456}]}}]}\r\n```",
        "link": "https://stackoverflow.com/questions/79081495/check-the-amount-of-traffic-on-server-and-then-detects-if-the-traffic-has-been",
        "title": "Check the amount of traffic on server, and then detects if the traffic has been decreased dramatically or not"
    },
    {
        "tags": [
            "json",
            "string",
            "bash",
            "curl",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1728855149,
                "creation_date": 1728855149,
                "answer_id": 79084201,
                "question_id": 79084052,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You need `transpose` function:\r\n\r\n```\r\ncurl -s &quot;https://api.open-meteo.com/v1/forecast?latitude=52.52&amp;longitude=13.41&amp;daily=weather_code,temperature_2m_max,temperature_2m_min,precipitation_probability_max&amp;temperature_unit=fahrenheit&amp;wind_speed_unit=mph&amp;precipitation_unit=inch&amp;timezone=auto&amp;forecast_days=14&quot; | \r\njq -r &#39;([ &quot;date&quot;, &quot;weather_code&quot;, &quot;temperature_2m_max&quot;, &quot;temperature_2m_min&quot;, &quot;precipitation_probability_max&quot;],\r\n        ([.daily[]] | transpose[])\r\n       ) | @csv&#39;\r\n```",
                "title": "How can i use jq to format json to csv?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1728855149,
        "creation_date": 1728849985,
        "question_id": 79084052,
        "body_markdown": "I am trying to format this json data to CSV format, but I get this error: `error (at &lt;stdin&gt;:0): Cannot index array with string &quot;time&quot;.\r\n`\r\nHere is a short version of my json data:\r\n\r\n\r\n```\r\n{\r\n  &quot;latitude&quot;: 52.52,\r\n  &quot;longitude&quot;: 13.419998,\r\n  &quot;generationtime_ms&quot;: 0.23293495178222656,\r\n  &quot;utc_offset_seconds&quot;: 7200,\r\n  &quot;timezone&quot;: &quot;Europe/Berlin&quot;,\r\n  &quot;timezone_abbreviation&quot;: &quot;CEST&quot;,\r\n  &quot;elevation&quot;: 38.0,\r\n  &quot;daily_units&quot;: {\r\n    &quot;time&quot;: &quot;iso8601&quot;,\r\n    &quot;weather_code&quot;: &quot;wmo code&quot;,\r\n    &quot;temperature_2m_max&quot;: &quot;&#176;F&quot;,\r\n    &quot;temperature_2m_min&quot;: &quot;&#176;F&quot;,\r\n    &quot;precipitation_probability_max&quot;: &quot;%&quot;\r\n  },\r\n  &quot;daily&quot;: {\r\n    &quot;time&quot;: [\r\n      &quot;2024-10-13&quot;,\r\n      &quot;2024-10-14&quot;\r\n    ],\r\n    &quot;weather_code&quot;: [\r\n      80,\r\n      61\r\n    ],\r\n    &quot;temperature_2m_max&quot;: [\r\n      52.7,\r\n      53.1\r\n    ],\r\n    &quot;temperature_2m_min&quot;: [\r\n      48.6,\r\n      43.7\r\n    ],\r\n    &quot;precipitation_probability_max&quot;: [\r\n      100,\r\n      10\r\n    ]\r\n  }\r\n}\r\n```\r\nI want it to be formatted like this:\r\n```\r\ntime,weather_code,temperature_2m_max,temperature_2m_min,precipitation_probability_max\r\n2024-10-13,80,52.7,48.6,100\r\n2024-10-14,61,53.1,43.7,10\r\n```\r\nThis is the command I wrote, but I get the error `jq: error (at &lt;stdin&gt;:0): Cannot index array with string &quot;time&quot;`. This also happens with each field if i delete all the previous ones.\r\n\r\n```\r\ncurl -s &quot;https://api.open-meteo.com/v1/forecast?latitude=52.52&amp;longitude=13.41&amp;daily=weather_code,temperature_2m_max,temperature_2m_min,precipitation_probability_max&amp;temperature_unit=fahrenheit&amp;wind_speed_unit=mph&amp;precipitation_unit=inch&amp;timezone=auto&amp;forecast_days=14&quot; | \r\n\r\njq -r &#39;\r\n  [\r\n    &quot;date&quot;, &quot;weather_code&quot;, &quot;temperature_2m_max&quot;, &quot;temperature_2m_min&quot;, &quot;precipitation_probability_max&quot;\r\n  ],\r\n  .daily |\r\n  [\r\n    .time[],\r\n    .weather_code[],\r\n    .temperature_2m_max[],\r\n    .temperature_2m_min[],\r\n    .precipitation_probability_max[]\r\n  ]\r\n  | @csv\r\n&#39;\r\n```\r\n\r\n\r\nI tried to change the &quot;time&quot; field to a Unix timestamp, but I am still not sure how to get it to work, because it throws the same error.",
        "link": "https://stackoverflow.com/questions/79084052/how-can-i-use-jq-to-format-json-to-csv",
        "title": "How can i use jq to format json to csv?"
    },
    {
        "tags": [
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 2671330,
                    "reputation": 192705,
                    "user_id": 2308683,
                    "user_type": "registered",
                    "accept_rate": 90,
                    "profile_image": "https://www.gravatar.com/avatar/fb8f5877d244f223b4b6d29e0afb3a4e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "OneCricketeer",
                    "link": "https://stackoverflow.com/users/2308683/onecricketeer"
                },
                "edited": false,
                "score": 4,
                "creation_date": 1729058530,
                "post_id": 79092640,
                "comment_id": 139462577,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 20135892,
                    "reputation": 67,
                    "user_id": 14766892,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/12708a9644d77a25bbca95c2414d6c53?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "BrianEbrahimi",
                    "link": "https://stackoverflow.com/users/14766892/brianebrahimi"
                },
                "reply_to_user": {
                    "account_id": 2671330,
                    "reputation": 192705,
                    "user_id": 2308683,
                    "user_type": "registered",
                    "accept_rate": 90,
                    "profile_image": "https://www.gravatar.com/avatar/fb8f5877d244f223b4b6d29e0afb3a4e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "OneCricketeer",
                    "link": "https://stackoverflow.com/users/2308683/onecricketeer"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1729058623,
                "post_id": 79092640,
                "comment_id": 139462586,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2671330,
                    "reputation": 192705,
                    "user_id": 2308683,
                    "user_type": "registered",
                    "accept_rate": 90,
                    "profile_image": "https://www.gravatar.com/avatar/fb8f5877d244f223b4b6d29e0afb3a4e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "OneCricketeer",
                    "link": "https://stackoverflow.com/users/2308683/onecricketeer"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1729058727,
                "post_id": 79092640,
                "comment_id": 139462592,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 3,
                "creation_date": 1729060612,
                "post_id": 79092640,
                "comment_id": 139462728,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 15204726,
                    "reputation": 18070,
                    "user_id": 10971581,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/XPQr1.png?s=256",
                    "display_name": "jhnc",
                    "link": "https://stackoverflow.com/users/10971581/jhnc"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1729061777,
                "post_id": 79092640,
                "comment_id": 139462835,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 15204726,
                    "reputation": 18070,
                    "user_id": 10971581,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/XPQr1.png?s=256",
                    "display_name": "jhnc",
                    "link": "https://stackoverflow.com/users/10971581/jhnc"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1729062096,
                "post_id": 79092640,
                "comment_id": 139462860,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 308303,
                    "reputation": 37458,
                    "user_id": 620097,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/820980fd43f2607a815c1f3dbfe152cc?s=256&d=identicon&r=PG",
                    "display_name": "shellter",
                    "link": "https://stackoverflow.com/users/620097/shellter"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1729097328,
                "post_id": 79092640,
                "comment_id": 139466884,
                "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": 1729248612,
                "post_id": 79092640,
                "comment_id": 139479126,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1729086411,
                "creation_date": 1729086411,
                "answer_id": 79094351,
                "question_id": 79092640,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "What you have there is not correct on its own. It&#39;s part of something larger\r\n\r\n```jq\r\n... | . + {Title: $departments[.Code].Title}\r\n```\r\n\r\nThe code represented by `...` produces a stream of values.\r\n\r\n`. + {Title: $departments[.Code].Title}` is evaluated for each of those values.\r\n\r\n`.` is the value for which the expression is being evaluated.\r\n\r\nFor example, let&#39;s say the code represented by `...` produces the following objects:\r\n\r\n1. `{ &quot;Code&quot;: &quot;ANI&quot;, ... }`\r\n2. `{ &quot;Code&quot;: &quot;HR&quot;, ... }`\r\n\r\n`. + {Title: $departments[.Code].Title}` will be evaluated twice.\r\n\r\nThe first time `. + {Title: $departments[.Code].Title}` is evaluated, `.` will be `{ &quot;Code&quot;: &quot;ANI&quot;, ... }`, and it will produce something like `{ &quot;Code&quot;: &quot;ANI&quot;, ..., &quot;Title&quot;: &quot;Animation&quot; }`.\r\n\r\nThe second time `. + {Title: $departments[.Code].Title}` is evaluated, `.` will be `{ &quot;Code&quot;: &quot;HR&quot;, ... }`, and it will produce something like `{ &quot;Code&quot;: &quot;HR&quot;, ..., &quot;Title&quot;: &quot;Human Resources&quot; }`.\r\n\r\nIt could also have been written as \r\n\r\n```jq\r\n... | .Title = $departments[.Code].Title\r\n```\r\n",
                "title": "| . + in jq meaning"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": -3,
        "last_activity_date": 1729086411,
        "creation_date": 1729058338,
        "last_edit_date": 1729064818,
        "question_id": 79092640,
        "body_markdown": "I&#39;m not sure what the dot and plus sign after a pipe mean, and I haven&#39;t been able to find anything on the internet about this. For example, when looking up a title in a Json object, I would write \r\n\r\n```| . + {Title: $departments[.Code].Title}```\r\n\r\nwhat is happening in this line of code?",
        "link": "https://stackoverflow.com/questions/79092640/in-jq-meaning",
        "title": "| . + in jq meaning"
    }
]