[
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 6196394,
                    "reputation": 86601,
                    "user_id": 5291015,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/4tAvO.jpg?s=256",
                    "display_name": "Inian",
                    "link": "https://stackoverflow.com/users/5291015/inian"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1664367297,
                "post_id": 73881065,
                "comment_id": 130454624,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 6,
                "is_accepted": false,
                "score": 6,
                "last_activity_date": 1664366929,
                "creation_date": 1664366929,
                "answer_id": 73881155,
                "question_id": 73881065,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "It&#39;s easier than that.\r\n``` sh\r\njq -s &#39;transpose | map(add)&#39; 1.json 2.json\r\n```\r\n&lt;sup&gt;[Online demo](https://jqplay.org/s/IaWBgWocbMk)&lt;/sup&gt;",
                "title": "How to use JQ to merge corresponding elements of two arrays"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1664367189,
        "creation_date": 1664366505,
        "last_edit_date": 1664367189,
        "question_id": 73881065,
        "body_markdown": "I have two arrays with the same amount of elements but with different keys/values. I want to integrate the key/value of the second array into the first for each index/position. \r\n\r\n`1.json`\r\n```\r\n[    \r\n    {\r\n      &quot;name&quot;: &quot;xxx&quot;,\r\n      &quot;url&quot;: &quot;yyy&quot;,\r\n      &quot;thumbnail&quot;: &quot;nnn&quot;\r\n    },\r\n    {\r\n      &quot;name&quot;: &quot;bla bla&quot;,\r\n      &quot;url&quot;: &quot;some-url&quot;,\r\n      &quot;thumbnail&quot;: &quot;another-pic&quot;\r\n    }\r\n]\r\n```\r\n`2.json`\r\n```\r\n[\r\n    {\r\n        &quot;spotifyUrl&quot;: &quot;first-spotify-url&quot;\r\n    },\r\n    {\r\n        &quot;spotifyUrl&quot;: &quot;second-spotify-url&quot;\r\n    }\r\n]\r\n```\r\nThe result I would like to achieve: \r\n```\r\n[    \r\n    {\r\n      &quot;name&quot;: &quot;xxx&quot;,\r\n      &quot;url&quot;: &quot;yyy&quot;,\r\n      &quot;thumbnail&quot;: &quot;nnn&quot;,\r\n      &quot;spotifyUrl&quot;: &quot;first-spotify-url&quot;\r\n    },\r\n    {\r\n      &quot;name&quot;: &quot;bla bla&quot;,\r\n      &quot;url&quot;: &quot;some-url&quot;,\r\n      &quot;thumbnail&quot;: &quot;another-pic&quot;,\r\n      &quot;spotifyUrl&quot;: &quot;second-spotify-url&quot;\r\n    }\r\n]\r\n```\r\nI already tried different things but couldn&#39;t find the result I wanted. For example this one here: \r\n```\r\njq -n &#39;\r\n  (input | map_values([.])) as $one\r\n  | input as $two\r\n  | reduce ($two|keys_unsorted[]) as $k2 ( $one;\r\n      .[$k2] += [$two[$k2]] )\r\n&#39; 1.json 2.json\r\n```\r\nis almost what I want, except that the spotify-url is nested into its own object and looks like this:\r\n```\r\n[    \r\n    {\r\n      &quot;name&quot;: &quot;xxx&quot;,\r\n      &quot;url&quot;: &quot;yyy&quot;,\r\n      &quot;thumbnail&quot;: &quot;nnn&quot;\r\n    },\r\n    {\r\n      &quot;spotifyUrl&quot;: &quot;first-spotify-url&quot;\r\n    }\r\n]\r\n```\r\n\r\nI appreciate any help and bet it&#39;s a lot simpler than I can think of. Thanks in advance.",
        "link": "https://stackoverflow.com/questions/73881065/how-to-use-jq-to-merge-corresponding-elements-of-two-arrays",
        "title": "How to use JQ to merge corresponding elements of two arrays"
    },
    {
        "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": 1664379705,
                "post_id": 73884180,
                "comment_id": 130459748,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 6462260,
                    "reputation": 79,
                    "user_id": 9579197,
                    "user_type": "registered",
                    "profile_image": "https://lh5.googleusercontent.com/-kx0pQiZLTxo/AAAAAAAAAAI/AAAAAAAAAFU/VP_HOZusmXs/s256-rj/photo.jpg",
                    "display_name": "Santosh Kumar Sahoo",
                    "link": "https://stackoverflow.com/users/9579197/santosh-kumar-sahoo"
                },
                "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": 1664380183,
                "post_id": 73884180,
                "comment_id": 130459915,
                "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": 1664380357,
                "post_id": 73884180,
                "comment_id": 130459957,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 6462260,
                    "reputation": 79,
                    "user_id": 9579197,
                    "user_type": "registered",
                    "profile_image": "https://lh5.googleusercontent.com/-kx0pQiZLTxo/AAAAAAAAAAI/AAAAAAAAAFU/VP_HOZusmXs/s256-rj/photo.jpg",
                    "display_name": "Santosh Kumar Sahoo",
                    "link": "https://stackoverflow.com/users/9579197/santosh-kumar-sahoo"
                },
                "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": 1664380944,
                "post_id": 73884180,
                "comment_id": 130460150,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 13795134,
                    "reputation": 3684,
                    "user_id": 10440128,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/xbqD0.jpg?s=256",
                    "display_name": "milahu",
                    "link": "https://stackoverflow.com/users/10440128/milahu"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1707386353,
                "post_id": 73884180,
                "comment_id": 137440461,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1664381048,
                "last_edit_date": 1664381048,
                "creation_date": 1664379982,
                "answer_id": 73884339,
                "question_id": 73884180,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If we loop over the `Workload` we can use the update assignment ([`|=`][1]) and an [`if`][2] to:\r\n1. Use [`all(. == null)`][3] to check if all values are `null`, if so, replace with `[ {} ]`\r\n2. Otherwise, use [`map(values)`][4] to only keep values that are not `null`\r\n\r\n```\r\n.&quot;EC2 Instance Metadata&quot;[].Workloads |= \r\n    if all(. == null) \r\n        then [ {} ] \r\n        else map(values)\r\n    end\r\n```\r\n\r\n\r\n----------\r\n\r\n\r\nWill give the following output, which you can [try in this online demo](https://jqplay.org/s/bZhAy475-87)\r\n```json\r\n{\r\n  &quot;EC2 Instance Metadata&quot;: [\r\n    {\r\n      &quot;EC2 Private IPv4 DNS Name&quot;: &quot;compute.internal-1&quot;,\r\n      &quot;EC2 Private IPv4 address&quot;: &quot;1.2.3.4&quot;,\r\n      &quot;Workloads&quot;: [\r\n        {}\r\n      ],\r\n      &quot;Application Pods&quot;: [\r\n        &quot;pod-1&quot;\r\n      ],\r\n      &quot;Application Containers&quot;: [\r\n        &quot;container&quot;\r\n      ],\r\n      &quot;Container Images&quot;: [\r\n        &quot;image/1.0&quot;\r\n      ]\r\n    },\r\n    {\r\n      &quot;EC2 Private IPv4 DNS Name&quot;: &quot;compute.internal-2&quot;,\r\n      &quot;EC2 Private IPv4 address&quot;: &quot;1.2.3.44&quot;,\r\n      &quot;Workloads&quot;: [\r\n        {}\r\n      ],\r\n      &quot;Application Pods&quot;: [\r\n        &quot;pod-2&quot;\r\n      ],\r\n      &quot;Application Containers&quot;: [\r\n        &quot;container-2&quot;\r\n      ],\r\n      &quot;Container Images&quot;: [\r\n        &quot;image/2.0&quot;\r\n      ]\r\n    },\r\n    {\r\n      &quot;EC2 Private IPv4 DNS Name&quot;: &quot;compute.internal-3&quot;,\r\n      &quot;EC2 Private IPv4 address&quot;: &quot;1.23.3.44&quot;,\r\n      &quot;Workloads&quot;: [\r\n        &quot;workload-1&quot;,\r\n        &quot;workload-2&quot;,\r\n        &quot;workload-3&quot;,\r\n        &quot;workload-4&quot;\r\n      ],\r\n      &quot;Application Pods&quot;: [\r\n        &quot;pod-1&quot;,\r\n        &quot;pod-2&quot;\r\n      ],\r\n      &quot;Application Containers&quot;: [\r\n        &quot;cnt-1&quot;,\r\n        &quot;cnt-2&quot;\r\n      ],\r\n      &quot;Container Images&quot;: [\r\n        &quot;image-1&quot;,\r\n        &quot;image-2&quot;\r\n      ]\r\n    }\r\n  ]\r\n}\r\n\r\n```\r\n\r\n\r\n  [1]: https://stedolan.github.io/jq/manual/#Update-assignment:%7C=\r\n  [2]: https://stedolan.github.io/jq/manual/#if-then-else\r\n  [3]: https://stedolan.github.io/jq/manual/#all,all(condition),all(generator;condition)\r\n  [4]: https://stedolan.github.io/jq/manual/#arrays,objects,iterables,booleans,numbers,normals,finites,strings,nulls,values,scalars",
                "title": "JQ: Removing null values from a JSON array in jq"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1664382429,
                "last_edit_date": 1664382429,
                "creation_date": 1664379988,
                "answer_id": 73884341,
                "question_id": 73884180,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "This recursively (`..`) reduces `arrays` containing (also) `values` (anything but `null`) to only contain those `values`, otherwise (containing nothing but `null`) it replaces them with `[{}]`:\r\n~~~sh\r\njq &#39;(.. | arrays) |= if any(values) then map(values) else [{}] end&#39;\r\n~~~\r\n~~~json\r\n{\r\n  &quot;EC2 Instance Metadata&quot;: [\r\n    {\r\n      &quot;EC2 Private IPv4 DNS Name&quot;: &quot;compute.internal-1&quot;,\r\n      &quot;EC2 Private IPv4 address&quot;: &quot;1.2.3.4&quot;,\r\n      &quot;Workloads&quot;: [\r\n        {}\r\n      ],\r\n      &quot;Application Pods&quot;: [\r\n        &quot;pod-1&quot;\r\n      ],\r\n      &quot;Application Containers&quot;: [\r\n        &quot;container&quot;\r\n      ],\r\n      &quot;Container Images&quot;: [\r\n        &quot;image/1.0&quot;\r\n      ]\r\n    },\r\n    {\r\n      &quot;EC2 Private IPv4 DNS Name&quot;: &quot;compute.internal-2&quot;,\r\n      &quot;EC2 Private IPv4 address&quot;: &quot;1.2.3.44&quot;,\r\n      &quot;Workloads&quot;: [\r\n        {}\r\n      ],\r\n      &quot;Application Pods&quot;: [\r\n        &quot;pod-2&quot;\r\n      ],\r\n      &quot;Application Containers&quot;: [\r\n        &quot;container-2&quot;\r\n      ],\r\n      &quot;Container Images&quot;: [\r\n        &quot;image/2.0&quot;\r\n      ]\r\n    },\r\n    {\r\n      &quot;EC2 Private IPv4 DNS Name&quot;: &quot;compute.internal-3&quot;,\r\n      &quot;EC2 Private IPv4 address&quot;: &quot;1.23.3.44&quot;,\r\n      &quot;Workloads&quot;: [\r\n        &quot;workload-1&quot;,\r\n        &quot;workload-2&quot;,\r\n        &quot;workload-3&quot;,\r\n        &quot;workload-4&quot;\r\n      ],\r\n      &quot;Application Pods&quot;: [\r\n        &quot;pod-1&quot;,\r\n        &quot;pod-2&quot;\r\n      ],\r\n      &quot;Application Containers&quot;: [\r\n        &quot;cnt-1&quot;,\r\n        &quot;cnt-2&quot;\r\n      ],\r\n      &quot;Container Images&quot;: [\r\n        &quot;image-1&quot;,\r\n        &quot;image-2&quot;\r\n      ]\r\n    }\r\n  ]\r\n}\r\n~~~\r\n[Demo](https://jqplay.org/s/6FKhOb3TWK9)",
                "title": "JQ: Removing null values from a JSON array in jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1664382429,
        "creation_date": 1664379291,
        "question_id": 73884180,
        "body_markdown": "Still I can&#39;t figure out how to remove null values from a key of JSON array type.\r\nI need an empty key({}) if all the values are null or remove nulls from the JSON array.\r\nIn the below example, I want to filter the nulls from Workloads JSON array. Please let me know any workaround . Thanks a lot.\r\n[ I am using jq version 1.5 ]\r\nFor example, with this input:\r\n\r\n```\r\n{\r\n  &quot;EC2 Instance Metadata&quot;: [\r\n    {\r\n      &quot;EC2 Private IPv4 DNS Name&quot;: &quot;compute.internal-1&quot;,\r\n      &quot;EC2 Private IPv4 address&quot;: &quot;1.2.3.4&quot;,\r\n      &quot;Workloads&quot;: [\r\n        null\r\n      ],\r\n      &quot;Application Pods&quot;: [\r\n        &quot;pod-1&quot;\r\n      ],\r\n      &quot;Application Containers&quot;: [\r\n        &quot;container&quot;\r\n      ],\r\n      &quot;Container Images&quot;: [\r\n        &quot;image/1.0&quot;\r\n      ]\r\n    },\r\n    {\r\n      &quot;EC2 Private IPv4 DNS Name&quot;: &quot;compute.internal-2&quot;,\r\n      &quot;EC2 Private IPv4 address&quot;: &quot;1.2.3.44&quot;,\r\n      &quot;Workloads&quot;: [\r\n        null\r\n      ],\r\n      &quot;Application Pods&quot;: [\r\n        &quot;pod-2&quot;\r\n      ],\r\n      &quot;Application Containers&quot;: [\r\n        &quot;container-2&quot;\r\n      ],\r\n      &quot;Container Images&quot;: [\r\n        &quot;image/2.0&quot;\r\n      ]\r\n    },\r\n    {\r\n      &quot;EC2 Private IPv4 DNS Name&quot;: &quot;compute.internal-3&quot;,\r\n      &quot;EC2 Private IPv4 address&quot;: &quot;1.23.3.44&quot;,\r\n      &quot;Workloads&quot;: [\r\n        &quot;workload-1&quot;,\r\n        &quot;workload-2&quot;,\r\n        &quot;workload-3&quot;,\r\n        null,\r\n        null,\r\n        null,\r\n        &quot;workload-4&quot;\r\n      ],\r\n      &quot;Application Pods&quot;: [\r\n        &quot;pod-1&quot;,\r\n        &quot;pod-2&quot;\r\n      ],\r\n      &quot;Application Containers&quot;: [\r\n        &quot;cnt-1&quot;,\r\n        &quot;cnt-2&quot;\r\n      ],\r\n      &quot;Container Images&quot;: [\r\n        &quot;image-1&quot;,\r\n        &quot;image-2&quot;\r\n      ]\r\n    }\r\n  ]\r\n}\r\n```\r\nI want this output :-\r\n```\r\n{\r\n  &quot;EC2 Instance Metadata&quot;: [\r\n    {\r\n      &quot;EC2 Private IPv4 DNS Name&quot;: &quot;compute.internal-1&quot;,\r\n      &quot;EC2 Private IPv4 address&quot;: &quot;1.2.3.4&quot;,\r\n      &quot;Workloads&quot;: [\r\n        {}\r\n      ],\r\n      &quot;Application Pods&quot;: [\r\n        &quot;pod-1&quot;\r\n      ],\r\n      &quot;Application Containers&quot;: [\r\n        &quot;container&quot;\r\n      ],\r\n      &quot;Container Images&quot;: [\r\n        &quot;image/1.0&quot;\r\n      ]\r\n    },\r\n    {\r\n      &quot;EC2 Private IPv4 DNS Name&quot;: &quot;compute.internal-2&quot;,\r\n      &quot;EC2 Private IPv4 address&quot;: &quot;1.2.3.44&quot;,\r\n      &quot;Workloads&quot;: [\r\n        {}\r\n      ],\r\n      &quot;Application Pods&quot;: [\r\n        &quot;pod-2&quot;\r\n      ],\r\n      &quot;Application Containers&quot;: [\r\n        &quot;container-2&quot;\r\n      ],\r\n      &quot;Container Images&quot;: [\r\n        &quot;image/2.0&quot;\r\n      ]\r\n    },\r\n    {\r\n      &quot;EC2 Private IPv4 DNS Name&quot;: &quot;compute.internal-3&quot;,\r\n      &quot;EC2 Private IPv4 address&quot;: &quot;1.23.3.44&quot;,\r\n      &quot;Workloads&quot;: [\r\n        &quot;workload-1&quot;,\r\n        &quot;workload-2&quot;,\r\n        &quot;workload-3&quot;,\r\n        &quot;workload-4&quot;\r\n      ],\r\n      &quot;Application Pods&quot;: [\r\n        &quot;pod-1&quot;,\r\n        &quot;pod-2&quot;\r\n      ],\r\n      &quot;Application Containers&quot;: [\r\n        &quot;cnt-1&quot;,\r\n        &quot;cnt-2&quot;\r\n      ],\r\n      &quot;Container Images&quot;: [\r\n        &quot;image-1&quot;,\r\n        &quot;image-2&quot;\r\n      ]\r\n    }\r\n  ]\r\n}\r\n```\r\nTried almost all the hints mentioned [Here][1], but no luck. \r\n\r\n\r\n  [1]: https://github.com/stedolan/jq/issues/104",
        "link": "https://stackoverflow.com/questions/73884180/jq-removing-null-values-from-a-json-array-in-jq",
        "title": "JQ: Removing null values from a JSON array in 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": 1664388621,
                "post_id": 73885999,
                "comment_id": 130462634,
                "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": 1664389002,
                "post_id": 73885999,
                "comment_id": 130462731,
                "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": 1664389078,
                "post_id": 73885999,
                "comment_id": 130462753,
                "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": 1664389614,
                "post_id": 73885999,
                "comment_id": 130462910,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1664389537,
                "creation_date": 1664389537,
                "answer_id": 73886234,
                "question_id": 73885999,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Create a JSON file:\r\n~~~sh\r\n$ jq -n --arg one &#39;Apple&#39; --arg two &#39;Banana&#39; \\\r\n  &#39;{Test1: $ARGS.named}&#39; &gt; config.json\r\n~~~\r\nView the JSON file:\r\n~~~sh\r\n$ cat config.json\r\n{\r\n  &quot;Test1&quot;: {\r\n    &quot;one&quot;: &quot;Apple&quot;,\r\n    &quot;two&quot;: &quot;Banana&quot;\r\n  }\r\n}\r\n~~~\r\nCreate another JSON file based on the first one (using jq&#39;s `.` for the input object, and `+` to add (merge) two objects):\r\n~~~sh\r\n$ jq --arg one &#39;Kiwi&#39; --arg two &#39;Tomato&#39; \\\r\n  &#39;. + {Test2: $ARGS.named}&#39; config.json &gt; config2.json\r\n~~~\r\nView that other JSON file:\r\n~~~sh\r\n$ cat config2.json\r\n{\r\n  &quot;Test1&quot;: {\r\n    &quot;one&quot;: &quot;Apple&quot;,\r\n    &quot;two&quot;: &quot;Banana&quot;\r\n  },\r\n  &quot;Test2&quot;: {\r\n    &quot;one&quot;: &quot;Kiwi&quot;,\r\n    &quot;two&quot;: &quot;Tomato&quot;\r\n  }\r\n}\r\n~~~\r\nOverwrite the first one with the second one:\r\n~~~sh\r\n$ mv config2.json config.json\r\n~~~\r\nNow the first one has the content of the second one:\r\n~~~SH\r\n$ cat config.json\r\n{\r\n  &quot;Test1&quot;: {\r\n    &quot;one&quot;: &quot;Apple&quot;,\r\n    &quot;two&quot;: &quot;Banana&quot;\r\n  },\r\n  &quot;Test2&quot;: {\r\n    &quot;one&quot;: &quot;Kiwi&quot;,\r\n    &quot;two&quot;: &quot;Tomato&quot;\r\n  }\r\n}\r\n~~~\r\n",
                "title": "How to create a json file with jq"
            },
            {
                "up_vote_count": 6,
                "is_accepted": true,
                "score": 6,
                "last_activity_date": 1664398903,
                "last_edit_date": 1664398903,
                "creation_date": 1664398227,
                "answer_id": 73887640,
                "question_id": 73885999,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Without creating a temporary file, assuming your shell is POSIX-based:\r\n```sh\r\n{\r\n  jq -cn  --arg one &#39;Apple&#39; --arg two &#39;Banana&#39; &#39;{Test1: $ARGS.named}&#39;\r\n  jq -cn  --arg one &#39;Kiwi&#39;  --arg two &#39;Tomato&#39; &#39;{Test2: $ARGS.named}&#39;\r\n} | jq -s add &gt; output.json\r\n```\r\n\r\nOr\r\n```sh\r\njq -n \\\r\n   --argjson Test1 &quot;$(jq -n --arg one &#39;Apple&#39; --arg two &#39;Banana&#39; &#39;$ARGS.named&#39;)&quot; \\\r\n   --argjson Test2 &quot;$(jq -n --arg one &#39;Kiwi&#39;  --arg two &#39;Tomato&#39; &#39;$ARGS.named&#39;)&quot; \\\r\n  &#39;$ARGS.named&#39; &gt; output.json\r\n```\r\n---\r\nIf this is a prelude to a list of &quot;TestN&quot; objects, we&#39;ll get a bit more programmitic, here with bash syntax:\r\n```sh\r\nones=( Apple Kiwi )\r\ntwos=( Banana Tomato )\r\n\r\nfor ((i=0; i &lt; ${#ones[@]}; i++)); do\r\n  jq -cn \\\r\n     --arg one &quot;${ones[i]}&quot; \\\r\n     --arg two &quot;${twos[i]}&quot; \\\r\n     --arg key &quot;Test$((i + 1))&quot; \\\r\n     &#39;{($key): {$one, $two}}&#39;\r\ndone | jq -s add &gt; output.json\r\n```\r\n\r\n---\r\nOr, use a different tool: [jo](https://github.com/jpmens/jo)\r\n```sh\r\njo Test1=&quot;$(jo one=Apple two=Banana)&quot; Test2=&quot;$(jo one=Kiwi two=Tomato)&quot;\r\n```\r\n```json\r\n{&quot;Test1&quot;:{&quot;one&quot;:&quot;Apple&quot;,&quot;two&quot;:&quot;Banana&quot;},&quot;Test2&quot;:{&quot;one&quot;:&quot;Kiwi&quot;,&quot;two&quot;:&quot;Tomato&quot;}}\r\n```",
                "title": "How to create a json file with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 4,
        "last_activity_date": 1664398903,
        "creation_date": 1664388219,
        "question_id": 73885999,
        "body_markdown": "Now I am trying to make a json file.\r\nI found an example which is with jq.\r\n\r\n```\r\necho &quot;$(jq -n &#39;{Test1: $ARGS.named}&#39; \\\r\n  --arg one &#39;Apple&#39; \\\r\n  --arg two &#39;Banana&#39;)&quot; &gt;&gt; config.json\r\n```\r\nI can get the result and save it into config.json\r\n```\r\n{\r\n  &quot;Test1&quot;: {\r\n    &quot;one&quot;: &quot;Apple&quot;,\r\n    &quot;two&quot;: &quot;Banana&quot;\r\n  }\r\n}\r\n```\r\n\r\nNow, how to make the following result and save it.\r\n```\r\n{\r\n  &quot;Test1&quot;: {\r\n    &quot;one&quot;: &quot;Apple&quot;,\r\n    &quot;two&quot;: &quot;Banana&quot;\r\n  },\r\n  &quot;Test2&quot;: {\r\n    &quot;one&quot;: &quot;Kiwi&quot;,\r\n    &quot;two&quot;: &quot;Tomato&quot;\r\n  }  \r\n}\r\n```\r\nThanks",
        "link": "https://stackoverflow.com/questions/73885999/how-to-create-a-json-file-with-jq",
        "title": "How to create a json file with jq"
    },
    {
        "tags": [
            "arrays",
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1664394447,
                "last_edit_date": 1664394447,
                "creation_date": 1664392889,
                "answer_id": 73886800,
                "question_id": 73886731,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You could use `implode` to create the letters by array index, which is provided in `.key` when `to_entries` is applied to an array.\r\n~~~sh\r\njq -r &#39;to_entries[] | &quot;\\([.key + 97] | implode)=\\(.value)&quot;&#39;\r\n~~~\r\n~~~\r\na=10\r\nb=20\r\nc=30\r\nd=40\r\n~~~\r\n[Demo](https://jqplay.org/s/kTFXBy5YZrG)\r\n\r\n---\r\nTo provide individual names, you can introduce an array of names and use `transpose` to make the alignment:\r\n~~~sh\r\njq -r &#39;\r\n  [[&quot;Price&quot;, &quot;Amount&quot;, &quot;Value&quot;, &quot;Tax&quot;], .]\r\n  | transpose[] | &quot;\\(first)=\\(last)&quot;\r\n&#39;\r\n~~~\r\n~~~\r\nPrice=10\r\nAmount=20\r\nValue=30\r\nTax=40\r\n~~~\r\n[Demo](https://jqplay.org/s/NWOd2XMdH1v)\r\n\r\nNote: The list could also be provided from outside jq:\r\n- using a JSON array\r\n~~~sh\r\njq -r --argjson names &#39;[&quot;Price&quot;, &quot;Amount&quot;, &quot;Value&quot;, &quot;Tax&quot;]&#39; \\\r\n  &#39;[$names, .] | transpose[] | &quot;\\(first)=\\(last)&quot;&#39;\r\n~~~\r\n- using positional parameters\r\n~~~sh\r\njq -r &#39;[$ARGS.positional, .] | transpose[] | &quot;\\(first)=\\(last)&quot;&#39; \\\r\n  --args Price Amount Value Tax\r\n~~~",
                "title": "append json output before saving into file"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1664394447,
        "creation_date": 1664392409,
        "question_id": 73886731,
        "body_markdown": "I am trying to curl some URL which returns a json file, as follows\r\n\r\n    [\r\n      10,\r\n      20,\r\n      30,\r\n      40,\r\n    ]\r\n\r\nnow I am trying to save these value in file with a variable assigned to it.\r\n\r\nneed output in file as \r\n\r\n    a=10\r\n    b=20\r\n    c=30\r\n    d=40\r\n\r\nthanks in advance.",
        "link": "https://stackoverflow.com/questions/73886731/append-json-output-before-saving-into-file",
        "title": "append json output before saving into file"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 6196394,
                    "reputation": 86601,
                    "user_id": 5291015,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/4tAvO.jpg?s=256",
                    "display_name": "Inian",
                    "link": "https://stackoverflow.com/users/5291015/inian"
                },
                "edited": false,
                "score": 4,
                "creation_date": 1664431658,
                "post_id": 73890739,
                "comment_id": 130470838,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1664453359,
                "last_edit_date": 1664453359,
                "creation_date": 1664435555,
                "answer_id": 73891602,
                "question_id": 73890739,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Build it from two JSON programs:\r\n\r\n1. Header lines: `.metric | to_entries | map(join(&quot;=&quot;)) | join(&quot;,&quot;)`\r\n   1. Get `metric` object: `.metric`\r\n   2. Convert to an array of key-value pairs: `to_entries`\r\n   3. Map each key-value pair object to a string &quot;key=value&quot;: `map(join(&quot;=&quot;))`\r\n   4. Join all pairs by comma: `join(&quot;,&quot;)`\r\n2. Value lists: `.values[] | [last,first] | join(&quot; &quot;)`\r\n   1. Stream values: `.values[]`\r\n   2. Reverse each two-valued array: `[last,first]`\r\n   3. Join items by blank: `join(&quot; &quot;)`\r\n\r\nAn alternative for 2.2. and 2.3. could be `&quot;\\(last) \\(first)&quot;`, i.e. `values[] | &quot;\\(last) \\(first)&quot;`. Or `[last,first]` could be replaced with `reverse`: `.values[] | reverse | join(&quot; &quot;)`.\r\n\r\nPutting the two programs together:\r\n\r\n```\r\n(.metric | to_entries | map(join(&quot;=&quot;)) | join(&quot;,&quot;)),\r\n(.values[] | [last,first] | join(&quot; &quot;))\r\n```\r\n\r\nAnd then execute with raw output enabled: `jq -r (.metrics|to_entries…`\r\n\r\nOutput:\r\n\r\n```\r\ncontainer=container1,namespace=namespace1,pod=pod1\r\n1 1664418600\r\n2 1664418900\r\n6 1664419200\r\n8 1664419500\r\n7 1664419800\r\n9 1664420100\r\ncontainer=container2,namespace=namespace2,pod=pod2\r\n1 1664420100\r\n```",
                "title": "how to format the result with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -2,
        "last_activity_date": 1664453359,
        "creation_date": 1664429906,
        "last_edit_date": 1664439119,
        "question_id": 73890739,
        "body_markdown": "I have the following printout,\r\n\r\n```json\r\n{\r\n  &quot;metric&quot;: {\r\n    &quot;container&quot;: &quot;container1&quot;,\r\n    &quot;namespace&quot;: &quot;namespace1&quot;,\r\n    &quot;pod&quot;: &quot;pod1&quot;\r\n  },\r\n  &quot;values&quot;: [\r\n    [\r\n      1664418600,\r\n      &quot;1&quot;\r\n    ],\r\n    [\r\n      1664418900,\r\n      &quot;2&quot;\r\n    ],\r\n    [\r\n      1664419200,\r\n      &quot;6&quot;\r\n    ],\r\n    [\r\n      1664419500,\r\n      &quot;8&quot;\r\n    ],\r\n    [\r\n      1664419800,\r\n      &quot;7&quot;\r\n    ],\r\n    [\r\n      1664420100,\r\n      &quot;9&quot;\r\n    ]\r\n  ]\r\n}\r\n{\r\n  &quot;metric&quot;: {\r\n    &quot;container&quot;: &quot;container2&quot;,\r\n    &quot;namespace&quot;: &quot;namespace2&quot;,\r\n    &quot;pod&quot;: &quot;pod2&quot;\r\n  },\r\n  &quot;values&quot;: [\r\n    [\r\n      1664420100,\r\n      &quot;1&quot;\r\n    ]\r\n  ]\r\n}\r\n```\r\n\r\n\r\nWhat I want:\r\n\r\n```none\r\ncontainer=container1,namespace=namespace1,pod=pod1\r\n1 1664418600\r\n2 1664418900\r\n6 1664419200\r\n8 1664419500\r\n7 1664419800\r\n9 1664420100\r\ncontainer=container2,namespace=namespace2,pod=pod2\r\n1 1664420100\r\n```",
        "link": "https://stackoverflow.com/questions/73890739/how-to-format-the-result-with-jq",
        "title": "how to format the result with 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": 2,
                "creation_date": 1664438257,
                "post_id": 73892015,
                "comment_id": 130472974,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1664439416,
                "creation_date": 1664439416,
                "answer_id": 73892380,
                "question_id": 73892015,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Is this what you are asking? Transforming the input array with all nested arrays and keeping only certain properties of each object? Any property not listed in the jq program will be ignored and dropped from the output.\r\n\r\n```\r\nmap({\r\n    row_title,\r\n    panels: .panels | map({\r\n        panel_title,\r\n        panel_description,\r\n        panel_format,\r\n        panel_exprs: .panel_exprs | map({\r\n            expr\r\n        })\r\n    })\r\n})\r\n```",
                "title": "How to select specific keys only from JSON keeping its structure?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1664439416,
        "creation_date": 1664437699,
        "question_id": 73892015,
        "body_markdown": "I have JSON configuration of Grafana dashboard.\r\nI want to get spicific keys like\r\n\r\n    .rows[].title\r\n    .rows[].panels[].title\r\n    .rows[].panels[].description\r\n    .rows[].panels[].format\r\n    .rows[].panels[].targets[].expr\r\n\r\nand transform it to new JSON with following structure:\r\n\r\n    [\r\n        {\r\n            &quot;row_title&quot;: &quot;.rows[].title&quot;,\r\n            &quot;panels&quot;: [\r\n                {\r\n                    &quot;panel_title&quot;: &quot;.rows[].panels[].title&quot;,\r\n                    &quot;panel_description&quot;: &quot;.rows[].panels[].description&quot;,\r\n                    &quot;panel_format&quot;: &quot;.rows[].panels[].format&quot;,\r\n                    &quot;panel_exprs&quot;: [\r\n                        {\r\n                            &quot;expr&quot;: &quot;.rows[].panels[].targets[].expr&quot;\r\n                        }\r\n                    ]\r\n                }\r\n    \r\n            ]\r\n        }\r\n    ]\r\nTried to do it with map(), but cannot understand how make nested arrays.",
        "link": "https://stackoverflow.com/questions/73892015/how-to-select-specific-keys-only-from-json-keeping-its-structure",
        "title": "How to select specific keys only from JSON keeping its structure?"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1664441560,
                "creation_date": 1664441560,
                "answer_id": 73892793,
                "question_id": 73892767,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Why not just wrap the `capture` in a new array:\r\n```\r\n.text | [ capture(&quot;(?&lt;letter&gt;[a-z])(?&lt;number&gt;[0-9])&quot;;&quot;g&quot;) ]\r\n```\r\n\r\n#### [JqPlay](https://jqplay.org/s/tvut-TPC7yS)",
                "title": "How to return an array from `capture` with `global` filter in `jq`"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1664441560,
        "creation_date": 1664441392,
        "question_id": 73892767,
        "body_markdown": "Given the following input:\r\n```json\r\n{\r\n  &quot;text&quot;: &quot;a1\\nb2&quot;\r\n}\r\n```\r\nHow do I get the following output:\r\n```json\r\n[\r\n  {\r\n    &quot;letter&quot;: &quot;a&quot;,\r\n    &quot;number&quot;: 1\r\n  },\r\n  {\r\n    &quot;letter&quot;: &quot;b&quot;,\r\n    &quot;number&quot;: 2\r\n  }\r\n]\r\n```\r\n\r\nI&#39;ve tried using `capture` with the `&quot;g&quot;` flag, but this yields two documents instead of a single document with an array of captured inputs:\r\n\r\n```shell\r\n$ echo &#39;{\r\n  &quot;text&quot;: &quot;a1\\\\nb2&quot;\r\n}&#39; | jq &#39;.text | capture(&quot;(?&lt;letter&gt;[a-z])(?&lt;number&gt;[0-9])&quot;;&quot;g&quot;)&#39;\r\n{\r\n  &quot;letter&quot;: &quot;a&quot;,\r\n  &quot;number&quot;: &quot;1&quot;\r\n}\r\n{\r\n  &quot;letter&quot;: &quot;b&quot;,\r\n  &quot;number&quot;: &quot;2&quot;\r\n}\r\n```\r\n\r\nHere is a [link](https://jqplay.org/s/Z4U5mzPkav-) to the jqplay example.",
        "link": "https://stackoverflow.com/questions/73892767/how-to-return-an-array-from-capture-with-global-filter-in-jq",
        "title": "How to return an array from `capture` with `global` filter in `jq`"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 6313442,
                    "reputation": 45115,
                    "user_id": 5625547,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/oqCND.jpg?s=256",
                    "display_name": "0stone0",
                    "link": "https://stackoverflow.com/users/5625547/0stone0"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1664443097,
                "post_id": 73893049,
                "comment_id": 130474656,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 12497503,
                    "reputation": 3771,
                    "user_id": 9096986,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/841e6e83a5fc76c72ce54d34e24add40?s=256&d=identicon&r=PG",
                    "display_name": "4r7if3x",
                    "link": "https://stackoverflow.com/users/9096986/4r7if3x"
                },
                "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": 1664443411,
                "post_id": 73893049,
                "comment_id": 130474763,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1664444534,
                "last_edit_date": 1664444534,
                "creation_date": 1664443438,
                "answer_id": 73893191,
                "question_id": 73893049,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "This outputs `true` or `false` based on your requirements:\r\n\r\n```\r\nany(.type==&quot;barcode&quot;) and any(.type==&quot;category&quot; and .name==&quot;food&quot;)\r\n```\r\n\r\n`jq -e` will set the exit code of the program accordingly:\r\n\r\n```\r\nif jq -e &#39;...&#39;; then\r\n  ...\r\nfi\r\n```\r\n\r\nWithout `-e`:\r\n\r\n```\r\nif test &quot;$(jq &#39;...&#39;)&quot; = true; then\r\n  ...\r\nfi\r\n```\r\n\r\n*****\r\n\r\nAnd not necessarily shorter or tidier, but semantically easier to follow:\r\n\r\n```\r\ngroup_by(.type)\r\n| map({\r\n    key: first.type,\r\n    value: map(.name)\r\n})\r\n| from_entries\r\n| .category as $cat\r\n| .barcode and (&quot;food&quot;|IN($cat[]))\r\n```\r\n\r\nThis first builds an intermediate object of the form:\r\n\r\n```\r\n{\r\n  &quot;barcode&quot;: [\r\n    &quot;123456&quot;\r\n  ],\r\n  &quot;category&quot;: [\r\n    &quot;food&quot;,\r\n    &quot;fruit&quot;\r\n  ]\r\n}\r\n```\r\n\r\nWhich you can then query, e.g. does it have a barcode and is &quot;food&quot; one of the categories.",
                "title": "How to get a key/value pair on a sibling object in a JSON array conditionally"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1664444534,
        "creation_date": 1664442752,
        "last_edit_date": 1664443354,
        "question_id": 73893049,
        "body_markdown": "I&#39;m interacting with an API that returns an array of objects related to a product in JSON format:\r\n\r\n```\r\n[\r\n  {\r\n    &quot;type&quot;: &quot;category&quot;,\r\n    &quot;name&quot;: &quot;food&quot;\r\n  },\r\n  {\r\n    &quot;type&quot;: &quot;category&quot;,\r\n    &quot;name&quot;: &quot;fruit&quot;\r\n  },\r\n  {\r\n    &quot;type&quot;: &quot;barcode&quot;,\r\n    &quot;name&quot;: &quot;123456&quot;\r\n  }\r\n]\r\n```\r\n\r\nI&#39;m trying to use `jq` tool on `bash` in the shortest and tidiest form, to check if a product has a barcode and it&#39;s categorized as food. In other words, check if an object with `type=barcode` exists in the array, then check if there is an object with `type=category` together with `name=food`.",
        "link": "https://stackoverflow.com/questions/73893049/how-to-get-a-key-value-pair-on-a-sibling-object-in-a-json-array-conditionally",
        "title": "How to get a key/value pair on a sibling object in a JSON array conditionally"
    },
    {
        "tags": [
            "json",
            "group-by",
            "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": 1664463133,
                "post_id": 73893818,
                "comment_id": 130482333,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1686898460,
                "last_edit_date": 1686898460,
                "creation_date": 1664446456,
                "answer_id": 73893819,
                "question_id": 73893818,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "It is possible to define a reusable function which groups an array by a criteria and uses this criteria as key. Obviously, this will only work for string keys (but one can always add `|tostring`).\r\n\r\n```\r\ndef group(k):\r\n  group_by(k) | map({ key: first|k, value: . }) | from_entries;\r\n```\r\n\r\nTransforming to the expected output is then simply:\r\n\r\n```\r\ngroup(.country)\r\n```\r\n\r\nAdditional tasks such as counting persons per country then become trivial:\r\n\r\n```\r\ngroup(.country) | map_values(length)\r\n```\r\n\r\nproduces:\r\n\r\n```json\r\n{\r\n  &quot;germany&quot;: 2,\r\n  &quot;usa&quot;: 1\r\n}\r\n```\r\n\r\nChaining other transformations is straightforward too with this helper function. Need a list of names per country?\r\n\r\n```\r\ngroup(.country) | map_values(map(.name))\r\n```\r\n\r\nvoil&#224;\r\n\r\n```json\r\n{\r\n  &quot;germany&quot;: [\r\n    &quot;anna&quot;,\r\n    &quot;lisa&quot;\r\n  ],\r\n  &quot;usa&quot;: [\r\n    &quot;john&quot;\r\n  ]\r\n}\r\n```\r\n\r\n*****\r\n\r\nIt might be beneficial to map the values in one go. This can be achieved with a second parameter. The original function can now be redefined to delegate to the more general function:\r\n\r\n```\r\ndef group(k;v):\r\n  group_by(k) | map({ key: first|k, value: map(v) }) | from_entries;\r\ndef group(k): group(k; .);\r\n```\r\n\r\n```\r\ngroup(.country; .name)\r\n```\r\n\r\n*****\r\n\r\nTo allow arbitrary objects to be used to group objects, the function needs a second parameter which will then convert the group into a string key.\r\n\r\n```\r\ndef group(group;key):\r\n  group_by(group) | map({key:first|group|key, value:.}) | from_entries;\r\ndef group(group): group(group; .);\r\n```\r\n\r\nSpecial attention needs to be paid that the string representation of the group must have a 1:1 mapping with the group, otherwise some items will be lost in the `from_entries` step.",
                "title": "Reusable function to group_by but return an object with group as key"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1664447217,
                "creation_date": 1664447217,
                "answer_id": 73893982,
                "question_id": 73893818,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s a variant using `reduce` instead of `group_by`:\r\n~~~sh\r\nreduce .[] as $m ({}; .[$m.country] += [$m])\r\n~~~\r\n[Demo](https://jqplay.org/s/sVVuSWg_ozX)\r\n\r\nOr as a defined function:\r\n~~~sh\r\ndef grp(f): reduce .[] as $m ({}; .[$m|f] += [$m]);\r\n\r\ngrp(.country)\r\n~~~\r\n[Demo](https://jqplay.org/s/UuP84ectvoy)\r\n\r\n~~~json\r\n{\r\n  &quot;germany&quot;: [\r\n    {\r\n      &quot;name&quot;: &quot;anna&quot;,\r\n      &quot;country&quot;: &quot;germany&quot;\r\n    },\r\n    {\r\n      &quot;name&quot;: &quot;lisa&quot;,\r\n      &quot;country&quot;: &quot;germany&quot;\r\n    }\r\n  ],\r\n  &quot;usa&quot;: [\r\n    {\r\n      &quot;name&quot;: &quot;john&quot;,\r\n      &quot;country&quot;: &quot;usa&quot;\r\n    }\r\n  ]\r\n}\r\n~~~",
                "title": "Reusable function to group_by but return an object with group as key"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1664447595,
                "last_edit_date": 1664447595,
                "creation_date": 1664447302,
                "answer_id": 73894005,
                "question_id": 73893818,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Shorter alternative using `group_by`, `map()` and [`add`][1]:\r\n```none\r\ngroup_by(.country) | map({ (.[0].country): . }) | add\r\n```\r\n\r\nProduces:\r\n```json\r\n{\r\n  &quot;germany&quot;: [\r\n    {\r\n      &quot;name&quot;: &quot;anna&quot;,\r\n      &quot;country&quot;: &quot;germany&quot;\r\n    },\r\n    {\r\n      &quot;name&quot;: &quot;lisa&quot;,\r\n      &quot;country&quot;: &quot;germany&quot;\r\n    }\r\n  ],\r\n  &quot;usa&quot;: [\r\n    {\r\n      &quot;name&quot;: &quot;john&quot;,\r\n      &quot;country&quot;: &quot;usa&quot;\r\n    }\r\n  ]\r\n}\r\n```\r\n[Jq{Play](https://jqplay.org/s/NUlHKffWrCv)\r\n\r\n\r\n  [1]: https://stedolan.github.io/jq/manual/#add",
                "title": "Reusable function to group_by but return an object with group as key"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": -1,
        "last_activity_date": 1686898460,
        "creation_date": 1664446456,
        "last_edit_date": 1666610072,
        "question_id": 73893818,
        "body_markdown": "This question is looking for a reusable function that can be imported into other jq programs. The question [group and key by property](https://stackoverflow.com/questions/43221453/jq-group-and-key-by-property) is addressing a specific problem. This question is aimed to be as general as possible, since this is a recurring problem.\r\n\r\nGiven the following (sample) input, how can I create a new object which groups together each person by their country? I know about `group_by`, but it returns an array of arrays.\r\n\r\n```json\r\n[\r\n  {\r\n    &quot;name&quot;: &quot;anna&quot;,\r\n    &quot;country&quot;: &quot;germany&quot;\r\n  },\r\n  {\r\n    &quot;name&quot;: &quot;lisa&quot;,\r\n    &quot;country&quot;: &quot;germany&quot;\r\n  },\r\n  {\r\n    &quot;name&quot;: &quot;john&quot;,\r\n    &quot;country&quot;: &quot;usa&quot;\r\n  }\r\n]\r\n```\r\n\r\nRunning `group_by(.country)` produces:\r\n\r\n```json\r\n[\r\n  [\r\n    {\r\n      &quot;name&quot;: &quot;anna&quot;,\r\n      &quot;country&quot;: &quot;germany&quot;\r\n    },\r\n    {\r\n      &quot;name&quot;: &quot;lisa&quot;,\r\n      &quot;country&quot;: &quot;germany&quot;\r\n    }\r\n  ],\r\n  [\r\n    {\r\n      &quot;name&quot;: &quot;john&quot;,\r\n      &quot;country&quot;: &quot;usa&quot;\r\n    }\r\n  ]\r\n]\r\n```\r\n\r\nbut this structure makes subsequent processing difficult. Instead, I&#39;d prefer to transform the document into the following structure:\r\n\r\n```json\r\n{\r\n  &quot;germany&quot;: [\r\n    {\r\n      &quot;name&quot;: &quot;anna&quot;,\r\n      &quot;country&quot;: &quot;germany&quot;\r\n    },\r\n    {\r\n      &quot;name&quot;: &quot;lisa&quot;,\r\n      &quot;country&quot;: &quot;germany&quot;\r\n    }\r\n  ],\r\n  &quot;usa&quot;: [\r\n    {\r\n      &quot;name&quot;: &quot;john&quot;,\r\n      &quot;country&quot;: &quot;usa&quot;\r\n    }\r\n  ]\r\n}\r\n```\r\n\r\nThis would make other tasks such as counting persons per country a lot easier.\r\n\r\nHow can I do it? If possible, the answer should not rely on the exact format of the sample format, but be applicable in the general case for arbitrary inputs.",
        "link": "https://stackoverflow.com/questions/73893818/reusable-function-to-group-by-but-return-an-object-with-group-as-key",
        "title": "Reusable function to group_by but return an object with group as key"
    },
    {
        "tags": [
            "arrays",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 6313442,
                    "reputation": 45115,
                    "user_id": 5625547,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/oqCND.jpg?s=256",
                    "display_name": "0stone0",
                    "link": "https://stackoverflow.com/users/5625547/0stone0"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1664456222,
                "post_id": 73895618,
                "comment_id": 130479376,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 39208,
                    "reputation": 267964,
                    "user_id": 112968,
                    "user_type": "registered",
                    "accept_rate": 68,
                    "profile_image": "https://i.sstatic.net/zHTaT.png?s=256",
                    "display_name": "knittl",
                    "link": "https://stackoverflow.com/users/112968/knittl"
                },
                "reply_to_user": {
                    "account_id": 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": 1664456302,
                "post_id": 73895618,
                "comment_id": 130479405,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 39208,
                    "reputation": 267964,
                    "user_id": 112968,
                    "user_type": "registered",
                    "accept_rate": 68,
                    "profile_image": "https://i.sstatic.net/zHTaT.png?s=256",
                    "display_name": "knittl",
                    "link": "https://stackoverflow.com/users/112968/knittl"
                },
                "reply_to_user": {
                    "account_id": 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": 1664458405,
                "post_id": 73895618,
                "comment_id": 130480237,
                "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": 1664459823,
                "post_id": 73895618,
                "comment_id": 130480881,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1664548661,
                "last_edit_date": 1664548661,
                "creation_date": 1664506511,
                "answer_id": 73903553,
                "question_id": 73895618,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Yes, for arrays as input, if A is an array, then `.[A]` asks for the sorted array of ALL the indices, $i, such that `.[0:$i] + A` is an initial subarray of the input.  \r\n\r\nExamples:\r\n```\r\njq -nc &#39;[0,1,2,3,4,1,2] | .[[1,2]]&#39;\r\n[1,5]\r\n\r\ngojq -nc &#39;[0,1,2,3,4,1,2] | .[[1,2]]&#39;\r\n[1,5]\r\n\r\n```\r\nAs you note, `indices/1` on arrays is defined using this feature, and the jq manual mentions this feature of `indices/1`:\r\n\r\n&gt; The input may be an array, in which case if s is an array then the indices output will be those where all elements in . match those of s.\r\n\r\nThe [jq FAQ][1] also has some pertinent documentation at\r\n\r\n&gt; &#119928;: Given an array, A, containing an item, X, how can I find the least index of X in A? Why does [[1]] | index([1]) return null rather than 0? Why does [1,2] | index([1,2]) return 0 rather than null?\r\n\r\n\r\nUnfortunately, the jq manual itself does not make the connection explicit.\r\n\r\n\r\n```Note:``` jaq has a different take on this.\r\n\r\n---\r\nFootnotes: \r\n\r\n(a) The behavior of `B|.[A]` when A and B are JSON arrays is now documented on the jq wiki at [How to: Avoid Pitfalls][2]\r\n\r\n(b) `.[x,y]` evaluates to`.[x], .[y]` by the ordinary rules governing the comma-operator.\r\n\r\n\r\n  [1]: https://github.com/stedolan/jq/wiki/FAQ\r\n  [2]: https://github.com/stedolan/jq/wiki/How-to:-Avoid-Pitfalls",
                "title": "Subscripting an array with an … array?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -1,
        "last_activity_date": 1664548661,
        "creation_date": 1664454770,
        "last_edit_date": 1664455234,
        "question_id": 73895618,
        "body_markdown": "jq is straightforward for the most part, but I&#39;m at a loss trying to decypher the following jq program. How does it work? Apparently, it finds the index of the value in the array. But how can this syntax be explained? Can it be deconstructed to be more explicit?\r\n\r\nI&#39;m aware of the `indices/1` function … but this function is defined as `def indices($i): .[[$i]];` (simplified) – which led me to ask this question.\r\n\r\n```\r\necho &#39;[1,2,3,4,3,2,1]&#39; | jq &#39;.[[1]]&#39; # output: [0,6]; 1 occurs at index 0 and 6\r\necho &#39;[1,2,3,4,3,2,1]&#39; | jq &#39;.[[2,3]]&#39; # output: [1]; [2,3] occurs at index 1\r\necho &#39;[1,2,3,4,3,2,1]&#39; | jq &#39;.[2,3]&#39; # output: 3 4; stream of values at index 2 and 3\r\n```\r\n\r\nI haven&#39;t found anything in [the manual](https://stedolan.github.io/jq/manual/v1.6/#ArrayIndex:.[2]) explaining this behavior. How does `.[x]` relate to `.[[x]]`, and `.[x,y]` to `.[[x,y]]`? Is this syntax (`.[[x]]`) documented somewhere?",
        "link": "https://stackoverflow.com/questions/73895618/subscripting-an-array-with-an-array",
        "title": "Subscripting an array with an … array?"
    },
    {
        "tags": [
            "jq",
            "zsh"
        ],
        "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": 1664470868,
                "post_id": 73899110,
                "comment_id": 130485221,
                "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": 1664471073,
                "post_id": 73899110,
                "comment_id": 130485282,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1664471481,
                "last_edit_date": 1664471481,
                "creation_date": 1664470702,
                "answer_id": 73899231,
                "question_id": 73899110,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "`printf` behavior is the same between both shells, as are all the shell expansions related to your `jq` invocation -- but default `echo` behavior differs.\r\n\r\nYou can avoid this by switching from `echo` to `printf`.\r\n\r\n```console\r\n% OUT=$(jq --null-input --compact-output --raw-output --monochrome-output --arg test &quot;$(printf %b &#39;A\\nB&#39;)&quot; &#39;{test: $test}&#39;)\r\n% printf &#39;%s\\n&#39; &quot;$OUT&quot;\r\n{&quot;test&quot;:&quot;A\\nB&quot;}\r\n```\r\n",
                "title": "jq - Discrepancy in newline treatment between bash and zsh and zsh-subshell"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1664471481,
        "creation_date": 1664470137,
        "last_edit_date": 1664470670,
        "question_id": 73899110,
        "body_markdown": "I&#39;m trying to [format a string as JSON](https://gist.github.com/jakub-g/b2ef123f8b754bc5c63bc854e7019987 ) using `jq` and I noticed differing behaviors on bash vs zsh; specifically when zsh runs `jq` directly, the outcome is different than when it runs it in subshell: `\\n` input gets output as `\\\\n` in first case, vs as`\\n` in the latter.\r\n\r\nI&#39;m puzzled and not sure what&#39;s going on there:\r\n\r\n- Is this a known zsh behavior?\r\n- Is this a `jq` bug? \r\n- Or does it work as designed and I&#39;m missing something?\r\n\r\nBTW: https://stackoverflow.com/questions/67391180/use-newline-with-jq suggests to use `printf %b` to obtain `\\n` instead of `\\\\n`, which works for bash,. but discrepancy in `zsh` between the modes is still there.\r\n\r\n\r\n```\r\n$ jq --version\r\njq-1.6\r\n\r\n# ---\r\n# Using \\n directly\r\n\r\nbash-3.2$        jq --null-input --compact-output --raw-output --monochrome-output --arg test &#39;A\\nB&#39; &#39;{test: $test}&#39;\r\n{&quot;test&quot;:&quot;A\\\\nB&quot;}\r\nbash-3.2$  OUT=$(jq --null-input --compact-output --raw-output --monochrome-output --arg test &#39;A\\nB&#39; &#39;{test: $test}&#39;); echo $OUT\r\n{&quot;test&quot;:&quot;A\\\\nB&quot;}\r\n\r\n\r\nzsh-5.8.1&gt;       jq --null-input --compact-output --raw-output --monochrome-output --arg test &#39;A\\nB&#39; &#39;{test: $test}&#39;\r\n{&quot;test&quot;:&quot;A\\\\nB&quot;}\r\nzsh-5.8.1&gt; OUT=$(jq --null-input --compact-output --raw-output --monochrome-output --arg test &#39;A\\nB&#39; &#39;{test: $test}&#39;); echo $OUT\r\n{&quot;test&quot;:&quot;A\\nB&quot;}\r\n\r\n# -----\r\n# Using `printf %b` to convert `\\n` to real newline\r\n\r\nbash-3.2$        jq --null-input --compact-output --raw-output --monochrome-output --arg test &quot;$(printf %b &#39;A\\nB&#39;)&quot; &#39;{test: $test}&#39;\r\n{&quot;test&quot;:&quot;A\\nB&quot;}\r\nbash-3.2$  OUT=$(jq --null-input --compact-output --raw-output --monochrome-output --arg test &quot;$(printf %b &#39;A\\nB&#39;)&quot; &#39;{test: $test}&#39;); echo $OUT\r\n{&quot;test&quot;:&quot;A\\nB&quot;}\r\n\r\n\r\nzsh-5.8.1&gt;       jq --null-input --compact-output --raw-output --monochrome-output --arg test &quot;$(printf %b &#39;A\\nB&#39;)&quot; &#39;{test: $test}&#39;\r\n{&quot;test&quot;:&quot;A\\nB&quot;}\r\nzsh-5.8.1&gt; OUT=$(jq --null-input --compact-output --raw-output --monochrome-output --arg test &quot;$(printf %b &#39;A\\nB&#39;)&quot; &#39;{test: $test}&#39;); echo $OUT\r\n{&quot;test&quot;:&quot;A\r\nB&quot;}\r\n```",
        "link": "https://stackoverflow.com/questions/73899110/jq-discrepancy-in-newline-treatment-between-bash-and-zsh-and-zsh-subshell",
        "title": "jq - Discrepancy in newline treatment between bash and zsh and zsh-subshell"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 6313442,
                    "reputation": 45115,
                    "user_id": 5625547,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/oqCND.jpg?s=256",
                    "display_name": "0stone0",
                    "link": "https://stackoverflow.com/users/5625547/0stone0"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1664530843,
                "post_id": 73906627,
                "comment_id": 130498043,
                "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": 1664530883,
                "post_id": 73906627,
                "comment_id": 130498058,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": -1,
                "last_activity_date": 1664530847,
                "creation_date": 1664530847,
                "answer_id": 73906783,
                "question_id": 73906627,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Create whole json string at once with `printf`:\r\n\r\n    fruit_array=(&quot;banana&quot; &quot;orange&quot;)\r\n    printf -v fruits &#39;{&quot;001&quot;: {&quot;002&quot;: %s}},&#39; &quot;${fruit_array[@]}&quot;\r\n    $ echo $fruits\r\n    {&quot;001&quot;: {&quot;002&quot;: banana}},{&quot;001&quot;: {&quot;002&quot;: orange}},\r\n\r\nThen add it to your template removing last comma:\r\n\r\n    $ echo ${fruits%,}\r\n    {&quot;001&quot;: {&quot;002&quot;: banana}},{&quot;001&quot;: {&quot;002&quot;: orange}}\r\n\r\n&quot;Numbers&quot; could also be set like this:\r\n\r\n    fruit_array=(&quot;1 2 banana&quot; &quot;3 4 orange&quot;)\r\n    printf &#39;{&quot;%.3d&quot;: {&quot;%.3d&quot;: %s}},&#39; ${fruit_array[@]}\r\n    {&quot;001&quot;: {&quot;002&quot;: banana}},{&quot;003&quot;: {&quot;004&quot;: orange}},",
                "title": "JQ Loop over Bash array add elements"
            },
            {
                "up_vote_count": 6,
                "is_accepted": true,
                "score": 6,
                "last_activity_date": 1664530907,
                "creation_date": 1664530907,
                "answer_id": 73906799,
                "question_id": 73906627,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "JQ can do all that on its own; you don&#39;t need a loop or anything.\r\n```\r\njq &#39;.foods.perishable.fruit += (\r\n  $ARGS.positional\r\n  | map({&quot;001&quot;: {&quot;002&quot;: .}})\r\n)&#39; template.json --args &quot;${fruit_array[@]}&quot; &gt;template_with_fruit.json\r\n```",
                "title": "JQ Loop over Bash array add elements"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1664531080,
                "creation_date": 1664531080,
                "answer_id": 73906840,
                "question_id": 73906627,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If you pass your array as a space delimited string, you can use JQ like so:\r\n```\r\njq --arg fruits &quot;$fruit_array&quot; \\\r\n    &#39;.foods.perishable.fruit |= ($fruits | split(&quot; &quot;) | map({ &quot;001&quot;: { &quot;002&quot;: . } }))&#39; input\r\n```\r\n\r\n\r\n----------\r\n\r\n\r\n```json\r\n{\r\n  &quot;foods&quot;: {\r\n    &quot;perishable&quot;: {\r\n      &quot;fruit&quot;: [\r\n        {\r\n          &quot;001&quot;: {\r\n            &quot;002&quot;: &quot;banana&quot;\r\n          }\r\n        },\r\n        {\r\n          &quot;001&quot;: {\r\n            &quot;002&quot;: &quot;orange&quot;\r\n          }\r\n        }\r\n      ]\r\n    }\r\n  }\r\n}\r\n```",
                "title": "JQ Loop over Bash array add elements"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 1,
        "last_activity_date": 1664531262,
        "creation_date": 1664530039,
        "last_edit_date": 1664531262,
        "question_id": 73906627,
        "body_markdown": "I do not seem to be able to find an answer, but have seen enough to know there is likely a better way of doing what I want to do. \r\n\r\nProblem: I have a bash array. For each element in the bash array, I want to update a JSON array.\r\n\r\nThe JSON looks like the below. I am wanting to update the *fruit* array.\r\n\r\n```\r\n  &quot;foods&quot;: {\r\n    &quot;perishable&quot;: {\r\n      &quot;fruit&quot;: []\r\n```\r\n\r\nI&#39;ll get an array of length *n*, for example:  \r\n```\r\nfruit_array=(&quot;banana&quot; &quot;orange&quot;)\r\n```\r\n\r\nIt should look something like this:\r\n```\r\n  &quot;foods&quot;: {\r\n    &quot;perishable&quot;: {\r\n      &quot;fruit&quot;: [\r\n        { \r\n          &quot;001&quot;: {\r\n            &quot;002&quot;: &quot;banana&quot;\r\n          }\r\n        },\r\n        { \r\n          &quot;001&quot;: {\r\n            &quot;002&quot;: &quot;orange&quot;\r\n          }\r\n        }\r\n      ]\r\n```\r\n\r\nIs there a nice way of doing this? At the moment I am trying the below:\r\n```\r\n#!/bin/bash\r\n\r\nfruit_array=(&quot;banana&quot; &quot;orange&quot;)\r\n\r\nfor fruit in &quot;${fruit_array[@]}&quot;; do\r\n   jq \\\r\n   --arg fruit $fruit \\\r\n   &#39;.foods.perishables.fruit += [{&quot;001&quot;: {&quot;002&quot;: $fruit}}]&#39; \\\r\n   template.json &gt; template_with_fruit.json\r\ndone\r\n```\r\n\r\nThis doesn&#39;t work for the obvious reason that the template is being re-read, but I have messed around to get it consuming the output of the previous iteration and nothing comes out at the end. I am only able to update the template once. \r\n\r\nHowever, I know this seems a little dodgy and suspect there is a cleaner, more *jq* way.\r\n\r\nA previous - aborted - attempt went something like this:\r\n```\r\njq \\\r\n--argjson fruit &quot;$(printf &#39;{&quot;001&quot;: {&quot;002&quot;: &quot;%s&quot;}}\\n&#39; \\&quot;${fruit_array[@]}\\&quot; | jq -nR &#39;[inputs]&#39;)&quot; \\\r\n&#39;.foods.perishables.fruit += $fruit&#39; \\\r\n```\r\n\r\nWhich produced a escaped string which I couldn&#39;t do anything with, but at least hinted that there might be a neater solution to the standard bash loop.\r\n\r\nI am missing something.\r\n\r\nAny help would, as always, be appreciated.",
        "link": "https://stackoverflow.com/questions/73906627/jq-loop-over-bash-array-add-elements",
        "title": "JQ Loop over Bash array add elements"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 4879,
                    "reputation": 248190,
                    "user_id": 7552,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/b60298053f87465641c1b1192338c8cd?s=256&d=identicon&r=PG",
                    "display_name": "glenn jackman",
                    "link": "https://stackoverflow.com/users/7552/glenn-jackman"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1664573739,
                "post_id": 73913094,
                "comment_id": 130510799,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1664568801,
                "last_edit_date": 1664568801,
                "creation_date": 1664565817,
                "answer_id": 73913202,
                "question_id": 73913094,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "`.relays[1:]` gives you an array of all but the first item. Use `.relays[0]` instead to get only the first item:\r\n~~~sh\r\n.countries[] | select(.name==$country_choice)\r\n| .cities[] | select(.name==$city_choice)\r\n| .relays[0] | .ipv4_addr_in+&quot;,&quot;+.public_key\r\n~~~\r\n~~~\r\n141.98.252.130,IJJe0TQtuQOyemL4IZn6oHEsMKSPqOuLfD5HoAWEPTY=\r\n~~~\r\n[Demo](https://jqplay.org/s/F6AEkX0X1xq)\r\n\r\n---\r\nAs for a random value, jq does not have a random number generator. You could, however, (poorly) emulate one based on the current time using `now`, or import one generated outside using `--arg` or `--argjson`.\r\n\r\n---\r\nHere&#39;s one very simple jq-only implementation of your script importing the `$RANDOM` variable from `bash`, which &quot;expands to a random integer between 0 and 32767&quot; (so make sure your arrays are not longer than that):\r\n~~~sh\r\ncountry_choice=UK    # setting the country\r\ncity_choice=         # omitting the city\r\n\r\njq --arg country_choice &quot;$country_choice&quot; --argjson country_random $RANDOM \\\r\n  --arg city_choice &quot;$city_choice&quot; --argjson city_random $RANDOM \\\r\n  --argjson relay_random $RANDOM -r \\\r\n  &#39;\r\n    .countries\r\n    | if $country_choice == &quot;&quot;\r\n      then .[$country_random % length]\r\n      else .[] | select(.name == $country_choice) end\r\n    \r\n    | .cities\r\n    | if $city_choice == &quot;&quot;\r\n      then .[$city_random % length]\r\n      else .[] | select(.name == $city_choice) end\r\n    \r\n    | .relays | .[$relay_random % length]\r\n    | .ipv4_addr_in + &quot;,&quot; + .public_key\r\n  &#39;\r\n~~~\r\n~~~\r\n146.70.133.98,Q2khJLbTSFxmppPGHgq2HdxMQx7CczPZCgVpYZMoNnM=\r\n~~~\r\n[Demo (with faked random numbers)](https://jqplay.org/s/Otqu8Q_mCQ1)",
                "title": "jq - Select Random object from each array and only return certain values in each object of filtered arrays"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1664568555,
                "creation_date": 1664568555,
                "answer_id": 73913530,
                "question_id": 73913094,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Since the question envisions requiring several or an *a priori* unknown number of random values, the following illustration may be of interest.\r\n```\r\n&lt; /dev/urandom tr -cd &#39;0-9&#39; | fold -w 1 | jq -MRcnr &#39;\r\n\r\n# Output: a prn in range(0;$n) where $n is `.`\r\ndef prn:\r\n  if . == 1 then 0\r\n  else . as $n\r\n  | ([1, (($n-1)|tostring|length)]|max) as $w\r\n  | [limit($w; inputs)] | join(&quot;&quot;) | tonumber\r\n  | if . &lt; $n then . else ($n | prn) end\r\n  end;\r\n\r\n\r\n# An illustration - 10 selections at random with replacement\r\n[range(0;10) | [&quot;a&quot;, &quot;b&quot;, &quot;c&quot;] | .[length|prn]]\r\n&#39;\r\n```\r\nNotice that STDIN is used for the entropy source; file inputs would have to be handled using command-line options such as `--rawfile` or `--slurpfile`.\r\n\r\nIn fact, if one requires an `a priori` unknown number of random values, then there really isn&#39;t any other practical choice when using the current version of jq.",
                "title": "jq - Select Random object from each array and only return certain values in each object of filtered arrays"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1664568801,
        "creation_date": 1664565106,
        "question_id": 73913094,
        "body_markdown": "Overall Goals:\r\n- I take user input, as country and/or city variables, then use those variables to filter down the JSON data to only the relays that meet the users choice. (Probably do some regex in JQ when selecting with the user input variables, to make sure someone can input ```New York``` and it would match ```New York, NY```)\r\n- I then want to select a random relay in the relay array, or 1 random relay in each cities relay array, which is where I am getting stuck.\r\n- After I get a random relay in that/each array, I want to print certain values based on the key (i.e. ipvr_addr_in and public_key), in a csv format (for now).\r\n- If there are multiple relays at this point, I would iterate through them to find the lowest latency, sort the list, choose the lowest and pass that IP,key pair on to the final configuration.\r\n\r\nOriginally, I thought I&#39;d just grab the first object in the array and use that:\r\n```\r\ncountry_choice=UK\r\ncity_choice=London\r\nif [[ -z &quot;$city_choice&quot; ]]; then\r\n    jq --arg country_choice &quot;$country_choice&quot; -r &#39;.countries[] | select(.name==$country_choice) | .cities[] | .relays[:1] | .ipv4_addr_in+&quot;,&quot;+.public_key&#39; testdata.json\r\nelse\r\n    jq --arg country_choice &quot;$country_choice&quot; --arg city_choice &quot;$city_choice&quot; -r &#39;.countries[] | select(.name==$country_choice) | .cities[] | select(.name==$city_choice) | .relays[:1] | .ipv4_addr_in+&quot;,&quot;+.public_key&#39; testdata.json\r\nfi\r\n```\r\nBut that resulted in the JQ error: ```Cannot index array with string &quot;public_key&quot;```\r\n\r\nI am still very new to JQ and JSONs, so I am unfamiliar with why I can&#39;t print out specific values after filtering down to a specific object of several arrays.\r\n\r\nCan anyone help me out here? I can&#39;t seem to find anything online about &quot;selecting random&quot; in jq.\r\n\r\nAlso any help with some of my other overall goals would be very much appreciated, I&#39;m no coding guru.\r\n\r\nAn abridged test dataset (testdata.json):\r\n```\r\n{\r\n  &quot;countries&quot;: [\r\n    {\r\n      &quot;name&quot;: &quot;UK&quot;,\r\n      &quot;code&quot;: &quot;gb&quot;,\r\n      &quot;cities&quot;: [\r\n        {\r\n          &quot;name&quot;: &quot;London&quot;,\r\n          &quot;code&quot;: &quot;lon&quot;,\r\n          &quot;relays&quot;: [\r\n            {\r\n              &quot;hostname&quot;: &quot;gb4-wireguard&quot;,\r\n              &quot;ipv4_addr_in&quot;: &quot;141.98.252.130&quot;,\r\n              &quot;ipv6_addr_in&quot;: &quot;2a03:1b20:7:f011::a01f&quot;,\r\n              &quot;public_key&quot;: &quot;IJJe0TQtuQOyemL4IZn6oHEsMKSPqOuLfD5HoAWEPTY=&quot;\r\n            },\r\n            {\r\n              &quot;hostname&quot;: &quot;gb5-wireguard&quot;,\r\n              &quot;ipv4_addr_in&quot;: &quot;141.98.252.222&quot;,\r\n              &quot;ipv6_addr_in&quot;: &quot;2a03:1b20:7:f011::a02f&quot;,\r\n              &quot;public_key&quot;: &quot;J57ba81Q8bigy9RXBXvl0DgABTrbl81nb37GuX50gnY=&quot;\r\n            },\r\n            {\r\n              &quot;hostname&quot;: &quot;gb-lon-wg-101&quot;,\r\n              &quot;ipv4_addr_in&quot;: &quot;146.70.119.66&quot;,\r\n              &quot;ipv6_addr_in&quot;: &quot;2001:ac8:31:f007::a39f&quot;,\r\n              &quot;public_key&quot;: &quot;MPZX0ZQtB5r1pmcvIcsAt1AMvenios2ICBz9rjbN/l4=&quot;\r\n            }\r\n          ]\r\n        },\r\n        {\r\n          &quot;name&quot;: &quot;Manchester&quot;,\r\n          &quot;code&quot;: &quot;mnc&quot;,\r\n          &quot;relays&quot;: [\r\n            {\r\n              &quot;hostname&quot;: &quot;gb45-wireguard&quot;,\r\n              &quot;ipv4_addr_in&quot;: &quot;146.70.133.34&quot;,\r\n              &quot;ipv6_addr_in&quot;: &quot;2001:ac8:8b:2b::a45f&quot;,\r\n              &quot;public_key&quot;: &quot;v+dOPx0FM8lGCjJ7m/7miWy67PGuazYYzvJoeMb97n4=&quot;\r\n            },\r\n            {\r\n              &quot;hostname&quot;: &quot;gb46-wireguard&quot;,\r\n              &quot;ipv4_addr_in&quot;: &quot;146.70.133.66&quot;,\r\n              &quot;ipv6_addr_in&quot;: &quot;2001:ac8:8b:2c::a46f&quot;,\r\n              &quot;public_key&quot;: &quot;2bciRobW0TPtjrZ2teilr+7PjyiBMUGfixvAKOE52Xo=&quot;\r\n            },\r\n            {\r\n              &quot;hostname&quot;: &quot;gb-mnc-wg-001&quot;,\r\n              &quot;ipv4_addr_in&quot;: &quot;146.70.133.98&quot;,\r\n              &quot;ipv6_addr_in&quot;: &quot;2001:ac8:8b:2d::a47f&quot;,\r\n              &quot;public_key&quot;: &quot;Q2khJLbTSFxmppPGHgq2HdxMQx7CczPZCgVpYZMoNnM=&quot;\r\n            }\r\n          ]\r\n        }\r\n      ]\r\n    },\r\n    {\r\n      &quot;name&quot;: &quot;USA&quot;,\r\n      &quot;code&quot;: &quot;us&quot;,\r\n      &quot;cities&quot;: [\r\n        {\r\n          &quot;name&quot;: &quot;New York, NY&quot;,\r\n          &quot;code&quot;: &quot;nyc&quot;,\r\n          &quot;relays&quot;: [\r\n            {\r\n              &quot;hostname&quot;: &quot;us97-wireguard&quot;,\r\n              &quot;ipv4_addr_in&quot;: &quot;86.106.143.210&quot;,\r\n              &quot;ipv6_addr_in&quot;: &quot;2a0d:5600:24:a94::a97f&quot;,\r\n              &quot;public_key&quot;: &quot;5fzEFqyRqc6qa1QPngIBK1gmWc0ex1Bpot/f6RqZPmc=&quot;\r\n            },\r\n            {\r\n              &quot;hostname&quot;: &quot;us98-wireguard&quot;,\r\n              &quot;ipv4_addr_in&quot;: &quot;86.106.143.223&quot;,\r\n              &quot;ipv6_addr_in&quot;: &quot;2a0d:5600:24:a95::a98f&quot;,\r\n              &quot;public_key&quot;: &quot;bo50ppMvVlNG4S6zqgd/J5l1Ce7Og89u+wR10OvJrQ4=&quot;\r\n            },\r\n            {\r\n              &quot;hostname&quot;: &quot;us99-wireguard&quot;,\r\n              &quot;ipv4_addr_in&quot;: &quot;86.106.143.236&quot;,\r\n              &quot;ipv6_addr_in&quot;: &quot;2a0d:5600:24:a96::a99f&quot;,\r\n              &quot;public_key&quot;: &quot;EPLh6pVel06dND8cE4Prix9GP4hGLYNhQhn5mSN2yzM=&quot;\r\n            }\r\n          ]\r\n        },\r\n        {\r\n          &quot;name&quot;: &quot;Seattle, WA&quot;,\r\n          &quot;code&quot;: &quot;sea&quot;,\r\n          &quot;relays&quot;: [\r\n            {\r\n              &quot;hostname&quot;: &quot;us274-wireguard&quot;,\r\n              &quot;ipv4_addr_in&quot;: &quot;138.199.43.78&quot;,\r\n              &quot;ipv6_addr_in&quot;: &quot;2a02:6ea0:d80b:2::b74f&quot;,\r\n              &quot;public_key&quot;: &quot;ujasJmDuU0t4y6JmBLrdDxakKuaHvPRupRDfyywSWyw=&quot;\r\n            },\r\n            {\r\n              &quot;hostname&quot;: &quot;us-sea-wg-001&quot;,\r\n              &quot;ipv4_addr_in&quot;: &quot;138.199.43.91&quot;,\r\n              &quot;ipv6_addr_in&quot;: &quot;2a02:6ea0:d80b:3::b75f&quot;,\r\n              &quot;public_key&quot;: &quot;bZQF7VRDRK/JUJ8L6EFzF/zRw2tsqMRk6FesGtTgsC0=&quot;\r\n            },\r\n            {\r\n              &quot;hostname&quot;: &quot;us-sea-wg-003&quot;,\r\n              &quot;ipv4_addr_in&quot;: &quot;138.199.43.65&quot;,\r\n              &quot;ipv6_addr_in&quot;: &quot;2a02:6ea0:d80b:1::b73f&quot;,\r\n              &quot;public_key&quot;: &quot;4ke8ZSsroiI6Sp23OBbMAU6yQmdF3xU2N8CyzQXE/Qw=&quot;\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/73913094/jq-select-random-object-from-each-array-and-only-return-certain-values-in-each",
        "title": "jq - Select Random object from each array and only return certain values in each object of filtered arrays"
    },
    {
        "tags": [
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 39208,
                    "reputation": 267964,
                    "user_id": 112968,
                    "user_type": "registered",
                    "accept_rate": 68,
                    "profile_image": "https://i.sstatic.net/zHTaT.png?s=256",
                    "display_name": "knittl",
                    "link": "https://stackoverflow.com/users/112968/knittl"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1664571202,
                "post_id": 73913849,
                "comment_id": 130510258,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 9145248,
                    "reputation": 43,
                    "user_id": 6801730,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/0baea9fc160a47568090f85c6489a5a1?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "qch2012",
                    "link": "https://stackoverflow.com/users/6801730/qch2012"
                },
                "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": 1664571799,
                "post_id": 73913849,
                "comment_id": 130510382,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1664573115,
                "last_edit_date": 1664573115,
                "creation_date": 1664571529,
                "answer_id": 73913898,
                "question_id": 73913849,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "A simple solution that prints the application in every row (not quite what you asked):\r\n\r\n```\r\n[&quot;Application&quot;, &quot;User&quot;, &quot;Access&quot;],\r\n[.application] + (.users[]|[.&quot;display-name&quot;,.access])\r\n| @tsv\r\n```\r\n\r\nor:\r\n\r\n```\r\n[&quot;Application&quot;, &quot;User&quot;, &quot;Access&quot;],\r\n(.application as $app | .users[] | [$app,.&quot;display-name&quot;,.access])\r\n| @tsv\r\n```\r\n\r\nOutput:\r\n\r\n```\r\nApplication\tUser\tAccess\r\ngrafana\tadmin\tadmin\r\ngrafana\tuser1\tread\r\ngrafana\tuser2\tedit\r\n```\r\n\r\nHere&#39;s a very crude way to have the application only printed for the first user. Im pretty sure there&#39;s a better way.\r\n\r\n```\r\n[&quot;Application&quot;, &quot;User&quot;, &quot;Access&quot;],\r\n(\r\n    .application as $app\r\n    | [.users[]]\r\n    | .[].application = null\r\n    | .[0].application = $app\r\n    | .[]\r\n    | [.application,.&quot;display-name&quot;,.access]\r\n)\r\n| @tsv\r\n```\r\n\r\nI wonder though if this is worth the effort, because parsing the TSV will then require additional extra rules instead of simply having app,name,access in each line. In other words: having the app only in the first line complicates the writing _and_ the reading part of the data",
                "title": "How to convert JSON to tsv format using jq"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1664573561,
                "creation_date": 1664573561,
                "answer_id": 73914130,
                "question_id": 73913849,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I&#39;d be tempted to use jq just to extract the raw tsv and the use another tool for the fine-tuning:\r\n```sh\r\njq -r &#39;[.application] + (.users[] | [.&quot;display-name&quot;, .access]) | @tsv&#39; file.json \\\r\n| awk &#39;\r\n    BEGIN {FS = OFS = &quot;\\t&quot;; print &quot;Application&quot;, &quot;user&quot;, &quot;Access&quot;}\r\n    NR &gt; 1 {$1 = &quot;&quot;}\r\n    {print}\r\n&#39; \\\r\n| column -ts $&#39;\\t&#39;\r\n```\r\n```none\r\nApplication  user   Access\r\ngrafana      admin  admin\r\n             user1  read\r\n             user2  edit\r\n```\r\nThis assumes you use GNU `column` and bash (for ASNI-C quoting `$&#39;\\t&#39;`)",
                "title": "How to convert JSON to tsv format using jq"
            },
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1664739691,
                "creation_date": 1664739691,
                "answer_id": 73928822,
                "question_id": 73913849,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "&gt; is there a way to only display application name in first row ?\r\n\r\nOne could utilize the facts that `transpose` compensates for a rigged matrix using `null` values, and that `@tsv` gracefully translates `null` values to empty strings:\r\n~~~sh\r\n[[&quot;Application&quot;], [&quot;User&quot;], [&quot;Access&quot;]],\r\n[[[.application]], [.users[] | [.&quot;display-name&quot;, .access]]]\r\n| transpose[] | flatten(1) | @tsv\r\n~~~\r\nThe same without butchering the headers array:\r\n~~~sh\r\n[&quot;Application&quot;, &quot;User&quot;, &quot;Access&quot;], (\r\n  [[[.application]], [.users[]|[.&quot;display-name&quot;,.access]]]\r\n  | transpose[] | flatten(1)\r\n) | @tsv\r\n~~~\r\n",
                "title": "How to convert JSON to tsv format using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 4,
        "last_activity_date": 1664739691,
        "creation_date": 1664571138,
        "question_id": 73913849,
        "body_markdown": "Given following json content ,  \r\n```\r\n{\r\n\t\r\n\t&quot;application&quot;: &quot;grafana&quot;,\r\n\t&quot;users&quot;: {\r\n\t    &quot;admin&quot;: {\r\n\t         &quot;display-name&quot;: &quot;admin&quot;,\r\n\t         &quot;access&quot;: &quot;admin&quot;\r\n\t    },\r\n\t    &quot;user1&quot;: {\r\n\t         &quot;display-name&quot;: &quot;user1&quot;,\r\n\t         &quot;access&quot;: &quot;read&quot;\r\n\t    },\r\n\t    &quot;user2&quot;: {\r\n\t         &quot;display-name&quot;: &quot;user2&quot;,\r\n\t         &quot;access&quot;: &quot;edit&quot;\r\n\t    }\r\n\t}\r\n}\r\n```\r\n\r\nI want to produce tsv format like following :\r\n\r\n```\r\nApplication  User   Access\r\ngrafana      admin  admin\r\n             user1  read\r\n             user2  edit\r\n```\r\nHow can I use jq @tsv to achieve that ?  ",
        "link": "https://stackoverflow.com/questions/73913849/how-to-convert-json-to-tsv-format-using-jq",
        "title": "How to convert JSON to tsv format using jq"
    },
    {
        "tags": [
            "bash",
            "curl",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1664600033,
                "creation_date": 1664600033,
                "answer_id": 73915898,
                "question_id": 73915736,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Just separate them with commas:\r\n\r\n```\r\nurl &quot;https://www.somewebsite.com&quot; | jq -r &#39;.parent | .field_1, .field_2&#39;\r\n```\r\n",
                "title": "How to get more than one json element from a cURL call using jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -1,
        "last_activity_date": 1664600033,
        "creation_date": 1664597192,
        "question_id": 73915736,
        "body_markdown": "I am trying to gather multiple json fields from a curl call in the command line. I have only been able to get one field at a time, each time it requires me to redo the curl call. For example, if there are two fields `field_1` and `field_2` under a `parent` field, I am having to do:\r\n\r\n\r\n    curl &quot;https://www.somewebsite.com&quot; | jq -r &#39;.parent | .field_1&#39;\r\n\r\nand\r\n\r\n    curl &quot;https://www.somewebsite.com&quot; | jq -r &#39;.parent | .field_2&#39;\r\n\r\nwhich is inefficient since the curl call already contains all piece of information. How can I gather both fields in just one curl call?",
        "link": "https://stackoverflow.com/questions/73915736/how-to-get-more-than-one-json-element-from-a-curl-call-using-jq",
        "title": "How to get more than one json element from a cURL call using jq?"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1664602283,
                "creation_date": 1664602283,
                "answer_id": 73916040,
                "question_id": 73915896,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "This produces 12 for your sample input:\r\n``` none\r\n[.main[][] | length] | add\r\n```\r\n&lt;sup&gt;[Online demo](https://jqplay.org/s/7cSBsnzj34Y)&lt;/sup&gt;",
                "title": "How to use jq to count all instances of a field that is nested numerically in an array?"
            },
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1664607941,
                "creation_date": 1664607941,
                "answer_id": 73916427,
                "question_id": 73915896,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You could count all scalars in the document:\r\n~~~\r\njq &#39;[..|scalars] | length&#39;\r\n~~~\r\n[Demo](https://jqplay.org/s/3BPM3wgqZ8o)\r\n\r\nIf you just want to consider the tree under `.main`, prepend it:\r\n~~~\r\njq &#39;.main | [..|scalars] | length&#39;\r\n~~~\r\n[Demo](https://jqplay.org/s/DOjteav9sgC)\r\n\r\nIf there&#39;s many elements and you don&#39;t want to buid up an intermediate array, only needed to take its length from, count on the fly using `reduce`:\r\n~~~\r\njq &#39;reduce (..|scalars) as $_ (0; .+1)&#39;\r\n~~~\r\n[Demo](https://jqplay.org/s/nkOYJEDwy5x)\r\n",
                "title": "How to use jq to count all instances of a field that is nested numerically in an array?"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1664696832,
                "last_edit_date": 1664696832,
                "creation_date": 1664608838,
                "answer_id": 73916508,
                "question_id": 73915896,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Double map + length + add:\r\n\r\n```\r\n.main|map(map(length)|add)|add\r\n```\r\n\r\nOr\r\n\r\n```\r\n.main|map(map(length))|add|add\r\n```\r\n\r\nOr stream all values first, wrap in array and get array length (this is probably the &lt;s&gt;sexiest&lt;/s&gt; shortest, but not very memory-efficient): \r\n\r\n```\r\n[.main[][][]]|length\r\n```\r\n\r\nIf memory is an issue or you have a huge number of elements, use `reduce` as suggested by @peak in another answer",
                "title": "How to use jq to count all instances of a field that is nested numerically in an array?"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1664623638,
                "creation_date": 1664623638,
                "answer_id": 73917932,
                "question_id": 73915896,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "It might not matter in many cases, but constructing arrays just for the sake of counting is inefficient. In any case, it’s nice to have the following stream-oriented def in your quiver:\r\n\r\n    def count(s): reduce s as $_ (0; .+1);\r\n\r\nWith that, you can e.g. write:\r\n\r\n    count(.main[][][])",
                "title": "How to use jq to count all instances of a field that is nested numerically in an array?"
            }
        ],
        "is_answered": true,
        "answer_count": 4,
        "score": 0,
        "last_activity_date": 1664696832,
        "creation_date": 1664600023,
        "last_edit_date": 1664601223,
        "question_id": 73915896,
        "body_markdown": "I have a json structure that looks like:\r\n\r\n    {  \r\n       &quot;main&quot;:[  \r\n          {  \r\n                &quot;0&quot;:[ {&quot;0&quot;:&quot;...&quot;},{&quot;1&quot;:&quot;...&quot;},{&quot;2&quot;:&quot;...&quot;},{&quot;3&quot;:&quot;...&quot;} ]\r\n          },\r\n          {  \r\n                &quot;1&quot;:[ {&quot;0&quot;:&quot;...&quot;},{&quot;1&quot;:&quot;...&quot;},{&quot;2&quot;:&quot;...&quot;} ]\r\n          },\r\n          {  \r\n                &quot;2&quot;:[ {&quot;0&quot;:&quot;...&quot;},{&quot;1&quot;:&quot;...&quot;},{&quot;2&quot;:&quot;...&quot;},{&quot;3&quot;:&quot;...&quot;},{&quot;4&quot;:&quot;...&quot;} ]\r\n          }\r\n        ]\r\n    }\r\n\r\nWhat I would like is to be able to count the total number of elements within each direct child of `&quot;main&quot;`. For example, in the above, `&quot;main&quot;` has an array containing 3 direct childs, `&quot;0&quot;, &quot;1&quot;, &quot;2&quot;`. For `&quot;0&quot;`, we have 4 such elements, `&quot;1&quot;` we have 3 such elements, and `&quot;2&quot;` we have 5 such elements.\r\n\r\nIs there a way to use `jq` to return `12` as the final answer for the above?",
        "link": "https://stackoverflow.com/questions/73915896/how-to-use-jq-to-count-all-instances-of-a-field-that-is-nested-numerically-in-an",
        "title": "How to use jq to count all instances of a field that is nested numerically in an array?"
    },
    {
        "tags": [
            "recursion",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1664613283,
                "last_edit_date": 1664613283,
                "creation_date": 1664611961,
                "answer_id": 73916779,
                "question_id": 73916663,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can use `recurse` to traverse the document, `INDEX` to create an object with IDs as keys, `map_values` to format their values using `select` to reduce according to your criteria.\r\n\r\n~~~sh\r\njq --arg type A &#39;\r\n  .references |= (\r\n    INDEX(.[] | recurse(.referencing[]?); .id)\r\n    | map_values(select(.objType == $type) | {version})\r\n  )\r\n&#39;\r\n~~~\r\n~~~json\r\n{\r\n  &quot;references&quot;: {\r\n    &quot;id1&quot;: {\r\n      &quot;version&quot;: 5\r\n    },\r\n    &quot;id4&quot;: {\r\n      &quot;version&quot;: 2\r\n    }\r\n  }\r\n}\r\n~~~\r\n[Demo](https://jqplay.org/s/1qM837mpov8)\r\n\r\nThis works for both questions, provide `A` or `B` to `--arg type`.\r\n\r\nNote that this is using the error suppression operator `?` when recursing down. If you want to restrict the traversal explicitly to `.objType == &quot;B&quot;`, just prepend it in a `select` expression, i.e. replace `recurse(.referencing[]?)` with `recurse(select(.objType == &quot;B&quot;) | .referencing[])`. [Demo](https://jqplay.org/s/t512claPIjW)",
                "title": "Using jq to conditionally flatten recursive json"
            },
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1664612335,
                "last_edit_date": 1664612335,
                "creation_date": 1664611973,
                "answer_id": 73916782,
                "question_id": 73916663,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Use [recursive decsent](https://stedolan.github.io/jq/manual/v1.6/#RecursiveDescent:..) operator and [from_entries](https://stedolan.github.io/jq/manual/v1.6/#to_entries,from_entries,with_entries). You don&#39;t need to follow the &quot;references&quot; (at least not to produce the expected output in your question)\r\n\r\n```json\r\n{\r\n    dependencies: [.. | select(.objType==&quot;A&quot;)? | { key: .id, value: {version} }] | from_entries\r\n},\r\n{\r\n    dependencies: [.. | select(.objType==&quot;B&quot;)? | { key: .id, value: {version} }] | from_entries\r\n}\r\n```\r\n\r\nOutput:\r\n```\r\n{\r\n  &quot;dependencies&quot;: {\r\n    &quot;id1&quot;: {\r\n      &quot;version&quot;: 5\r\n    },\r\n    &quot;id4&quot;: {\r\n      &quot;version&quot;: 2\r\n    }\r\n  }\r\n}\r\n{\r\n  &quot;dependencies&quot;: {\r\n    &quot;id2&quot;: {\r\n      &quot;version&quot;: 4\r\n    },\r\n    &quot;id3&quot;: {\r\n      &quot;version&quot;: 4\r\n    },\r\n    &quot;id5&quot;: {\r\n      &quot;version&quot;: 3\r\n    }\r\n  }\r\n}\r\n```\r\n\r\nIt&#39;s also possible to merge ([add](https://stedolan.github.io/jq/manual/v1.6/#add)) objects instead of constructing them from their entries, which makes the code minimally shorter:\r\n\r\n```\r\n{\r\n    dependencies: [.. | select(.objType==&quot;A&quot;)? | { (.id): {version} }] | add\r\n}\r\n```",
                "title": "Using jq to conditionally flatten recursive json"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1664613283,
        "creation_date": 1664610650,
        "question_id": 73916663,
        "body_markdown": "The simplest version of the input document I could come up with is\r\n\r\n    {\r\n        &quot;references&quot;: [\r\n            {\r\n                &quot;version&quot;: 5,\r\n                &quot;id&quot;: &quot;id1&quot;,\r\n                &quot;objType&quot;: &quot;A&quot;\r\n            },\r\n            {\r\n                &quot;version&quot;: 4,\r\n                &quot;id&quot;: &quot;id2&quot;,\r\n                &quot;objType&quot;: &quot;B&quot;,\r\n                &quot;referencing&quot;: []\r\n            },\r\n            {\r\n                &quot;version&quot;: 4,\r\n                &quot;id&quot;: &quot;id3&quot;,\r\n                &quot;objType&quot;: &quot;B&quot;,\r\n                &quot;referencing&quot;: [\r\n                    {\r\n                        &quot;version&quot;: 2,\r\n                        &quot;id&quot;: &quot;id4&quot;,\r\n                        &quot;objType&quot;: &quot;A&quot;\r\n                    },\r\n                    {\r\n                        &quot;version&quot;: 3,\r\n                        &quot;id&quot;: &quot;id5&quot;,\r\n                        &quot;objType&quot;: &quot;B&quot;,\r\n                        &quot;referencing&quot;: []\r\n                    }\r\n                ]\r\n            }\r\n        ]\r\n    }\r\n\r\nObjects of type A have no referencing objects.\r\n\r\nObjects of type B can be referenced by either type of object.\r\n\r\nThere are two outputs I need from this json:\r\n\r\nOutput #1 is the version info for objects of type A with the `id` value as a key with the value of `version`. `A` objects can be at the top level or at some arbitrary depth in the `referencing` arrays.\r\n\r\n    {\r\n        &quot;references&quot;: {\r\n            &quot;id1&quot;: {&quot;version&quot;: 5},\r\n            &quot;id4&quot;: {&quot;version&quot;: 2}\r\n        }\r\n    }\r\n\r\nThe 2nd output is similar: the version info for objects of type B. The can be a chain of type `B` objects referencing other type `B` objects.\r\n\r\n    {\r\n        &quot;references&quot;: {\r\n            &quot;id2&quot;: {&quot;version&quot;: 4},\r\n            &quot;id3&quot;: {&quot;version&quot;: 4},\r\n            &quot;id5&quot;: {&quot;version&quot;: 3}\r\n        }\r\n    } \r\n\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/73916663/using-jq-to-conditionally-flatten-recursive-json",
        "title": "Using jq to conditionally flatten recursive json"
    },
    {
        "tags": [
            "json",
            "unique",
            "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": 1664615381,
                "post_id": 73917096,
                "comment_id": 130515547,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "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": 1664616508,
                "post_id": 73917096,
                "comment_id": 130515718,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "reply_to_user": {
                    "account_id": 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": 2,
                "creation_date": 1664618184,
                "post_id": 73917096,
                "comment_id": 130515970,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "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"
                },
                "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": 1664618966,
                "post_id": 73917096,
                "comment_id": 130516091,
                "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": 1708888281,
                "post_id": 73917096,
                "comment_id": 137609481,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1664615659,
                "creation_date": 1664615659,
                "answer_id": 73917126,
                "question_id": 73917096,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Just provide to `unique_by` an array with everything included, so that the array must become unique:\r\n~~~sh\r\njq &#39;unique_by([.name, .url])&#39;\r\n~~~\r\n~~~json\r\n[\r\n  {\r\n    &quot;name&quot;: &quot;abc&quot;,\r\n    &quot;url&quot;: &quot;https://aa.com&quot;,\r\n    &quot;created_at&quot;: &quot;2022-09-30T11:17:33.181Z&quot;\r\n  },\r\n  {\r\n    &quot;name&quot;: &quot;bb&quot;,\r\n    &quot;url&quot;: &quot;https://ddd.com&quot;,\r\n    &quot;created_at&quot;: &quot;2022-09-30T11:14:33.180Z&quot;\r\n  }\r\n]\r\n~~~\r\n[Demo](https://jqplay.org/s/M-FQMAGp4iO)",
                "title": "jq get unique value from two keys"
            },
            {
                "up_vote_count": 5,
                "is_accepted": false,
                "score": 5,
                "last_activity_date": 1664615717,
                "creation_date": 1664615717,
                "answer_id": 73917134,
                "question_id": 73917096,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Collect the criteria into an array:\r\n\r\n    unique_by([.name, .url]) ",
                "title": "jq get unique value from two keys"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 4,
        "last_activity_date": 1680806224,
        "creation_date": 1664615254,
        "last_edit_date": 1680806224,
        "question_id": 73917096,
        "body_markdown": "I know to get a unique from one key - `unique_by(&#39;.[].name)`\r\n\r\nI want to get output by checking for unique values in two keys\r\n\r\nbut how to do for two keys like `unique_by(&#39;.[].name,.[].url&#39;)`  and return the input along with other keys?\r\n\r\n\r\n#input\r\n\r\n    [\r\n      {\r\n        &quot;name&quot;: &quot;abc&quot;,\r\n        &quot;url&quot;: &quot;https://aa.com&quot;,\r\n        &quot;created_at&quot;: &quot;2022-09-30T11:17:33.181Z&quot;\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;bb&quot;,\r\n        &quot;url&quot;: &quot;https://ddd.com&quot;,\r\n        &quot;created_at&quot;: &quot;2022-09-30T11:14:33.180Z&quot;\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;abc&quot;,\r\n        &quot;url&quot;: &quot;https://aa.com&quot;,\r\n        &quot;created_at&quot;: &quot;2022-09-30T11:14:33.180Z&quot;\r\n      }\r\n    ]\r\n\r\n\r\n#expected output\r\n\r\n    [\r\n      {\r\n        &quot;name&quot;: &quot;abc&quot;,\r\n        &quot;url&quot;: &quot;https://aa.com&quot;,\r\n        &quot;created_at&quot;: &quot;2022-09-30T11:17:33.181Z&quot;\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;bb&quot;,\r\n        &quot;url&quot;: &quot;https://ddd.com&quot;,\r\n        &quot;created_at&quot;: &quot;2022-09-30T11:14:33.180Z&quot;\r\n      }\r\n    ]",
        "link": "https://stackoverflow.com/questions/73917096/jq-get-unique-value-from-two-keys",
        "title": "jq get unique value from two keys"
    },
    {
        "tags": [
            "json",
            "python-3.x",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1664780352,
                "last_edit_date": 1664780352,
                "creation_date": 1664777754,
                "answer_id": 73931705,
                "question_id": 73931572,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Variables are intended to be used for _values_, not for jq expressions (at least not directly).\r\n\r\nI think the easiest option here is to go for an fstring:\r\n\r\n    match = pyjq.all(f&#39;.[]|select({query}==$value)&#39;, records, vars={&quot;value&quot;: value})\r\n\r\nand it probably makes sense to prepend the period inside the fstring:\r\n\r\n    match = pyjq.all(f&#39;.[]|select(.{key}==$value)&#39;, records, vars={&quot;value&quot;: value})",
                "title": "pyjq - how to use &quot;select&quot; with both query and value as variables"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1664785737,
        "creation_date": 1664776738,
        "last_edit_date": 1664785737,
        "question_id": 73931572,
        "body_markdown": "I am writing a code in python3 where i am struggling with usage of variables with &quot;pyjq&quot;, the code works without variables but variables are not getting parsed inside pyjq.\r\n\r\nThe documentation referred is https://github.com/doloopwhile/pyjq/blob/master/README.md#api\r\n\r\nPlease check the code given below and suggest - \r\n\r\nMy code\r\n```\r\nimport json, os\r\nimport pyjq\r\nfrom flask import Flask, request, jsonify\r\n\r\ndef query_records():\r\n    args = {&quot;meta.antivirus.enabled&quot;: &quot;true&quot;}\r\n    for key, value in args.items():\r\n      with open(&#39;/tmp/data.txt&#39;, &#39;r&#39;) as f:\r\n          print (key)\r\n          print (value)\r\n          data = f.read()\r\n          records = json.loads(data)\r\n          query = (&quot;.&quot; + key)\r\n          print (query)\r\n#jq &#39;.[]|select(.meta.antivirus.enabled==&quot;true&quot;)&#39; filename.json works,issue with variable substitution in python\r\n          match = pyjq.all(&#39;.[]|select([&quot;$query&quot;]==$value)&#39;, records, vars={&quot;value&quot;: value,&quot;query&quot;: query})\r\n          print (match)\r\nquery_records()\r\n```\r\nContent of file &quot;/tmp/data.txt&quot;\r\n```\r\n[\r\n  {\r\n    &quot;name&quot;: &quot;alpharetta&quot;,\r\n    &quot;meta&quot;: {\r\n      &quot;antivirus&quot;: {\r\n        &quot;enabled&quot;: &quot;true&quot;\r\n      },\r\n      &quot;limits&quot;: {\r\n        &quot;cpu&quot;: {\r\n          &quot;enabled&quot;: &quot;true&quot;,\r\n          &quot;value&quot;: &quot;250m&quot;\r\n        }\r\n      }\r\n    }\r\n  },\r\n  {\r\n    &quot;meta&quot;: {\r\n      &quot;allergens&quot;: {\r\n        &quot;eggs&quot;: &quot;true&quot;,\r\n        &quot;nuts&quot;: &quot;false&quot;,\r\n        &quot;seafood&quot;: &quot;false&quot;\r\n      },\r\n      &quot;calories&quot;: 230,\r\n      &quot;carbohydrates&quot;: {\r\n        &quot;dietary-fiber&quot;: &quot;4g&quot;,\r\n        &quot;sugars&quot;: &quot;1g&quot;\r\n      },\r\n      &quot;fats&quot;: {\r\n        &quot;saturated-fat&quot;: &quot;0g&quot;,\r\n        &quot;trans-fat&quot;: &quot;1g&quot;\r\n      }\r\n    },\r\n    &quot;name&quot;: &quot;sandwich-nutrition&quot;\r\n  },\r\n  {\r\n    &quot;meta&quot;: {\r\n      &quot;allergens&quot;: {\r\n        &quot;eggs&quot;: &quot;true&quot;,\r\n        &quot;nuts&quot;: &quot;false&quot;,\r\n        &quot;seafood&quot;: &quot;true&quot;\r\n      },\r\n      &quot;calories&quot;: 440,\r\n      &quot;carbohydrates&quot;: {\r\n        &quot;dietary-fiber&quot;: &quot;4g&quot;,\r\n        &quot;sugars&quot;: &quot;2g&quot;\r\n      },\r\n      &quot;fats&quot;: {\r\n        &quot;saturated-fat&quot;: &quot;0g&quot;,\r\n        &quot;trans-fat&quot;: &quot;1g&quot;\r\n      }\r\n    },\r\n    &quot;name&quot;: &quot;random-nutrition&quot;\r\n  }\r\n]\r\n```\r\nExpected output(which works without variables)\r\n```\r\n{\r\n    &quot;name&quot;: &quot;alpharetta&quot;,\r\n    &quot;meta&quot;: {\r\n      &quot;antivirus&quot;: {\r\n        &quot;enabled&quot;: &quot;true&quot;\r\n      },\r\n      &quot;limits&quot;: {\r\n        &quot;cpu&quot;: {\r\n          &quot;enabled&quot;: &quot;true&quot;,\r\n          &quot;value&quot;: &quot;250m&quot;\r\n        }\r\n      }\r\n    }\r\n  }\r\n```\r\n\r\nCurrent output ``[]``\r\n\r\nseems like some issue with variables not being passed in case of &quot;query&quot; , help would be appreciated.\r\n\r\nEdit 1\r\nIt works if I hardcode &quot;query&quot; - \r\n```match = pyjq.all(&#39;.[]|select(.meta.antivirus.enabled==$value)&#39;, records, vars={&quot;value&quot;: value,&quot;query&quot;: query})```\r\n\r\nbut not vice-versa\r\n\r\nwhich probably narrows it down to issue with the variable &quot;query&quot;\r\n\r\n**JQ is not a necessity and I can use other libraries too,given that json is returned**",
        "link": "https://stackoverflow.com/questions/73931572/pyjq-how-to-use-select-with-both-query-and-value-as-variables",
        "title": "pyjq - how to use &quot;select&quot; with both query and value as variables"
    },
    {
        "tags": [
            "json",
            "bash",
            "curl",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 32384,
                    "reputation": 127026,
                    "user_id": 89817,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/df253c3b6533949ea94f31f328f3e769?s=256&d=identicon&r=PG",
                    "display_name": "Gordon Davisson",
                    "link": "https://stackoverflow.com/users/89817/gordon-davisson"
                },
                "edited": false,
                "score": 3,
                "creation_date": 1664844142,
                "post_id": 73942028,
                "comment_id": 130558978,
                "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": 6,
                "creation_date": 1664846586,
                "post_id": 73942028,
                "comment_id": 130559328,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 4272484,
                    "reputation": 1104,
                    "user_id": 3493998,
                    "user_type": "registered",
                    "accept_rate": 94,
                    "profile_image": "https://i.sstatic.net/5e2wt.jpg?s=256",
                    "display_name": "Ismoh",
                    "link": "https://stackoverflow.com/users/3493998/ismoh"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1664880087,
                "post_id": 73942028,
                "comment_id": 130566354,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 4272484,
                    "reputation": 1104,
                    "user_id": 3493998,
                    "user_type": "registered",
                    "accept_rate": 94,
                    "profile_image": "https://i.sstatic.net/5e2wt.jpg?s=256",
                    "display_name": "Ismoh",
                    "link": "https://stackoverflow.com/users/3493998/ismoh"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1664896058,
                "post_id": 73942028,
                "comment_id": 130572154,
                "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": 1664912133,
                "post_id": 73942028,
                "comment_id": 130577142,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1704488146,
                "last_edit_date": 1704488146,
                "creation_date": 1664904000,
                "answer_id": 73951473,
                "question_id": 73942028,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s how to build that JSON with jq:\r\n\r\n```\r\nbody=&quot;\\&quot;\\:warning\\: \\:exclamation\\: Your pull request is not linked to any issue, please make the corresponding changes in the very first comments body by adding \\&#39;Fixes #issue-number\\&#39; or \\&#39;Resolves #issue-number\\&#39;. If your pull request isn\\&#39;t linked to any issue, ignore this comment\\!\\&quot;&quot;\r\njson=&quot;$(jq -n --arg body &quot;$body&quot; &#39;{ $body }&#39;)&quot;\r\n# or: json=$(printf &#39;%s\\n&#39; &quot;$body&quot; | jq -R &#39;{ body: . }&#39;)\r\n```\r\n\r\nI doubt that all that escaping above is actually necessary – why escape a colon, an exclamation mark or a single quote? But it might be that the API expects these character quoted; I don&#39;t see why though, since it consumes JSON. Best bet is probably to get rid of all the backslashes above when assigning body (except the ones before `&quot;`).\r\n\r\nHere&#39;s how to correctly expand a variable which contains whitespace, for instance when using it as payload for a curl command (note the quotes around the variable). Variables should _always_ be quoted, unless you know 110% what you are doing:\r\n\r\n```\r\ncurl -X POST \\\r\n -H &#39;Accept: application/vnd.github+json&#39; \\\r\n -H &#39;Authorization: token ****&#39; \\\r\n -H &#39;Content-Type: application/json&#39; \\\r\n https://api.github.com/repos/Ismoh/NoitaMP/issues/79/comments \\\r\n -d &quot;$json&quot;\r\n```\r\n\r\nUseful resources:\r\n\r\n* [jq 1.6 Manual](https://stedolan.github.io/jq/manual/v1.6/)\r\n* [jq wiki](https://github.com/stedolan/jq/wiki)\r\n* [jq FAQ](https://github.com/stedolan/jq/wiki/FAQ)\r\n* [jq cookbook](https://github.com/stedolan/jq/wiki/Cookbook)\r\n* [Advanced topics](https://github.com/stedolan/jq/wiki/Advanced-Topics)\r\n* [A stream-oriented introduction to jq](https://github.com/pkoppstein/jq/wiki/A-Stream-oriented-Introduction-to-jq)",
                "title": "How to string concatenate on bash and send it as json with curl?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1704488146,
        "creation_date": 1664843197,
        "last_edit_date": 1664912106,
        "question_id": 73942028,
        "body_markdown": "This is what I am trying to get working:\r\n```\r\nbody=&quot;\\&quot;\\:warning\\: \\:exclamation\\: Your pull request is not linked to any issue, please make the corresponding changes in the very first comments body by adding \\&#39;Fixes #issue-number\\&#39; or \\&#39;Resolves #issue-number\\&#39;. If your pull request isn\\&#39;t linked to any issue, ignore this comment\\!\\&quot;&quot;\r\necho $body\r\njson=&quot;&#39;{\\&quot;body\\&quot;: ${body} }&#39;&quot;\r\necho $json\r\nstatusCode=`curl -X POST -H &#39;Accept: application/vnd.github+json&#39; -H &#39;Authorization: token ****&#39; -H &#39;Content-Type: application/json&#39; https://api.github.com/repos/Ismoh/NoitaMP/issues/79/comments -d $json`\r\necho &quot;statusCode=&quot;$statusCode\r\n```\r\necho $body:\r\n```\r\n$ echo $body\r\n&quot;\\:warning\\: \\:exclamation\\: Your pull request is not linked to any issue, please make the corresponding changes in the very first comments body by adding \\&#39;Fixes #issue-number\\&#39; or \\&#39;Resolves #issue-number\\&#39;. If your pull request isn\\&#39;t linked to any issue, ignore this comment\\!&quot;\r\n```\r\necho $json\r\n```\r\n$ echo $json\r\n&#39;{&quot;body&quot;: &quot;\\:warning\\: \\:exclamation\\: Your pull request is not linked to any issue, please make the corresponding changes in the very first comments body by adding \\&#39;Fixes #issue-number\\&#39; or \\&#39;Resolves #issue-number\\&#39;. If your pull request isn\\&#39;t linked to any issue, ignore this comment\\!&quot; }&#39;\r\n```\r\ncurl\r\n```\r\n$ curl -X POST -H &#39;Accept: application/vnd.github+json&#39; -H &#39;Authorization: token ****&#39; -H &#39;Content-Type: application/json\r\n&#39; https://api.github.com/repos/Ismoh/NoitaMP/issues/79/comments -d $json\r\n{\r\n  &quot;message&quot;: &quot;Problems parsing JSON&quot;,\r\n  &quot;documentation_url&quot;: &quot;https://docs.github.com/rest/reference/issues#create-an-issue-comment&quot;\r\n}\r\ncurl: (3) URL using bad/illegal format or missing URL\r\ncurl: (3) URL using bad/illegal format or missing URL\r\ncurl: (6) Could not resolve host: Your\r\ncurl: (6) Could not resolve host: pull\r\ncurl: (6) Could not resolve host: request\r\ncurl: (6) Could not resolve host: is\r\ncurl: (6) Could not resolve host: not\r\ncurl: (6) Could not resolve host: linked\r\ncurl: (6) Could not resolve host: to\r\ncurl: (6) Could not resolve host: any\r\ncurl: (6) Could not resolve host: issue,\r\ncurl: (6) Could not resolve host: please\r\ncurl: (6) Could not resolve host: make\r\ncurl: (6) Could not resolve host: the\r\ncurl: (6) Could not resolve host: corresponding\r\ncurl: (6) Could not resolve host: changes\r\ncurl: (6) Could not resolve host: in\r\ncurl: (6) Could not resolve host: the\r\ncurl: (6) Could not resolve host: very\r\ncurl: (6) Could not resolve host: first\r\ncurl: (6) Could not resolve host: comments\r\ncurl: (6) Could not resolve host: body\r\ncurl: (6) Could not resolve host: by\r\ncurl: (6) Could not resolve host: adding\r\ncurl: (6) Could not resolve host: \\&#39;Fixes\r\ncurl: (3) URL using bad/illegal format or missing URL\r\ncurl: (6) Could not resolve host: or\r\ncurl: (6) Could not resolve host: \\&#39;Resolves\r\ncurl: (3) URL using bad/illegal format or missing URL\r\ncurl: (6) Could not resolve host: If\r\ncurl: (6) Could not resolve host: your\r\ncurl: (6) Could not resolve host: pull\r\ncurl: (6) Could not resolve host: request\r\ncurl: (6) Could not resolve host: isn\\&#39;t\r\ncurl: (6) Could not resolve host: linked\r\ncurl: (6) Could not resolve host: to\r\ncurl: (6) Could not resolve host: any\r\ncurl: (6) Could not resolve host: issue,\r\ncurl: (6) Could not resolve host: ignore\r\ncurl: (6) Could not resolve host: this\r\ncurl: (6) Could not resolve host: comment\\!&quot;\r\ncurl: (3) unmatched close brace/bracket in URL position 1:\r\n}&#39;\r\n```\r\n\r\n[GitHub API Docs][1] shows the json data as following:\r\n```\r\ncurl \\\r\n  -X POST \\\r\n  -H &quot;Accept: application/vnd.github+json&quot; \\\r\n  -H &quot;Authorization: Bearer &lt;YOUR-TOKEN&gt;&quot; \\\r\n  https://api.github.com/repos/OWNER/REPO/issues/ISSUE_NUMBER/comments \\\r\n  -d &#39;{&quot;body&quot;:&quot;Me too&quot;}&#39;\r\n```\r\n\r\nIs anyone out there, who can tell me what I am doing wrong?\r\n\r\nIs there a better way to escape string for json usage? I already tried out `jq -Rsa .`, but didn&#39;t work either.\r\n\r\n  [1]: https://docs.github.com/en/rest/issues/comments#create-an-issue-comment",
        "link": "https://stackoverflow.com/questions/73942028/how-to-string-concatenate-on-bash-and-send-it-as-json-with-curl",
        "title": "How to string concatenate on bash and send it as json with curl?"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1664869419,
                "creation_date": 1664869419,
                "answer_id": 73944556,
                "question_id": 73944354,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "It seems that&#39;s because you&#39;re using `inputs` with `--stream`.\r\n\r\n```bash\r\n$ echo &#39;[{&quot;id&quot;:482,&quot;a&quot;:&quot;2&quot;,&quot;b&quot;:1},{&quot;id&quot;:483,&quot;a&quot;:&quot;3&quot;,&quot;b&quot;:2}]&#39; \\\r\n| jq  -c --stream &#39;inputs&#39;\r\n[[0,&quot;a&quot;],&quot;2&quot;]\r\n[[0,&quot;b&quot;],1]\r\n[[0,&quot;b&quot;]]\r\n[[1,&quot;id&quot;],483]\r\n[[1,&quot;a&quot;],&quot;3&quot;]\r\n[[1,&quot;b&quot;],2]\r\n[[1,&quot;b&quot;]]\r\n[[1]]\r\n```\r\nUsing `.` seems better, but I&#39;m not sure what you&#39;re after:\r\n```bash\r\n$ echo &#39;[{&quot;id&quot;:482,&quot;a&quot;:&quot;2&quot;,&quot;b&quot;:1},{&quot;id&quot;:483,&quot;a&quot;:&quot;3&quot;,&quot;b&quot;:2}]&#39; \\\r\n| jq  -c --stream &#39;. as $i | (1 | truncate_stream($i))&#39;\r\n[[&quot;id&quot;],482]\r\n[[&quot;a&quot;],&quot;2&quot;]\r\n[[&quot;b&quot;],1]\r\n[[&quot;b&quot;]]\r\n[[&quot;id&quot;],483]\r\n[[&quot;a&quot;],&quot;3&quot;]\r\n[[&quot;b&quot;],2]\r\n[[&quot;b&quot;]]\r\n```",
                "title": "jq streaming eats first element, why?"
            },
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1664870419,
                "creation_date": 1664870419,
                "answer_id": 73944754,
                "question_id": 73944354,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Use the `--null-input` (or `-n`) flag. That way the standard input is set to `null`, and `inputs` can fetch all actual inputs.\r\n~~~sh\r\njq -cn --stream &quot;fromstream(1|truncate_stream(inputs))&quot;\r\n~~~\r\n~~~json\r\n{&quot;id&quot;:482,&quot;a&quot;:&quot;2&quot;,&quot;b&quot;:1}\r\n{&quot;id&quot;:483,&quot;a&quot;:&quot;3&quot;,&quot;b&quot;:2}\r\n~~~",
                "title": "jq streaming eats first element, why?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1664870419,
        "creation_date": 1664868215,
        "question_id": 73944354,
        "body_markdown": "When using jq in streaming mode (because 100 GB file) it eats the first element. How can I avoid that? \r\n```\r\necho [{&quot;id&quot;:482,&quot;a&quot;:&quot;2&quot;,&quot;b&quot;:1},{&quot;id&quot;:483,&quot;a&quot;:&quot;3&quot;,&quot;b&quot;:2}] | jq  -c --stream &quot;fromstream(1|truncate_stream(inputs))&quot;\r\n```\r\nOutput is \r\n```\r\n{&quot;a&quot;:&quot;2&quot;,&quot;b&quot;:1}\r\n{&quot;id&quot;:483,&quot;a&quot;:&quot;3&quot;,&quot;b&quot;:2}\r\n```\r\nThe first element (id) is missing from the first array element.\r\n \r\nThis is jq version 1.6. It is on Windows 2010, but the same behaviour is also on jq 1.6 on Ubuntu 22.04. \r\n\r\nThanks\r\n\r\n",
        "link": "https://stackoverflow.com/questions/73944354/jq-streaming-eats-first-element-why",
        "title": "jq streaming eats first element, why?"
    },
    {
        "tags": [
            "linux",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1664874768,
                "creation_date": 1664874768,
                "answer_id": 73945590,
                "question_id": 73945485,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If in your source document `.is_superuser` is a boolean value, your `select` expression should read `select(.is_superuser == true)` (which can be abbreviated as `select(.is_superuser)`), and not `select(.is_superuser == &quot;true&quot;)` (which makes a comparison to the literal string `&quot;true&quot;`).\r\n~~~sh\r\n.User[]\r\n| select(.is_superuser)\r\n| {Username: .username, Full_name: .full_name, Superuser: .is_superuser, Active: .is_active}\r\n~~~\r\n\r\nAlso note that this does not create a CSV output. For that you&#39;d need to generate an array for each record (e.g. `[.username, .full_name, .is_active]`), and apply `@csv` to it.",
                "title": "JQ how to filter an output"
            },
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1664876712,
                "last_edit_date": 1664876712,
                "creation_date": 1664875752,
                "answer_id": 73945810,
                "question_id": 73945485,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If you want to filter on the property `is_superuser`, you need to apply the `select` filter before transforming the object to a new structure:\r\n\r\n```\r\n.User[]\r\n| select(.is_superuser)\r\n| {Username: .username, Full_name: .full_name, Superuser: .is_superuser, Active: .is_active}\r\n```\r\n\r\nor, if you want to filter the newly created object structure:\r\n\r\n```\r\n.User[]\r\n| {Username: .username, Full_name: .full_name, Superuser: .is_superuser, Active: .is_active}\r\n| select(.Superuser)\r\n```\r\n\r\nNote that this will generate one JSON object per line, not CSV. If you want CSV output, you have to transform to an array and filter through `@csv`:\r\n\r\n\r\n```\r\n.User[]\r\n| select(.is_superuser)\r\n| [ .username, .full_name, .is_superuser, .is_active ]\r\n| @csv\r\n```\r\n\r\nand if you need headers for your CSV file:\r\n\r\n```\r\n[&quot;Username&quot;, &quot;Full name&quot;, &quot;Superuser&quot;, &quot;Active&quot;],\r\n(.User[]\r\n| select(.is_superuser)\r\n| [ .username, .full_name, .is_superuser, .is_active ])\r\n| @csv\r\n```\r\n\r\nTo get raw CSV output, run the with `--raw-output`/`-r` flag of jq:\r\n\r\n```sh\r\n$ cat input.json\r\n{\r\n  &quot;User&quot;: [\r\n    {\r\n      &quot;username&quot;: &quot;name1&quot;,\r\n      &quot;full_name&quot;: &quot;full_name&quot;,\r\n      &quot;is_superuser&quot;: true,\r\n      &quot;is_active&quot;: false\r\n    },\r\n    {\r\n      &quot;username&quot;: &quot;name1&quot;,\r\n      &quot;full_name&quot;: &quot;full_name&quot;,\r\n      &quot;is_superuser&quot;: false,\r\n      &quot;is_active&quot;: false\r\n    },\r\n    {\r\n      &quot;username&quot;: &quot;name2&quot;,\r\n      &quot;full_name&quot;: &quot;full_name&quot;,\r\n      &quot;is_superuser&quot;: true,\r\n      &quot;is_active&quot;: false\r\n    },\r\n    {\r\n      &quot;username&quot;: &quot;name2&quot;,\r\n      &quot;full_name&quot;: &quot;full_name&quot;,\r\n      &quot;is_superuser&quot;: false,\r\n      &quot;is_active&quot;: false\r\n    }\r\n  ]\r\n}\r\n\r\n$ jq -r &#39;[&quot;Username&quot;, &quot;Full name&quot;, &quot;Superuser&quot;, &quot;Active&quot;],\r\n(.User[]\r\n| select(.is_superuser)\r\n| [ .username, .full_name, .is_superuser, .is_active ])\r\n| @csv&#39; input.json &gt; output.csv\r\n\r\n$ cat output.csv\r\n&quot;Username&quot;,&quot;Full name&quot;,&quot;Superuser&quot;,&quot;Active&quot;\r\n&quot;name1&quot;,&quot;full_name&quot;,true,false\r\n&quot;name2&quot;,&quot;full_name&quot;,true,false\r\n```",
                "title": "JQ how to filter an output"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1664876712,
        "creation_date": 1664874288,
        "last_edit_date": 1664875497,
        "question_id": 73945485,
        "body_markdown": "I am still early in my scripting and coding and new to linux so please bear with me. I have the following command that works but just not as well as I hope it can. \r\n\r\n    jq -r &#39;.User[]|{Username: .username, Full_name: .full_name, Superuser: .is_superuser, Active: .is_active}&#39; lbc.prod.xxx.yyyy.zzzz.json &gt; lbc.prod.xxx.yyyy.zzzz_Users.csv\r\n\r\nThis produces a CSV with all the users on it. I would really like to narrow this down to just superusers. I have tried the following but it failed\r\n\r\n    jq -r &#39;.User[]|{Username: .username, Full_name: .full_name, Superuser: .is_superuser, Active: .is_active} | select(.is_superuser = &quot;true&quot;)&#39; lbc.prod.xxx.yyyy.zzzz.json &gt; lbc.prod.xxx.yyyy.zzzz_SuperUsers.csv\r\n\r\nThat didn&#39;t work I also tried\r\n\r\n    jq -r &#39;.User[]|{Username: .username, Full_name: .full_name, Superuser: .is_superuser{true}, Active: .is_active} &#39; lbc.prod.xxx.yyyy.zzzz.json &gt; lbc.prod.xxx.yyyy.zzzz_SuperUsers.csv\r\n\r\nbut this produced errors and didn&#39;t run.",
        "link": "https://stackoverflow.com/questions/73945485/jq-how-to-filter-an-output",
        "title": "JQ how to filter an output"
    },
    {
        "tags": [
            "json",
            "curl",
            "post",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1664883175,
                "creation_date": 1664883175,
                "answer_id": 73947266,
                "question_id": 73946917,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "```\r\ncurl -i http://localhost:8080/api/v2/torrents/info?category=test | jq --raw-output &#39;.[] | .name&#39;\r\n```\r\n\r\nThe `-i` let curl give some header info, that is parsed to `jq`, but `jq` can only parse JSON end therefore fails.\r\n\r\nRemove the `-i` and optionally replace it with `-s` to remove the stats:\r\n```\r\ncurl -s http://localhost:8080/api/v2/torrents/info?category=test | jq --raw-output &#39;.[] | .name&#39;\r\n```",
                "title": "Filtering array using curl (qBittorrent Web API)"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1664883175,
        "creation_date": 1664881358,
        "last_edit_date": 1664882316,
        "question_id": 73946917,
        "body_markdown": "Hoping someone can help me. I&#39;m trying to understand the [qBittorrent Web API](https://github.com/qbittorrent/qBittorrent/wiki/WebUI-API-(qBittorrent-4.1)). At the moment I&#39;m listing all the paused torrents with:\r\n\r\n```\r\ncurl -i http://localhost:8080/api/v2/torrents/info?category=test\r\n```\r\nThe problem is that lists the whole JSON array - my question is can I just display the &quot;name&quot; or &quot;hash&quot; fields? This is all using curl through cmd, but I&#39;ve tried this in Git Bash &amp; Powershell:\r\n\r\n```\r\n[{&quot;eta&quot;:8640000,&quot;f_l_piece_prio&quot;:false,&quot;force_start&quot;:false,&quot;hash&quot;:&quot;8419d48d86a14335c83fdf4930843438a2f75a6b&quot;,&quot;last_activity&quot;:1664863523,&quot;magnet_uri&quot;:&quot;&quot;,&quot;max_seeding_time&quot;:0,&quot;**name**&quot;:&quot;TestTorrentName&quot;,&quot;num_complete&quot;:12,&quot;num_incomplete&quot;:1,&quot;num_leechs&quot;:0,&quot;num_seeds&quot;:0,&quot;priority&quot;:0,&quot;progress&quot;:1,&quot;ratio&quot;:0,&quot;ratio_limit&quot;:-2,&quot;save_path&quot;:&quot;F:\\\\Completed\\\\test\\\\&quot;,&quot;seeding_time&quot;:0,&quot;seeding_time_limit&quot;:-2,&quot;seen_complete&quot;:1664863523,&quot;seq_dl&quot;:false,&quot;size&quot;:217388295,&quot;state&quot;:&quot;pausedUP&quot;,&quot;super_seeding&quot;:false,&quot;tags&quot;:&quot;&quot;,&quot;time_active&quot;:569,&quot;total_size&quot;:217388295,&quot;tracker&quot;:&quot;udp://open.stealth.si:80/announce&quot;,&quot;trackers_count&quot;:10,&quot;up_limit&quot;:-1,&quot;uploaded&quot;:0,&quot;uploaded_session&quot;:0,&quot;upspeed&quot;:0}]\r\n```\r\n\r\nI&#39;ve tried the following that should work according to https://jqplay.org/ - see [screenshot][1]\r\n```\r\ncurl -i http://localhost:8080/api/v2/torrents/info?category=test | jq --raw-output &#39;.[] | .name&#39;\r\n```\r\nBut unfortunately I&#39;m getting the following error:\r\n```\r\ncurl -i http://localhost:8080/api/v2/torrents/info?category=test | jq --raw-output &#39;.[] | .name&#39;\r\n  % Total    % Received % Xferd  Average Speed   Time    &#39;.name&#39;&#39; is not recognized as an internal or external command,\r\noperable program or batch file.\r\nTi\r\n```\r\n\r\n  [1]: https://i.sstatic.net/Pfnok.png",
        "link": "https://stackoverflow.com/questions/73946917/filtering-array-using-curl-qbittorrent-web-api",
        "title": "Filtering array using curl (qBittorrent Web API)"
    },
    {
        "tags": [
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 39208,
                    "reputation": 267964,
                    "user_id": 112968,
                    "user_type": "registered",
                    "accept_rate": 68,
                    "profile_image": "https://i.sstatic.net/zHTaT.png?s=256",
                    "display_name": "knittl",
                    "link": "https://stackoverflow.com/users/112968/knittl"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1664888414,
                "post_id": 73948046,
                "comment_id": 130569100,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 25978257,
                    "reputation": 31,
                    "user_id": 19692410,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/e6b6b192551c14cdc5c4db497bd5d581?s=256&d=identicon&r=PG",
                    "display_name": "asthmatic_weasel",
                    "link": "https://stackoverflow.com/users/19692410/asthmatic-weasel"
                },
                "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": 1664888805,
                "post_id": 73948046,
                "comment_id": 130569237,
                "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": 1664888866,
                "post_id": 73948046,
                "comment_id": 130569257,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 25978257,
                    "reputation": 31,
                    "user_id": 19692410,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/e6b6b192551c14cdc5c4db497bd5d581?s=256&d=identicon&r=PG",
                    "display_name": "asthmatic_weasel",
                    "link": "https://stackoverflow.com/users/19692410/asthmatic-weasel"
                },
                "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": 1664888984,
                "post_id": 73948046,
                "comment_id": 130569310,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 25978257,
                    "reputation": 31,
                    "user_id": 19692410,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/e6b6b192551c14cdc5c4db497bd5d581?s=256&d=identicon&r=PG",
                    "display_name": "asthmatic_weasel",
                    "link": "https://stackoverflow.com/users/19692410/asthmatic-weasel"
                },
                "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": 1664890024,
                "post_id": 73948046,
                "comment_id": 130569720,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1664890528,
                "last_edit_date": 1664890528,
                "creation_date": 1664889725,
                "answer_id": 73948556,
                "question_id": 73948046,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I _think_ you are looking for this:\r\n\r\n```\r\n[&quot;Interface Name&quot;, &quot;Vlan ID&quot;, &quot;IP address&quot;, &quot;Subnet Mask&quot;],\r\n(\r\n    .ServiceEngine[].data_vnics[].vlan_interfaces[]\r\n    | . as { $if_name, $vlan_id }\r\n    | .vnic_networks[].ip\r\n    | [ $if_name, $vlan_id, .ip_addr.addr, .mask]\r\n)\r\n| @csv\r\n```\r\n\r\nor\r\n\r\n```\r\n[&quot;Interface Name&quot;, &quot;Vlan ID&quot;, &quot;IP address&quot;, &quot;Subnet Mask&quot;],\r\n(\r\n    .ServiceEngine[].data_vnics[].vlan_interfaces[]\r\n    | [ .if_name, .vlan_id ] + (.vnic_networks[].ip | [.ip_addr.addr, .mask])\r\n)\r\n| @csv\r\n```\r\n\r\nor\r\n\r\n```\r\n[&quot;Interface Name&quot;, &quot;Vlan ID&quot;, &quot;IP address&quot;, &quot;Subnet Mask&quot;],\r\n(\r\n    .ServiceEngine[].data_vnics[].vlan_interfaces[]\r\n    | { if_name, vlan_id, ips: .vnic_networks[].ip }\r\n    | [ .if_name, .vlan_id, (.ips|.ip_addr.addr, .mask) ]\r\n)\r\n| @csv\r\n```\r\n\r\nAll three generate the same CSV with one line per IP. Interface name and VLAN id will be printed multiple times if they contain more than one IP.",
                "title": "JQ query extraction"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1664890528,
        "creation_date": 1664887465,
        "last_edit_date": 1664888754,
        "question_id": 73948046,
        "body_markdown": "First off thanks to everyone who takes time to answer questions for us who are learning or struggling. I have this code that works as I need, I had help from knittl earlier. \r\n\r\n        jq -r &#39;[&quot;Username&quot;, &quot;Full name&quot;, &quot;Superuser&quot;, &quot;Active&quot;],\r\n         &gt; (.User[]\r\n         &gt; | select(.is_superuser)\r\n         &gt; | [ .username, .full_name, .is_superuser, .is_active ])\r\n         &gt; | @csv&#39; lbc.noprod1.xxx.json &gt; lbc.noprod1.xxx_Superuser.csv\r\n\r\nI have tried to adjust it so that I can use the same concept but to get other information and have this\r\n\r\n         jq -r &#39;[&quot;Interface Name&quot;, &quot;Vlan ID&quot;, &quot;IP address&quot;, &quot;Subnet Mask&quot;],\r\n          (.ServiceEngine[].data_vnics[].vlan_interfaces[]\r\n          | [ .if_name, .vlan_id])\r\n          (.ServiceEngine[].data_vnics[].vlan_interfaces[].vnic_networks[].ip[].ip_addr[]\r\n          |  [.addr])\r\n          (.ServiceEngine[].data_vnics[].vlan_interfaces[].vnic_networks[].ip[]\r\n          | [.mask])\r\n          | @csv&#39; 20221004_lbc.prod1.xxx.json &gt; 20221004_lbc.prod1.xxx_VNIC.csv\r\n\r\nI receive the error below\r\n\r\njq: error: syntax error, unexpected &#39;(&#39;, expecting $end (Unix shell quoting issues?) at &lt;top-level&gt;, line 4:\r\n(.ServiceEngine[].data_vnics[].vlan_interfaces[].vnic_networks[].ip[].ip_addr[]\r\njq: 1 compile error\r\n\r\nIf it helps this is an extract from the JSON with fields that aren&#39;t relevant removed but all formatting kept\r\n\r\n        &quot;ServiceEngine&quot;: [\r\n        {\r\n            &quot;data_vnics&quot;: [\r\n                {\r\n                    &quot;vlan_interfaces&quot;: [\r\n                        {\r\n                            &quot;if_name&quot;: &quot;bond1.109&quot;,\r\n                            &quot;vlan_id&quot;: 109,\r\n                            &quot;vnic_networks&quot;: [\r\n                                {\r\n                                    &quot;ctlr_alloc&quot;: false,\r\n                                    &quot;ip&quot;: {\r\n                                        &quot;ip_addr&quot;: {\r\n                                            &quot;addr&quot;: &quot;123.123.123.123&quot;,\r\n                                            &quot;type&quot;: &quot;V4&quot;\r\n                                        },\r\n                                        &quot;mask&quot;: 24\r\n                                    },\r\n                                    &quot;mode&quot;: &quot;STATIC&quot;\r\n                                }\r\n                            ],\r\n                            &quot;vrf_ref&quot;: &quot;/api/vrfcontext/?tenant=admin&amp;name=branch-pci-client-vlan109&amp;cloud=Default-Cloud&quot;\r\n                        },\r\n                        {\r\n                            &quot;dhcp_enabled&quot;: true,\r\n                            &quot;enabled&quot;: true,\r\n                            &quot;if_name&quot;: &quot;bond1.1622&quot;,\r\n                            &quot;ip6_autocfg_enabled&quot;: true,\r\n                            &quot;is_mgmt&quot;: false,\r\n                            &quot;vlan_id&quot;: 1622,\r\n                            &quot;vnic_networks&quot;: [\r\n                                {\r\n                                    &quot;ctlr_alloc&quot;: false,\r\n                                    &quot;ip&quot;: {\r\n                                        &quot;ip_addr&quot;: {\r\n                                            &quot;addr&quot;: &quot;456.456.456.456&quot;,\r\n                                            &quot;type&quot;: &quot;V4&quot;\r\n                                        },\r\n                                        &quot;mask&quot;: 22\r\n                                    },\r\n                                    &quot;mode&quot;: &quot;STATIC&quot;\r\n                                }\r\n                            ],\r\n                            &quot;vrf_ref&quot;: &quot;/api/vrfcontext/?tenant=admin&amp;name=onprem-pci-prod-vlan1622&amp;cloud=Default-Cloud&quot;\r\n                        },\r\n\r\n\r\nAs always if you have any tips and suggestions I would be greatful. \r\n\r\nKind regards\r\n\r\n",
        "link": "https://stackoverflow.com/questions/73948046/jq-query-extraction",
        "title": "JQ query extraction"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1664891987,
                "creation_date": 1664891987,
                "answer_id": 73949090,
                "question_id": 73949045,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can use `test` with regular expressions, and `select` to filter:\r\n~~~sh\r\njq -r --arg addr &quot;192\\\\.168\\\\.1\\\\..*&quot; &#39;\r\n  .[0] | select(.result == 0) | .arguments.leases[]\r\n  | &quot;\\(.[&quot;hw-address&quot;]) \\(.[&quot;ip-address&quot;] | select(test($addr)))&quot;\r\n&#39; \r\n~~~\r\n~~~\r\n00:11:22:33:44:55 192.168.1.3\r\n~~~\r\n[Demo](https://jqplay.org/s/MAngJ_gDIlD)\r\n\r\nNote: `192.168.1.*` is not a regular expression (or at least not one you want to use, as it would also match `192.168.100.4` for instance, because `.` stands for any value; a literal dot has to be escaped)",
                "title": "jq: filter out IP addresses by regular expression"
            },
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1664892452,
                "last_edit_date": 1664892452,
                "creation_date": 1664892126,
                "answer_id": 73949123,
                "question_id": 73949045,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "jq has [`test`](https://stedolan.github.io/jq/manual/v1.6/#test(val),test(regex;flags)) to test an input against a regular expression:\r\n\r\n```\r\nfirst\r\n| select(.result == 0)\r\n| .arguments.leases[]\r\n| select(.&quot;ip-address&quot;|test(&quot;^192\\\\.168\\\\.1&quot;))\r\n| &quot;\\(.&quot;hw-address&quot;) \\(.&quot;ip-address&quot;)&quot;\r\n```\r\n\r\nand to provide the regex as argument via command line:\r\n\r\n```\r\njq -r --arg regex &#39;^192\\.168\\.1\\.&#39; &#39;first\r\n| select(.result == 0)\r\n| .arguments.leases[]\r\n| select(.&quot;ip-address&quot;|test($regex))\r\n| &quot;\\(.&quot;hw-address&quot;) \\(.&quot;ip-address&quot;)&quot;&#39;\r\n```\r\n\r\n_If_ you only want to check the start of the IP address, you could also use [`startswith`](https://stedolan.github.io/jq/manual/v1.6/#startswith(str)): `select(.&quot;ip-address&quot;|startswith(&quot;192.168.1.&quot;))`:\r\n\r\n```\r\njq -r --arg prefix &#39;192.168.1.&#39; &#39;first\r\n| select(.result == 0)\r\n| .arguments.leases[]\r\n| select(.&quot;ip-address&quot;|startswith($prefix))\r\n| &quot;\\(.&quot;hw-address&quot;) \\(.&quot;ip-address&quot;)&quot;&#39;\r\n```",
                "title": "jq: filter out IP addresses by regular expression"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1664892554,
        "creation_date": 1664891792,
        "last_edit_date": 1664892554,
        "question_id": 73949045,
        "body_markdown": "\r\n    [\r\n          {\r\n            &quot;arguments&quot;: {\r\n              &quot;leases&quot;: [\r\n                {\r\n                  &quot;cltt&quot;: 1658763299,\r\n                  &quot;fqdn-fwd&quot;: false,\r\n                  &quot;fqdn-rev&quot;: false,\r\n                  &quot;hostname&quot;: &quot;&quot;,\r\n                  &quot;hw-address&quot;: &quot;00:aa:bb:cc:dd:ee&quot;,\r\n                  &quot;ip-address&quot;: &quot;192.168.0.2&quot;,\r\n                  &quot;state&quot;: 0,\r\n                  &quot;subnet-id&quot;: 1,\r\n                  &quot;valid-lft&quot;: 3600\r\n                },\r\n                {\r\n                  &quot;cltt&quot;: 1658763207,\r\n                  &quot;fqdn-fwd&quot;: false,\r\n                  &quot;fqdn-rev&quot;: false,\r\n                  &quot;hostname&quot;: &quot;&quot;,\r\n                  &quot;hw-address&quot;: &quot;00:11:22:33:44:55&quot;,\r\n                  &quot;ip-address&quot;: &quot;192.168.1.3&quot;,\r\n                  &quot;state&quot;: 0,\r\n                  &quot;subnet-id&quot;: 1,\r\n                  &quot;valid-lft&quot;: 3600\r\n                }\r\n              ]\r\n            },\r\n            &quot;result&quot;: 0,\r\n            &quot;text&quot;: &quot;2 IPv4 lease(s) found.&quot;\r\n          }\r\n        ]\r\n\r\nThis is a snippet, but in reality there&#39;s much more entries. Currently I filter out MAC and IP with `jq` expression:\r\n\r\n    jq --raw-output &#39;.[0] | select(.result == 0) | .arguments.leases[] | &quot;\\(.[&quot;hw-address&quot;]) \\(.[&quot;ip-address&quot;])&quot;&#39;\r\n\r\nNow I&#39;m wondering: does `jq` have ability to filter out by regexp? For instance I&#39;d like to dump only entries where IP is `192.168.1.*`, can it be done with jq? Ideally I&#39;d like to pass regexp to my script as a parameter:\r\n\r\n    jq --raw-output --arg addr &quot;$1&quot; ...\r\n\r\nWould appreciate suggestions on how to do this.\r\n",
        "link": "https://stackoverflow.com/questions/73949045/jq-filter-out-ip-addresses-by-regular-expression",
        "title": "jq: filter out IP addresses by regular expression"
    },
    {
        "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": 1664949892,
                "post_id": 73954010,
                "comment_id": 130583156,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1664921355,
                "creation_date": 1664921355,
                "answer_id": 73954078,
                "question_id": 73954010,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Try indexing with `[]` instead.\r\n```\r\ndel(.body[].error)\r\n```\r\n&lt;sup&gt;[Online demo](https://jqplay.org/s/uxpewQc0i7P)&lt;/sup&gt;",
                "title": "remove element from json file using jq"
            },
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1664921925,
                "creation_date": 1664921925,
                "answer_id": 73954142,
                "question_id": 73954010,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "&gt; delete &#39;error&#39; field in every child\r\n\r\nOne way to delete every &quot;error&quot; field in every object:\r\n\r\n    jq &#39;del(..|objects|.error)&#39;\r\n",
                "title": "remove element from json file using jq"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1664953329,
                "creation_date": 1664953329,
                "answer_id": 73956845,
                "question_id": 73954010,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "This removes `error` properties anywhere in your document:\r\n\r\n    del(..|.error?)\r\n\r\nMight be sufficient, might be not, depending on the real structure of your document.",
                "title": "remove element from json file using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 0,
        "last_activity_date": 1664953329,
        "creation_date": 1664920795,
        "last_edit_date": 1664921596,
        "question_id": 73954010,
        "body_markdown": "Maybe you could give me a right direction using this &#39;jq&#39; component, I was using &#39;yq&#39; and now I have to change to &#39;jq&#39;, so I wanted to convert to equivalent but I couldn&#39;t \r\n\r\n    yq -i &#39;del(.body.*.error)&#39; &quot;output.json&quot;\r\n\r\nThe idea is to delete &#39;error&#39; field in every child, without specifying every field, only one general character, similar than equivalent in above yq.\r\n\r\n    delpaths([[&quot;body&quot;,&quot;.$&quot;,&quot;error&quot;]])\r\n\r\nbut this is not working, this is my json file:\r\n\r\n    {\r\n        &quot;body&quot;: {\r\n            &quot;field1&quot;:{\r\n                &quot;name&quot;: &quot;test&quot;,\r\n                &quot;error&quot;:&quot;messsage empty&quot;\r\n            },\r\n            &quot;field2&quot;:{\r\n                &quot;name&quot;:&quot;jose&quot;\r\n            },\r\n            &quot;field3&quot;:{\r\n                &quot;name&quot;:&quot;tere&quot;,\r\n                &quot;error&quot;:&quot;messsage empty 2&quot;\r\n            }\r\n        }\r\n    }\r\n\r\nAnd this is my expectation:\r\n\r\n    {\r\n        &quot;body&quot;: {\r\n            &quot;field1&quot;:{\r\n                &quot;name&quot;: &quot;test&quot;,\r\n            },\r\n            &quot;field2&quot;:{\r\n                &quot;name&quot;:&quot;jose&quot;\r\n            },\r\n            &quot;field3&quot;:{\r\n                &quot;name&quot;:&quot;tere&quot;,\r\n            }\r\n        }\r\n    }",
        "link": "https://stackoverflow.com/questions/73954010/remove-element-from-json-file-using-jq",
        "title": "remove element from json file using jq"
    },
    {
        "tags": [
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 4879,
                    "reputation": 248190,
                    "user_id": 7552,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/b60298053f87465641c1b1192338c8cd?s=256&d=identicon&r=PG",
                    "display_name": "glenn jackman",
                    "link": "https://stackoverflow.com/users/7552/glenn-jackman"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1664966696,
                "post_id": 73956418,
                "comment_id": 130587906,
                "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": 1664976049,
                "post_id": 73956418,
                "comment_id": 130591121,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1664950895,
                "last_edit_date": 1664950895,
                "creation_date": 1664949972,
                "answer_id": 73956439,
                "question_id": 73956418,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "With `reduce`, add the items to and as an array:\r\n~~~sh\r\njq &#39;reduce .[] as $curr ({}; .[$curr.cat] += [$curr])&#39;\r\n~~~\r\n[Demo](https://jqplay.org/s/nyvM9IBMuzu)\r\n\r\nAlternatively, you can use `group_by`, then `add` the `map`ped items:\r\n~~~sh\r\njq &#39;group_by(.cat) | map({(first.cat): .}) | add&#39;\r\n~~~\r\n[Demo](https://jqplay.org/s/WcMsDqZ4uuu)\r\n\r\nThe same can be achieved using `with_entries`:\r\n~~~sh\r\njq &#39;group_by(.cat) | with_entries(.key = .value[0].cat)&#39;\r\n~~~\r\n[Demo](https://jqplay.org/s/Qp-yPO-P4Xx)\r\n\r\nOr even shorter, using `INDEX`:\r\n~~~sh\r\njq &#39;group_by(.cat) | INDEX(first.cat)&#39;\r\n~~~\r\n[Demo](https://jqplay.org/s/0pSJ5VzKb8-)\r\n\r\n~~~json\r\n{\r\n  &quot;low&quot;: [\r\n    {\r\n      &quot;cat&quot;: &quot;low&quot;,\r\n      &quot;value&quot;: &quot;1&quot;\r\n    }\r\n  ],\r\n  &quot;med&quot;: [\r\n    {\r\n      &quot;cat&quot;: &quot;med&quot;,\r\n      &quot;value&quot;: &quot;2&quot;\r\n    },\r\n    {\r\n      &quot;cat&quot;: &quot;med&quot;,\r\n      &quot;value&quot;: &quot;3&quot;\r\n    }\r\n  ]\r\n}\r\n~~~\r\n",
                "title": "How to use jq reduce to sort array into an object"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1664969774,
        "creation_date": 1664949791,
        "last_edit_date": 1664969774,
        "question_id": 73956418,
        "body_markdown": "I am trying to reduce an array \r\n```json\r\n  [\r\n  {&quot;cat&quot;: &quot;low&quot;, &quot;value&quot;: &quot;1&quot;},\r\n  {&quot;cat&quot;: &quot;med&quot;, &quot;value&quot;: &quot;2&quot;},\r\n  {&quot;cat&quot;: &quot;med&quot;, &quot;value&quot;: &quot;3&quot;}\r\n  ]\r\n```\r\nsuch that it produces this output:\r\n```json\r\n{\r\n  &quot;low&quot;: [\r\n    {\r\n      &quot;cat&quot;: &quot;low&quot;,\r\n      &quot;value&quot;: &quot;1&quot;\r\n    }\r\n  ],\r\n  &quot;med&quot;: [\r\n    {\r\n      &quot;cat&quot;: &quot;med&quot;,\r\n      &quot;value&quot;: &quot;2&quot;\r\n    },\r\n    {\r\n      &quot;cat&quot;: &quot;med&quot;,\r\n      &quot;value&quot;: &quot;3&quot;\r\n    }\r\n  ]\r\n}\r\n```\r\n## jq code\r\nI tried this jq code:\r\n```jq\r\nreduce .[] as $curr ({}; \r\n                     $curr.cat as $category |                         # store the current category, eg &quot;low&quot;\r\n                     .[$category] as $currArray |                     # store the current array that eg &quot;low&quot; points to\r\n                     $currArray + [($curr)] as $newCategoryArray |    # add the current object to the current array\r\n                     . + {($category): ($newCategoryArray)}           # use object addition to update the accumulator\r\n                    )\r\n```\r\n## Error\r\nhowever I am getting the error\r\n```\r\njq: error (at &lt;stdin&gt;:5): array ([{&quot;cat&quot;:&quot;me...) and object ({&quot;low&quot;:[{&quot;c...) cannot be added\r\nexit status 5\r\n```\r\n\r\nAny help is appreciated.\r\n\r\njq snippet here: https://jqplay.org/s/HL0r2CqewAr\r\n\r\n### Notes:\r\nIf possible, could someone also explain why my reducer is throwing the error. I have simplified my problem so an explanation would help me greatly.\r\n\r\nRemoving an item from the input array, jq is able to run successfully.\r\n\r\nThe error is only encountered when the &#39;category&#39; is not unique.\r\n\r\neg, this input parses without any error\r\n\r\n```json\r\n  [\r\n  {&quot;cat&quot;: &quot;low&quot;, &quot;value&quot;: &quot;1&quot;},\r\n  {&quot;cat&quot;: &quot;med&quot;, &quot;value&quot;: &quot;2&quot;}\r\n  ]\r\n```",
        "link": "https://stackoverflow.com/questions/73956418/how-to-use-jq-reduce-to-sort-array-into-an-object",
        "title": "How to use jq reduce to sort array into an object"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1664971728,
                "creation_date": 1664971728,
                "answer_id": 73960115,
                "question_id": 73960114,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can use `jq &#39;keys | length&#39;`, which will do exactly the same as `Object.keys(myJson).length`.",
                "title": "Count the number of key value pairs in a given JSON structure using jq"
            },
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1664971913,
                "creation_date": 1664971913,
                "answer_id": 73960152,
                "question_id": 73960114,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Just use `length` directly on the object.\r\n\r\nFrom the [manual](https://stedolan.github.io/jq/manual/#length):\r\n&gt; The length of an object is the number of key-value pairs\r\n\r\n~~~sh\r\n{&quot;foo&quot;:&quot;bar&quot;, &quot;baz&quot;:5, &quot;qux&quot;:false} | length\r\n~~~\r\n~~~json\r\n3\r\n~~~\r\n[Demo](https://jqplay.org/s/6A46L4RgrIY)",
                "title": "Count the number of key value pairs in a given JSON structure using jq"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1664975262,
                "creation_date": 1664975262,
                "answer_id": 73960840,
                "question_id": 73960114,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If the object is the input to JQ, then simply `length`:\r\n\r\n    echo &#39;{&quot;a&quot;:4,&quot;b&quot;:2}&#39; | jq &#39;length&#39;",
                "title": "Count the number of key value pairs in a given JSON structure using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 1,
        "last_activity_date": 1664975262,
        "creation_date": 1664971728,
        "question_id": 73960114,
        "body_markdown": "Given a JSON structure that looks similar to this:\r\n\r\n```\r\n{\r\n  &quot;foo&quot;: &quot;bar&quot;,\r\n  &quot;baz&quot;: 5,\r\n  &quot;qux&quot;: false\r\n}\r\n```\r\n\r\nHow do I find out how many key value pairs are in it? In JavaScript I could call `Object.keys(myJson).length` to get the result, but it would be much more convenient for me to do it with `jq` directly.",
        "link": "https://stackoverflow.com/questions/73960114/count-the-number-of-key-value-pairs-in-a-given-json-structure-using-jq",
        "title": "Count the number of key value pairs in a given JSON structure using jq"
    },
    {
        "tags": [
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1664973285,
                "post_id": 73960343,
                "comment_id": 130590050,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1664973351,
                "post_id": 73960343,
                "comment_id": 130590073,
                "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": 1664973522,
                "post_id": 73960343,
                "comment_id": 130590120,
                "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": 1664974065,
                "post_id": 73960343,
                "comment_id": 130590342,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1664974387,
                "last_edit_date": 1664974387,
                "creation_date": 1664972935,
                "answer_id": 73960374,
                "question_id": 73960343,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "All of it can be done from within jq:\r\n~~~sh\r\nmap(keys_unsorted[] | sub(&quot;\\\\.md$&quot;; &quot;.html&quot;))\r\n~~~\r\n[Demo](https://jqplay.org/s/VqX6Pb8oXtg)\r\n\r\nAlternatively, you can use `to_entries` to access each `.key`:\r\n~~~sh\r\nmap(to_entries[].key | sub(&quot;\\\\.md$&quot;; &quot;.html&quot;))\r\n~~~\r\n[Demo](https://jqplay.org/s/hoGTXAo6xav)\r\n\r\nBoth will give you an array of strings\r\n~~~json\r\n[&quot;index.html&quot;,&quot;user_profil.html&quot;]\r\n~~~\r\nwhich you can then -still in jq- concatenate using `join` and a glue character:\r\n\r\n~~~sh\r\njq -r &#39;map(keys_unsorted[] | sub(&quot;\\\\.md$&quot;; &quot;.html&quot;)) | join(&quot; &quot;)&#39; test.json\r\n~~~\r\n[Demo](https://jqplay.org/s/F7fCwL9bxmA)\r\n\r\nor using the alternative approach:\r\n~~~sh\r\njq -r &#39;map(to_entries[].key | sub(&quot;\\\\.md$&quot;; &quot;.html&quot;)) | join(&quot; &quot;)&#39; test.json\r\n~~~\r\n[Demo](https://jqplay.org/s/9YBhvLqgqMK)\r\n\r\nNote: Using `keys` instead of `keys_unsorted` (as you did in your attempt) will additionally sort the keys.",
                "title": "jq keys as concenated string"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1664974387,
        "creation_date": 1664972763,
        "question_id": 73960343,
        "body_markdown": "I have a source file that looks like\r\n\r\n    {\r\n        &quot;admin-user&quot; : {\r\n            &quot;index.md&quot;: &quot;Index&quot;,\r\n            &quot;user_profil.md&quot;: &quot;User Profil&quot;\r\n        }\r\n    }\r\n\r\nBy help of bash and jq I like to concat a string of the second level keys `index.md` and `user_profile.md`. Further I like replace `.md` with `.html` (key admin-user is unknown an can change)\r\n\r\nThis is where I hang:\r\n\r\n    KEYS=$(cat test.json | jq  -r &#39;.[]|keys&#39;)\r\n\r\n    concat_string=&quot;&quot;\r\n    for i in $KEYS\r\n        do \r\n            md_name=${i/.md/.html}\r\n            concat_string=&quot;$concat_string$md_name&quot;\r\n        done\r\n    \r\n    echo $concat_string\r\n\r\nResult:\r\n\r\n    [&quot;index.html&quot;,&quot;user_profil.html&quot;]\r\n\r\nSo the result is an array. How can I concat a string with blanks between strings?\r\n",
        "link": "https://stackoverflow.com/questions/73960343/jq-keys-as-concenated-string",
        "title": "jq keys as concenated string"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 6196394,
                    "reputation": 86601,
                    "user_id": 5291015,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/4tAvO.jpg?s=256",
                    "display_name": "Inian",
                    "link": "https://stackoverflow.com/users/5291015/inian"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1665135508,
                "post_id": 73985189,
                "comment_id": 130633631,
                "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": 1665135909,
                "post_id": 73985189,
                "comment_id": 130633759,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1665135595,
                "last_edit_date": 1665135595,
                "creation_date": 1665135502,
                "answer_id": 73985220,
                "question_id": 73985189,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If all you want is the content of `.SomeValue`, that&#39;s already exactly your filter:\r\n~~~\r\njq &#39;.SomeValue&#39;\r\n~~~\r\n\r\nIf this part is nested deeper, and you want to update that part while keeping the rest, use the update operator `|=` with `.SomeValue` on that context (with your small sample this is still just `.`):\r\n~~~sh\r\njq &#39;. |= SomeValue&#39;\r\n~~~",
                "title": "Use jq to remove top level module while retaining values"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -1,
        "last_activity_date": 1665135595,
        "creation_date": 1665135330,
        "question_id": 73985189,
        "body_markdown": "I&#39;m trying to use jq in order to achieve the following - \r\n\r\nWith an input of:\r\n\r\n    {\r\n        &quot;SomeValue&quot;: {\r\n            &quot;x&quot; : &quot;y&quot;,\r\n            &quot;a&quot; : &quot;b&quot;\r\n        }\r\n    }\r\n\r\nI&#39;d like to be able to remove &#39;SomeValue&#39; and return just the key/values below so that my output would look like:\r\n\r\n    {\r\n        &quot;x&quot; : &quot;y&quot;,\r\n        &quot;a&quot; : &quot;b&quot;\r\n    }\r\n\r\nI&#39;ve tried various permutations of commands I&#39;ve seen on the forum but either end up deleting the whole structure or nothing at all - thanks in advance for any help/pointers in the right direction. \r\n \r\n\r\n",
        "link": "https://stackoverflow.com/questions/73985189/use-jq-to-remove-top-level-module-while-retaining-values",
        "title": "Use jq to remove top level module while retaining values"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1665140400,
                "last_edit_date": 1665140400,
                "creation_date": 1665138637,
                "answer_id": 73985800,
                "question_id": 73985783,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You could use `keys_unsorted` to get the sub-keys, and update `|=` to replace the former content:\r\n~~~sh\r\njq &#39;.paths | .[] |= keys_unsorted&#39; \r\n~~~\r\n~~~json\r\n{\r\n  &quot;/api/A&quot;: [\r\n    &quot;get&quot;,\r\n    &quot;put&quot;\r\n  ]\r\n}\r\n~~~\r\n[Demo](https://jqplay.org/s/F3Z-hCGaUaC)\r\n\r\n---\r\nTo filter out certain elements, you can beforehand update items (not) matching your criteria:\r\n~~~sh\r\njq &#39;.paths | .[][] |= select(.deprecated | not) | .[] |= keys_unsorted&#39;\r\n~~~\r\n[Demo](https://jqplay.org/s/UemNZgd803d)\r\n\r\nOr the two steps combined:\r\n~~~sh\r\njq &#39;.paths | .[] |= (.[] |= select(.deprecated | not) | keys_unsorted)&#39; \r\n~~~\r\n[Demo](https://jqplay.org/s/wLw7o19b45B)\r\n\r\n~~~json\r\n{\r\n  &quot;/api/A&quot;: [\r\n    &quot;get&quot;\r\n  ]\r\n}\r\n~~~\r\n---\r\n\r\nNote: Referring to your own approach, if you prefer using `keys` over `keys_unsorted` (the former will additionally sort the output list), and `map_values` over `.[] |=` (they are identical), my approach would translate to:\r\n~~~sh\r\njq &#39;.paths | map_values(map_values(select(.deprecated | not)) | keys)&#39;\r\n~~~\r\n",
                "title": "How do I use jq to not display keys depending on the value?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1665140400,
        "creation_date": 1665138531,
        "last_edit_date": 1665138747,
        "question_id": 73985783,
        "body_markdown": "This is the json file. I&#39;m trying to use jq to show the list of APIs and methods.\r\n\r\n    {\r\n      &quot;paths&quot;: {\r\n        &quot;/api/A&quot;: {\r\n          &quot;get&quot;: {\r\n            &quot;summary&quot;: &quot;lorem ipsum&quot;,\r\n            &quot;parameters&quot;: [\r\n              {\r\n                &quot;name&quot;: &quot;Guid&quot;,\r\n                &quot;description&quot;: &quot;Guid&quot;\r\n              }\r\n            ]\r\n          },\r\n          &quot;put&quot;: {\r\n            &quot;summary&quot;: &quot;Adds or updates an item&quot;,\r\n            &quot;parameters&quot;: [\r\n              {\r\n                &quot;name&quot;: &quot;lorem ipsum&quot;,\r\n                &quot;description&quot;: &quot;lorem ipsum&quot;\r\n              }\r\n            ],\r\n            &quot;deprecated&quot;: true\r\n          }\r\n        }\r\n      }\r\n    }\r\n\r\nThe `put` has a key `deprecated` which is set to `true`. \r\nRunning `jq &quot;.paths|map_values(keys)&quot; json` returns this\r\n\r\n    jq &quot;.paths | map_values(keys)&quot; json\r\n\r\n    {\r\n      &quot;/api/A&quot;: [\r\n        &quot;get&quot;,\r\n        &quot;put&quot;\r\n      ]\r\n    }\r\n\r\nHow do I not display the key `put` just because it has child key `&quot;deprecated&quot;: true`? \r\n\r\n",
        "link": "https://stackoverflow.com/questions/73985783/how-do-i-use-jq-to-not-display-keys-depending-on-the-value",
        "title": "How do I use jq to not display keys depending on the value?"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1665141243,
                "last_edit_date": 1665141243,
                "creation_date": 1665140081,
                "answer_id": 73986096,
                "question_id": 73986020,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can use `group_by` to make clusters of matching IDs (I assumed `.PartNumber` together with `.ClassificationNo` to make a unique ID), then within each cluster, take the ID fields from the first item (all have the same ID fields), and add to it the values of all items by converting them to a key-value structure that can be used with `from_entries` to turn it into an object:\r\n\r\n~~~sh\r\ngroup_by([.PartNumber, .ClassificationNo]) | map(\r\n  (first | {PartNumber, ClassificationNo}) +\r\n  (map({key: .Field, value: .StringValue}) | from_entries)\r\n)\r\n~~~\r\n[Demo](https://jqplay.org/s/Fiph1rVQ1EL)\r\n\r\nInstead of `from_entries`, you can also use `INDEX` to create an object with the right fields, but then subsequently the values need to be trimmed down to only contain the right values:\r\n~~~sh\r\ngroup_by([.PartNumber, .ClassificationNo]) | map(\r\n  (first | {PartNumber, ClassificationNo}) +\r\n  (INDEX(.Field) | .[] |= .StringValue)\r\n)\r\n~~~\r\n[Demo](https://jqplay.org/s/8Jub36wVcMg)\r\n\r\n~~~json\r\n[\r\n  {\r\n    &quot;PartNumber&quot;: &quot;5SD30104GN114&quot;,\r\n    &quot;ClassificationNo&quot;: &quot;500001&quot;,\r\n    &quot;95001&quot;: &quot;L0035WSGE&quot;,\r\n    &quot;95002&quot;: &quot;&quot;\r\n  }\r\n]\r\n~~~\r\n",
                "title": "Converting JSON Array to object using JQ"
            },
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1665160172,
                "creation_date": 1665160172,
                "answer_id": 73990089,
                "question_id": 73986020,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s a solution using reduce:\r\n\r\n```\r\ngroup_by({PartNumber,ClassificationNo})\r\n| map(reduce .[] as $item ({}; .+($item|{PartNumber, ClassificationNo, (.Field):.StringValue})))\r\n```\r\n\r\nProbably not the most efficient one (part number and classification number are always overwritten), but it gets the job done while being somewhat readable.\r\n\r\nOutput:\r\n\r\n```json\r\n[\r\n  {\r\n    &quot;PartNumber&quot;: &quot;5SD30104GN114&quot;,\r\n    &quot;ClassificationNo&quot;: &quot;500001&quot;,\r\n    &quot;95001&quot;: &quot;L0035WSGE&quot;,\r\n    &quot;95002&quot;: &quot;&quot;\r\n  }\r\n]\r\n```\r\n\r\nWith a function:\r\n\r\n```\r\ndef reducer($item):\r\n  $item|{PartNumber, ClassificationNo, (.Field):.StringValue};\r\n\r\ngroup_by({PartNumber,ClassificationNo})\r\n| map(reduce .[] as $item ({}; .+reducer($item)))\r\n```",
                "title": "Converting JSON Array to object using JQ"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1665160172,
        "creation_date": 1665139688,
        "question_id": 73986020,
        "body_markdown": "I would like to ask for help. How can I transfer array to one list.\r\nMy input is\r\n\r\n    [\r\n      {\r\n        &quot;PartNumber&quot;: &quot;5SD30104GN114&quot;,\r\n        &quot;ClassificationNo&quot;: &quot;500001&quot;,\r\n        &quot;StringValue&quot;: &quot;L0035WSGE&quot;,\r\n        &quot;Field&quot;: &quot;95001&quot;\r\n      },\r\n      {\r\n        &quot;PartNumber&quot;: &quot;5SD30104GN114&quot;,\r\n        &quot;ClassificationNo&quot;: &quot;500001&quot;,\r\n        &quot;StringValue&quot;: &quot;&quot;,\r\n        &quot;Field&quot;: &quot;95002&quot;\r\n      }\r\n    ]\r\n\r\nAnd I like to expect this\r\n\r\n    [\r\n      {\r\n        &quot;PartNumber&quot;: &quot;5SD30104GN114&quot;,\r\n        &quot;ClassificationNo&quot;: &quot;500001&quot;,\r\n        &quot;95001&quot;: &quot;L0035WSGE&quot;,\r\n        &quot;95002&quot;: &quot;&quot;,\r\n      }\r\n    ]\r\n\r\nHow Can I do ?\r\nI tried use \r\n\r\n&gt; | .[] | [.PartNumber, .ClassificationNo, .StringValue, .Field]\r\n\r\nBut generate again arrays\r\n\r\n    [\r\n      &quot;5SD30104GN114&quot;,\r\n      &quot;500001&quot;,\r\n      &quot;L0035WSGE&quot;,\r\n      &quot;95001&quot;\r\n    ]\r\n    [\r\n      &quot;5SD30104GN114&quot;,\r\n      &quot;500001&quot;,\r\n      &quot;&quot;,\r\n      &quot;95002&quot;\r\n    ]\r\n   ",
        "link": "https://stackoverflow.com/questions/73986020/converting-json-array-to-object-using-jq",
        "title": "Converting JSON Array to object using JQ"
    },
    {
        "tags": [
            "bash",
            "shell",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 468289,
                    "reputation": 190915,
                    "user_id": 874188,
                    "user_type": "registered",
                    "accept_rate": 62,
                    "profile_image": "https://www.gravatar.com/avatar/091f411d57db5be8298e057a32e5ad72?s=256&d=identicon&r=PG",
                    "display_name": "tripleee",
                    "link": "https://stackoverflow.com/users/874188/tripleee"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1665145952,
                "post_id": 73987116,
                "comment_id": 130637304,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1665148619,
                "last_edit_date": 1665148619,
                "creation_date": 1665145850,
                "answer_id": 73987197,
                "question_id": 73987116,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Your input is a stream of objects. As such your filter expression, `.games = &quot;66&quot;` asserts that the record `games` is present in each of the object present in the stream.\r\n\r\nTo update the specific object alone, select it first and assign the required value or update it.\r\n\r\n```sh\r\njq -c &#39;select(has(&quot;games&quot;)).games = &quot;66&quot;&#39;\r\n```\r\n\r\nTo answer OP&#39;s clarification on how to do the same with variables, do\r\n\r\n```sh\r\njq -c --arg key &quot;games&quot; &#39;select(has($key))[$key] = &quot;555&quot;&#39;\r\n```",
                "title": "How to update value in key using jq inside a file in shell script?"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1665181112,
                "creation_date": 1665181112,
                "answer_id": 73993050,
                "question_id": 73987116,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "A simple solution is using `select` with assignment. select will return the special value `empty` if the condition does not match and the input value if it does match.\r\n\r\n```\r\nselect(.games).games = &quot;66&quot;\r\n```\r\n\r\n`jq -c` to generate compact format, i.e. one JSON object/document per line.\r\n\r\nTo handle arbitrary names, change the syntax slightly:\r\n\r\n```\r\nselect(.[&quot;games&quot;])[&quot;games&quot;] = &quot;66&quot;\r\n```\r\n\r\nand used with arguments passed via CLI:\r\n\r\n```\r\njq -r --arg key &quot;$var&quot; &#39;select(.[$key])[$key] = &quot;66&quot;&#39;\r\n```",
                "title": "How to update value in key using jq inside a file in shell script?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1665181112,
        "creation_date": 1665145442,
        "question_id": 73987116,
        "body_markdown": "I have file like this(exact format):\r\n\r\n    { &quot;test&quot;: &quot;10&quot; }\r\n    { &quot;games&quot;: &quot;30&quot; }\r\n    { &quot;REPOSITORY&quot;: &quot;5&quot;}\r\n\r\nI want to update the value of key. For example games to 66. So the new file would be:\r\n\r\n    { &quot;test&quot;: &quot;10&quot; }\r\n    { &quot;games&quot;: &quot;66&quot; }\r\n    { &quot;REPOSITORY&quot;:&quot;5&quot;}\r\n\r\nI used jq with combination of a temporary file \r\n\r\n```\r\ntmp=$(mktemp);\r\njq &#39;.games = &quot;66&quot;&#39; pair.json &gt; &quot;$tmp&quot; &amp;&amp; mv &quot;$tmp&quot; change.json\r\n```\r\n\r\nbut got this kind of output. \r\n\r\n    {\r\n      &quot;test&quot;: &quot;10&quot;,\r\n      &quot;games&quot;: &quot;66&quot;\r\n    }\r\n    {\r\n      &quot;games&quot;: &quot;66&quot;\r\n    }\r\n    {\r\n      &quot;REPOSITORY&quot;: &quot;5&quot;,\r\n      &quot;games&quot;: &quot;66&quot;\r\n    }\r\nwhere games is written all 3 whereas I just want it be updated only at its position. \r\nFurthermore i want the value to be updated using bash variable but that I can try to figure out using --arg after I resolve this issue. Pls assist here. ",
        "link": "https://stackoverflow.com/questions/73987116/how-to-update-value-in-key-using-jq-inside-a-file-in-shell-script",
        "title": "How to update value in key using jq inside a file in shell script?"
    },
    {
        "tags": [
            "bash",
            "shell",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 6313442,
                    "reputation": 45115,
                    "user_id": 5625547,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/oqCND.jpg?s=256",
                    "display_name": "0stone0",
                    "link": "https://stackoverflow.com/users/5625547/0stone0"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1665156121,
                "post_id": 73989336,
                "comment_id": 130640998,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 138066,
                    "reputation": 1989,
                    "user_id": 342743,
                    "user_type": "registered",
                    "accept_rate": 72,
                    "profile_image": "https://i.sstatic.net/ylFnx.jpg?s=256",
                    "display_name": "Amir",
                    "link": "https://stackoverflow.com/users/342743/amir"
                },
                "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": 1665156191,
                "post_id": 73989336,
                "comment_id": 130641020,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 47502,
                    "reputation": 213658,
                    "user_id": 140750,
                    "user_type": "registered",
                    "accept_rate": 92,
                    "profile_image": "https://www.gravatar.com/avatar/4c7af12cad08c95bc206a9636d164224?s=256&d=identicon&r=PG",
                    "display_name": "William Pursell",
                    "link": "https://stackoverflow.com/users/140750/william-pursell"
                },
                "edited": false,
                "score": 3,
                "creation_date": 1665157410,
                "post_id": 73989336,
                "comment_id": 130641447,
                "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": 1665159492,
                "post_id": 73989336,
                "comment_id": 130642127,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 5,
                "is_accepted": true,
                "score": 5,
                "last_activity_date": 1665159397,
                "last_edit_date": 1665159397,
                "creation_date": 1665156261,
                "answer_id": 73989411,
                "question_id": 73989336,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Since you&#39;re dealing with JSON, I&#39;d recommend a tool like [tag:jq], which provides us with the `--compact-output` option and is capable of encoding to Base64 using `@base64`\r\n\r\n\r\n----------\r\n\r\nTo single-line output\r\n```\r\njq --compact-output &#39;&#39; &lt;&lt;&lt; &quot;$test&quot;\r\n```\r\n\r\n\r\n----------\r\n\r\n\r\nTo Base64 single-line output\r\n```\r\njq --compact-output  &#39;@base64&#39; &lt;&lt;&lt; &quot;$test&quot;\r\n```\r\n\r\n\r\n----------\r\n\r\n\r\nTo Base64 single-line output, and decoding with bash\r\n```\r\njq --compact-output --raw-output &#39;@base64&#39; &lt;&lt;&lt; &quot;$test&quot; | base64 --decode\r\n```\r\n\r\n**Note** the `--raw-output` to remove the `&quot;&quot;`&#39;s. \r\n\r\n----------\r\n\r\nLocal shell example of above lines:\r\n```none\r\n$ test=&#39;{\r\n  &quot;type&quot;: &quot;service_account&quot;,\r\n  &quot;project_id&quot;: &quot;projectid234&quot;,\r\n  &quot;private_key_id&quot;: &quot;aasdadsxzce5&quot;,\r\n  &quot;private_key&quot;: &quot;-----BEGIN PRIVATE KEY-----\\nMIIEvgIBADANBgkqhkiG9w0BAQEFAASCBKgwggSkAgEAAoIBAQCiWjA5+xF6gsGC\\nOknIL9DOCQpV2LRXYPEKl5+mXuN45vwqh6QvG4lw/Hi7EJhtAn+FQy7+yOQYrw3l\\nQ2CpxDotT+PT2OuQ6LVbc/F+SblPlrK3B+8aEMo57PZ+gnwMcQ7+ofPnzC635uUP\\npOG0idMTK\\n-----END PRIVATE KEY-----\\n&quot;,\r\n  &quot;client_email&quot;: &quot;clinetmail@asdasd3435.iam.gserviceaccount.com&quot;,\r\n  &quot;client_id&quot;: &quot;1234242342341&quot;,\r\n  &quot;auth_uri&quot;: &quot;https://accounts.google.com/o/oauth2/auth&quot;,\r\n  &quot;token_uri&quot;: &quot;https://oauth2.googleapis.com/token&quot;,\r\n  &quot;auth_provider_x509_cert_url&quot;: &quot;https://www.googleapis.com/oauth2/v1/certs&quot;,\r\n  &quot;client_x509_cert_url&quot;: &quot;https://www.googleapis.com/robot/v1/metadata/x509/assadjashd.iam.gserviceaccount.com&quot;\r\n}&#39;\r\n$\r\n$ jq --compact-output &#39;&#39; &lt;&lt;&lt; &quot;$test&quot;\r\n{&quot;type&quot;:&quot;service_account&quot;,&quot;project_id&quot;:&quot;projectid234&quot;,&quot;private_key_id&quot;:&quot;aasdadsxzce5&quot;,&quot;private_key&quot;:&quot;-----BEGIN PRIVATE KEY-----\\nMIIEvgIBADANBgkqhkiG9w0BAQEFAASCBKgwggSkAgEAAoIBAQCiWjA5+xF6gsGC\\nOknIL9DOCQpV2LRXYPEKl5+mXuN45vwqh6QvG4lw/Hi7EJhtAn+FQy7+yOQYrw3l\\nQ2CpxDotT+PT2OuQ6LVbc/F+SblPlrK3B+8aEMo57PZ+gnwMcQ7+ofPnzC635uUP\\npOG0idMTK\\n-----END PRIVATE KEY-----\\n&quot;,&quot;client_email&quot;:&quot;clinetmail@asdasd3435.iam.gserviceaccount.com&quot;,&quot;client_id&quot;:&quot;1234242342341&quot;,&quot;auth_uri&quot;:&quot;https://accounts.google.com/o/oauth2/auth&quot;,&quot;token_uri&quot;:&quot;https://oauth2.googleapis.com/token&quot;,&quot;auth_provider_x509_cert_url&quot;:&quot;https://www.googleapis.com/oauth2/v1/certs&quot;,&quot;client_x509_cert_url&quot;:&quot;https://www.googleapis.com/robot/v1/metadata/x509/assadjashd.iam.gserviceaccount.com&quot;}\r\n$\r\n$\r\n$ jq --compact-output &#39;@base64&#39; &lt;&lt;&lt; &quot;$test&quot;\r\n&quot;eyJ0eXBlIjoic2VydmljZV9hY2NvdW50IiwicHJvamVjdF9pZCI6InByb2plY3RpZDIzNCIsInByaXZhdGVfa2V5X2lkIjoiYWFzZGFkc3h6Y2U1IiwicHJpdmF0ZV9rZXkiOiItLS0tLUJFR0lOIFBSSVZBVEUgS0VZLS0tLS1cbk1JSUV2Z0lCQURBTkJna3Foa2lHOXcwQkFRRUZBQVNDQktnd2dnU2tBZ0VBQW9JQkFRQ2lXakE1K3hGNmdzR0Ncbk9rbklMOURPQ1FwVjJMUlhZUEVLbDUrbVh1TjQ1dndxaDZRdkc0bHcvSGk3RUpodEFuK0ZReTcreU9RWXJ3M2xcblEyQ3B4RG90VCtQVDJPdVE2TFZiYy9GK1NibFBsckszQis4YUVNbzU3UForZ253TWNRNytvZlBuekM2MzV1VVBcbnBPRzBpZE1US1xuLS0tLS1FTkQgUFJJVkFURSBLRVktLS0tLVxuIiwiY2xpZW50X2VtYWlsIjoiY2xpbmV0bWFpbEBhc2Rhc2QzNDM1LmlhbS5nc2VydmljZWFjY291bnQuY29tIiwiY2xpZW50X2lkIjoiMTIzNDI0MjM0MjM0MSIsImF1dGhfdXJpIjoiaHR0cHM6Ly9hY2NvdW50cy5nb29nbGUuY29tL28vb2F1dGgyL2F1dGgiLCJ0b2tlbl91cmkiOiJodHRwczovL29hdXRoMi5nb29nbGVhcGlzLmNvbS90b2tlbiIsImF1dGhfcHJvdmlkZXJfeDUwOV9jZXJ0X3VybCI6Imh0dHBzOi8vd3d3Lmdvb2dsZWFwaXMuY29tL29hdXRoMi92MS9jZXJ0cyIsImNsaWVudF94NTA5X2NlcnRfdXJsIjoiaHR0cHM6Ly93d3cuZ29vZ2xlYXBpcy5jb20vcm9ib3QvdjEvbWV0YWRhdGEveDUwOS9hc3NhZGphc2hkLmlhbS5nc2VydmljZWFjY291bnQuY29tIn0=&quot;\r\n$\r\n$\r\n$ jq --compact-output --raw-output &#39;@base64&#39; &lt;&lt;&lt; &quot;$test&quot; | base64 --decode\r\n{&quot;type&quot;:&quot;service_account&quot;,&quot;project_id&quot;:&quot;projectid234&quot;,&quot;private_key_id&quot;:&quot;aasdadsxzce5&quot;,&quot;private_key&quot;:&quot;-----BEGIN PRIVATE KEY-----\\nMIIEvgIBADANBgkqhkiG9w0BAQEFAASCBKgwggSkAgEAAoIBAQCiWjA5+xF6gsGC\\nOknIL9DOCQpV2LRXYPEKl5+mXuN45vwqh6QvG4lw/Hi7EJhtAn+FQy7+yOQYrw3l\\nQ2CpxDotT+PT2OuQ6LVbc/F+SblPlrK3B+8aEMo57PZ+gnwMcQ7+ofPnzC635uUP\\npOG0idMTK\\n-----END PRIVATE KEY-----\\n&quot;,&quot;client_email&quot;:&quot;clinetmail@asdasd3435.iam.gserviceaccount.com&quot;,&quot;client_id&quot;:&quot;1234242342341&quot;,&quot;auth_uri&quot;:&quot;https://accounts.google.com/o/oauth2/auth&quot;,&quot;token_uri&quot;:&quot;https://oauth2.googleapis.com/token&quot;,&quot;auth_provider_x509_cert_url&quot;:&quot;https://www.googleapis.com/oauth2/v1/certs&quot;,&quot;client_x509_cert_url&quot;:&quot;https://www.googleapis.com/robot/v1/metadata/x509/assadjashd.iam.gserviceaccount.com&quot;}%\r\n$\r\n$\r\n```",
                "title": "How to convert a multiple-line variable containing JSON to single line in shell?"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1665158958,
                "last_edit_date": 1665158958,
                "creation_date": 1665157167,
                "answer_id": 73989586,
                "question_id": 73989336,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Not sure I understand the use of `base64` but a simple `tr` should work, eg:\r\n\r\n    $ var2=$(echo ${var1} | tr -d &#39;\\n&#39;)              # ${var1} is not wrapped in double quotes so repetitive white space is squeezed to single spaces\r\n    \r\n    $ echo &quot;${var2}&quot;\r\n    { &quot;type&quot;: &quot;service_account&quot;, &quot;project_id&quot;: &quot;projectid234&quot;, &quot;private_key_id&quot;: &quot;aasdadsxzce5&quot;, &quot;private_key&quot;: &quot;-----BEGIN PRIVATE KEY-----\\nMIIEvgIBADANBgkqhkiG9w0BAQEFAASCBKgwggSkAgEAAoIBAQCiWjA5+xF6gsGC\\nOknIL9DOCQpV2LRXYPEKl5+mXuN45vwqh6QvG4lw/Hi7EJhtAn+FQy7+yOQYrw3l\\nQ2CpxDotT+PT2OuQ6LVbc/F+SblPlrK3B+8aEMo57PZ+gnwMcQ7+ofPnzC635uUP\\npOG0idMTK\\n-----END PRIVATE KEY-----\\n&quot;, &quot;client_email&quot;: &quot;clinetmail@asdasd3435.iam.gserviceaccount.com&quot;, &quot;client_id&quot;: &quot;1234242342341&quot;, &quot;auth_uri&quot;: &quot;https://accounts.google.com/o/oauth2/auth&quot;, &quot;token_uri&quot;: &quot;https://oauth2.googleapis.com/token&quot;, &quot;auth_provider_x509_cert_url&quot;: &quot;https://www.googleapis.com/oauth2/v1/certs&quot;, &quot;client_x509_cert_url&quot;: &quot;https://www.googleapis.com/robot/v1/metadata/x509/assadjashd.iam.gserviceaccount.com&quot; }\r\n\r\nOr as William Pursell pointed out in comments, don&#39;t wrap `${var1}` in quotes and you can also eliminate the `od` call:\r\n\r\n    $ var2=$(echo ${var1})                           # the unquoted ${var1} also removes linefeeds so no need for tr\r\n    \r\n    $ echo &quot;${var2}&quot;\r\n    { &quot;type&quot;: &quot;service_account&quot;, &quot;project_id&quot;: &quot;projectid234&quot;, &quot;private_key_id&quot;: &quot;aasdadsxzce5&quot;, &quot;private_key&quot;: &quot;-----BEGIN PRIVATE KEY-----\\nMIIEvgIBADANBgkqhkiG9w0BAQEFAASCBKgwggSkAgEAAoIBAQCiWjA5+xF6gsGC\\nOknIL9DOCQpV2LRXYPEKl5+mXuN45vwqh6QvG4lw/Hi7EJhtAn+FQy7+yOQYrw3l\\nQ2CpxDotT+PT2OuQ6LVbc/F+SblPlrK3B+8aEMo57PZ+gnwMcQ7+ofPnzC635uUP\\npOG0idMTK\\n-----END PRIVATE KEY-----\\n&quot;, &quot;client_email&quot;: &quot;clinetmail@asdasd3435.iam.gserviceaccount.com&quot;, &quot;client_id&quot;: &quot;1234242342341&quot;, &quot;auth_uri&quot;: &quot;https://accounts.google.com/o/oauth2/auth&quot;, &quot;token_uri&quot;: &quot;https://oauth2.googleapis.com/token&quot;, &quot;auth_provider_x509_cert_url&quot;: &quot;https://www.googleapis.com/oauth2/v1/certs&quot;, &quot;client_x509_cert_url&quot;: &quot;https://www.googleapis.com/robot/v1/metadata/x509/assadjashd.iam.gserviceaccount.com&quot; }\r\n\r\n\r\nOr if you wish to maintain all the extra white space you can wrap `${var1}` in double quotes before passing to `tr`, eg:\r\n\r\n    $ var2=$(echo &quot;${var1}&quot; | tr -d &#39;\\n&#39;)            # ${var1} is wrapped in double quotes to maintain all white space\r\n    \r\n    $ echo &quot;${var2}&quot;\r\n    {      &quot;type&quot;: &quot;service_account&quot;,      &quot;project_id&quot;: &quot;projectid234&quot;,      &quot;private_key_id&quot;: &quot;aasdadsxzce5&quot;,      &quot;private_key&quot;: &quot;-----BEGIN PRIVATE KEY-----\\nMIIEvgIBADANBgkqhkiG9w0BAQEFAASCBKgwggSkAgEAAoIBAQCiWjA5+xF6gsGC\\nOknIL9DOCQpV2LRXYPEKl5+mXuN45vwqh6QvG4lw/Hi7EJhtAn+FQy7+yOQYrw3l\\nQ2CpxDotT+PT2OuQ6LVbc/F+SblPlrK3B+8aEMo57PZ+gnwMcQ7+ofPnzC635uUP\\npOG0idMTK\\n-----END PRIVATE KEY-----\\n&quot;,      &quot;client_email&quot;: &quot;clinetmail@asdasd3435.iam.gserviceaccount.com&quot;,      &quot;client_id&quot;: &quot;1234242342341&quot;,      &quot;auth_uri&quot;: &quot;https://accounts.google.com/o/oauth2/auth&quot;,      &quot;token_uri&quot;: &quot;https://oauth2.googleapis.com/token&quot;,      &quot;auth_provider_x509_cert_url&quot;: &quot;https://www.googleapis.com/oauth2/v1/certs&quot;,      &quot;client_x509_cert_url&quot;: &quot;https://www.googleapis.com/robot/v1/metadata/x509/assadjashd.iam.gserviceaccount.com&quot;    }\r\n\r\n\r\n",
                "title": "How to convert a multiple-line variable containing JSON to single line in shell?"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1665407901,
                "last_edit_date": 1665407901,
                "creation_date": 1665157609,
                "answer_id": 73989663,
                "question_id": 73989336,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Just as a quick pass, you really should be able to just do this with built-in parameter expansion in `bash`.\r\n\r\nThe simplest:\r\n\r\n    $: echo &quot;$var1&quot; # this should present it exactly as you saved it\r\n    {\r\n          &quot;type&quot;: &quot;service_account&quot;,\r\n          &quot;project_id&quot;: &quot;projectid234&quot;,\r\n          &quot;private_key_id&quot;: &quot;aasdadsxzce5&quot;,\r\n          &quot;private_key&quot;: &quot;-----BEGIN PRIVATE KEY-----\\nMIIEvgIBADANBgkqhkiG9w0BAQEFAASCBKgwggSkAgEAAoIBAQCiWjA5+xF6gsGC\\nOknIL9DOCQpV2LRXYPEKl5+mXuN45vwqh6QvG4lw/Hi7EJhtAn+FQy7+yOQYrw3l\\nQ2CpxDotT+PT2OuQ6LVbc/F+SblPlrK3B+8aEMo57PZ+gnwMcQ7+ofPnzC635uUP\\npOG0idMTK\\n-----END PRIVATE KEY-----\\n&quot;,\r\n          &quot;client_email&quot;: &quot;clinetmail@asdasd3435.iam.gserviceaccount.com&quot;,\r\n          &quot;client_id&quot;: &quot;1234242342341&quot;,\r\n          &quot;auth_uri&quot;: &quot;https://accounts.google.com/o/oauth2/auth&quot;,\r\n          &quot;token_uri&quot;: &quot;https://oauth2.googleapis.com/token&quot;,\r\n          &quot;auth_provider_x509_cert_url&quot;: &quot;https://www.googleapis.com/oauth2/v1/certs&quot;,\r\n          &quot;client_x509_cert_url&quot;: &quot;https://www.googleapis.com/robot/v1/metadata/x509/assadjashd.iam.gserviceaccount.com&quot;\r\n        }\r\n\r\n    $: echo &quot;${var1//$&#39;\\n&#39;/}&quot; # this should strip out the newlines\r\n    {      &quot;type&quot;: &quot;service_account&quot;,      &quot;project_id&quot;: &quot;projectid234&quot;,      &quot;private_key_id&quot;: &quot;aasdadsxzce5&quot;,      &quot;private_key&quot;: &quot;-----BEGIN PRIVATE KEY-----\\nMIIEvgIBADANBgkqhkiG9w0BAQEFAASCBKgwggSkAgEAAoIBAQCiWjA5+xF6gsGC\\nOknIL9DOCQpV2LRXYPEKl5+mXuN45vwqh6QvG4lw/Hi7EJhtAn+FQy7+yOQYrw3l\\nQ2CpxDotT+PT2OuQ6LVbc/F+SblPlrK3B+8aEMo57PZ+gnwMcQ7+ofPnzC635uUP\\npOG0idMTK\\n-----END PRIVATE KEY-----\\n&quot;,      &quot;client_email&quot;: &quot;clinetmail@asdasd3435.iam.gserviceaccount.com&quot;,      &quot;client_id&quot;: &quot;1234242342341&quot;,      &quot;auth_uri&quot;: &quot;https://accounts.google.com/o/oauth2/auth&quot;,      &quot;token_uri&quot;: &quot;https://oauth2.googleapis.com/token&quot;,      &quot;auth_provider_x509_cert_url&quot;: &quot;https://www.googleapis.com/oauth2/v1/certs&quot;,      &quot;client_x509_cert_url&quot;: &quot;https://www.googleapis.com/robot/v1/metadata/x509/assadjashd.iam.gserviceaccount.com&quot;    }\r\n\r\nAssuming you also want to squeeze out extraneous whitespace with a more complex pattern, you might be tempted to use a regex...which won&#39;t work, because the parameter parsing actually usesw globbing, but regular expressions *per se*... but try `shopt` for *extended* globbing -\r\n\r\n    $: shopt -s extglob # c.f. https://mywiki.wooledge.org/glob#extglob\r\n    $: echo &quot;${var1//$&#39;\\n&#39;+( )/}&quot; # remove a newline followed by one or more spaces\r\n    {&quot;type&quot;: &quot;service_account&quot;,&quot;project_id&quot;: &quot;projectid234&quot;,&quot;private_key_id&quot;: &quot;aasdadsxzce5&quot;,&quot;private_key&quot;: &quot;-----BEGIN PRIVATE KEY-----\\nMIIEvgIBADANBgkqhkiG9w0BAQEFAASCBKgwggSkAgEAAoIBAQCiWjA5+xF6gsGC\\nOknIL9DOCQpV2LRXYPEKl5+mXuN45vwqh6QvG4lw/Hi7EJhtAn+FQy7+yOQYrw3l\\nQ2CpxDotT+PT2OuQ6LVbc/F+SblPlrK3B+8aEMo57PZ+gnwMcQ7+ofPnzC635uUP\\npOG0idMTK\\n-----END PRIVATE KEY-----\\n&quot;,&quot;client_email&quot;: &quot;clinetmail@asdasd3435.iam.gserviceaccount.com&quot;,&quot;client_id&quot;: &quot;1234242342341&quot;,&quot;auth_uri&quot;: &quot;https://accounts.google.com/o/oauth2/auth&quot;,&quot;token_uri&quot;: &quot;https://oauth2.googleapis.com/token&quot;,&quot;auth_provider_x509_cert_url&quot;: &quot;https://www.googleapis.com/oauth2/v1/certs&quot;,&quot;client_x509_cert_url&quot;: &quot;https://www.googleapis.com/robot/v1/metadata/x509/assadjashd.iam.gserviceaccount.com&quot;}\r\n\r\n# edit\r\n\r\nThere IS whitespace: this changes `-----BEGIN PRIVATE KEY-----` to `-----BEGINPRIVATEKEY-----`, I just missed it.  \r\n&gt; Since you seem to have no whitespaces embedded in your *data* (that I noticed), you could take out the *requirement* for a newline in front of them, and just remove ALL spaces to compact it even more.\r\n\r\n    $: echo &quot;${var1//*($&#39;\\n&#39;)+( )/}&quot;\r\n    {&quot;type&quot;:&quot;service_account&quot;,&quot;project_id&quot;:&quot;projectid234&quot;,&quot;private_key_id&quot;:&quot;aasdadsxzce5&quot;,&quot;private_key&quot;:&quot;-----BEGINPRIVATEKEY-----\\nMIIEvgIBADANBgkqhkiG9w0BAQEFAASCBKgwggSkAgEAAoIBAQCiWjA5+xF6gsGC\\nOknIL9DOCQpV2LRXYPEKl5+mXuN45vwqh6QvG4lw/Hi7EJhtAn+FQy7+yOQYrw3l\\nQ2CpxDotT+PT2OuQ6LVbc/F+SblPlrK3B+8aEMo57PZ+gnwMcQ7+ofPnzC635uUP\\npOG0idMTK\\n-----ENDPRIVATEKEY-----\\n&quot;,&quot;client_email&quot;:&quot;clinetmail@asdasd3435.iam.gserviceaccount.com&quot;,&quot;client_id&quot;:&quot;1234242342341&quot;,&quot;auth_uri&quot;:&quot;https://accounts.google.com/o/oauth2/auth&quot;,&quot;token_uri&quot;:&quot;https://oauth2.googleapis.com/token&quot;,&quot;auth_provider_x509_cert_url&quot;:&quot;https://www.googleapis.com/oauth2/v1/certs&quot;,&quot;client_x509_cert_url&quot;:&quot;https://www.googleapis.com/robot/v1/metadata/x509/assadjashd.iam.gserviceaccount.com&quot;}\r\n\r\nAgain, this changes `-----BEGIN PRIVATE KEY-----` to `-----BEGINPRIVATEKEY-----`  \r\n&gt; So...in this case, with no embedded spaces, you can achieve the best result without extended globbing at all, by just using POSIX character classes to remove all whitespace, as at the top. :)\r\n\r\n    $: echo &quot;${var1//[[:space:]]/}&quot; # // means global replacement\r\n    {&quot;type&quot;:&quot;service_account&quot;,&quot;project_id&quot;:&quot;projectid234&quot;,&quot;private_key_id&quot;:&quot;aasdadsxzce5&quot;,&quot;private_key&quot;:&quot;-----BEGINPRIVATEKEY-----\\nMIIEvgIBADANBgkqhkiG9w0BAQEFAASCBKgwggSkAgEAAoIBAQCiWjA5+xF6gsGC\\nOknIL9DOCQpV2LRXYPEKl5+mXuN45vwqh6QvG4lw/Hi7EJhtAn+FQy7+yOQYrw3l\\nQ2CpxDotT+PT2OuQ6LVbc/F+SblPlrK3B+8aEMo57PZ+gnwMcQ7+ofPnzC635uUP\\npOG0idMTK\\n-----ENDPRIVATEKEY-----\\n&quot;,&quot;client_email&quot;:&quot;clinetmail@asdasd3435.iam.gserviceaccount.com&quot;,&quot;client_id&quot;:&quot;1234242342341&quot;,&quot;auth_uri&quot;:&quot;https://accounts.google.com/o/oauth2/auth&quot;,&quot;token_uri&quot;:&quot;https://oauth2.googleapis.com/token&quot;,&quot;auth_provider_x509_cert_url&quot;:&quot;https://www.googleapis.com/oauth2/v1/certs&quot;,&quot;client_x509_cert_url&quot;:&quot;https://www.googleapis.com/robot/v1/metadata/x509/assadjashd.iam.gserviceaccount.com&quot;}\r\n\r\n",
                "title": "How to convert a multiple-line variable containing JSON to single line in shell?"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 2,
        "last_activity_date": 1665407901,
        "creation_date": 1665155812,
        "last_edit_date": 1665182334,
        "question_id": 73989336,
        "body_markdown": "I have below variable in shell\r\n\r\n    {\r\n      &quot;type&quot;: &quot;service_account&quot;,\r\n      &quot;project_id&quot;: &quot;projectid234&quot;,\r\n      &quot;private_key_id&quot;: &quot;aasdadsxzce5&quot;,\r\n      &quot;private_key&quot;: &quot;-----BEGIN PRIVATE KEY-----\\nMIIEvgIBADANBgkqhkiG9w0BAQEFAASCBKgwggSkAgEAAoIBAQCiWjA5+xF6gsGC\\nOknIL9DOCQpV2LRXYPEKl5+mXuN45vwqh6QvG4lw/Hi7EJhtAn+FQy7+yOQYrw3l\\nQ2CpxDotT+PT2OuQ6LVbc/F+SblPlrK3B+8aEMo57PZ+gnwMcQ7+ofPnzC635uUP\\npOG0idMTK\\n-----END PRIVATE KEY-----\\n&quot;,\r\n      &quot;client_email&quot;: &quot;clinetmail@asdasd3435.iam.gserviceaccount.com&quot;,\r\n      &quot;client_id&quot;: &quot;1234242342341&quot;,\r\n      &quot;auth_uri&quot;: &quot;https://accounts.google.com/o/oauth2/auth&quot;,\r\n      &quot;token_uri&quot;: &quot;https://oauth2.googleapis.com/token&quot;,\r\n      &quot;auth_provider_x509_cert_url&quot;: &quot;https://www.googleapis.com/oauth2/v1/certs&quot;,\r\n      &quot;client_x509_cert_url&quot;: &quot;https://www.googleapis.com/robot/v1/metadata/x509/assadjashd.iam.gserviceaccount.com&quot;\r\n    }\r\nLike below:\r\n\r\n    export var1=&#39;{\r\n          &quot;type&quot;: &quot;service_account&quot;,\r\n          &quot;project_id&quot;: &quot;projectid234&quot;,\r\n          &quot;private_key_id&quot;: &quot;aasdadsxzce5&quot;,\r\n          &quot;private_key&quot;: &quot;-----BEGIN PRIVATE KEY-----\\nMIIEvgIBADANBgkqhkiG9w0BAQEFAASCBKgwggSkAgEAAoIBAQCiWjA5+xF6gsGC\\nOknIL9DOCQpV2LRXYPEKl5+mXuN45vwqh6QvG4lw/Hi7EJhtAn+FQy7+yOQYrw3l\\nQ2CpxDotT+PT2OuQ6LVbc/F+SblPlrK3B+8aEMo57PZ+gnwMcQ7+ofPnzC635uUP\\npOG0idMTK\\n-----END PRIVATE KEY-----\\n&quot;,\r\n          &quot;client_email&quot;: &quot;clinetmail@asdasd3435.iam.gserviceaccount.com&quot;,\r\n          &quot;client_id&quot;: &quot;1234242342341&quot;,\r\n          &quot;auth_uri&quot;: &quot;https://accounts.google.com/o/oauth2/auth&quot;,\r\n          &quot;token_uri&quot;: &quot;https://oauth2.googleapis.com/token&quot;,\r\n          &quot;auth_provider_x509_cert_url&quot;: &quot;https://www.googleapis.com/oauth2/v1/certs&quot;,\r\n          &quot;client_x509_cert_url&quot;: &quot;https://www.googleapis.com/robot/v1/metadata/x509/assadjashd.iam.gserviceaccount.com&quot;\r\n        }&#39;\r\n\r\nNow I want to convert it to a single line, what should I do?\r\nI tried various solutions but they didn&#39;t work. for instance I used below code which I found but after converting to base64 and decoding it, it just return the first line. would you mind help me?\r\n\r\n    $((echo $var1 | tr -d &#39;\\n&#39;) | base64)",
        "link": "https://stackoverflow.com/questions/73989336/how-to-convert-a-multiple-line-variable-containing-json-to-single-line-in-shell",
        "title": "How to convert a multiple-line variable containing JSON to single line in shell?"
    },
    {
        "tags": [
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 39208,
                    "reputation": 267964,
                    "user_id": 112968,
                    "user_type": "registered",
                    "accept_rate": 68,
                    "profile_image": "https://i.sstatic.net/zHTaT.png?s=256",
                    "display_name": "knittl",
                    "link": "https://stackoverflow.com/users/112968/knittl"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1665179594,
                "post_id": 73992039,
                "comment_id": 130647340,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1665172687,
                "creation_date": 1665172687,
                "answer_id": 73992086,
                "question_id": 73992039,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Simply indicate you want the result in a list by wrapping the expression with [];\r\n\r\n    &gt; cat test.json | jq &#39;[.[] | select(.blah==&quot;true&quot;)]&#39;\r\n\r\n    [\r\n      {\r\n        &quot;a&quot;: &quot;1&quot;,\r\n        &quot;blah&quot;: &quot;true&quot;\r\n      },\r\n      {\r\n        &quot;c&quot;: &quot;3&quot;,\r\n        &quot;blah&quot;: &quot;true&quot;\r\n      }\r\n    ]",
                "title": "In jq, can you get objects back in a list, so you can index them?"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1665173354,
                "creation_date": 1665173354,
                "answer_id": 73992163,
                "question_id": 73992039,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Using `map` to iterate over the array\r\n```sh\r\njq &#39;map(select(.blah == &quot;true&quot;))&#39;\r\n```",
                "title": "In jq, can you get objects back in a list, so you can index them?"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1680415042,
                "creation_date": 1680415042,
                "answer_id": 75910361,
                "question_id": 73992039,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Using param -s:\r\n\r\n    jq  &#39;.[]|select(.blah==&quot;true&quot;)&#39; | jq -s &#39;.&#39;",
                "title": "In jq, can you get objects back in a list, so you can index them?"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 1,
        "last_activity_date": 1680415042,
        "creation_date": 1665172188,
        "question_id": 73992039,
        "body_markdown": "So, say I have this JSON...\r\n\r\n    [\r\n      {\r\n        &quot;a&quot;: &quot;1&quot;,\r\n        &quot;blah&quot;: &quot;true&quot;\r\n      },\r\n      {\r\n        &quot;b&quot;: &quot;2&quot;,\r\n        &quot;blah&quot;: &quot;false&quot;\r\n      },\r\n      {\r\n        &quot;c&quot;: &quot;3&quot;,\r\n        &quot;blah&quot;: &quot;true&quot;\r\n      }\r\n    ]\r\n\r\n...and then use jq to select certain entries...\r\n\r\n    jq &#39;.[] | select(.blah==&quot;true)&#39;\r\n\r\nI get this...\r\n\r\n    {\r\n      &quot;a&quot;: &quot;1&quot;,\r\n      &quot;blah&quot;: &quot;true&quot;\r\n    }\r\n    {\r\n      &quot;c&quot;: &quot;3&quot;,\r\n      &quot;blah&quot;: &quot;true&quot;\r\n    }\r\n\r\nBut I *want* it to look like...\r\n\r\n    [\r\n      {\r\n        &quot;a&quot;: &quot;1&quot;,\r\n        &quot;blah&quot;: &quot;true&quot;\r\n      }\r\n      {\r\n        &quot;c&quot;: &quot;3&quot;,\r\n        &quot;blah&quot;: &quot;true&quot;\r\n      }\r\n    ]\r\n\r\n...this, so that I can use indexing to get certain of these entries. How do I do that?",
        "link": "https://stackoverflow.com/questions/73992039/in-jq-can-you-get-objects-back-in-a-list-so-you-can-index-them",
        "title": "In jq, can you get objects back in a list, so you can index them?"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1665205721,
                "creation_date": 1665205721,
                "answer_id": 73994537,
                "question_id": 73994331,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The error suppression operator returns the special value `empty` in case of error. `empty` is not part of the result. But you can provide an alternative value with the [`//` alternative operator](https://stedolan.github.io/jq/manual/v1.6/#Alternativeoperator://):\r\n\r\n```\r\n.[] | {section:.a, area_or_null:(.in[]?.id//null)}\r\n```\r\n\r\nOutput:\r\n\r\n```json\r\n{\r\n  &quot;section&quot;: 1,\r\n  &quot;area_or_null&quot;: 2\r\n}\r\n{\r\n  &quot;section&quot;: 4,\r\n  &quot;area_or_null&quot;: null\r\n}\r\n```",
                "title": "How to get field in an array or null with jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1665205721,
        "creation_date": 1665202551,
        "question_id": 73994331,
        "body_markdown": "If you run the below you&#39;ll see I get only the first item in the array with the error of not being able to iterate over null. I can&#39;t seem to figure out how to allow the area to be null if `.in` or `.in.id` is null. Using `?` makes the error go away but it&#39;s still only the first item\r\n\r\n    echo &#39;[{&quot;a&quot;:1, &quot;in&quot;: [{&quot;id&quot;:2}] },{&quot;a&quot;:4}]&#39; | jq &#39;.[] | {section:.a, area_or_null:.in[].id}&#39;\r\n    {\r\n      &quot;id&quot;: 1,\r\n      &quot;id_or_null&quot;: 2\r\n    }\r\n    jq: error (at &lt;stdin&gt;:1): Cannot iterate over null (null)\r\n",
        "link": "https://stackoverflow.com/questions/73994331/how-to-get-field-in-an-array-or-null-with-jq",
        "title": "How to get field in an array or null with jq?"
    },
    {
        "tags": [
            "python",
            "jupyter-notebook",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 99309,
                    "reputation": 146060,
                    "user_id": 1832058,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/relWs.jpg?s=256",
                    "display_name": "furas",
                    "link": "https://stackoverflow.com/users/1832058/furas"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1665226523,
                "post_id": 73995671,
                "comment_id": 130653288,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 99309,
                    "reputation": 146060,
                    "user_id": 1832058,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/relWs.jpg?s=256",
                    "display_name": "furas",
                    "link": "https://stackoverflow.com/users/1832058/furas"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1665226593,
                "post_id": 73995671,
                "comment_id": 130653298,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 99309,
                    "reputation": 146060,
                    "user_id": 1832058,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/relWs.jpg?s=256",
                    "display_name": "furas",
                    "link": "https://stackoverflow.com/users/1832058/furas"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1665226624,
                "post_id": 73995671,
                "comment_id": 130653306,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 99309,
                    "reputation": 146060,
                    "user_id": 1832058,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/relWs.jpg?s=256",
                    "display_name": "furas",
                    "link": "https://stackoverflow.com/users/1832058/furas"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1665226684,
                "post_id": 73995671,
                "comment_id": 130653313,
                "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": 1665240809,
                "post_id": 73995671,
                "comment_id": 130655874,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1665231381,
                "last_edit_date": 1665231381,
                "creation_date": 1665228593,
                "answer_id": 73996628,
                "question_id": 73995671,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If you use `shell=True` then you have to use single string instead of list\r\n\r\n```\r\ncmd = &quot;cd Users/avinash/Downloads/reports/reports &amp;&amp; jq -r &#39;.&#39; *.json | jq &#39;(.steps) |= []&#39; | grep -c &#39;\\&quot;status\\&quot;: \\&quot;failed\\&quot;&#39;&quot;\r\n```\r\n\r\nAnd rest is the same:\r\n\r\n```\r\nresult = subprocess.check_output(cmd, shell=True)\r\nprint(result)\r\n```\r\n\r\n---\r\n\r\n\r\n**EDIT:**\r\n\r\nIn original list you have two `&#39;&#39;` after `&amp;&amp;` and this makes first problem.   \r\nThere are also other problems with `&#39;` in other parts.  \r\nBut if you use `|` then you have to use `shell` and you don&#39;t need  list.\r\n\r\nBut if you would have to use list then there is standard module `shlex` to convert string to list\r\n\r\n```\r\nimport shlex\r\n\r\ncmd = &quot;cd Users/avinash/Downloads/reports/reports &amp;&amp; jq -r &#39;.&#39; *.json | jq &#39;(.steps) |= []&#39; | grep -c &#39;\\&quot;status\\&quot;: \\&quot;failed\\&quot;&#39;&quot;\r\n\r\nprint(shlex.split(cmd))\r\n```\r\n\r\nResult:\r\n\r\n```\r\n[&#39;cd&#39;, &#39;Users/avinash/Downloads/reports/reports&#39;, &#39;&amp;&amp;&#39;, &#39;jq&#39;, &#39;-r&#39;, &#39;.&#39;, &#39;*.json&#39;, &#39;|&#39;, &#39;jq&#39;, &#39;(.steps) |= []&#39;, &#39;|&#39;, &#39;grep&#39;, &#39;-c&#39;, &#39;&quot;status&quot;: &quot;failed&quot;&#39;]\r\n```\r\n\r\n(but `|` will not work without `shell=True`)",
                "title": "i need to find &quot;status&quot;: &quot;failed&quot; in the json file in jupyter notebook but it is showing syntax error i was using same jq command in javascript"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -2,
        "last_activity_date": 1665231381,
        "creation_date": 1665219583,
        "last_edit_date": 1665228589,
        "question_id": 73995671,
        "body_markdown": "i&#39;m new to python i need to use jq on an Json file and find match for &quot;status&quot; : &quot;failed&quot; in file, i had tried this in js code using this \r\n\r\n    jq -r &#39;.&#39; *.json | jq &#39;(.steps) |= []&#39; | grep -c &#39;&quot;status&quot;: &quot;failed&quot;&#39;\r\n\r\nit worked now i need to use it in jupyter notebook using below command it is not working giving syntax error,\r\n\r\n    import os\r\n    import json\r\n    import subprocess\r\n    \r\n    cmd=[&#39;cd&#39;, &#39;Users/avinash/Downloads/reports/reports&#39;, &#39;&amp;&amp;&#39;&#39;,&#39;jq -r &#39;.&#39; *.json&#39; | jq &#39;(.steps) |= []&#39; | grep -c &quot;status&quot;: &quot;failed&quot;&#39;]\r\n    result = subprocess.check_output(cmd, shell=True)\r\n    print(result)\r\n\r\nany help would be much appreciated, thanks i&#39;m new to python\r\n\r\nit says below error [![enter image description here][1]][1]\r\n\r\n\r\n  [1]: https://i.sstatic.net/RES3B.png",
        "link": "https://stackoverflow.com/questions/73995671/i-need-to-find-status-failed-in-the-json-file-in-jupyter-notebook-but-it-is",
        "title": "i need to find &quot;status&quot;: &quot;failed&quot; in the json file in jupyter notebook but it is showing syntax error i was using same jq command in javascript"
    },
    {
        "tags": [
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 6313442,
                    "reputation": 45115,
                    "user_id": 5625547,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/oqCND.jpg?s=256",
                    "display_name": "0stone0",
                    "link": "https://stackoverflow.com/users/5625547/0stone0"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1665241327,
                "post_id": 73998004,
                "comment_id": 130655966,
                "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": 1665241768,
                "post_id": 73998004,
                "comment_id": 130656045,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 15944425,
                    "reputation": 395,
                    "user_id": 11505412,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f20fceb4da643cabfffb826fda12ff76?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "prasanth",
                    "link": "https://stackoverflow.com/users/11505412/prasanth"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1665241887,
                "post_id": 73998004,
                "comment_id": 130656071,
                "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": 1665242242,
                "post_id": 73998004,
                "comment_id": 130656147,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 15944425,
                    "reputation": 395,
                    "user_id": 11505412,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f20fceb4da643cabfffb826fda12ff76?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "prasanth",
                    "link": "https://stackoverflow.com/users/11505412/prasanth"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1665242486,
                "post_id": 73998004,
                "comment_id": 130656195,
                "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": 1665243189,
                "post_id": 73998004,
                "comment_id": 130656344,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": false,
                "score": 4,
                "last_activity_date": 1724144806,
                "last_edit_date": 1724144806,
                "creation_date": 1665394360,
                "answer_id": 74012818,
                "question_id": 73998004,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "1. `jq &#39;.address&#39;` will output the value of the property `value`, e.g. `&quot;192.168.123.1&quot;`. (`jq -r` to get rid of the quote marks)\r\n2. `jq &#39;has(&quot;address&quot;)&#39;` will output `true`/`false`\r\n3. `jq -e &#39;has(&quot;address&quot;)&#39; &gt; /dev/null` will set the process&#39; exit status to `0`/`1` depending on the object having the key &quot;address&quot; (regardless of value)\r\n4. `jq -e &#39;.address&#39; &gt; /dev/null` will set the process&#39; exit status to `0` if the &quot;address&quot; property has a _truthy_ value (anything except `null` or `false`). A `null` or `false` valued property will set the exit code to `1`.\r\n\r\nHaving the appropriate exit status allows you to do things such as:\r\n\r\n```sh\r\nif jq -e &#39;.address&#39; &gt; /dev/null; then\r\n  echo &#39;object has address field&#39;\r\nfi\r\n# or:\r\njq -e &#39;has(&quot;address&quot;)&#39; &gt; /dev/null || echo &#39;object does not have an address&#39;\r\n```",
                "title": "How to check if an attribute exists in a json using jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1724144806,
        "creation_date": 1665241213,
        "question_id": 73998004,
        "body_markdown": "Hi I am having a shell script ,\r\nthe shell script  has a variable named RESPONSE\r\n\r\nI want a to check if the json object has an attribute named &quot;address&quot; is present. Also how to get value of the attribute address . I want to use jq library\r\n\r\n    #!/bin/bash\r\n    \r\n    RESPONSE={&quot;content-length&quot;:&quot;2&quot;,&quot;address&quot;:&quot;192.168.123.1&quot;,&quot;path&quot;:&quot;/hello-world&quot;}\r\n\r\nappreciate any help",
        "link": "https://stackoverflow.com/questions/73998004/how-to-check-if-an-attribute-exists-in-a-json-using-jq",
        "title": "How to check if an attribute exists in a json using jq?"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1665264870,
                "creation_date": 1665264870,
                "answer_id": 74000691,
                "question_id": 74000292,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Just traverse and `select` in a single jq call. The `?` filters out the `null` values.\r\n~~~sh\r\njq -r &#39;.[].content.data[].&quot;content-item&quot;[].text | select(startswith(&quot;23.acmestable.0.&quot;))?&#39;\r\n~~~\r\n~~~\r\n23.acmestable.0.0-SNAPSHOT\r\n23.acmestable.0.24\r\n23.acmestable.0.25\r\n23.acmestable.0.22\r\n23.acmestable.0.23\r\n~~~\r\n[Demo](https://jqplay.org/s/LyLCztrbBEP)\r\n\r\nNote: `startswith` takes a plain (sub)string, not a regular expression. Replace it with `test` to perform a regex matching instead. [Demo](https://jqplay.org/s/elVWJQ_Jqle)",
                "title": "How to retrieve value using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1666984864,
        "creation_date": 1665260535,
        "last_edit_date": 1666984864,
        "question_id": 74000292,
        "body_markdown": "Below is the JSON we have, and I want to filter only these below values (that is available under &quot;text&quot; field). I want to use the `jq` command for this. I have tried this command, but it is resulting in an error:\r\n\r\n`jq -r&#39;.[].content.data[][&quot;content-item&quot;]&#39;|jq -r &#39;.[]| select (.text |startswith(&quot;^23.acmestable.0.&quot;))&#39;` \r\n\r\nExpected result:\r\n\r\n    23.acmestable.0.22\r\n    23.acmestable.0.23\r\n    23.acmestable.0.24\r\n    23.acmestable.0.25\r\n\r\nWhich is this JQ query runs for &quot;hardcoded&quot; value:\r\n\r\n`&#39;.[].content.data[][&quot;content-item&quot;]&#39;|jq -r &#39;.[]| select (.text==&quot;23.acme.0.23&quot;)&#39;` \r\n\r\nand returns:\r\n\r\n    {\r\n      &quot;text&quot;: &quot;23.acmestable.0.23&quot;\r\n    }\r\n\r\nSample JSON:\r\n\r\n    [\r\n       {\r\n          &quot;content&quot;: {\r\n             &quot;data&quot;: [\r\n                 {\r\n                   &quot;content-item&quot;: [\r\n                      {\r\n                         &quot;resourceURI&quot;: &quot;https://acme.example.com/service/local/repositories/public/content/com/acme/acme-files/23.acmestable.0.0-SNAPSHOT/&quot;\r\n                      },\r\n                      {\r\n                         &quot;relativePath&quot;: &quot;/com/acme/acme-files/23.acmestable.0.0-SNAPSHOT/&quot;\r\n                      },\r\n                      {\r\n                         &quot;text&quot;: &quot;23.acmestable.0.0-SNAPSHOT&quot;\r\n                      },\r\n                      {\r\n                         &quot;leaf&quot;: &quot;false&quot;\r\n                      },\r\n                      {\r\n                         &quot;lastModified&quot;: &quot;2022-10-06 11:54:58.0 UTC&quot;\r\n                      },\r\n                      {\r\n                         &quot;sizeOnDisk&quot;: &quot;-1&quot;\r\n                      }\r\n                   ]\r\n                },\r\n                 {\r\n                   &quot;content-item&quot;: [\r\n                      {\r\n                         &quot;resourceURI&quot;: &quot;https://acme.example.com/service/local/repositories/public/content/com/acme/acme-files/23.acmestable.0.24/&quot;\r\n                      },\r\n                      {\r\n                         &quot;relativePath&quot;: &quot;/com/acme/acme-files/23.acmestable.0.24/&quot;\r\n                      },\r\n                      {\r\n                         &quot;text&quot;: &quot;23.acmestable.0.24&quot;\r\n                      },\r\n                      {\r\n                         &quot;leaf&quot;: &quot;false&quot;\r\n                      },\r\n                      {\r\n                         &quot;lastModified&quot;: &quot;2022-10-07 03:17:23.0 UTC&quot;\r\n                      },\r\n                      {\r\n                         &quot;sizeOnDisk&quot;: &quot;-1&quot;\r\n                      }\r\n                   ]\r\n                },\r\n                 {\r\n                   &quot;content-item&quot;: [\r\n                      {\r\n                         &quot;resourceURI&quot;: &quot;https://acme.example.com/service/local/repositories/public/content/com/acme/acme-files/23.acmestable.0.25/&quot;\r\n                      },\r\n                      {\r\n                         &quot;relativePath&quot;: &quot;/com/acme/acme-files/23.acmestable.0.25/&quot;\r\n                      },\r\n                      {\r\n                         &quot;text&quot;: &quot;23.acmestable.0.25&quot;\r\n                      },\r\n                      {\r\n                         &quot;leaf&quot;: &quot;false&quot;\r\n                      },\r\n                      {\r\n                         &quot;lastModified&quot;: &quot;2022-10-07 03:17:23.0 UTC&quot;\r\n                      },\r\n                      {\r\n                         &quot;sizeOnDisk&quot;: &quot;-1&quot;\r\n                      }\r\n                   ]\r\n                },\r\n                {\r\n                   &quot;content-item&quot;: [\r\n                      {\r\n                         &quot;resourceURI&quot;: &quot;https://acme.example.com/service/local/repositories/public/content/com/acme/acme-files/23.acmestable.0.22/&quot;\r\n                      },\r\n                      {\r\n                         &quot;relativePath&quot;: &quot;/com/acme/acme-files/23.acmestable.0.22/&quot;\r\n                      },\r\n                      {\r\n                         &quot;text&quot;: &quot;23.acmestable.0.22&quot;\r\n                      },\r\n                      {\r\n                         &quot;leaf&quot;: &quot;false&quot;\r\n                      },\r\n                      {\r\n                         &quot;lastModified&quot;: &quot;2022-10-07 03:17:23.0 UTC&quot;\r\n                      },\r\n                      {\r\n                         &quot;sizeOnDisk&quot;: &quot;-1&quot;\r\n                      }\r\n                   ]\r\n                },\r\n                 {\r\n                   &quot;content-item&quot;: [\r\n                      {\r\n                         &quot;resourceURI&quot;: &quot;https://acme.example.com/service/local/repositories/public/content/com/acme/acme-files/23.acmestable.0.23/&quot;\r\n                      },\r\n                      {\r\n                         &quot;relativePath&quot;: &quot;/com/acme/acme-files/23.acmestable.0.23/&quot;\r\n                      },\r\n                      {\r\n                         &quot;text&quot;: &quot;23.acmestable.0.23&quot;\r\n                      },\r\n                      {\r\n                         &quot;leaf&quot;: &quot;false&quot;\r\n                      },\r\n                      {\r\n                         &quot;lastModified&quot;: &quot;2022-10-07 03:17:23.0 UTC&quot;\r\n                      },\r\n                      {\r\n                         &quot;sizeOnDisk&quot;: &quot;-1&quot;\r\n                      }\r\n                   ]\r\n                }\r\n             ]\r\n          }\r\n       }\r\n    ]",
        "link": "https://stackoverflow.com/questions/74000292/how-to-retrieve-value-using-jq",
        "title": "How to retrieve value using jq"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": false,
                "score": 4,
                "last_activity_date": 1665305933,
                "creation_date": 1665305933,
                "answer_id": 74003382,
                "question_id": 74003358,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Use [`tojson`](https://stedolan.github.io/jq/manual/#Convertto/fromJSON), not `tostring`. It does exactly what you need for all data types.\r\n\r\n```jq\r\nto_entries|map(&quot;export let &quot; + .key + &quot; = &quot; + (.value | tojson)) | .[]\r\n```\r\n\r\nCheck it [online](https://jqplay.org/s/cvA8BiByhPq).",
                "title": "jq: how to add double quotes for string values"
            },
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1665306534,
                "last_edit_date": 1665306534,
                "creation_date": 1665305940,
                "answer_id": 74003384,
                "question_id": 74003358,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "To get a JSON-encoded output, use `tojson` instead of `tostring`:\r\n~~~sh\r\njq -r &#39;to_entries[] | &quot;export let &quot; + .key + &quot; = &quot; + (.value | tojson)&#39;\r\n~~~\r\n~~~sh\r\nexport let stringKey = &quot;this is a string&quot;\r\nexport let numberKey = 1234\r\nexport let jsonKey = [{&quot;numberKey&quot;:1,&quot;stringKey&quot;:&quot;0x&quot;}]\r\n~~~\r\n[Demo](https://jqplay.org/s/7x8BoChyoNx)\r\n\r\n---\r\nWith the same effect, you can also use the `@json` syntax and provide the value through string interpolation:\r\n~~~sh\r\njq -r &#39;to_entries[] | &quot;export let &quot; + .key + @json &quot; = \\(.value)&quot;&#39;\r\n~~~\r\n~~~sh\r\nexport let stringKey = &quot;this is a string&quot;\r\nexport let numberKey = 1234\r\nexport let jsonKey = [{&quot;numberKey&quot;:1,&quot;stringKey&quot;:&quot;0x&quot;}]\r\n~~~\r\n[Demo](https://jqplay.org/s/gK7cAcAg-_F)\r\n\r\n---\r\nNote: For simplicity, I have also turned `map(…) | .[]` into `.[] | …`.",
                "title": "jq: how to add double quotes for string values"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1665308951,
        "creation_date": 1665305641,
        "last_edit_date": 1665308951,
        "question_id": 74003358,
        "body_markdown": "given this JSON:\r\n\r\n```json\r\n{\r\n  &quot;stringKey&quot;: &quot;this is a string&quot;,\r\n  &quot;numberKey&quot;: 1234,\r\n  &quot;jsonKey&quot;: [\r\n    {&quot;numberKey&quot;: 1, &quot;stringKey&quot;: &quot;0x&quot; }\r\n  ]\r\n}\r\n```\r\n\r\nand this jq expression \r\n```sh\r\nto_entries|map(&quot;export let &quot; + .key + &quot; = &quot; + (.value | tostring)) | .[]\r\n```\r\n\r\nI get this:\r\n\r\n```\r\nexport let stringKey = this is a string\r\nexport let numberKey = 1234\r\nexport let jsonKey = [{&quot;numberKey&quot;:1,&quot;stringKey&quot;:&quot;0x&quot;}]\r\n```\r\n\r\nhowever I want this (note double quotes around `this is a string`):\r\n\r\n```\r\nexport let stringKey = &quot;this is a string&quot;\r\nexport let numberKey = 1234\r\nexport let jsonKey = [{&quot;numberKey&quot;:1,&quot;stringKey&quot;:&quot;0x&quot;}]\r\n```\r\n\r\njqplay snippet can be found https://jqplay.org/s/MYdILy4Xfw3\r\n\r\nany help? thanks!",
        "link": "https://stackoverflow.com/questions/74003358/jq-how-to-add-double-quotes-for-string-values",
        "title": "jq: how to add double quotes for string values"
    },
    {
        "tags": [
            "bash",
            "sh",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 468289,
                    "reputation": 190915,
                    "user_id": 874188,
                    "user_type": "registered",
                    "accept_rate": 62,
                    "profile_image": "https://www.gravatar.com/avatar/091f411d57db5be8298e057a32e5ad72?s=256&d=identicon&r=PG",
                    "display_name": "tripleee",
                    "link": "https://stackoverflow.com/users/874188/tripleee"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1665314577,
                "post_id": 74004219,
                "comment_id": 130666724,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1665314576,
                "last_edit_date": 1665314576,
                "creation_date": 1665314463,
                "answer_id": 74004316,
                "question_id": 74004219,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Unlike in various other languages, in the shell, `return` isn&#39;t used to return a value but a status. So `return` can only return numerical values. See `help return`:\r\n\r\n```\r\n$ help return\r\nreturn: return [n]\r\n    Return from a shell function.\r\n    \r\n    Causes a function or sourced script to exit with the return value\r\n    specified by N.  If N is omitted, the return status is that of the\r\n    last command executed within the function or script.\r\n    \r\n    Exit Status:\r\n    Returns N, or failure if the shell is not executing a function or script.\r\n```\r\n\r\nIf you want to return a string, you need to print it. Or, if its the output of a command, just run the command. You should also [quote all variables][1] and avoid using CAPS for your shell variables since, by convention, global environment variables are in caps and this can lead to naming collisions and hard to debug bugs. So, try something like this:\r\n\r\n```\r\n#!/bin/bash\r\n\r\nfunction getHeader() {\r\n  jq &quot;.\\&quot;$1\\&quot;&quot; &lt;&lt;&lt; &quot;$2&quot;\r\n}\r\n\r\nresponse=&#39;{&quot;content-length&quot;:&quot;2&quot;,&quot;address&quot;:&quot;10.244.3.1:37930&quot;,&quot;path&quot;:&quot;/hello-world&quot;}&#39;\r\n\r\nprintf &#39;%s\\n&#39; &quot;$response&quot; | jq &#39;.&#39;\r\n\r\nx_header=$(getHeader  &quot;content-length&quot; &quot;$response&quot; )\r\n```\r\n\r\nAlso see [Why is printf better than echo?][2]\r\n\r\n\r\n  [1]: https://unix.stackexchange.com/q/171346/22222\r\n  [2]: https://unix.stackexchange.com/q/65803/22222",
                "title": "error : numeric argument required while executing jq command"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1665314576,
        "creation_date": 1665313729,
        "question_id": 74004219,
        "body_markdown": "Hi I am having a small shell script . however when i run the script it gives the error \r\n\r\n    sample.sh: line 5: return: null: numeric argument required\r\n\r\nThe following is my script\r\n\r\n    #!/bin/bash\r\n    \r\n    function getHeader() {\r\n    \r\n      return $(jq &#39;.&quot;$1&quot;&#39; &lt;&lt;&lt; $2)\r\n    \r\n    \r\n    }\r\n    \r\n    \r\n    RESPONSE=&#39;{&quot;content-length&quot;:&quot;2&quot;,&quot;address&quot;:&quot;10.244.3.1:37930&quot;,&quot;path&quot;:&quot;/hello-world&quot;}&#39;\r\n    \r\n    echo $RESPONSE | jq &#39;.&#39;\r\n    \r\n    x_header=$(getHeader  &quot;content-length&quot; $RESPONSE )\r\n\r\nI am also using jq library to handle the json data. In the above example i want the content-length value in the x_header variable\r\n\r\nappreciate if you can help",
        "link": "https://stackoverflow.com/questions/74004219/error-numeric-argument-required-while-executing-jq-command",
        "title": "error : numeric argument required while executing jq command"
    },
    {
        "tags": [
            "json",
            "stream",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1665387704,
                "last_edit_date": 1665387704,
                "creation_date": 1665384421,
                "answer_id": 74011094,
                "question_id": 74010890,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You need to understand how `1 | truncate_stream()` works before subsequently applying other filter expressions. The `truncate_stream()` prefixed with a non-zero integer is used to _remove_ paths specified by the integer in the streamed result.\r\n\r\ne.g.  if your original result produced the following`[path, value]` pairs\r\n\r\n```sh\r\njq -cn --stream &#39;inputs&#39; json\r\n[[&quot;empty&quot;],null]\r\n[[&quot;name&quot;],&quot;John Smith&quot;]\r\n[[&quot;sex&quot;],&quot;male&quot;]\r\n[[&quot;age&quot;],51]\r\n[[&quot;hobbies&quot;,0],&quot;running&quot;]\r\n[[&quot;hobbies&quot;,1],&quot;kayaking&quot;]\r\n[[&quot;hobbies&quot;,2],&quot;camping&quot;]\r\n[[&quot;hobbies&quot;,3],&quot;foraging&quot;]\r\n[[&quot;hobbies&quot;,3]]\r\n[[&quot;hobbies&quot;]]\r\n```\r\n\r\nTruncation with `1` would remove the first element of each path provided. Those with the paths removed are completely discarded from the output\r\n\r\n```sh\r\njq -cn --stream &#39;1|truncate_stream(inputs)&#39; json\r\n[[0],&quot;running&quot;]\r\n[[1],&quot;kayaking&quot;]\r\n[[2],&quot;camping&quot;]\r\n[[3],&quot;foraging&quot;]\r\n[[3]]\r\n```\r\n\r\nYour original attempt worked because, the `select` expression was able to get the desired paths to `hobbies`, with the parent root key `hobbies` removed, retaining only a list of elements.\r\n\r\nBut the same doesn&#39;t work for `age`, as you cannot completely trim down the path away. Remove the `[&quot;age&quot;]` entry would leave a result as `[[],51]` leaving only the value field.\r\n\r\n```sh\r\njq -cn --stream &#39;inputs|select(.[0][0] == &quot;age&quot;)&#39; json\r\n[[&quot;age&quot;],51]\r\n```\r\n\r\nIf a level is provided to the above expression, i.e. `1|..` the `age` path would be completely removed, making the `fromstream` not construct your object back.\r\n\r\nSo for simple scalars, simply extract away the value from the indices as below without needing to use truncate at all\r\n\r\n```sh\r\njq -cn --stream &#39;inputs|select(.[0][0] == &quot;age&quot;)[1]&#39;\r\n51\r\n```",
                "title": "Extracting values using jq streaming"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1665387704,
        "creation_date": 1665382960,
        "question_id": 74010890,
        "body_markdown": "I am trying to extract the values from a top-level JSON object using streaming with `jq`. For the sake of illustration, this is what the data look like (the actual data are rather large, hence needing to use streaming):\r\n\r\n```\r\n{\r\n        &quot;empty&quot;: null,\r\n        &quot;name&quot;: &quot;John Smith&quot;,\r\n        &quot;sex&quot;: &quot;male&quot;,\r\n        &quot;age&quot;: 51,\r\n        &quot;hobbies&quot;: [\r\n          &quot;running&quot;,\r\n          &quot;kayaking&quot;,\r\n          &quot;camping&quot;,\r\n          &quot;foraging&quot;\r\n         ]\r\n}\r\n```\r\n\r\nWithout streaming it&#39;s easy to get what I need:\r\n\r\n```\r\n$ jq &quot;.name&quot; sample.json \r\n&quot;John Smith&quot;\r\n$ jq &quot;.age&quot; sample.json \r\n51\r\n$ jq &quot;.hobbies&quot; sample.json \r\n[\r\n  &quot;running&quot;,\r\n  &quot;kayaking&quot;,\r\n  &quot;camping&quot;,\r\n  &quot;foraging&quot;\r\n]\r\n```\r\n\r\nWhen I use streaming I can get the value for the `&quot;hobbies&quot;` key:\r\n\r\n```\r\n$ jq -cn --stream &#39;fromstream(1|truncate_stream(inputs | select(.[0][0] == &quot;hobbies&quot;)))&#39; &lt;sample.json\r\n[&quot;running&quot;,&quot;kayaking&quot;,&quot;camping&quot;,&quot;foraging&quot;]\r\n```\r\n\r\nBut using the analogous command for the `&quot;name&quot;` or `&quot;age&quot;` keys gives an empty result:\r\n\r\n```\r\n$ jq -cn --stream &#39;fromstream(1|truncate_stream(inputs | select(.[0][0] == &quot;name&quot;)))&#39; &lt;sample.json\r\n$ jq -cn --stream &#39;fromstream(1|truncate_stream(inputs | select(.[0][0] == &quot;age&quot;)))&#39; &lt;sample.json\r\n```\r\n\r\nI suspect that this is because the value is a scalar. But I&#39;m not sure that this is the reason and, even if I was, I&#39;m not sure how to use that information.\r\n\r\nI discovered the `debug` operation which seems to yield some light on the situation.\r\n\r\n```\r\n$ jq -cn --stream &#39;fromstream(1|truncate_stream(inputs | select(.[0][0] == &quot;hobbies&quot;) | debug))&#39; &lt;sample.json\r\n[&quot;DEBUG:&quot;,[[&quot;hobbies&quot;,0],&quot;running&quot;]]\r\n[&quot;DEBUG:&quot;,[[&quot;hobbies&quot;,1],&quot;kayaking&quot;]]\r\n[&quot;DEBUG:&quot;,[[&quot;hobbies&quot;,2],&quot;camping&quot;]]\r\n[&quot;DEBUG:&quot;,[[&quot;hobbies&quot;,3],&quot;foraging&quot;]]\r\n[&quot;DEBUG:&quot;,[[&quot;hobbies&quot;,3]]]\r\n[&quot;running&quot;,&quot;kayaking&quot;,&quot;camping&quot;,&quot;foraging&quot;]\r\n[&quot;DEBUG:&quot;,[[&quot;hobbies&quot;]]]\r\n$ jq -cn --stream &#39;fromstream(1|truncate_stream(inputs | select(.[0][0] == &quot;name&quot;) | debug))&#39; &lt;sample.json\r\n[&quot;DEBUG:&quot;,[[&quot;name&quot;],&quot;John Smith&quot;]]\r\n$ jq -cn --stream &#39;fromstream(1|truncate_stream(inputs | select(.[0][0] == &quot;age&quot;) | debug))&#39; &lt;sample.json\r\n[&quot;DEBUG:&quot;,[[&quot;age&quot;],51]]\r\n```\r\n\r\nSo it looks like these values are being selected, but they are just not making it through to the output.\r\n\r\nAny suggestions would be appreciated! Thank you.",
        "link": "https://stackoverflow.com/questions/74010890/extracting-values-using-jq-streaming",
        "title": "Extracting values using jq streaming"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq",
            "ls"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1665439938,
                "last_edit_date": 1665439938,
                "creation_date": 1665388755,
                "answer_id": 74011760,
                "question_id": 74011653,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If you don&#39;t have any &quot;problematic&quot; file names, e.g. ones that have new lines as part of their name, the following should work:\r\n\r\n```\r\nls -1 | jq -Rn &#39;{ listoffiles: [inputs | { file: &quot;prefix/\\(.)&quot; }] }&#39;\r\n```\r\n\r\nIt reads each line as string, and reads them through the `inputs` filter (must be combined with `-n` null-input). It then builds your object.\r\n\r\n```\r\n$ cat &lt;&lt;LS | jq -Rn &#39;{ listoffiles: [inputs | {file:&quot;prefix/\\(.)&quot;}] }&#39;\r\nfile1\r\nfile2\r\nfile with spaces\r\nLS\r\n{\r\n  &quot;listoffiles&quot;: [\r\n    {\r\n      &quot;file&quot;: &quot;prefix/file1&quot;\r\n    },\r\n    {\r\n      &quot;file&quot;: &quot;prefix/file2&quot;\r\n    },\r\n    {\r\n      &quot;file&quot;: &quot;prefix/file with spaces&quot;\r\n    }\r\n  ]\r\n}\r\n```\r\n\r\nYou _could_ use `for` with a glob which should handle new lines in file names as well. But it requires you to chain 2 jq commands:\r\n\r\n```\r\nfor f in *; do\r\n  printf &#39;%s&#39; &quot;$f&quot; | jq -Rs &#39;{file:&quot;prefix/\\(.)&quot;}&#39;;\r\ndone | jq -s &#39;{listoffiles:.}&#39;\r\n```\r\n\r\nTo specify the prefix as variable from the outside, use `--arg`, e.g.\r\n\r\n```\r\njq --arg prefix &quot;yourprefixvalue&quot; &#39;$prefix + .&#39;\r\n```",
                "title": "get files from directory in bash and build JSON object using jq"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1665389346,
                "last_edit_date": 1665389346,
                "creation_date": 1665389044,
                "answer_id": 74011810,
                "question_id": 74011653,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You [shouldn&#39;t](https://unix.stackexchange.com/questions/128985/why-not-parse-ls-and-what-to-do-instead) parse the output of `ls`. If installed, you could use `tree` with the `-J` option to produce a JSON listing, which you can transform to your needs using `jq`:\r\n~~~sh\r\ntree -aJL 1 | jq &#39;\r\n  {listoffiles: first.contents | map({file: (&quot;myawesomeprefix/&quot; + .name)})}\r\n&#39;\r\n~~~\r\n\r\nOr more comfortably using `--arg`:\r\n~~~sh\r\ntree -aJL 1 | jq --arg prefix myawesomeprefix &#39;\r\n  {listoffiles: first.contents | map({file: &quot;\\($prefix)/\\(.name)&quot;})}\r\n&#39;",
                "title": "get files from directory in bash and build JSON object using jq"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1665390079,
                "creation_date": 1665390079,
                "answer_id": 74012008,
                "question_id": 74011653,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "This is another alternative :\r\n\r\n```\r\njq -n --arg prefix &quot;myawesomeprefix&quot;\\\r\n    &#39;.listoffiles = ($ARGS.positional |\r\n                     map({file:($prefix+&quot;/&quot;+.)}))&#39;\\\r\n    --args *\r\n```",
                "title": "get files from directory in bash and build JSON object using jq"
            },
            {
                "up_vote_count": 4,
                "is_accepted": false,
                "score": 4,
                "last_activity_date": 1665522325,
                "last_edit_date": 1665522325,
                "creation_date": 1665391066,
                "answer_id": 74012179,
                "question_id": 74011653,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can try the nice little command line tool ```jc```:\r\n\r\n    ls | jc --ls\r\n\r\nIt converts the output of many shell commands to JSON. For reference have a look there in Github https://github.com/kellyjonbrazil/jc .\r\n\r\nThen you can transform the result using ```jq```:\r\n\r\n    ls | jc --ls | jq &quot;{ listoffiles: [.[] | { file: (\\&quot;$prefix/\\&quot; + .filename) }] }&quot;",
                "title": "get files from directory in bash and build JSON object using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 4,
        "score": 2,
        "last_activity_date": 1665522325,
        "creation_date": 1665388111,
        "last_edit_date": 1665435394,
        "question_id": 74011653,
        "body_markdown": "I am trying to build list of JSON objects with the files in a particular directory. I am looping thru the `files` and creating the expected output object as string. I am sure there is a better way of doing this using `jq`.\r\n\r\nCan someone please help me out here?\r\n\r\n \r\n    # input\r\n    files=($( ls * )) \r\n    prefix=&quot;myawesomeprefix&quot;\r\n    # expected output\r\n\r\n    {\r\n      &quot;listoffiles&quot;: [\r\n        {&quot;file&quot;:&quot;myawesomeprefix/file1.txt&quot;},\r\n        {&quot;file&quot;:&quot;myawesomeprefix/file2.txt&quot;},\r\n        {&quot;file&quot;:&quot;myawesomeprefix/file3.txt&quot;},\r\n     ]\r\n    }\r\n\r\n",
        "link": "https://stackoverflow.com/questions/74011653/get-files-from-directory-in-bash-and-build-json-object-using-jq",
        "title": "get files from directory in bash and build JSON object using jq"
    },
    {
        "tags": [
            "arrays",
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1665427163,
                "post_id": 74012228,
                "comment_id": 130693249,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1665397323,
                "last_edit_date": 1665397323,
                "creation_date": 1665391797,
                "answer_id": 74012321,
                "question_id": 74012228,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If the arrays fit your memory, you can make two copies, shift them one apart to each other, transpose and subtract:\r\n~~~sh\r\n.values | [.[:-1], .[1:]] | transpose[]\r\n| &quot;\\(.[1][0]),\\(map(.[1] | tonumber) | .[1]-.[0])&quot;\r\n~~~\r\n[Demo](https://jqplay.org/s/52urnHqq2HO)\r\n\r\nAlternatively, you can use either `foreach` or `while` to iterate over a window of two adjacent items:\r\n~~~sh\r\n.values | foreach .[1:][] as $v ([null, .[0]]; .[1:] + [$v];\r\n  &quot;\\(.[1][0]),\\(map(.[1] | tonumber) | .[1]-.[0])&quot;\r\n)\r\n~~~\r\n[Demo](https://jqplay.org/s/DixOP5eVlVv)\r\n\r\n~~~sh\r\n.values | while(has(1); .[1:])[:2]\r\n| &quot;\\(.[1][0]),\\(map(.[1] | tonumber) | .[1]-.[0])&quot;\r\n~~~\r\n[Demo](https://jqplay.org/s/m4JEIqYW1EI)\r\n\r\n\r\nOutput:\r\n~~~sh\r\n1665129236,1\r\n1665129266,1\r\n1665129296,5\r\n~~~\r\n",
                "title": "how to use jq to get the gap value between array"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1665392388,
                "creation_date": 1665392388,
                "answer_id": 74012423,
                "question_id": 74012228,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Building on [pmf&#39;s excellent answer](https://stackoverflow.com/a/74012321/112968):\r\n\r\n```\r\n.values[][1] |= tonumber\r\n| [.values[1:], .values[:-1]]\r\n| transpose[]\r\n| [\r\n  first[0],\r\n  (map(last) | first-last)\r\n]\r\n| join(&quot;,&quot;)\r\n```\r\n\r\nSince all your values are numbers, the final `join` filter could be replaced with `@csv`.",
                "title": "how to use jq to get the gap value between array"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1665433495,
                "creation_date": 1665433495,
                "answer_id": 74020344,
                "question_id": 74012228,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s a solution that uses a generic `derivative` function that has already been used elsewhere on SO:\r\n```\r\n# Input: an array\r\n# `delta` should be a non-negative integer, typically 1;\r\n# p is the jq path expression to the quantity within an item, e.g. `.`\r\ndef derivative(delta; p):\r\n  . as $in\r\n  | [ range(delta; length) as $i\r\n      | .[$i]\r\n      | (p = ($in[$i] | p) - ($in[$i - delta] | p)) ];\r\n\r\n.values |=\r\n  (map(.[1] |= tonumber)\r\n   | derivative( 1; .[1]))\r\n\r\n```\r\n",
                "title": "how to use jq to get the gap value between array"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 0,
        "last_activity_date": 1665458689,
        "creation_date": 1665391271,
        "last_edit_date": 1665458689,
        "question_id": 74012228,
        "body_markdown": "**I had the following json array:**\r\n```json\r\n{\r\n  &quot;metric&quot;: {\r\n    &quot;instance&quot;: &quot;100.120.207.215:8081&quot;,\r\n    &quot;job&quot;: &quot;job1&quot;,\r\n    &quot;error_code&quot;: &quot;500&quot;\r\n  },\r\n  &quot;values&quot;: [\r\n    [\r\n      1665129206,\r\n      &quot;128&quot;\r\n    ],\r\n    [\r\n      1665129236,\r\n      &quot;129&quot;\r\n    ],\r\n    [\r\n      1665129266,\r\n      &quot;130&quot;\r\n    ],\r\n    [\r\n      1665129296,\r\n      &quot;135&quot;\r\n    ]\r\n  ]\r\n}\r\n```\r\nI want to get the difference between each array, looks like\r\n```\r\n1665129236,1\r\n1665129266,1\r\n1665129296,5\r\n```\r\nPlease help on it. Thanks a lot.\r\n\r\n",
        "link": "https://stackoverflow.com/questions/74012228/how-to-use-jq-to-get-the-gap-value-between-array",
        "title": "how to use jq to get the gap value between array"
    },
    {
        "tags": [
            "json",
            "path",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 5,
                "is_accepted": true,
                "score": 5,
                "last_activity_date": 1665438235,
                "creation_date": 1665438235,
                "answer_id": 74020943,
                "question_id": 74020796,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You could use `index` to check if you keys are in the `path` array:\r\n```\r\npath(..) | select(index(&quot;a&quot;) or index(&quot;b&quot;)) | join(&quot;.&quot;)\r\n```\r\n\r\n```\r\n&quot;parent2.a&quot;\r\n&quot;parent2.b&quot;\r\n&quot;parent3.child1.a&quot;\r\n&quot;parent3.child2.b&quot;\r\n```\r\n\r\n### [JqPlay demo]( https://jqplay.org/s/S0mBX56p2Ik) \r\n\r\n\r\n----------\r\n\r\nIf you don&#39;t want the last key, you could add `[:-1]` to &#39;remove&#39; the last index in each array to output: \r\n```none\r\npath(..) | select(index(&quot;a&quot;) or index(&quot;b&quot;))[:-1] | join(&quot;.&quot;)\r\n```\r\n```none\r\n&quot;parent2&quot;\r\n&quot;parent2&quot;\r\n&quot;parent3.child1&quot;\r\n&quot;parent3.child2&quot;\r\n```\r\n\r\n### [JqPlay demo](https://jqplay.org/s/sTupEwb1tPm)",
                "title": "How to generate all JSON paths conditionally with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1665467563,
        "creation_date": 1665436993,
        "last_edit_date": 1665467563,
        "question_id": 74020796,
        "body_markdown": "I have arbitrarily nested JSON objects similar to below. \r\n\r\n```\r\n{\r\n  &quot;parent1&quot; : &quot;someval&quot;`,\r\n  &quot;parent2&quot; : {\r\n     &quot;a&quot; : &quot;someval&quot;,\r\n     &quot;b&quot; : &quot;someval&quot;\r\n   },\r\n  &quot;parent3&quot; : {\r\n     &quot;child1&quot; : { \r\n        &quot;a&quot; : &quot;someval&quot;\r\n      },\r\n     &quot;child2&quot; : { \r\n        &quot;b&quot; : &quot;someval&quot;\r\n      }\r\n   }\r\n}\r\n```\r\n\r\nI need to recursively go through them and check to see if any parent has children keys ```a``` or ```b```, or both, and generate the JSON path to that parent like so: \r\n\r\n```\r\nOutput:\r\nparent2 \r\nparent3.child1\r\nparent3.child2\r\n``` \r\n\r\nI have tried using \r\n\r\n```\r\njq -r &#39;path(..) | map (. | tostring) | join (&quot;.&quot;)\r\n```\r\n\r\nWhich helps me generate all paths, but I haven&#39;t found a way to combine conditions like ```has(&quot;a&quot;)``` with ```path``` successfully. How can I go about achieving this ?\r\n",
        "link": "https://stackoverflow.com/questions/74020796/how-to-generate-all-json-paths-conditionally-with-jq",
        "title": "How to generate all JSON paths conditionally with jq"
    },
    {
        "tags": [
            "bash",
            "curl",
            "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": 1665468372,
                "post_id": 74023537,
                "comment_id": 130700879,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1665469567,
                "creation_date": 1665469567,
                "answer_id": 74023820,
                "question_id": 74023537,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The gitlab documentation says:\r\n\r\n&gt; When accessed without authentication, this endpoint also supports keyset pagination:\r\n\r\n&gt; When requesting consecutive pages of results, we recommend you use keyset pagination.\r\nBeyond a specific offset limit (specified by max offset allowed by the REST API for offset-based pagination), offset pagination is unavailable.\r\n\r\n\r\nSee https://docs.gitlab.com/ee/api/index.html#keyset-based-pagination for more details about keyset pagination.  You will have to call curl repeatedly until there are no more results:\r\n\r\n&gt; When the end of the collection is reached and there are no additional records to retrieve, the Link header is absent and the resulting array is empty. We recommend using only the given link to retrieve the next page instead of building your own URL. \r\n\r\n\r\nThe retrieved JSON documents can then can be fed to jq.",
                "title": "unable to extract the group under gitlab through API call"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -1,
        "last_activity_date": 1665469567,
        "creation_date": 1665467769,
        "last_edit_date": 1665468338,
        "question_id": 74023537,
        "body_markdown": "I am using shell script to list out all the group under GITLAB. its huge number of list how can we find out all groups, its more than 30 seems. and iterate through it to find out ID of group?\r\nif any other solution please suggest to list all the group ID.\r\n\r\n    grouplist=$(curl --header &quot;PRIVATE-TOKEN: $1&quot; &quot;https://gitlab.com/api/v4/groups?per_page=100&amp;page=30&quot; | jq -r &#39;.[].id&#39;)",
        "link": "https://stackoverflow.com/questions/74023537/unable-to-extract-the-group-under-gitlab-through-api-call",
        "title": "unable to extract the group under gitlab through API call"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1665487998,
                "last_edit_date": 1665487998,
                "creation_date": 1665487181,
                "answer_id": 74027273,
                "question_id": 74027159,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Either perform setting the value first (where you could simply use `=` to set the new value as it does not depend on the old one), then use `map({name, origins})` to get your expected output reduction:\r\n~~~sh\r\n(.[].origins[] | select(.address == &quot;1.1.1.1&quot;)).weight = 0\r\n| map({name, origins})\r\n~~~\r\n[Demo](https://jqplay.org/s/MB7iKLrzdqw)\r\n\r\nOr combine both within the `map` in one go:\r\n~~~sh\r\nmap(\r\n  {name, origins}\r\n  | .origins[] |= (select(.address == &quot;1.1.1.1&quot;).weight = 0)\r\n)\r\n~~~\r\n[Demo](https://jqplay.org/s/RTgOdi-gLj0)\r\n\r\nOutput:\r\n~~~json\r\n[\r\n  {\r\n    &quot;name&quot;: &quot;test&quot;,\r\n    &quot;origins&quot;: [\r\n      {\r\n        &quot;name&quot;: &quot;AAAA&quot;,\r\n        &quot;address&quot;: &quot;1.1.1.1&quot;,\r\n        &quot;enabled&quot;: true,\r\n        &quot;weight&quot;: 0,\r\n        &quot;healthy&quot;: true,\r\n        &quot;failure_reason&quot;: &quot;No failures&quot;\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;BBBB&quot;,\r\n        &quot;address&quot;: &quot;2.2.2.2&quot;,\r\n        &quot;enabled&quot;: true,\r\n        &quot;weight&quot;: 1,\r\n        &quot;healthy&quot;: true,\r\n        &quot;failure_reason&quot;: &quot;No failures&quot;\r\n      }\r\n    ]\r\n  }\r\n]\r\n~~~\r\n",
                "title": "modify json with jq"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1665488047,
                "creation_date": 1665488047,
                "answer_id": 74027438,
                "question_id": 74027159,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s a slightly different version, but pmf&#39;s answer is preferable.\r\n\r\n```\r\nmap({\r\n    name,\r\n    origins: .origins | map(select(.address==&quot;1.1.1.1&quot;).weight = 0)\r\n})\r\n```",
                "title": "modify json with jq"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1665520482,
                "creation_date": 1665520482,
                "answer_id": 74033830,
                "question_id": 74027159,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If for whatever reason you want to avoid assignments with complex left-hand-sides (e.g., if you want portability across various versions of jq and jq look-alikes):\r\n```\r\nmap( {name, origins} \r\n     | .origins |= map( if .address == &quot;1.1.1.1&quot; then .weight = 0 else . end) )\r\n```",
                "title": "modify json with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 0,
        "last_activity_date": 1665520482,
        "creation_date": 1665486633,
        "question_id": 74027159,
        "body_markdown": "I would like to use JQ to modify the following JSON input:\r\n\r\n```\r\n[\r\n  {\r\n    &quot;description&quot;: &quot;&quot;,\r\n    &quot;created_on&quot;: &quot;2021-12-27T11:32:03.171682Z&quot;,\r\n    &quot;modified_on&quot;: &quot;2021-12-27T11:32:03.171682Z&quot;,\r\n    &quot;id&quot;: &quot;test&quot;,\r\n    &quot;enabled&quot;: true,\r\n    &quot;minimum_origins&quot;: 1,\r\n    &quot;monitor&quot;: &quot;test&quot;,\r\n    &quot;name&quot;: &quot;test&quot;,\r\n    &quot;notification_email&quot;: &quot;&quot;,\r\n    &quot;check_regions&quot;: null,\r\n    &quot;latitude&quot;: 43.7417,\r\n    &quot;longitude&quot;: -79.3733,\r\n    &quot;notification_filter&quot;: {\r\n      &quot;pool&quot;: {}\r\n    },\r\n    &quot;healthy&quot;: true,\r\n    &quot;origins&quot;: [\r\n      {\r\n        &quot;name&quot;: &quot;AAAA&quot;,\r\n        &quot;address&quot;: &quot;1.1.1.1&quot;,\r\n        &quot;enabled&quot;: true,\r\n        &quot;weight&quot;: 1,\r\n        &quot;healthy&quot;: true,\r\n        &quot;failure_reason&quot;: &quot;No failures&quot;\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;BBBB&quot;,\r\n        &quot;address&quot;: &quot;2.2.2.2&quot;,\r\n        &quot;enabled&quot;: true,\r\n        &quot;weight&quot;: 1,\r\n        &quot;healthy&quot;: true,\r\n        &quot;failure_reason&quot;: &quot;No failures&quot;\r\n      }\r\n    ]\r\n  }\r\n]\r\n```\r\nif address == 1.1.1.1 then weight 0\r\n\r\n\r\nthat&#39;s what i expect\r\n\r\n```\r\n[\r\n  {\r\n    &quot;name&quot;: &quot;test&quot;,\r\n    &quot;origins&quot;: [\r\n      {\r\n        &quot;name&quot;: &quot;AAAA&quot;,\r\n        &quot;address&quot;: &quot;1.1.1.1&quot;,\r\n        &quot;enabled&quot;: true,\r\n        &quot;weight&quot;: 0,\r\n        &quot;healthy&quot;: true,\r\n        &quot;failure_reason&quot;: &quot;No failures&quot;\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;BBBB&quot;,\r\n        &quot;address&quot;: &quot;2.2.2.2&quot;,\r\n        &quot;enabled&quot;: true,\r\n        &quot;weight&quot;: 1,\r\n        &quot;healthy&quot;: true,\r\n        &quot;failure_reason&quot;: &quot;No failures&quot;\r\n      }\r\n    ]\r\n  }\r\n]\r\n```\r\n\r\nmy best attempt but it doesn&#39;t fit my format. I tried many different options but could not find the correct code\r\n\r\n**(.[].origins[] | select(.address == &quot;1.1.1.1&quot;) | .weight ) |= 0**\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/74027159/modify-json-with-jq",
        "title": "modify json with jq"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 6196394,
                    "reputation": 86601,
                    "user_id": 5291015,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/4tAvO.jpg?s=256",
                    "display_name": "Inian",
                    "link": "https://stackoverflow.com/users/5291015/inian"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1665493831,
                "post_id": 74028696,
                "comment_id": 130709666,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 6196394,
                    "reputation": 86601,
                    "user_id": 5291015,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/4tAvO.jpg?s=256",
                    "display_name": "Inian",
                    "link": "https://stackoverflow.com/users/5291015/inian"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1665493874,
                "post_id": 74028696,
                "comment_id": 130709682,
                "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": 1665493974,
                "post_id": 74028696,
                "comment_id": 130709722,
                "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": 1665494216,
                "post_id": 74028696,
                "comment_id": 130709826,
                "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": 1665495416,
                "post_id": 74028696,
                "comment_id": 130710357,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2186012,
                    "reputation": 22650,
                    "user_id": 1934428,
                    "user_type": "registered",
                    "accept_rate": 86,
                    "profile_image": "https://www.gravatar.com/avatar/072774c5d4204a1c2385560e6114a887?s=256&d=identicon&r=PG",
                    "display_name": "user1934428",
                    "link": "https://stackoverflow.com/users/1934428/user1934428"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1665498614,
                "post_id": 74028696,
                "comment_id": 130711843,
                "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": 1665501581,
                "post_id": 74028696,
                "comment_id": 130712943,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1665494810,
                "creation_date": 1665494810,
                "answer_id": 74028907,
                "question_id": 74028696,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If we rewrite your data until it&#39;s actually _valid_, an answer might look like:\r\n\r\n```\r\njq -rn &#39;\r\n([ &quot;Id&quot;, &quot;paymentId&quot;, &quot;motthamAmount&quot;, &quot;currency&quot; ] | @csv),\r\n(inputs | .counts.counts[] | [\r\n  ._source.payload.ID, \r\n  ._source.payload.paymentId, \r\n  ._source.payload.dabbulluInfo.motthamAmount, \r\n  ._source.payload.dabbulluInfo.currency\r\n] | @csv)\r\n&#39; &lt;test.json\r\n```\r\n\r\nSee this functioning at https://replit.com/@CharlesDuffy2/RequiredInfiniteComment#main.sh",
                "title": "parsing/extract json data with jq"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1665496573,
                "last_edit_date": 1665496573,
                "creation_date": 1665495991,
                "answer_id": 74029207,
                "question_id": 74028696,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s another attempt trying to reuse traversal:\r\n~~~sh\r\njq -r &#39;\r\n  [&quot;Id&quot;, &quot;paymentId&quot;, &quot;motthamAmount&quot;, &quot;curreny&quot;], (\r\n    .counts.counts[]._source.payload\r\n    | [.ID, .paymentId, (.dabbulluInfo | .motthamAmount, .currency)]\r\n  ) | @csv\r\n&#39;\r\n~~~\r\n~~~none\r\n&quot;Id&quot;,&quot;paymentId&quot;,&quot;motthamAmount&quot;,&quot;curreny&quot;\r\n&quot;11390&quot;,&quot;LSDLSLS-LSLSLSLs-KGOGK&quot;,&quot;331&quot;,&quot;INR&quot;\r\n~~~\r\n[Demo](https://jqplay.org/s/xH-MV0rn_lE)",
                "title": "parsing/extract json data with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1665496573,
        "creation_date": 1665493707,
        "question_id": 74028696,
        "body_markdown": "Please help me to extract json data. i tried to fetch the data with some jq queriesm but results came as line-by-line  \r\n\r\n```\r\ncat test.json\r\n..\r\n{\r\n  &quot;took&quot; : 43,\r\n  &quot;timed_out&quot; : false,\r\n  &quot;cardss&quot; : {\r\n    &quot;values&quot; : 0,\r\n    &quot;faileds&quot; : 0\r\n  },\r\n &quot;counts&quot; : {\r\n    &quot;total&quot; : 200,\r\n    &quot;max_hint&quot; : 1.0000004,\r\n\t&quot;counts&quot; : [\r\n      {\r\n        &quot;_index&quot; : &quot;test_90.008.&quot;,\r\n        &quot;_type&quot; : &quot;fluentdd&quot;,\r\n        &quot;_id&quot; : &quot;SLSLSLSLSLLSdfsdhjdshfdshfdshfkjdsfdsfsfdsf&quot;,\r\n        &quot;_score&quot; : 1.0000004,\r\n        &quot;_source&quot; : {\r\n          &quot;payload&quot; : &quot;&quot;&quot;{&quot;ID&quot;:&quot;11390&quot;,&quot;Key&quot;:&quot;SKSKDISKSK&quot;,&quot;paymentId&quot;:&quot;LSDLSLS-LSLSLSLs-KGOGK&quot;,&quot;bunkoinfo&quot;:{&quot;janaluID&quot;:&quot;918282827&quot;,&quot;ipAddress&quot;:&quot;0.0.0.0&quot;,&quot;chethiid&quot;:&quot;fkfkfkfkfkfkfkfkfkkf&quot;},&quot;dabbulluInfo&quot;:{&quot;checkType&quot;:&quot;mundhucheck&quot;,&quot;currency&quot;:&quot;INR&quot;,&quot;method&quot;:&quot;paper&quot;,&quot;motthamAmount&quot;:&quot;331&quot;,&quot;cards&quot;:{&quot;cardsToken&quot;:&quot;2021000&quot;,&quot;upicodes&quot;:&quot;331&quot;,&quot;cardchettha&quot;:&quot;6739837&quot;,&quot;digitcardss&quot;:&quot;0000&quot;,&quot;kaliDate&quot;:&quot;00000&quot;}},&quot;PackOrdetls&quot;:[{&quot;items&quot;:[{&quot;itemName&quot;:&quot;00&quot;,&quot;quantity&quot;:&quot;0&quot;,&quot;price&quot;:&quot;331&quot;}]}],&quot;dtdcid&quot;:&quot;kskdkskdsjsjsjdososlsksj&quot;}&quot;&quot;&quot;\r\n        }\r\n      },\r\n\r\n  }\r\n}\r\n```\r\n\r\nrequired output is below, please support. \r\n```\r\nId,paymentId,motthamAmount,curreny\r\n11390,LSDLSLS-LSLSLSLs-KGOGK,331,INR\r\n```\r\n\r\ni tried \r\n\r\n```\r\ncat test.json  | jq -r &#39;.counts.counts[]._source.payload.ID, .counts.counts[]._source.payload.paymentId, .counts.counts[]._source.payload.dabbulluInfo.motthamAmount, .counts.counts[]._source.payload.dabbulluInfo.currency&#39;\r\n\r\ngot output as one-by-one \r\n\r\n\r\n11390\r\nLSDLSLS-LSLSLSLs-KGOGK\r\n331\r\nINR\r\n```",
        "link": "https://stackoverflow.com/questions/74028696/parsing-extract-json-data-with-jq",
        "title": "parsing/extract json data with jq"
    },
    {
        "tags": [
            "unix",
            "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": 1665535968,
                "post_id": 74035356,
                "comment_id": 130721942,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1665586601,
                "last_edit_date": 1665586601,
                "creation_date": 1665535900,
                "answer_id": 74035378,
                "question_id": 74035356,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "```bash\r\n{ shopt -s nullglob; set -- *.txt; printf &#39;%s\\0&#39; &quot;$@&quot;; } | jq -Rn &#39;\r\n  {&quot;&quot;: [ input\r\n         | split(&quot;\\u0000&quot;)[]\r\n         | select(. != &quot;&quot;)\r\n         | {&quot;title&quot;: &quot;&quot;,\r\n            &quot;file&quot;: . | rtrimstr(&quot;.txt&quot;)\r\n           }\r\n       ]\r\n  }\r\n&#39;\r\n```\r\n\r\nLet&#39;s break this down into pieces.\r\n\r\nOn the bash side:\r\n\r\n- `shopt -s nullglob` tells the shell that if `*.txt` has no arguments, it should emit _nothing at all_, instead of emitting the string `*.txt` as a result.\r\n- `set --` overwrites the argument list in the current context (because this is a block on the left-hand side of the pipeline that context is transient and won&#39;t change `&quot;$@&quot;` in code outside the pipe).\r\n- `printf &#39;%s\\0&#39; &quot;$@&quot;` prints our arguments, with a NUL character after each one; if there are no arguments at all, it prints only a NUL.\r\n\r\nOn the jq side:\r\n\r\n- `-R` specifies that the input is raw data, not json.\r\n- `-n` specifies that we don&#39;t automatically consume any inputs, but will instead use `input` or `inputs` to specify where input should be read.\r\n- `split(&quot;\\u0000&quot;)` splits the input on NULs. (This is important because the NUL is the only character that can&#39;t exist in a filename, which is why we used `printf &#39;%s\\0&#39;` on the shell end; that way we work correctly with filenames with newlines, literal quotes, whitespace, and all the other weirdness that&#39;s able to exist).\r\n- `select(. != &quot;&quot;)` ignores empty strings.\r\n- `rtrimstr(&quot;.txt&quot;)` removes `.txt` from the name.\r\n\r\n---\r\n\r\n### Addendum: Sorting by mtime\r\n\r\nThe jq parts don&#39;t need to be modified here: to sort by mtime you can adjust only the shell. On a system with GNU `find`, `sort` and `sed`, this might look like:\r\n\r\n```bash\r\nfind . -maxdepth 1 -type f -name &#39;*.txt&#39; -printf &#39;%T@ %P\\0&#39; |\r\n  sort -zn |\r\n  sed -z -re &#39;s/^[[:digit:].]+ //g&#39; |\r\n  jq -Rn &#39;\r\n```\r\n\r\n...followed by the same jq given above.",
                "title": "How to put specific filenames into a specific JSON format using bash or Perl?"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1665536513,
                "creation_date": 1665536513,
                "answer_id": 74035423,
                "question_id": 74035356,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Using just `jq`, any shell:\r\n\r\n```sh\r\n$&#160;jq  -n --args &#39;{&quot;&quot;: [ $ARGS.positional[] | rtrimstr(&quot;.txt&quot;) | { title: &quot;&quot;, file: . } ] }&#39; *.txt \r\n{\r\n  &quot;&quot;: [\r\n    {\r\n      &quot;title&quot;: &quot;&quot;,\r\n      &quot;file&quot;: &quot;1&quot;\r\n    },\r\n    {\r\n      &quot;title&quot;: &quot;&quot;,\r\n      &quot;file&quot;: &quot;2&quot;\r\n    },\r\n    {\r\n      &quot;title&quot;: &quot;&quot;,\r\n      &quot;file&quot;: &quot;3&quot;\r\n    }\r\n  ]\r\n}\r\n```\r\n\r\nThe filenames passed on the command line (The expansion of `*.txt` are in the jq variable `$ARGS.positional`. For each one, remove the .txt extension and use the rest in a object of the desired structure.\r\n\r\nOr with a perl one-liner:\r\n\r\n```sh\r\n$ perl -MJSON::PP -E &#39;say encode_json({&quot;&quot; =&gt; [ map { { title =&gt; &quot;&quot;, file =&gt; s/\\.txt$//r } } @ARGV ] })&#39; *.txt\r\n{&quot;&quot;:[{&quot;file&quot;:&quot;1&quot;,&quot;title&quot;:&quot;&quot;},{&quot;title&quot;:&quot;&quot;,&quot;file&quot;:&quot;2&quot;},{&quot;file&quot;:&quot;3&quot;,&quot;title&quot;:&quot;&quot;}]}\r\n```",
                "title": "How to put specific filenames into a specific JSON format using bash or Perl?"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1665580747,
                "creation_date": 1665580747,
                "answer_id": 74042531,
                "question_id": 74035356,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If installed, `tree` can be a good alternative to list the contents of directories as it can encode its output as well-defined JSON which comes in handy when dealing with strange file names (and especially when your desired output is JSON anyways).\r\n~~~sh\r\ntree -JtL 1 -P &#39;*.txt&#39;\r\n~~~\r\n~~~json\r\n[\r\n  {&quot;type&quot;:&quot;directory&quot;,&quot;name&quot;:&quot;.&quot;,&quot;contents&quot;:[\r\n    {&quot;type&quot;:&quot;file&quot;,&quot;name&quot;:&quot;3.txt&quot;},\r\n    {&quot;type&quot;:&quot;file&quot;,&quot;name&quot;:&quot;2.txt&quot;},\r\n    {&quot;type&quot;:&quot;file&quot;,&quot;name&quot;:&quot;1.txt&quot;}\r\n  ]}\r\n,\r\n  {&quot;type&quot;:&quot;report&quot;,&quot;directories&quot;:0,&quot;files&quot;:3}\r\n]\r\n~~~\r\n\r\n- `tree -J` outputs JSON\r\n- `tree -t` sorts by last modification time\r\n- `tree -L 1` recurses only `1` level deep\r\n- `tree -P &#39;*.txt&#39;` reduces the the list to file pattern `*.txt`\r\n\r\nOf course, you can also add more details, if needed, such as\r\n\r\n- `tree -p` includes file permissions\r\n- `tree -u` and `tree -g` include user and group names\r\n- `tree -s` includes the file size in bytes\r\n- `tree -D --timefmt &#39;%F %T&#39;` includes the last modification time\r\n\r\n~~~sh\r\ntree -JtL 1 -P &#39;*.txt&#39; -pusD --timefmt=&#39;%F %T&#39;\r\n~~~\r\n~~~json\r\n[\r\n  {&quot;type&quot;:&quot;directory&quot;,&quot;name&quot;:&quot;.&quot;,&quot;mode&quot;:&quot;0755&quot;,&quot;prot&quot;:&quot;drwxr-xr-x&quot;,&quot;user&quot;:&quot;hustnzj&quot;,&quot;size&quot;:4096,&quot;time&quot;:&quot;2022-10-12 09:35:00&quot;,&quot;contents&quot;:[\r\n    {&quot;type&quot;:&quot;file&quot;,&quot;name&quot;:&quot;3.txt&quot;,&quot;mode&quot;:&quot;0644&quot;,&quot;prot&quot;:&quot;-rw-r--r--&quot;,&quot;user&quot;:&quot;hustnzj&quot;,&quot;size&quot;:123,&quot;time&quot;:&quot;2022-10-12 09:35:05&quot;},\r\n    {&quot;type&quot;:&quot;file&quot;,&quot;name&quot;:&quot;2.txt&quot;,&quot;mode&quot;:&quot;0644&quot;,&quot;prot&quot;:&quot;-rw-r--r--&quot;,&quot;user&quot;:&quot;hustnzj&quot;,&quot;size&quot;:456,&quot;time&quot;:&quot;2022-10-12 09:35:08&quot;},\r\n    {&quot;type&quot;:&quot;file&quot;,&quot;name&quot;:&quot;1.txt&quot;,&quot;mode&quot;:&quot;0644&quot;,&quot;prot&quot;:&quot;-rw-r--r--&quot;,&quot;user&quot;:&quot;hustnzj&quot;,&quot;size&quot;:789,&quot;time&quot;:&quot;2022-10-12 09:35:12&quot;}\r\n  ]}\r\n,\r\n  {&quot;type&quot;:&quot;report&quot;,&quot;directories&quot;:0,&quot;files&quot;:3}\r\n]\r\n~~~\r\n&gt; A note regarding [this comment](https://stackoverflow.com/questions/74035356/how-to-put-specific-filenames-into-a-specific-json-format-using-bash-or-perl#comment130723331_74035378): `tree -t` sorts by last modification time. There&#39;s also an option `tree -c` to sort by (and with `tree -D` to show time as) last status change instead, but there&#39;s no dedicated option (I know of) that uses creation/birth times (if supported by the file system).\r\n\r\n\r\nThen, using that JSON output as input, you can employ `jq` for further filtering and formatting:\r\n~~~sh\r\ntree … | jq --arg ext &#39;.txt&#39; &#39;\r\n  {&quot;&quot;: (first.contents | map(\r\n    select(.type == &quot;file&quot;) | {title: &quot;&quot;, file: .name | rtrimstr($ext)}\r\n  ))}\r\n&#39;\r\n~~~\r\n~~~json\r\n{\r\n  &quot;&quot;: [\r\n    {\r\n      &quot;title&quot;: &quot;&quot;,\r\n      &quot;file&quot;: &quot;3&quot;\r\n    },\r\n    {\r\n      &quot;title&quot;: &quot;&quot;,\r\n      &quot;file&quot;: &quot;2&quot;\r\n    },\r\n    {\r\n      &quot;title&quot;: &quot;&quot;,\r\n      &quot;file&quot;: &quot;1&quot;\r\n    }\r\n  ]\r\n}\r\n~~~\r\n[Demo](https://jqplay.org/s/BKYGHqnMtxb)\r\n\r\nNote: This includes the filter `select(.type == &quot;file&quot;)` as `tree` would also include the names of subdirectories. Drop it if you want them included.",
                "title": "How to put specific filenames into a specific JSON format using bash or Perl?"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1665585093,
                "creation_date": 1665585093,
                "answer_id": 74043632,
                "question_id": 74035356,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "My take:\r\n```sh\r\nstat -c &#39;%Y:%n&#39; *.txt \\\r\n| sort -t: -n \\\r\n| cut -d: -f2- \\\r\n| xargs basename -s .txt \\\r\n| jq -s &#39;map({title: &quot;&quot;, file: tostring}) | {&quot;&quot;: .}&#39;\r\n```",
                "title": "How to put specific filenames into a specific JSON format using bash or Perl?"
            }
        ],
        "is_answered": true,
        "answer_count": 4,
        "score": 0,
        "last_activity_date": 1665586601,
        "creation_date": 1665535593,
        "last_edit_date": 1665557443,
        "question_id": 74035356,
        "body_markdown": "Assuming I&#39;m in the folder like this:\r\n```sh\r\n➜  tmp.lDrLPUOF ls\r\n1.txt 2.txt 3.txt 1.zip 2.rb\r\n```\r\nI want to put all the filenames of text files into a specific JSON format like this:\r\n```JSON\r\n{\r\n  &quot;&quot;: [\r\n    {\r\n      &quot;title&quot;: &quot;&quot;,\r\n      &quot;file&quot;: &quot;1&quot;\r\n    },\r\n    {\r\n      &quot;title&quot;: &quot;&quot;,\r\n      &quot;file&quot;: &quot;2&quot;\r\n    },\r\n    {\r\n      &quot;title&quot;: &quot;&quot;,\r\n      &quot;file&quot;: &quot;3&quot;\r\n    }\r\n  ]\r\n}\r\n```\r\nNow I just know how to list all the filenames:\r\n```sh\r\n➜  tmp.lDrLPUOF ls *&#39;.txt&#39;\r\n1.txt 2.txt 3.txt\r\n```\r\n\r\nCan I use bash or Perl to achieve this purpose? Thank you very much!\r\n\r\n## Edit\r\nThanks for @Charles Duffy and @Shawn &#39;s great answers. But it&#39;s my fault to forget another important piece of information——time. I want to put the filenames into the resulting JSON per their creating time.\r\n\r\nThe creating time is as below:\r\n```sh\r\n➜  tmp.lDrLPUOF ls -lTr\r\ntotal 0\r\n-rw-r--r--  1 administrator  staff  0 Oct 12 09:35:05 2022 3.txt\r\n-rw-r--r--  1 administrator  staff  0 Oct 12 09:35:08 2022 2.txt\r\n-rw-r--r--  1 administrator  staff  0 Oct 12 09:35:12 2022 1.txt\r\n```\r\n\r\nSo the resulting JSON I wanted should be like this:\r\n\r\n```JSON\r\n{\r\n  &quot;&quot;: [\r\n    {\r\n      &quot;title&quot;: &quot;&quot;,\r\n      &quot;file&quot;: &quot;3&quot;\r\n    },\r\n    {\r\n      &quot;title&quot;: &quot;&quot;,\r\n      &quot;file&quot;: &quot;2&quot;\r\n    },\r\n    {\r\n      &quot;title&quot;: &quot;&quot;,\r\n      &quot;file&quot;: &quot;1&quot;\r\n    }\r\n  ]\r\n}\r\n```\r\n\r\n",
        "link": "https://stackoverflow.com/questions/74035356/how-to-put-specific-filenames-into-a-specific-json-format-using-bash-or-perl",
        "title": "How to put specific filenames into a specific JSON format using bash or Perl?"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1665559489,
                "creation_date": 1665559489,
                "answer_id": 74037955,
                "question_id": 74037727,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Just [join](https://stedolan.github.io/jq/manual/#join(str)) them?\r\n``` sh\r\njq -r &#39;.entries | map(.Name) | join(&quot; &quot;)&#39; test.json\r\n```",
                "title": "How to output the value of a json file in one line using jq, including one space for each value?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1665559633,
        "creation_date": 1665558461,
        "last_edit_date": 1665559633,
        "question_id": 74037727,
        "body_markdown": "```\r\n{\r\n  &quot;entries&quot;: [\r\n    {\r\n      &quot;Name&quot;: &quot;cat&quot;,\r\n      &quot;size&quot;: &quot;100&quot;\r\n    },\r\n    {\r\n      &quot;Name&quot;: &quot;dog&quot;,\r\n      &quot;size&quot;: &quot;200&quot;\r\n    }\r\n  ]\r\n}\r\n\r\n```\r\n\r\nI have a json file like the one above, and I want to output the value of Name in one line including spaces.\r\n\r\n\r\n\r\nWith the following command I used, the output was output with consecutive values without spaces as follows.\r\n``` sh\r\njq -j .entries[].Name test.json\r\n```\r\noutput\r\n\r\n``` none\r\ncatdog\r\n```\r\n\r\nbut I want to output the value as follows using the Name key.\r\n``` none\r\ncat dog\r\n```\r\n\r\nHow can I output a single line including single spaces for each value in a json file?\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/74037727/how-to-output-the-value-of-a-json-file-in-one-line-using-jq-including-one-space",
        "title": "How to output the value of a json file in one line using jq, including one space for each value?"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1665563915,
                "last_edit_date": 1665563915,
                "creation_date": 1665563482,
                "answer_id": 74038773,
                "question_id": 74038570,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If you have jq 1.6, just use `JOIN` with an `INDEX`:\r\n\r\n~~~sh\r\njq &#39;[JOIN(INDEX(input[]; .classid); .[]; .classid; add)]&#39; file1.json file2.json\r\n~~~\r\n~~~json\r\n[\r\n  {\r\n    &quot;classid&quot;: &quot;abc&quot;,\r\n    &quot;name&quot;: &quot;Alex&quot;,\r\n    &quot;classname&quot;: &quot;math&quot;\r\n  },\r\n  {\r\n    &quot;classid&quot;: &quot;abc&quot;,\r\n    &quot;name&quot;: &quot;Bob&quot;,\r\n    &quot;classname&quot;: &quot;math&quot;\r\n  }\r\n]\r\n~~~\r\n[Demo](https://jqplay.org/s/Vi7SE3esRme)",
                "title": "Merge json files on a &quot;primary key&quot; using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1665563915,
        "creation_date": 1665562597,
        "last_edit_date": 1665563806,
        "question_id": 74038570,
        "body_markdown": "I have two files containing json arrays like so\r\n\r\n**file1.json**\r\n```\r\n[\r\n  {\r\n    &quot;classid&quot;:&quot;abc&quot;,\r\n    &quot;name&quot;:&quot;Alex&quot;\r\n  },\r\n  {\r\n    &quot;classid&quot;:&quot;abc&quot;,\r\n    &quot;name&quot;:&quot;Bob&quot;\r\n  }\r\n]\r\n```\r\n\r\n**file2.json**\r\n```\r\n[\r\n  {\r\n    &quot;classid&quot;:&quot;abc&quot;,\r\n    &quot;classname&quot;:&quot;math&quot;\r\n  }\r\n]\r\n```\r\n\r\nI&#39;d like to combine these two files on &quot;classid&quot;.\r\nDesired **output.json**\r\n```\r\n[\r\n  {\r\n    &quot;classid&quot;:&quot;abc&quot;,\r\n    &quot;name&quot;:&quot;Alex&quot;,\r\n    &quot;classname&quot;:&quot;math\r\n  },\r\n  {\r\n    &quot;classid&quot;:&quot;abc&quot;,\r\n    &quot;name&quot;:&quot;Bob&quot;,\r\n    &quot;classname&quot;:&quot;math\r\n  }\r\n]\r\n```\r\nI tried\r\n```&gt; jq -s &#39;reduce .[] as $item ({}; . *= $item)&#39; file1.json file2.json ```\r\nbut I see a ```jq: error (at file1.json:10): object ({}) and array ([{&quot;classid...) cannot be multiplied```\r\n\r\nWould appreciate any help. ",
        "link": "https://stackoverflow.com/questions/74038570/merge-json-files-on-a-primary-key-using-jq",
        "title": "Merge json files on a &quot;primary key&quot; using jq"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1665566286,
                "creation_date": 1665566286,
                "answer_id": 74039398,
                "question_id": 74039101,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can use `--arg` to set a jq variable from the command line.\r\n\r\n\r\n```bash\r\nfield=hello\r\ncurl url | jq --arg property &quot;$field&quot; &#39;.properties[$property][] == &quot;saysay&quot;&#39;\r\n```",
                "title": "how to dynamically build jq command"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1665566286,
        "creation_date": 1665564967,
        "last_edit_date": 1665565033,
        "question_id": 74039101,
        "body_markdown": "given this input \r\n\r\n    {\r\n      &quot;properties&quot;: {\r\n        &quot;hello&quot;: [\r\n          &quot;saysay&quot;\r\n        ],\r\n        &quot;test&quot;: [\r\n          &quot;1&quot;\r\n        ]\r\n      },\r\n      &quot;uri&quot;: &quot;uri&quot;\r\n    }\r\n\r\nI&#39;ve managed to check whether hello exists using this command\r\n\r\n    curl url | jq &#39;has(&quot;hello&quot;)&#39;\r\n\r\nNow how to check if the value of hello equals to saysay when it is a string variable ?\r\n\r\nif hardcoded, below command return true which is expected\r\n\r\n    curl url | jq -r &#39;.properties.hello[]==&quot;saysay&quot;&#39;\r\n\r\nwhen i try this one, I&#39;ve got the following error : (23) Failed writing body\r\n\r\n    curl url | jq -r &#39;.properties.$variable[]==&quot;saysay&quot;&#39;\r\n",
        "link": "https://stackoverflow.com/questions/74039101/how-to-dynamically-build-jq-command",
        "title": "how to dynamically build jq command"
    },
    {
        "tags": [
            "json",
            "linux",
            "bash",
            "shell",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 7750510,
                    "reputation": 134447,
                    "user_id": 5866580,
                    "user_type": "registered",
                    "accept_rate": 25,
                    "profile_image": "https://www.gravatar.com/avatar/f69cec226400d61f887446d813471488?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "RavinderSingh13",
                    "link": "https://stackoverflow.com/users/5866580/ravindersingh13"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1665582299,
                "post_id": 74042901,
                "comment_id": 130734754,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 3473122,
                    "reputation": 25,
                    "user_id": 2907000,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d402c54d38e20d3287c979108a2ad039?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Guillaume",
                    "link": "https://stackoverflow.com/users/2907000/guillaume"
                },
                "reply_to_user": {
                    "account_id": 7750510,
                    "reputation": 134447,
                    "user_id": 5866580,
                    "user_type": "registered",
                    "accept_rate": 25,
                    "profile_image": "https://www.gravatar.com/avatar/f69cec226400d61f887446d813471488?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "RavinderSingh13",
                    "link": "https://stackoverflow.com/users/5866580/ravindersingh13"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1665585013,
                "post_id": 74042901,
                "comment_id": 130735930,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1665584374,
                "last_edit_date": 1665584374,
                "creation_date": 1665582280,
                "answer_id": 74042940,
                "question_id": 74042901,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "&gt; I need to get the &quot;ubuntu&quot; node content\r\n\r\nYou can use `.[]` to get all nodes&#39; contents, and `has` to check for their keys:\r\n~~~sh\r\njq &#39;.os[] | select(has(&quot;18.04&quot;))&#39;\r\n~~~\r\n~~~json\r\n{\r\n  &quot;16.04&quot;: {\r\n    &quot;codename&quot;: &quot;xenial&quot;,\r\n    &quot;bootstrap&quot;: &quot;preseed&quot;,\r\n    &quot;guest_type&quot;: &quot;ubuntu64Guest&quot;,\r\n    &quot;iso_name&quot;: &quot;ubuntu-16.04.7-server-amd64.iso&quot;,\r\n    &quot;iso_checksum&quot;: &quot;9bb30a2ea6466b0c02aacfa96f6e3516&quot;\r\n  },\r\n  &quot;18.04&quot;: {\r\n    &quot;codename&quot;: &quot;bionic&quot;,\r\n    &quot;bootstrap&quot;: &quot;preseed&quot;,\r\n    &quot;guest_type&quot;: &quot;ubuntu64Guest&quot;,\r\n    &quot;iso_name&quot;: &quot;ubuntu-18.04.2-server-amd64.iso&quot;,\r\n    &quot;iso_checksum&quot;: &quot;34416ff83179728d54583bf3f18d42d2&quot;,\r\n    &quot;arm&quot;: {\r\n      &quot;iso_name&quot;: &quot;ubuntu-18.04.5-server-arm64.iso&quot;,\r\n      &quot;iso_checksum&quot;: &quot;5056eaf87425b550376e6733b05de6e9&quot;\r\n    }\r\n  }\r\n}\r\n~~~\r\n[Demo](https://jqplay.org/s/jvvqPgJeH6s)\r\n\r\nIf you want the object with the &quot;ubuntu&quot; field included, update `|=` the nodes:\r\n~~~sh\r\njq &#39;.os | .[] |= select(has(&quot;18.04&quot;))&#39;\r\n~~~\r\n~~~json\r\n{\r\n  &quot;ubuntu&quot;: {\r\n    &quot;16.04&quot;: {\r\n      &quot;codename&quot;: &quot;xenial&quot;,\r\n      &quot;bootstrap&quot;: &quot;preseed&quot;,\r\n      &quot;guest_type&quot;: &quot;ubuntu64Guest&quot;,\r\n      &quot;iso_name&quot;: &quot;ubuntu-16.04.7-server-amd64.iso&quot;,\r\n      &quot;iso_checksum&quot;: &quot;9bb30a2ea6466b0c02aacfa96f6e3516&quot;\r\n    },\r\n    &quot;18.04&quot;: {\r\n      &quot;codename&quot;: &quot;bionic&quot;,\r\n      &quot;bootstrap&quot;: &quot;preseed&quot;,\r\n      &quot;guest_type&quot;: &quot;ubuntu64Guest&quot;,\r\n      &quot;iso_name&quot;: &quot;ubuntu-18.04.2-server-amd64.iso&quot;,\r\n      &quot;iso_checksum&quot;: &quot;34416ff83179728d54583bf3f18d42d2&quot;,\r\n      &quot;arm&quot;: {\r\n        &quot;iso_name&quot;: &quot;ubuntu-18.04.5-server-arm64.iso&quot;,\r\n        &quot;iso_checksum&quot;: &quot;5056eaf87425b550376e6733b05de6e9&quot;\r\n      }\r\n    }\r\n  }\r\n}\r\n~~~\r\n[Demo](https://jqplay.org/s/8NOFbNi_Ze0)",
                "title": "jq, getting an unknown parent node after finding it with one of its children value"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1665583042,
                "last_edit_date": 1665583042,
                "creation_date": 1665582655,
                "answer_id": 74043033,
                "question_id": 74042901,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "&gt; Basically, with an os version, i should get the os name, but i have no way of knowing the os name beforehand.\r\n\r\nYou can use [`to_entires()`][1] with [`select()`][2] and [`has()`][3] to filter those which nested object contains the desired key: `select(.value | has(&quot;18.04&quot;))`. \r\n\r\nThen return the parent&#39;s key to get the OS name (`.key`):\r\n```\r\n.os | to_entries[] | select(.value | has(&quot;18.04&quot;)).key\r\n// &quot;ubuntu&quot;\r\n\r\n.os | to_entries[] | select(.value | has(&quot;7.6&quot;)).key\r\n// &quot;rhel&quot;\r\n```\r\n\r\n\r\n----------\r\n\r\n\r\n[JqPlay Demo](https://jqplay.org/s/TS1RFpaszZv)\r\n\r\n\r\n  [1]: https://stedolan.github.io/jq/manual/#to_entries,from_entries,with_entries\r\n  [2]: https://stedolan.github.io/jq/manual/#select(boolean_expression)\r\n  [3]: https://stedolan.github.io/jq/manual/#has(key)",
                "title": "jq, getting an unknown parent node after finding it with one of its children value"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1665586121,
        "creation_date": 1665582141,
        "last_edit_date": 1665586121,
        "question_id": 74042901,
        "body_markdown": "I have a complex (at least for me) issue with jq, and this structure :\r\n```json\r\n{\r\n  &quot;os&quot;: {\r\n    &quot;ubuntu&quot;: {\r\n      &quot;16.04&quot;: {\r\n        &quot;codename&quot;: &quot;xenial&quot;,\r\n        &quot;bootstrap&quot;: &quot;preseed&quot;,\r\n        &quot;guest_type&quot;: &quot;ubuntu64Guest&quot;,\r\n        &quot;iso_name&quot;: &quot;ubuntu-16.04.7-server-amd64.iso&quot;,\r\n        &quot;iso_checksum&quot;: &quot;9bb30a2ea6466b0c02aacfa96f6e3516&quot;,\r\n      },\r\n      &quot;18.04&quot;: {\r\n        &quot;codename&quot;: &quot;bionic&quot;,\r\n        &quot;bootstrap&quot;: &quot;preseed&quot;,\r\n        &quot;guest_type&quot;: &quot;ubuntu64Guest&quot;,\r\n        &quot;iso_name&quot;: &quot;ubuntu-18.04.2-server-amd64.iso&quot;,\r\n        &quot;iso_checksum&quot;: &quot;34416ff83179728d54583bf3f18d42d2&quot;,\r\n        &quot;arm&quot;: {\r\n          &quot;iso_name&quot;: &quot;ubuntu-18.04.5-server-arm64.iso&quot;,\r\n          &quot;iso_checksum&quot;: &quot;5056eaf87425b550376e6733b05de6e9&quot;\r\n        }\r\n      }\r\n    },\r\n    &quot;rhel&quot;: {\r\n      &quot;7.4&quot;: {\r\n        &quot;codename&quot;: &quot;maipo&quot;,\r\n        &quot;bootstrap&quot;: &quot;kickstart&quot;,\r\n        &quot;guest_type&quot;: &quot;rhel7_64Guest&quot;,\r\n        &quot;iso_name&quot;: &quot;rhel-server-7.4-x86_64-boot.iso&quot;,\r\n        &quot;iso_checksum&quot;: &quot;94ad0929b79b5d13b33acafc8da8d364&quot;,\r\n      },\r\n      &quot;7.6&quot;: {\r\n        &quot;codename&quot;: &quot;maipo&quot;,\r\n        &quot;bootstrap&quot;: &quot;kickstart&quot;,\r\n        &quot;guest_type&quot;: &quot;rhel7_64Guest&quot;,\r\n        &quot;iso_name&quot;: &quot;rhel-server-7.6-x86_64-boot.iso&quot;,\r\n        &quot;iso_checksum&quot;: &quot;4a611d2bbfa6912eada91096af14ec84&quot;,\r\n      }\r\n    }\r\n  }\r\n}\r\n```\r\n\r\nI need to get the &quot;ubuntu&quot; node content by searching it with &quot;18.04&quot;, without knowing the &quot;ubuntu&quot; node key name.\r\nSo if i search the children node named &quot;7.4&quot;, it should identify its parent as &quot;rhel&quot; and returns it.\r\n\r\nBasically, with an os version, i should get the os name, but i have no way of knowing the os name beforehand.\r\n\r\nI tried a few commands (didn&#39;t keep them sorry), with the help of this cheatsheet, without luck :\r\nhttps://gist.github.com/olih/f7437fb6962fb3ee9fe95bda8d2c8fa4\r\n\r\nIt is even possible ?\r\n\r\nThanks.",
        "link": "https://stackoverflow.com/questions/74042901/jq-getting-an-unknown-parent-node-after-finding-it-with-one-of-its-children-val",
        "title": "jq, getting an unknown parent node after finding it with one of its children value"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1665610220,
                "last_edit_date": 1665610220,
                "creation_date": 1665607045,
                "answer_id": 74047789,
                "question_id": 74047703,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If you know the field names, just add them together using `+`. Using `[]` on arrays will automatically iterate over their items.\r\n~~~sh\r\n.[] | .repo + &quot;:&quot; + .tags[]\r\n~~~\r\n[Demo](https://jqplay.org/s/su5UxGYe2OM)\r\n\r\nIf you don&#39;t know their names, create an array of arrays of items (getting rid of the objects), and iterate over the inner arrays as above while successively reducing the outer ones, e.g. using `until`:\r\n~~~sh\r\n.[] | map([.[]? // .]) | until(has(1) | not;\r\n  .[:2] |= [[.[0][] + &quot;:&quot; + .[1][]]]\r\n)[][]\r\n~~~\r\n[Demo](https://jqplay.org/s/vbADi-e0k8Y)\r\n\r\nOutput:\r\n~~~json\r\n&quot;bar/foo/bat:0.0.4-22.09&quot;\r\n&quot;thing/foo/baz:0.0.2-22.09&quot;\r\n&quot;thing/foo/baz:0.0.3-22.09&quot;\r\n~~~\r\n\r\nTo output the strings without JSON encoding (~ without quotes), use the `-r` (or `--raw-output`) flag when invoking `jq`.",
                "title": "How can I create a flattened and concatenated series in jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1665610220,
        "creation_date": 1665606569,
        "question_id": 74047703,
        "body_markdown": "This is the data I have:\r\n\r\n```json\r\n[\r\n  {\r\n    &quot;repo&quot;: &quot;bar/foo/bat&quot;,\r\n    &quot;tags&quot;: [\r\n      &quot;0.0.4-22.09&quot;\r\n    ]\r\n  },\r\n  {\r\n    &quot;repo&quot;: &quot;thing/foo/baz&quot;,\r\n    &quot;tags&quot;: [\r\n      &quot;0.0.2-22.09&quot;,\r\n      &quot;0.0.3-22.09&quot;\r\n    ]\r\n  }\r\n]\r\n```\r\nAnd what I want is a flattened list of `repo:tag` for each of these entries\r\n```\r\n&quot;bar/foo/bat:0.0.4-22.09&quot;\r\n&quot;thing/foo/baz:0.0.2-22.09&quot;\r\n&quot;thing/foo/baz:0.0.3-22.09&quot;\r\n```\r\n\r\nI am not quite sure how to express this",
        "link": "https://stackoverflow.com/questions/74047703/how-can-i-create-a-flattened-and-concatenated-series-in-jq",
        "title": "How can I create a flattened and concatenated series in jq"
    },
    {
        "tags": [
            "json",
            "bash",
            "curl",
            "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": 1665610490,
                "post_id": 74048192,
                "comment_id": 130743957,
                "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": 1665610600,
                "post_id": 74048192,
                "comment_id": 130743980,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 12388142,
                    "reputation": 31,
                    "user_id": 9030977,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/1894aeecc9ee78b8266a4bd0280fbd35?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "lem",
                    "link": "https://stackoverflow.com/users/9030977/lem"
                },
                "reply_to_user": {
                    "account_id": 1143565,
                    "reputation": 535973,
                    "user_id": 1126841,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/fa05233b2357f8d11c22ef4cfc7bb85c?s=256&d=identicon&r=PG",
                    "display_name": "chepner",
                    "link": "https://stackoverflow.com/users/1126841/chepner"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1665611043,
                "post_id": 74048192,
                "comment_id": 130744050,
                "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": 1665611338,
                "post_id": 74048192,
                "comment_id": 130744109,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 12388142,
                    "reputation": 31,
                    "user_id": 9030977,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/1894aeecc9ee78b8266a4bd0280fbd35?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "lem",
                    "link": "https://stackoverflow.com/users/9030977/lem"
                },
                "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": 1665611452,
                "post_id": 74048192,
                "comment_id": 130744137,
                "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": 1665611704,
                "post_id": 74048192,
                "comment_id": 130744186,
                "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": 2,
                "creation_date": 1665611753,
                "post_id": 74048192,
                "comment_id": 130744191,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 12388142,
                    "reputation": 31,
                    "user_id": 9030977,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/1894aeecc9ee78b8266a4bd0280fbd35?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "lem",
                    "link": "https://stackoverflow.com/users/9030977/lem"
                },
                "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": 1665612186,
                "post_id": 74048192,
                "comment_id": 130744256,
                "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": 1665612342,
                "post_id": 74048192,
                "comment_id": 130744279,
                "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": 1665613520,
                "post_id": 74048192,
                "comment_id": 130744499,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 12388142,
                    "reputation": 31,
                    "user_id": 9030977,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/1894aeecc9ee78b8266a4bd0280fbd35?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "lem",
                    "link": "https://stackoverflow.com/users/9030977/lem"
                },
                "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": 1665616139,
                "post_id": 74048192,
                "comment_id": 130744925,
                "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": 1665616628,
                "post_id": 74048192,
                "comment_id": 130744999,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1665612221,
                "creation_date": 1665612221,
                "answer_id": 74048415,
                "question_id": 74048192,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "To extract multiple fields, you need to wrap them in quotes within the filter. \r\n\r\n    .[] | &quot;\\(.first_name) \\(.last_name)&quot;\r\n\r\nOutput\r\n\r\n```\r\nJohn Doe\r\nbat man\r\n```\r\n\r\nhttps://jqplay.org/s/iH-c-d2sgYm\r\n\r\nOtherwise, you can just to `.[].first_name` to get all first names, for example",
                "title": "How to properly read JSON array returned from cURL request in bash"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1665612221,
        "creation_date": 1665610292,
        "last_edit_date": 1665611993,
        "question_id": 74048192,
        "body_markdown": "I&#39;m trying to process the result of a cURL request, piped into `jq`, which returns an array of JSON objects like so: \r\n\r\n```\r\n[\r\n  { \r\n    &quot;first_name&quot; : &quot;John&quot;,\r\n    &quot;last_name&quot; : &quot;Doe&quot;\r\n\r\n  },\r\n  { \r\n    &quot;first_name&quot; : &quot;bat&quot;,\r\n    &quot;last_name&quot; : &quot;man&quot;\r\n\r\n  }\r\n]\r\n```\r\n\r\nWhich I then try to format into a JSON array and read through by running \r\n\r\n```\r\nitem_list=`curl &quot;https://linkhere.com&quot; | jq`\r\n\r\nfor item in ${item_list[@]}; do \r\n    echo &quot;item is $item&quot;\r\ndone\r\n```\r\n\r\nHowever, the items in the array are being read like strings, not JSON objects, outputting:\r\n\r\n```\r\nitem is [\r\nitem is { \r\nitem is &quot;John&quot;:\r\nitem is &quot;Doe&quot;\r\nitem is }, \r\n... \r\n```\r\n\r\nI want to iterate through each object in the JSON array to extract and store the `first_name` and `last_name` values. How can I go about properly doing this ?",
        "link": "https://stackoverflow.com/questions/74048192/how-to-properly-read-json-array-returned-from-curl-request-in-bash",
        "title": "How to properly read JSON array returned from cURL request in bash"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1665618692,
                "last_edit_date": 1665618692,
                "creation_date": 1665612523,
                "answer_id": 74048458,
                "question_id": 74048427,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "This map produces the 4 unique items.\r\n\r\n~~~sh\r\njq &#39;map(\r\n  (.categories[].products | unique_by(.id)[] | {id, name: .display_name})\r\n  + {category: .name}\r\n)&#39;\r\n~~~\r\n~~~json\r\n[\r\n  {\r\n    &quot;id&quot;: &quot;62466&quot;,\r\n    &quot;name&quot;: &quot;Ice B&quot;,\r\n    &quot;category&quot;: &quot;Ice&quot;\r\n  },\r\n  {\r\n    &quot;id&quot;: &quot;66642&quot;,\r\n    &quot;name&quot;: &quot;Ice A&quot;,\r\n    &quot;category&quot;: &quot;Ice&quot;\r\n  },\r\n  {\r\n    &quot;id&quot;: &quot;14105&quot;,\r\n    &quot;name&quot;: &quot;Cake 2&quot;,\r\n    &quot;category&quot;: &quot;Cakes&quot;\r\n  },\r\n  {\r\n    &quot;id&quot;: &quot;14518&quot;,\r\n    &quot;name&quot;: &quot;Cake 1&quot;,\r\n    &quot;category&quot;: &quot;Cakes&quot;\r\n  }\r\n]\r\n~~~\r\n[Demo](https://jqplay.org/s/YC4G5nt5lIB)\r\n",
                "title": "Access a key outside of an array and store in a variable"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1665619641,
                "creation_date": 1665619641,
                "answer_id": 74049155,
                "question_id": 74048427,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Assigning the category name in a variable and then transforming each product with unique id:\r\n\r\n```\r\nmap(\r\n    .name as $category\r\n    | .categories[].products\r\n    | unique_by(.id)\r\n    | .[]\r\n    | { id, name: .display_name, $category }\r\n)\r\n```\r\n",
                "title": "Access a key outside of an array and store in a variable"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1665619641,
        "creation_date": 1665612304,
        "last_edit_date": 1665616581,
        "question_id": 74048427,
        "body_markdown": "I have this bit of json:\r\n\r\n    \r\n\r\n        [{\r\n    \t\t&quot;id&quot;: 123,\r\n    \t\t&quot;name&quot;: &quot;Ice&quot;,\r\n    \t\t&quot;categories&quot;: [{\r\n    \t\t\t&quot;products&quot;: [{\r\n    \t\t\t\t\t&quot;id&quot;: &quot;66642&quot;,\r\n    \t\t\t\t\t&quot;display_name&quot;: &quot;Ice A&quot;\r\n    \t\t\t\t},\r\n    \t\t\t\t{\r\n    \t\t\t\t\t&quot;id&quot;: &quot;62466&quot;,\r\n    \t\t\t\t\t&quot;display_name&quot;: &quot;Ice B&quot;\r\n    \t\t\t\t},\r\n    \t\t\t\t{\r\n    \t\t\t\t\t&quot;id&quot;: &quot;62466&quot;,\r\n    \t\t\t\t\t&quot;display_name&quot;: &quot;Ice B duplicate&quot;\r\n    \t\t\t\t}\r\n    \t\t\t]\r\n    \t\t}]\r\n    \t},\r\n    \t{\r\n    \t\t&quot;id&quot;: 97,\r\n    \t\t&quot;name&quot;: &quot;Cakes&quot;,\r\n    \t\t&quot;categories&quot;: [{\r\n    \t\t\t&quot;products&quot;: [{\r\n    \t\t\t\t\t&quot;id&quot;: &quot;14518&quot;,\r\n    \t\t\t\t\t&quot;display_name&quot;: &quot;Cake 1&quot;\r\n    \t\t\t\t},\r\n    \t\t\t\t{\r\n    \t\t\t\t\t&quot;id&quot;: &quot;14105&quot;,\r\n    \t\t\t\t\t&quot;display_name&quot;: &quot;Cake 2&quot;\r\n    \t\t\t\t}\r\n    \t\t\t]\r\n    \t\t}]\r\n    \t}\r\n    ]\r\n\r\nI&#39;m using jq 1.6 and I&#39;m trying to get this output:\r\n\r\n    [{\r\n      &quot;id&quot;: &quot;62466&quot;,\r\n      &quot;name&quot;: &quot;Ice B&quot;,\r\n      &quot;category&quot;: &quot;Ice&quot;\r\n    },\r\n    {\r\n      &quot;id&quot;: &quot;66642&quot;,\r\n      &quot;name&quot;: &quot;Ice A&quot;,\r\n      &quot;category&quot;: &quot;Ice&quot;\r\n    },\r\n    {\r\n      &quot;id&quot;: &quot;14105&quot;,\r\n      &quot;name&quot;: &quot;Cake 2&quot;,\r\n      &quot;category&quot;: &quot;Cakes&quot;\r\n    },\r\n    {\r\n      &quot;id&quot;: &quot;14518&quot;,\r\n      &quot;name&quot;: &quot;Cake 1&quot;,\r\n      &quot;category&quot;: &quot;Cakes&quot;\r\n    }]\r\n\r\nI&#39;ve tried with this code:\r\n\r\n    .[].name as $x | map(.categories[].products[]) | unique_by(.id) | .[] | \r\n    [{\r\n        id: .id,\r\n        name: .display_name,\r\n        category: $x\r\n    }]\r\n\r\nBut I get this output:\r\n\r\n    [\r\n      {\r\n        &quot;id&quot;: &quot;14105&quot;,\r\n        &quot;name&quot;: &quot;Cake 2&quot;,\r\n        &quot;category&quot;: &quot;Ice&quot;\r\n      }\r\n    ]\r\n    [\r\n      {\r\n        &quot;id&quot;: &quot;14518&quot;,\r\n        &quot;name&quot;: &quot;Cake 1&quot;,\r\n        &quot;category&quot;: &quot;Ice&quot;\r\n      }\r\n    ]\r\n    [\r\n      {\r\n        &quot;id&quot;: &quot;62466&quot;,\r\n        &quot;name&quot;: &quot;Ice B&quot;,\r\n        &quot;category&quot;: &quot;Ice&quot;\r\n      }\r\n    ]\r\n    [\r\n      {\r\n        &quot;id&quot;: &quot;66642&quot;,\r\n        &quot;name&quot;: &quot;Ice A&quot;,\r\n        &quot;category&quot;: &quot;Ice&quot;\r\n      }\r\n    ]\r\n    [\r\n      {\r\n        &quot;id&quot;: &quot;14105&quot;,\r\n        &quot;name&quot;: &quot;Cake 2&quot;,\r\n        &quot;category&quot;: &quot;Cakes&quot;\r\n      }\r\n    ]\r\n    [\r\n      {\r\n        &quot;id&quot;: &quot;14518&quot;,\r\n        &quot;name&quot;: &quot;Cake 1&quot;,\r\n        &quot;category&quot;: &quot;Cakes&quot;\r\n      }\r\n    ]\r\n    [\r\n      {\r\n        &quot;id&quot;: &quot;62466&quot;,\r\n        &quot;name&quot;: &quot;Ice B&quot;,\r\n        &quot;category&quot;: &quot;Cakes&quot;\r\n      }\r\n    ]\r\n    [\r\n      {\r\n        &quot;id&quot;: &quot;66642&quot;,\r\n        &quot;name&quot;: &quot;Ice A&quot;,\r\n        &quot;category&quot;: &quot;Cakes&quot;\r\n      }\r\n    ]\r\n\r\nI looks like as there are two names\r\n\r\n    Ice\r\n    Cakes\r\n\r\nIt&#39;s multiplying the output by two , one for each name instead of just returning the 4 products and I can&#39;t get the result into and array of objects. Here is a reproducible code in [jqplay][1]. Because there are some duplicate records, ie: products that have more than one category I need them to be unique. How can i fix this?\r\n\r\n\r\n  [1]: https://jqplay.org/s/ELjP4cjXmYQ",
        "link": "https://stackoverflow.com/questions/74048427/access-a-key-outside-of-an-array-and-store-in-a-variable",
        "title": "Access a key outside of an array and store in a variable"
    },
    {
        "tags": [
            "json",
            "bash",
            "amazon-web-services",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 20993197,
                    "reputation": 421,
                    "user_id": 15425628,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/472b50054332bb4500a90c27ddd93773?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "ExceptionNotThrownException",
                    "link": "https://stackoverflow.com/users/15425628/exceptionnotthrownexception"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1665651886,
                "post_id": 74053106,
                "comment_id": 130751526,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 26609159,
                    "reputation": 1,
                    "user_id": 20229566,
                    "user_type": "registered",
                    "profile_image": "https://lh3.googleusercontent.com/a/ALm5wu3PncM1LdRliqylxbMscRk60xgq8XhBo7OyNPbP=k-s256",
                    "display_name": "Muthu",
                    "link": "https://stackoverflow.com/users/20229566/muthu"
                },
                "reply_to_user": {
                    "account_id": 20993197,
                    "reputation": 421,
                    "user_id": 15425628,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/472b50054332bb4500a90c27ddd93773?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "ExceptionNotThrownException",
                    "link": "https://stackoverflow.com/users/15425628/exceptionnotthrownexception"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1665652089,
                "post_id": 74053106,
                "comment_id": 130751606,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 20993197,
                    "reputation": 421,
                    "user_id": 15425628,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/472b50054332bb4500a90c27ddd93773?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "ExceptionNotThrownException",
                    "link": "https://stackoverflow.com/users/15425628/exceptionnotthrownexception"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1665652250,
                "post_id": 74053106,
                "comment_id": 130751647,
                "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": 1665652593,
                "post_id": 74053106,
                "comment_id": 130751747,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 26609159,
                    "reputation": 1,
                    "user_id": 20229566,
                    "user_type": "registered",
                    "profile_image": "https://lh3.googleusercontent.com/a/ALm5wu3PncM1LdRliqylxbMscRk60xgq8XhBo7OyNPbP=k-s256",
                    "display_name": "Muthu",
                    "link": "https://stackoverflow.com/users/20229566/muthu"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1665652725,
                "post_id": 74053106,
                "comment_id": 130751791,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 26609159,
                    "reputation": 1,
                    "user_id": 20229566,
                    "user_type": "registered",
                    "profile_image": "https://lh3.googleusercontent.com/a/ALm5wu3PncM1LdRliqylxbMscRk60xgq8XhBo7OyNPbP=k-s256",
                    "display_name": "Muthu",
                    "link": "https://stackoverflow.com/users/20229566/muthu"
                },
                "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": 1665652810,
                "post_id": 74053106,
                "comment_id": 130751825,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 26609159,
                    "reputation": 1,
                    "user_id": 20229566,
                    "user_type": "registered",
                    "profile_image": "https://lh3.googleusercontent.com/a/ALm5wu3PncM1LdRliqylxbMscRk60xgq8XhBo7OyNPbP=k-s256",
                    "display_name": "Muthu",
                    "link": "https://stackoverflow.com/users/20229566/muthu"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1665653068,
                "post_id": 74053106,
                "comment_id": 130751905,
                "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": 1665658017,
                "post_id": 74053106,
                "comment_id": 130753493,
                "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": 1665667040,
                "post_id": 74053106,
                "comment_id": 130756593,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 26609159,
                    "reputation": 1,
                    "user_id": 20229566,
                    "user_type": "registered",
                    "profile_image": "https://lh3.googleusercontent.com/a/ALm5wu3PncM1LdRliqylxbMscRk60xgq8XhBo7OyNPbP=k-s256",
                    "display_name": "Muthu",
                    "link": "https://stackoverflow.com/users/20229566/muthu"
                },
                "reply_to_user": {
                    "account_id": 4879,
                    "reputation": 248190,
                    "user_id": 7552,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/b60298053f87465641c1b1192338c8cd?s=256&d=identicon&r=PG",
                    "display_name": "glenn jackman",
                    "link": "https://stackoverflow.com/users/7552/glenn-jackman"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1665687655,
                "post_id": 74053106,
                "comment_id": 130763554,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1665653060,
                "creation_date": 1665653060,
                "answer_id": 74053398,
                "question_id": 74053106,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If I understand your question correctly, you simply want to embed/wrap the input document in a top level document.\r\n\r\n```\r\necho &#39;{&quot;Username&quot;:&quot;admin&quot;,&quot;Password&quot;:&quot;admin&quot;,&quot;Endpoint&quot;:&quot;localhost&quot;,&quot;DatabaseName&quot;:&quot;example&quot;,&quot;Port&quot;:&quot;3306&quot;}&#39; | jq &#39;{\r\n  &quot;Logging&quot;: {\r\n    &quot;LogLevel&quot;: {\r\n      &quot;Default&quot;: &quot;Information&quot;,\r\n      &quot;Microsoft.AspNetCore&quot;: &quot;Warning&quot;\r\n    }\r\n  },\r\n  &quot;Aurora&quot;: .\r\n}&#39;\r\n```\r\n\r\nOutput:\r\n\r\n```\r\n{\r\n  &quot;Logging&quot;: {\r\n    &quot;LogLevel&quot;: {\r\n      &quot;Default&quot;: &quot;Information&quot;,\r\n      &quot;Microsoft.AspNetCore&quot;: &quot;Warning&quot;\r\n    }\r\n  },\r\n  &quot;Aurora&quot;: {\r\n    &quot;Username&quot;: &quot;admin&quot;,\r\n    &quot;Password&quot;: &quot;admin&quot;,\r\n    &quot;Endpoint&quot;: &quot;localhost&quot;,\r\n    &quot;DatabaseName&quot;: &quot;example&quot;,\r\n    &quot;Port&quot;: &quot;3306&quot;\r\n  }\r\n}\r\n```\r\n\r\nThe key &quot;Aurora&quot; will contain your input document. If you need only specific fields, then replace `.` with `{Username,Password}`",
                "title": "How to Iterate Json key value pair and get the value and store in another json using Bash Script with JQ utility"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1665656647,
                "creation_date": 1665656647,
                "answer_id": 74054170,
                "question_id": 74053106,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here is one solution how to jq&#39;s `--slurpfile` option to use another file as &quot;template&quot; to format your input and then replace the parts according to your requirements:\r\n\r\n```\r\n$ cat template.json\r\n{\r\n\t&quot;Logging&quot;: {\r\n\t\t&quot;LogLevel&quot;: {\r\n\t\t\t&quot;Default&quot;: &quot;Information&quot;,\r\n\t\t\t&quot;Microsoft.AspNetCore&quot;: &quot;Warning&quot;\r\n\t\t}\r\n\t},\r\n\t&quot;Aurora&quot;: {\r\n\t\t&quot;Username&quot;: &quot;&quot;,\r\n\t\t&quot;Password&quot;: &quot;&quot;,\r\n\t\t&quot;Endpoint&quot;: &quot;&quot;,\r\n\t\t&quot;DatabaseName&quot;: &quot;&quot;,\r\n\t\t&quot;Port&quot;: &quot;&quot;,\r\n\t\t&quot;Environment&quot;: &quot;&quot;\r\n\t}\r\n}\r\n\r\n$ cat input.json\r\n{\r\n  &quot;Username&quot;: &quot;admin&quot;,\r\n  &quot;Password&quot;: &quot;admin&quot;,\r\n  &quot;Endpoint&quot;: &quot;localhost&quot;,\r\n  &quot;DatabaseName&quot;: &quot;example&quot;,\r\n  &quot;Port&quot;: &quot;3306&quot;,\r\n  &quot;SomethingElse&quot;: &quot;ignore me&quot;\r\n}\r\n\r\n$ jq --slurpfile tpl template.json &#39;$tpl[0] + {Aurora: with_entries(select(.key | IN($tpl[0].Aurora|keys[])))}&#39; &lt;input.json\r\n{\r\n  &quot;Logging&quot;: {\r\n    &quot;LogLevel&quot;: {\r\n      &quot;Default&quot;: &quot;Information&quot;,\r\n      &quot;Microsoft.AspNetCore&quot;: &quot;Warning&quot;\r\n    }\r\n  },\r\n  &quot;Aurora&quot;: {\r\n    &quot;Username&quot;: &quot;admin&quot;,\r\n    &quot;Password&quot;: &quot;admin&quot;,\r\n    &quot;Endpoint&quot;: &quot;localhost&quot;,\r\n    &quot;DatabaseName&quot;: &quot;example&quot;,\r\n    &quot;Port&quot;: &quot;3306&quot;\r\n  }\r\n}\r\n```\r\n\r\nOr swapping template and input files:\r\n\r\n```\r\n$ jq --slurpfile in input.json &#39;.Aurora |= keys as $keys | $in[0] | with_entries(select(.key | IN($keys[])))&#39; &lt;template.json\r\n{\r\n  &quot;Logging&quot;: {\r\n    &quot;LogLevel&quot;: {\r\n      &quot;Default&quot;: &quot;Information&quot;,\r\n      &quot;Microsoft.AspNetCore&quot;: &quot;Warning&quot;\r\n    }\r\n  },\r\n  &quot;Aurora&quot;: {\r\n    &quot;Username&quot;: &quot;admin&quot;,\r\n    &quot;Password&quot;: &quot;admin&quot;,\r\n    &quot;Endpoint&quot;: &quot;localhost&quot;,\r\n    &quot;DatabaseName&quot;: &quot;example&quot;,\r\n    &quot;Port&quot;: &quot;3306&quot;\r\n  }\r\n}\r\n```",
                "title": "How to Iterate Json key value pair and get the value and store in another json using Bash Script with JQ utility"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1665657289,
                "creation_date": 1665657289,
                "answer_id": 74054345,
                "question_id": 74053106,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If you can change your &quot;template&quot; file, I would suggest not keeping it as JSON, but make it a jq program instead:\r\n\r\n```\r\n$ cat input.json\r\n{\r\n  &quot;Username&quot;: &quot;admin&quot;,\r\n  &quot;Password&quot;: &quot;admin&quot;,\r\n  &quot;Endpoint&quot;: &quot;localhost&quot;,\r\n  &quot;DatabaseName&quot;: &quot;example&quot;,\r\n  &quot;Port&quot;: &quot;3306&quot;,\r\n  &quot;SomethingElse&quot;: &quot;ignore me&quot;\r\n}\r\n\r\n$ cat filter.jq\r\n{\r\n\t&quot;Logging&quot;: {\r\n\t\t&quot;LogLevel&quot;: {\r\n\t\t\t&quot;Default&quot;: &quot;Information&quot;,\r\n\t\t\t&quot;Microsoft.AspNetCore&quot;: &quot;Warning&quot;\r\n\t\t}\r\n\t},\r\n\t&quot;Aurora&quot;: {\r\n\t\t&quot;Username&quot;: .Username,\r\n\t\t&quot;Password&quot;: .Password,\r\n\t\t&quot;Endpoint&quot;: .Endpoint,\r\n\t\t&quot;DatabaseName&quot;: .DatabaseName,\r\n\t\t&quot;Port&quot;: .Port\r\n\t}\r\n}\r\n\r\n$ jq -f filter.jq &lt; input.json\r\n{\r\n  &quot;Logging&quot;: {\r\n    &quot;LogLevel&quot;: {\r\n      &quot;Default&quot;: &quot;Information&quot;,\r\n      &quot;Microsoft.AspNetCore&quot;: &quot;Warning&quot;\r\n    }\r\n  },\r\n  &quot;Aurora&quot;: {\r\n    &quot;Username&quot;: &quot;admin&quot;,\r\n    &quot;Password&quot;: &quot;admin&quot;,\r\n    &quot;Endpoint&quot;: &quot;localhost&quot;,\r\n    &quot;DatabaseName&quot;: &quot;example&quot;,\r\n    &quot;Port&quot;: &quot;3306&quot;\r\n  }\r\n}\r\n```\r\n\r\nNote that the filter program can be written with shorthand syntax:\r\n\r\n```\r\n$ cat filter.jq\r\n{\r\n\t&quot;Logging&quot;: {\r\n\t\t&quot;LogLevel&quot;: {\r\n\t\t\t&quot;Default&quot;: &quot;Information&quot;,\r\n\t\t\t&quot;Microsoft.AspNetCore&quot;: &quot;Warning&quot;\r\n\t\t}\r\n\t},\r\n\t&quot;Aurora&quot;: {\r\n        Username,\r\n\t\tPassword,\r\n\t\tEndpoint,\r\n\t\tDatabaseName,\r\n\t\tPort\r\n\t}\r\n}\r\n```",
                "title": "How to Iterate Json key value pair and get the value and store in another json using Bash Script with JQ utility"
            }
        ],
        "is_answered": false,
        "answer_count": 3,
        "score": -1,
        "last_activity_date": 1665657289,
        "creation_date": 1665651610,
        "last_edit_date": 1665654487,
        "question_id": 74053106,
        "body_markdown": "Im writing bash script for AWS Secret Manager .\r\n\r\nQuestion:\r\n\r\nI have one aws secret manager it will contain multiple secret\r\n\r\nExample:\r\naws secretsmanager get-secret-value --secret-id Example | jq -r &quot;.SecretString&quot;\r\n\r\ninput.json\r\n\r\n    {&quot;Username&quot;:&quot;admin&quot;,&quot;Password&quot;:&quot;admin&quot;,&quot;Endpoint&quot;:&quot;localhost&quot;,&quot;DatabaseName&quot;:&quot;example&quot;,&quot;Port&quot;:&quot;3306&quot;}\r\n\r\nUsing this command got a json output \r\n\r\nNow I want to extract All values like (Username , password,..)\r\n\r\nAfter get all extract values add in another json file called (secondfile.json)\r\n\r\nI have another json file it will contain \r\n\r\n   this is secondfile.json\r\n\r\n     {\r\n      &quot;Logging&quot;: {\r\n        &quot;LogLevel&quot;: {\r\n          &quot;Default&quot;: &quot;Information&quot;,\r\n          &quot;Microsoft.AspNetCore&quot;: &quot;Warning&quot;\r\n        }\r\n      },\r\n      &quot;Aurora&quot;: {\r\n        &quot;Username&quot;: &quot;&quot;,\r\n        &quot;Password&quot;: &quot;&quot;,\r\n        &quot;Endpoint&quot;: &quot;&quot;,\r\n        &quot;DatabaseName&quot;: &quot;&quot;,\r\n        &quot;Port&quot;: &quot;&quot;\r\n      }\r\n    }\r\n\r\n\r\nSample Output: extracted values now stored second file.json file in Aurora[] array elements.\r\n\r\n    {\r\n      &quot;Logging&quot;: {\r\n        &quot;LogLevel&quot;: {\r\n          &quot;Default&quot;: &quot;Information&quot;,\r\n          &quot;Microsoft.AspNetCore&quot;: &quot;Warning&quot;\r\n        }\r\n      },\r\n      &quot;Aurora&quot;: {\r\n        &quot;Username&quot;: &quot;admin&quot;,\r\n        &quot;Password&quot;: &quot;admin&quot;,\r\n        &quot;Endpoint&quot;: &quot;localhost&quot;,\r\n        &quot;DatabaseName&quot;: &quot;example&quot;,\r\n        &quot;Port&quot;: &quot;3306&quot;\r\n      }\r\n    }\r\n\r\n\r\nNeed Help on do with bash script .\r\n\r\n**Note: Input.json value not fixed , it may be contain 3 json key/value or n number of key/value**\r\n\r\n\r\n\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/74053106/how-to-iterate-json-key-value-pair-and-get-the-value-and-store-in-another-json-u",
        "title": "How to Iterate Json key value pair and get the value and store in another json using Bash Script with JQ utility"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1665653309,
                "creation_date": 1665653309,
                "answer_id": 74053470,
                "question_id": 74053418,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can use the [alternative operator](https://stedolan.github.io/jq/manual/#Alternativeoperator%3A%2F%2F) `//` to provide a default value:\r\n~~~sh\r\n{\r\n  miscellenous,\r\n  &quot;city&quot;: (\r\n    (.relations[] | select(.primary) | .address[] | select(.type == &quot;project&quot;) | .city) // &quot;&quot;\r\n  )\r\n}\r\n~~~\r\n\r\nNote: Instead of `{&quot;miscellenous&quot; : .miscellenous}` you can just write `{miscellenous}`, and instead of `select(.primary == true)` you can just write `select(.primary)`.",
                "title": "JQ transformation from a JSON array to simple JSON based on array elements value matching else null string"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1665653309,
        "creation_date": 1665653137,
        "question_id": 74053418,
        "body_markdown": "I&#39;m trying to transform below JSON using JQ. Wanted to transform it to a simple JSON which has city if relation&#39;s primary is true and relation address type is project. Wanted to populate it as empty string as &quot;&quot; in case source is not having a relation address type of project.\r\n\r\n    {\r\n        &quot;miscellenous&quot; : &quot;apple&quot;,\r\n        &quot;relations&quot; : [ \r\n            {\r\n                &quot;primary&quot;: false,\r\n                &quot;rel&quot; : 123,\r\n                &quot;address&quot; : [\r\n                    {\r\n                        &quot;type&quot; : &quot;project&quot;,\r\n                        &quot;city&quot; : &quot;xyz&quot;\r\n                    },\r\n                    {\r\n                        &quot;type&quot; : &quot;mailing&quot;,\r\n                        &quot;city&quot; : &quot;abc&quot;\r\n                    }\r\n                ]\r\n            },\r\n            {\r\n                &quot;primary&quot;: true,\r\n                &quot;rel&quot; : 456,\r\n                &quot;address&quot; : [\r\n                    {\r\n                        &quot;type&quot; : &quot;project&quot;,\r\n                        &quot;city&quot; : &quot;xyz&quot;\r\n                    },\r\n                    {\r\n                        &quot;type&quot; : &quot;mailing&quot;,\r\n                        &quot;city&quot; : &quot;abc&quot;\r\n                    }\r\n                ]\r\n            }\r\n        ]\r\n    }\r\n\r\nIt&#39;s working if values are matching that is primary is true and address type is &quot;project&quot; available in source JSON then transformation is working fine with either of the below JQ logic. But it&#39;s not giving expected response if address type &quot;project&quot; is not available and it&#39;s giving blank JSON.\r\n\r\nUsing select \r\n\r\n    {\r\n     &quot;miscellenous&quot; : .miscellenous,\r\n     &quot;city&quot; :  .relations[] | select(.primary == true) | .address[] | select(.type == &quot;project&quot;) | .city\r\n    }\r\n\r\nUsing if else\r\n\r\n    {\r\n     &quot;miscellenous&quot; : .miscellenous,\r\n     &quot;city&quot; :  .relations[] | (if .primary == true then .address[] | (if .type == &quot;project&quot; then .city else empty end) else empty end)\r\n    }\r\n\r\nExpected output if address type &quot;project&quot; is available in source JSON - This is working as expected\r\n\r\n    {\r\n      &quot;miscellenous&quot;: &quot;apple&quot;,\r\n      &quot;city&quot;: &quot;xyz&quot;\r\n    }\r\n\r\nExpected output if address type &quot;project&quot; is not available in source JSON -  This is not working as expected as it&#39;s blanking out whole JSON if &quot;project&quot; type address is not available in source.\r\n\r\n    {\r\n          &quot;miscellenous&quot;: &quot;apple&quot;,\r\n          &quot;city&quot;: &quot;&quot;\r\n    }\r\n\r\n",
        "link": "https://stackoverflow.com/questions/74053418/jq-transformation-from-a-json-array-to-simple-json-based-on-array-elements-value",
        "title": "JQ transformation from a JSON array to simple JSON based on array elements value matching else null string"
    },
    {
        "tags": [
            "json",
            "unix",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 6313442,
                    "reputation": 45115,
                    "user_id": 5625547,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/oqCND.jpg?s=256",
                    "display_name": "0stone0",
                    "link": "https://stackoverflow.com/users/5625547/0stone0"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1665662843,
                "post_id": 74055447,
                "comment_id": 130755054,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 6196394,
                    "reputation": 86601,
                    "user_id": 5291015,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/4tAvO.jpg?s=256",
                    "display_name": "Inian",
                    "link": "https://stackoverflow.com/users/5291015/inian"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1665662915,
                "post_id": 74055447,
                "comment_id": 130755075,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 6196394,
                    "reputation": 86601,
                    "user_id": 5291015,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/4tAvO.jpg?s=256",
                    "display_name": "Inian",
                    "link": "https://stackoverflow.com/users/5291015/inian"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1665662924,
                "post_id": 74055447,
                "comment_id": 130755078,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 6196394,
                    "reputation": 86601,
                    "user_id": 5291015,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/4tAvO.jpg?s=256",
                    "display_name": "Inian",
                    "link": "https://stackoverflow.com/users/5291015/inian"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1665666070,
                "post_id": 74055447,
                "comment_id": 130756189,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 13698467,
                    "reputation": 875,
                    "user_id": 9884374,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/544091991ab494c9696377f79a73d5c4?s=256&d=identicon&r=PG",
                    "display_name": "hustnzj",
                    "link": "https://stackoverflow.com/users/9884374/hustnzj"
                },
                "reply_to_user": {
                    "account_id": 6196394,
                    "reputation": 86601,
                    "user_id": 5291015,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/4tAvO.jpg?s=256",
                    "display_name": "Inian",
                    "link": "https://stackoverflow.com/users/5291015/inian"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1665669568,
                "post_id": 74055447,
                "comment_id": 130757500,
                "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": 1665760741,
                "post_id": 74055447,
                "comment_id": 130780768,
                "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": 1665760828,
                "post_id": 74055447,
                "comment_id": 130780790,
                "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": 1665761104,
                "post_id": 74055447,
                "comment_id": 130780872,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1665666511,
                "last_edit_date": 1665666511,
                "creation_date": 1665663981,
                "answer_id": 74055765,
                "question_id": 74055447,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Since the `.title` and `.files` has the same number, we can use that to index it from the input.\r\n\r\nSo using `cut` we can read all the `*.txt` files, split on ` ` and then get the second to last field, this gives:\r\n```none\r\ncat *.txt | cut -d &#39; &#39; -f 1-\r\nhello\r\nworld\r\ngood\r\n```\r\n\r\n(titles with spaces will work due to the `-f 1-`)\r\n\r\n----------\r\n\r\n\r\nUsing `--arg` we pass that to jq, which we then parse into an array:\r\n```none\r\n($inputs | split(&quot;\\n&quot;)) as $parsed\r\n```\r\n\r\nNow that `$parsed` looks like:\r\n```json\r\n[\r\n  &quot;hello&quot;,\r\n  &quot;world&quot;,\r\n  &quot;good&quot;\r\n]\r\n```\r\n\r\n\r\n----------\r\n\r\nTo update the value, loop over each object in the `&quot;&quot;` array, then get the matching value from `$parsed` by using `.file | tonumber - 1` (since array are 0-indexed)\r\n\r\n```none\r\njq --arg inputs &quot;$(cat *.txt | cut -d &#39; &#39; -f 1-)&quot; \\\r\n    &#39;($inputs | split(&quot;\\n&quot;)) as $parsed\r\n        | .&quot;&quot;[]\r\n        |= (.title = $parsed[.file | tonumber - 1])&#39; \\\r\nabc.json\r\n```\r\n\r\nOutput:\r\n```json\r\n{\r\n  &quot;&quot;: [\r\n    {\r\n      &quot;title&quot;: &quot;hello&quot;,\r\n      &quot;file&quot;: &quot;1&quot;\r\n    },\r\n    {\r\n      &quot;title&quot;: &quot;world&quot;,\r\n      &quot;file&quot;: &quot;2&quot;\r\n    },\r\n    {\r\n      &quot;title&quot;: &quot;good&quot;,\r\n      &quot;file&quot;: &quot;3&quot;\r\n    }\r\n  ]\r\n}\r\n```",
                "title": "How to update a json file by the contents read from other files using jq?"
            },
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1665820512,
                "last_edit_date": 1665820512,
                "creation_date": 1665665520,
                "answer_id": 74056106,
                "question_id": 74055447,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can use a shell loop to iterate over your files, extract the second column, create each array element and then transform the stream of array elements into your final object:\r\n\r\n```\r\nfor f in *.txt; do\r\n  cut -d&#39; &#39; -f2- &quot;$f&quot; | jq -R --arg file &quot;$f&quot; &#39;{title:.,file:($file/&quot;.&quot;|first)}&#39;;\r\ndone | jq -s &#39;{&quot;&quot;:.}&#39;\r\n```\r\n\r\nIt is also possible to remove the file extension in shell directly, which makes the jq filter a little bit simpler:\r\n\r\n```\r\nfor f in *.txt; do\r\n  cut -d&#39; &#39; -f2- &quot;$f&quot; | jq -R --arg file &quot;${f%.txt}&quot; &#39;{title:.,$file}&#39;;\r\ndone | jq -s &#39;{&quot;&quot;:.}&#39;\r\n```\r\n\r\n`cut` extracts the title value and must be adapted if the files are structured differently, e.g. by using grep, sed, or awk to extract the title and then feed it to jq.",
                "title": "How to update a json file by the contents read from other files using jq?"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1665684826,
                "last_edit_date": 1665684826,
                "creation_date": 1665682200,
                "answer_id": 74059673,
                "question_id": 74055447,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Use `input_filename` to get the input files&#39; names, read their raw content with the `-R` flag set, and use `select` to find the right item to update; all in one go:\r\n~~~sh\r\njq -Rn --argfile base abc.json &#39;\r\n  reduce (inputs | [\r\n    ltrimstr(&quot;title: &quot;),\r\n    (input_filename | rtrimstr(&quot;.txt&quot;))\r\n  ]) as [$title, $file] ($base;\r\n    (.[&quot;&quot;][] | select(.file == $file)).title = $title\r\n  )\r\n&#39; *.txt\r\n~~~\r\n\r\nIf the left part of the text files&#39; contents (&quot;title&quot; in the samples) should be a dynamic field name, you could `capture` it as well:\r\n~~~sh\r\njq -Rn --argfile base abc.json &#39;\r\n  reduce (inputs | [\r\n    capture(&quot;^(?&lt;key&gt;.*): (?&lt;value&gt;.*)$&quot;),\r\n    (input_filename | rtrimstr(&quot;.txt&quot;))\r\n  ]) as [{$key, $value}, $file] ($base;\r\n    (.[&quot;&quot;][] | select(.file == $file))[$key] = $value\r\n  )\r\n&#39; *.txt\r\n~~~\r\n\r\nOutput:\r\n~~~json\r\n{\r\n  &quot;&quot;: [\r\n    {\r\n      &quot;title&quot;: &quot;hello&quot;,\r\n      &quot;file&quot;: &quot;1&quot;\r\n    },\r\n    {\r\n      &quot;title&quot;: &quot;world&quot;,\r\n      &quot;file&quot;: &quot;2&quot;\r\n    },\r\n    {\r\n      &quot;title&quot;: &quot;good&quot;,\r\n      &quot;file&quot;: &quot;3&quot;\r\n    }\r\n  ]\r\n}\r\n~~~",
                "title": "How to update a json file by the contents read from other files using jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": -1,
        "last_activity_date": 1665820512,
        "creation_date": 1665662541,
        "last_edit_date": 1665710081,
        "question_id": 74055447,
        "body_markdown": "I have several text files, each one has a **title** inside. For example:\r\n```sh\r\necho &#39;title: hello&#39; &gt; 1.txt\r\necho &#39;title: world&#39; &gt; 2.txt\r\necho &#39;title: good&#39; &gt; 3.txt\r\n```\r\nAnd I have a JSON file called *abc.json* generated by a shell script like this: \r\n```json\r\n{\r\n  &quot;&quot;: [\r\n    {\r\n      &quot;title&quot;: &quot;&quot;,\r\n      &quot;file&quot;: &quot;1&quot;\r\n    },\r\n    {\r\n      &quot;title&quot;: &quot;&quot;,\r\n      &quot;file&quot;: &quot;2&quot;\r\n    },\r\n    {\r\n      &quot;title&quot;: &quot;&quot;,\r\n      &quot;file&quot;: &quot;3&quot;\r\n    }\r\n  ]\r\n}\r\n```\r\n\r\nWhat I want is to update the **title** value in the *abc.json* by the **title** in the respective text file, like this:\r\n```json\r\n{\r\n  &quot;&quot;: [\r\n    {\r\n      &quot;title&quot;: &quot;hello&quot;,\r\n      &quot;file&quot;: &quot;1&quot;\r\n    },\r\n    {\r\n      &quot;title&quot;: &quot;world&quot;,\r\n      &quot;file&quot;: &quot;2&quot;\r\n    },\r\n    {\r\n      &quot;title&quot;: &quot;good&quot;,\r\n      &quot;file&quot;: &quot;3&quot;\r\n    }\r\n  ]\r\n}\r\n```\r\n\r\nThe text files and the JSON files are in the same directory like this:\r\n```sh\r\n➜  tmp.uFtH6hMC ls\r\n1.txt    2.txt    3.txt    abc.json\r\n```\r\n\r\nThank you very much!\r\n\r\n## Update requirement\r\nSorry, guys. All your answers are perfect for the above requirement. \r\n\r\nBut some important detailed information I missed:\r\n\r\n1. The filename of text files may contain space, so the current directory should be like this:\r\n\r\n   ```sh\r\n   ➜  $ gfind . -maxdepth 1 -type f -printf &#39;%P\\n&#39;\r\n   The text file contain one title line and more content.txt\r\n   The title identifier in the text file is fixed.txt\r\n   The filename of text file may contain space.txt\r\n   abc.json\r\n   ```\r\n\r\n2. The text files include one **title-line** which contains the **title-value** that will be extracted into the *abc.json*, i.e., `## hello` means that &quot;hello&quot; need to be put into `title` field in *abc.json*. The **title-line**, could be anyline in the file, looks like `## &lt;title-value&gt;`. The **title-identifier** `##` is fixed and sperated with **title-value** by one single whitespace which is the first whitespace in the **title-line**. So the text files content could look like this:\r\n\r\n   *The text file contain one title line and more content.txt*:\r\n\r\n   ```txt\r\n   ## hello world\r\n   some more content below...\r\n   ...\r\n   ```\r\n\r\n   *The title identifier in the text file is fixed.txt*:\r\n\r\n   ```txt\r\n   ## How are you?\r\n   some more content below...\r\n   ...\r\n   ```\r\n\r\n   *The filename of text file may contain space.txt*:\r\n\r\n   ```txt\r\n   some pre-content...\r\n   ...\r\n   \r\n   ## I&#39;m fine, thank you.\r\n   \r\n   some more content below...\r\n   ...\r\n   ```\r\n\r\n3. Before updating, the *abc.json* looks like this:\r\n\r\n   ```sh\r\n   {\r\n     &quot;&quot;: [\r\n       {\r\n         &quot;title&quot;: &quot;&quot;,\r\n         &quot;file&quot;: &quot;The filename of text file may contain space&quot;\r\n       },\r\n       {\r\n         &quot;title&quot;: &quot;&quot;,\r\n         &quot;file&quot;: &quot;The text file contain one title line and more content&quot;\r\n       },\r\n       {\r\n         &quot;title&quot;: &quot;&quot;,\r\n         &quot;file&quot;: &quot;The title identifier in the text file is fixed&quot;\r\n       }\r\n     ]\r\n   }\r\n   \r\n   ```\r\n\r\n4. After updating, the *abc.json* should be like this:\r\n\r\n   ```json\r\n   {\r\n     &quot;&quot;: [\r\n       {\r\n         &quot;title&quot;: &quot;I&#39;m fine, thank you.&quot;,\r\n         &quot;file&quot;: &quot;The filename of text file may contain space&quot;\r\n       },\r\n       {\r\n         &quot;title&quot;: &quot;hello world&quot;,\r\n         &quot;file&quot;: &quot;The text file contain one title line and more content&quot;\r\n       },\r\n       {\r\n         &quot;title&quot;: &quot;How are you?&quot;,\r\n         &quot;file&quot;: &quot;The title identifier in the text file is fixed&quot;\r\n       }\r\n     ]\r\n   }\r\n   ```\r\n\r\n   Sorry again...thank you for your patience and great help!",
        "link": "https://stackoverflow.com/questions/74055447/how-to-update-a-json-file-by-the-contents-read-from-other-files-using-jq",
        "title": "How to update a json file by the contents read from other files using jq?"
    },
    {
        "tags": [
            "shell",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1665672226,
                "creation_date": 1665672226,
                "answer_id": 74057717,
                "question_id": 74057674,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "```\r\nmap(select(.ServiceTags | index(&quot;orchestrator&quot;)).Node)\r\n```\r\n\r\nWill filter based on if `orchestrator` exist in the `ServiceTags` array, then output `.Node` for those objects\r\n\r\n\r\n----------\r\n\r\nOutput:\r\n```json\r\n[\r\n  &quot;xyz&quot;,\r\n  &quot;teb&quot;\r\n]\r\n```\r\n\r\n#### [Try it online!](https://jqplay.org/s/g5ctwqknP_z)",
                "title": "jq obtain all values of a field only if inside string array the value V is found"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -1,
        "last_activity_date": 1665672379,
        "creation_date": 1665672018,
        "last_edit_date": 1665672379,
        "question_id": 74057674,
        "body_markdown": "I need to get all Distinct &quot;Node&quot; from an array of data objects only if in the object the &quot;ServiceTags&quot; has the String element &quot;orchestrator&quot;.\r\n\r\nFor example, for the json:\r\n```json\r\n[\r\n    {\r\n        &quot;Node&quot;: &quot;abc&quot;,\r\n        &quot;ServiceTags&quot;: [],\r\n        &quot;Type&quot;: &quot;&quot;,\r\n        &quot;Definition&quot;: {\r\n            &quot;Interval&quot;: &quot;0s&quot;,\r\n            &quot;Timeout&quot;: &quot;0s&quot;\r\n        },\r\n        &quot;CreateIndex&quot;: 11241543,\r\n        &quot;ModifyIndex&quot;: 11241543\r\n    },\r\n    {\r\n        &quot;Node&quot;: &quot;xyz&quot;,\r\n        &quot;ServiceTags&quot;: [\r\n            &quot;rules&quot;,\r\n            &quot;rhdm_es&quot;,\r\n            &quot;rhdm&quot;,\r\n            &quot;orchestrator&quot;\r\n        ],\r\n        &quot;Type&quot;: &quot;http&quot;,\r\n        &quot;Definition&quot;: {\r\n            &quot;Interval&quot;: &quot;0s&quot;,\r\n            &quot;Timeout&quot;: &quot;0s&quot;\r\n        },\r\n        &quot;CreateIndex&quot;: 12907642,\r\n        &quot;ModifyIndex&quot;: 12907659\r\n    },\r\n    {\r\n        &quot;Node&quot;: &quot;teb&quot;,\r\n        &quot;ServiceTags&quot;: [\r\n            &quot;rules&quot;,\r\n            &quot;orchestrator&quot;\r\n        ],\r\n        &quot;Type&quot;: &quot;http&quot;,\r\n        &quot;Definition&quot;: {\r\n            &quot;Interval&quot;: &quot;0s&quot;,\r\n            &quot;Timeout&quot;: &quot;0s&quot;\r\n        },\r\n        &quot;CreateIndex&quot;: 12907642,\r\n        &quot;ModifyIndex&quot;: 12907659\r\n    },\r\n    {\r\n        &quot;Node&quot;: &quot;iry&quot;,\r\n        &quot;ServiceTags&quot;: [\r\n            &quot;rules&quot;\r\n        ],\r\n        &quot;Type&quot;: &quot;http&quot;,\r\n        &quot;Definition&quot;: {\r\n            &quot;Interval&quot;: &quot;0s&quot;,\r\n            &quot;Timeout&quot;: &quot;0s&quot;\r\n        },\r\n        &quot;CreateIndex&quot;: 12907642,\r\n        &quot;ModifyIndex&quot;: 12907659\r\n    }\r\n]\r\n```\r\n\r\nthe expected result would be an array that contains the values &quot;xyz&quot; and &quot;teb&quot; because there is a &quot;orchestrator&quot; as part of &quot;ServiceTags&quot; property.\r\n\r\nI would appreciate any help, I&#39;m currently making this in a basic shell script that only prints all the ServiceTags:\r\n\r\n\r\n    # Get consul data in json format\r\n    consulResult=$(cat -)\r\n\r\n    # Validate if the json is not null or empty\r\n    if [ -z &quot;$consulResult&quot; ];\r\n    then\r\n        echo &quot;NULL OR EMPTY&quot;;\r\n    else\r\n            echo &quot;Not NULL&quot;;\r\n            echo $consulResult | jq &#39;.[].ServiceTags&#39;\r\n    fi",
        "link": "https://stackoverflow.com/questions/74057674/jq-obtain-all-values-of-a-field-only-if-inside-string-array-the-value-v-is-found",
        "title": "jq obtain all values of a field only if inside string array the value V is found"
    },
    {
        "tags": [
            "sorting",
            "jq",
            "reverse"
        ],
        "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": 1665674131,
                "post_id": 74058111,
                "comment_id": 130759253,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2242920,
                    "reputation": 3302,
                    "user_id": 1976993,
                    "user_type": "registered",
                    "accept_rate": 56,
                    "profile_image": "https://www.gravatar.com/avatar/b45ba47b05c15f41c27efcc98f11a193?s=256&d=identicon&r=PG",
                    "display_name": "xakepp35",
                    "link": "https://stackoverflow.com/users/1976993/xakepp35"
                },
                "reply_to_user": {
                    "account_id": 6196394,
                    "reputation": 86601,
                    "user_id": 5291015,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/4tAvO.jpg?s=256",
                    "display_name": "Inian",
                    "link": "https://stackoverflow.com/users/5291015/inian"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1665674141,
                "post_id": 74058111,
                "comment_id": 130759261,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2242920,
                    "reputation": 3302,
                    "user_id": 1976993,
                    "user_type": "registered",
                    "accept_rate": 56,
                    "profile_image": "https://www.gravatar.com/avatar/b45ba47b05c15f41c27efcc98f11a193?s=256&d=identicon&r=PG",
                    "display_name": "xakepp35",
                    "link": "https://stackoverflow.com/users/1976993/xakepp35"
                },
                "reply_to_user": {
                    "account_id": 6196394,
                    "reputation": 86601,
                    "user_id": 5291015,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/4tAvO.jpg?s=256",
                    "display_name": "Inian",
                    "link": "https://stackoverflow.com/users/5291015/inian"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1665674217,
                "post_id": 74058111,
                "comment_id": 130759299,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 6196394,
                    "reputation": 86601,
                    "user_id": 5291015,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/4tAvO.jpg?s=256",
                    "display_name": "Inian",
                    "link": "https://stackoverflow.com/users/5291015/inian"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1665674291,
                "post_id": 74058111,
                "comment_id": 130759334,
                "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": 1665689030,
                "post_id": 74058111,
                "comment_id": 130763917,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1665676599,
                "creation_date": 1665676599,
                "answer_id": 74058663,
                "question_id": 74058111,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "More of an idea than a good solution, but you could sort by negative codepoints obtained by using `explode`. At least there&#39;s no `reverse` involved, and only one call to `sort_by` is needed for all criteria.\r\n~~~sh\r\nsort_by(.person, (.city | [-explode[]]))\r\n~~~\r\n",
                "title": "How to sort_by in descending order without reverse in jq"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1665822280,
                "last_edit_date": 1665822280,
                "creation_date": 1665692060,
                "answer_id": 74061320,
                "question_id": 74058111,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "`reverse_merge_sort_by(f)` as defined here is a stable reverse merge-sort, where the primary order is determined by f:\r\n\r\n```\r\n# If both the input arrays $x and $y are reverse sorted according to f,\r\n# then the result will also be reverse sorted with stability maintained\r\ndef reverse_merge_by($x; $y; f):\r\n  def m:  # state: [i, j, array]  (i and j being indices into x and y respectively)\r\n    .[0] as $i | .[1] as $j\r\n    | if $i == -1 then $y[:$j + 1] + .[2]\r\n      elif $j == -1 then $x[:$i + 1] + .[2]\r\n      elif ($x[$i]|f) &lt; ($y[$j]|f)  # to ensure stability, one must not use &lt;= here\r\n      then [$i - 1, $j,     [$x[$i]] + .[2] ] | m\r\n      else [$i,     $j - 1, [$y[$j]] + .[2] ] | m\r\n      end\r\n      ;\r\n   [($x|length - 1), ($y|length -1), []] | m;\r\n\r\ndef reverse_merge_sort_by(f):\r\n  if length &lt;= 1 then .\r\n  else (length/2 |floor) as $len\r\n  | reverse_merge_by( .[:$len] | reverse_merge_sort_by(f);\r\n                      .[$len:] | reverse_merge_sort_by(f); f )\r\n  end;\r\n\r\n```\r\nFor convenience, you may want to define an alias, e.g.\r\n```\r\ndef rs(f): reverse_merge_sort_by(f);\r\n```\r\nThis has been tested with both the C and Go implementations (jq and gojq).\r\n\r\n--- \r\n\r\nExample:\r\n```\r\n[[2,1], [2,2], [1,1],[1,2],[1,0]]\r\n | . == reverse_merge_sort_by(.[0])\r\n```\r\nyields `true`.",
                "title": "How to sort_by in descending order without reverse in jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 2,
        "last_activity_date": 1665822280,
        "creation_date": 1665673906,
        "question_id": 74058111,
        "body_markdown": "When you have a columns and want to sort by multiple columns in various orders - you will start chaining reverses\r\n\r\nmy jq sort_by is stable, but if i need to sort by descending - I have to do double reverse, which i dont like\r\n\r\n```\r\nsort_by(.person) # first sort in ascending\r\n| reverse | sort_by(.city) | reverse # then sort by in descending\r\n```\r\n\r\nIn order to keep both `city` descending and `person` ascending, (but by city)  - I feel like I need double reverse, so this api does not looks good, in terms of performance for advanced sorting.\r\n\r\nDo you know any workaround, not using double reverse?",
        "link": "https://stackoverflow.com/questions/74058111/how-to-sort-by-in-descending-order-without-reverse-in-jq",
        "title": "How to sort_by in descending order without reverse in jq"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1665710382,
                "creation_date": 1665710382,
                "answer_id": 74063365,
                "question_id": 74063270,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Just use jq&#39;s command-line option `-r`.",
                "title": "Can jq parse json without containing double quote?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -1,
        "last_activity_date": 1665710382,
        "creation_date": 1665709033,
        "question_id": 74063270,
        "body_markdown": "    curl http://api.open-notify.org/iss-now.json\r\n    {&quot;message&quot;: &quot;success&quot;, &quot;timestamp&quot;: 1665708640, &quot;iss_position&quot;: {&quot;longitude&quot;: &quot;-114.2621&quot;, &quot;latitude&quot;: &quot;8.5148&quot;}}\r\n\r\nI want to parse the json to get property `message`.\r\n\r\n    x=$(curl http://api.open-notify.org/iss-now.json | jq .message)\r\n    echo $x\r\n    &quot;success&quot;\r\n\r\nI want to get `success` without containing double quote.\r\n\r\n    x=$(curl http://api.open-notify.org/iss-now.json | jq .message | sed &#39;s/&quot;//g&#39;)\r\n    echo $x\r\n    success\r\n\r\nCan jq achieve same target with its some argument without piping to sed?\r\n\r\n",
        "link": "https://stackoverflow.com/questions/74063270/can-jq-parse-json-without-containing-double-quote",
        "title": "Can jq parse json without containing double quote?"
    },
    {
        "tags": [
            "json",
            "key",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1665713379,
                "creation_date": 1665713379,
                "answer_id": 74063607,
                "question_id": 74063595,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Oops, it was easy as:\r\n```\r\njq &quot;. | {name: .name, info: {address: .info.address, telephone: .info.telephone}}&quot; sample.json\r\n```\r\n\r\nResult:\r\n```\r\n{\r\n  &quot;name&quot;: &quot;john&quot;,\r\n  &quot;info&quot;: {\r\n    &quot;address&quot;: &quot;1234 Main st&quot;,\r\n    &quot;telephone&quot;: &quot;444-5555&quot;\r\n  }\r\n}\r\n{\r\n  &quot;name&quot;: &quot;jane&quot;,\r\n  &quot;info&quot;: {\r\n    &quot;address&quot;: &quot;1234 Eagle st&quot;,\r\n    &quot;telephone&quot;: &quot;222-3333&quot;\r\n  }\r\n}\r\n```",
                "title": "Re-order nested json with jq"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1665729003,
                "creation_date": 1665729003,
                "answer_id": 74065186,
                "question_id": 74063595,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Or just: `.info |= {address,telephone}`",
                "title": "Re-order nested json with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1665968331,
        "creation_date": 1665713214,
        "last_edit_date": 1665968331,
        "question_id": 74063595,
        "body_markdown": "I have this simple JSON which has a name and a nested info with telephone and address, but now I want my address to show first before telephone.  How do I do this with jq?\r\n\r\nSample:\r\n```\r\n jq . sample.json\r\n{\r\n  &quot;name&quot;: &quot;john&quot;,\r\n  &quot;info&quot;: {\r\n    &quot;telephone&quot;: &quot;444-5555&quot;,\r\n    &quot;address&quot;: &quot;1234 Main st&quot;\r\n  }\r\n}\r\n{\r\n  &quot;name&quot;: &quot;jane&quot;,\r\n  &quot;info&quot;: {\r\n    &quot;telephone&quot;: &quot;222-3333&quot;,\r\n    &quot;address&quot;: &quot;1234 Eagle st&quot;\r\n  }\r\n}\r\n```\r\n\r\nUltimately, I want address before telephone:\r\n```\r\n{\r\n  &quot;name&quot;: &quot;john&quot;,\r\n  &quot;info&quot;: {\r\n    &quot;address&quot;: &quot;1234 Main st&quot;\r\n    &quot;telephone&quot;: &quot;444-5555&quot;,\r\n  }\r\n}\r\n```\r\n\r\nSo I would do something like this: \r\n```\r\n jq &quot;. | {name: .name, info: [.info.address, .info.telephone]}&quot; sample.json\r\n```\r\nBut this would give me instead:\r\n```\r\n{\r\n  &quot;name&quot;: &quot;john&quot;,\r\n  &quot;info&quot;: [\r\n    &quot;1234 Main st&quot;,\r\n    &quot;444-5555&quot;\r\n  ]\r\n}\r\n{\r\n  &quot;name&quot;: &quot;jane&quot;,\r\n  &quot;info&quot;: [\r\n    &quot;1234 Eagle st&quot;,\r\n    &quot;222-3333&quot;\r\n  ]\r\n}\r\n```",
        "link": "https://stackoverflow.com/questions/74063595/re-order-nested-json-with-jq",
        "title": "Re-order nested json with jq"
    },
    {
        "tags": [
            "json",
            "jq",
            "fromjson"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1665727106,
                "creation_date": 1665727106,
                "answer_id": 74064900,
                "question_id": 74064774,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s a starting point, assigning a real JSON object to the activities key:\r\n\r\n```\r\nmap(.activities |= fromjson)\r\n```\r\n\r\nOutput:\r\n\r\n```json\r\n[\r\n  {\r\n    &quot;id&quot;: 101,\r\n    &quot;created_at&quot;: &quot;1987-10-12 03:20:22.903&quot;,\r\n    &quot;updated_at&quot;: &quot;1987-10-12 01:20:36.019&quot;,\r\n    &quot;activities&quot;: {\r\n      &quot;hero&quot;: &quot;batman&quot;,\r\n      &quot;weapon&quot;: &quot;sword&quot;,\r\n      &quot;ts&quot;: null,\r\n      &quot;remote&quot;: &quot;1&quot;,\r\n      &quot;game&quot;: &quot;joker&quot;,\r\n      &quot;image&quot;: &quot;bold&quot;\r\n    }\r\n  },\r\n  {\r\n    &quot;id&quot;: 102,\r\n    &quot;created_at&quot;: &quot;2022-10-12 11:20:22.903724&quot;,\r\n    &quot;updated_at&quot;: &quot;2022-10-12 11:20:36.019043&quot;,\r\n    &quot;activities&quot;: {\r\n      &quot;hero&quot;: &quot;superman&quot;,\r\n      &quot;weapon&quot;: &quot;cape&quot;,\r\n      &quot;ts&quot;: null,\r\n      &quot;remote&quot;: &quot;2&quot;,\r\n      &quot;game&quot;: &quot;batman&quot;,\r\n      &quot;image&quot;: &quot;kind&quot;\r\n    }\r\n  }\r\n]\r\n```\r\n\r\nAnd to merge the activities sub-object into its parent object, while deleting the old property:\r\n\r\n```\r\nmap(. + (.activities | fromjson) | del(.activities))\r\n```\r\n\r\nOutput:\r\n\r\n```json\r\n[\r\n  {\r\n    &quot;id&quot;: 101,\r\n    &quot;created_at&quot;: &quot;1987-10-12 03:20:22.903&quot;,\r\n    &quot;updated_at&quot;: &quot;1987-10-12 01:20:36.019&quot;,\r\n    &quot;hero&quot;: &quot;batman&quot;,\r\n    &quot;weapon&quot;: &quot;sword&quot;,\r\n    &quot;ts&quot;: null,\r\n    &quot;remote&quot;: &quot;1&quot;,\r\n    &quot;game&quot;: &quot;joker&quot;,\r\n    &quot;image&quot;: &quot;bold&quot;\r\n  },\r\n  {\r\n    &quot;id&quot;: 102,\r\n    &quot;created_at&quot;: &quot;2022-10-12 11:20:22.903724&quot;,\r\n    &quot;updated_at&quot;: &quot;2022-10-12 11:20:36.019043&quot;,\r\n    &quot;hero&quot;: &quot;superman&quot;,\r\n    &quot;weapon&quot;: &quot;cape&quot;,\r\n    &quot;ts&quot;: null,\r\n    &quot;remote&quot;: &quot;2&quot;,\r\n    &quot;game&quot;: &quot;batman&quot;,\r\n    &quot;image&quot;: &quot;kind&quot;\r\n  }\r\n]\r\n```",
                "title": "Parsing string with fromjson and collapsing into the parent in JQ"
            },
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1665727476,
                "creation_date": 1665727476,
                "answer_id": 74064960,
                "question_id": 74064774,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Something like this should be enough:\r\n```\r\nmap(del(.activities) + (.activities | fromjson))\r\n```\r\n&lt;sup&gt;[Online demo](https://jqplay.org/s/jmySS6FybFf)&lt;/sup&gt;",
                "title": "Parsing string with fromjson and collapsing into the parent in JQ"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1665728691,
        "creation_date": 1665726178,
        "last_edit_date": 1665728691,
        "question_id": 74064774,
        "body_markdown": "I am attempting to parse out the following json array below. The activities object is a string and I have successfully been able to parse it out with the following in jq. \r\n\r\n\r\n```\r\n[\r\n {\r\n    &quot;id&quot;: 101,\r\n    &quot;created_at&quot;: &quot;1987-10-12 03:20:22.903&quot;,\r\n    &quot;updated_at&quot;: &quot;1987-10-12 01:20:36.019&quot;,\r\n    &quot;activities&quot;: &quot;{\\&quot;hero\\&quot;: \\&quot;batman\\&quot;, \\&quot;weapon\\&quot;: \\&quot;sword\\&quot;, \\&quot;ts\\&quot;: null, \\&quot;remote\\&quot;: \\&quot;1\\&quot;,\\&quot;game\\&quot;: \\&quot;joker\\&quot;, \\&quot;image\\&quot;: \\&quot;bold\\&quot;}&quot;\r\n },\r\n {   \r\n    &quot;id&quot;: 102,\r\n    &quot;created_at&quot;: &quot;2022-10-12 11:20:22.903724&quot;,\r\n    &quot;updated_at&quot;: &quot;2022-10-12 11:20:36.019043&quot;,\r\n    &quot;activities&quot;: &quot;{\\&quot;hero\\&quot;: \\&quot;superman\\&quot;, \\&quot;weapon\\&quot;: \\&quot;cape\\&quot;, \\&quot;ts\\&quot;: null, \\&quot;remote\\&quot;: \\&quot;2\\&quot;,\\&quot;game\\&quot;: \\&quot;batman\\&quot;, \\&quot;image\\&quot;: \\&quot;kind\\&quot;}&quot;\r\n  }\r\n]\r\n```\r\n\r\nThe following command allows me to parse out the string object but I haven&#39;t quite figured out how to get it back into the original array. \r\n\r\n```jq &#39;.[].activities | fromjson?&#39; test.json```\r\n\r\nOutput: \r\n\r\n```\r\n{\r\n  &quot;hero&quot;: &quot;batman&quot;,\r\n  &quot;weapon&quot;: &quot;sword&quot;,\r\n  &quot;ts&quot;: null,\r\n  &quot;remote&quot;: &quot;1&quot;,\r\n  &quot;game&quot;: &quot;joker&quot;,\r\n  &quot;image&quot;: &quot;bold&quot;\r\n}\r\n{\r\n  &quot;hero&quot;: &quot;superman&quot;,\r\n  &quot;weapon&quot;: &quot;cape&quot;,\r\n  &quot;ts&quot;: null,\r\n  &quot;remote&quot;: &quot;2&quot;,\r\n  &quot;game&quot;: &quot;batman&quot;,\r\n  &quot;image&quot;: &quot;kind&quot;\r\n}\r\n```\r\n\r\nI tried several variances of the += and |= operators to add back to the original without any luck. \r\n\r\n```jq &#39;.[].activities |= fromjson? | select( . != &quot;&quot;)&#39; ```\r\nBypassed any empty values with the select command. \r\n\r\nThis yields no results for the activities object when I run it. It brings the original id, created_at, and updated_at forward but nothing else. \r\n\r\nAppreciate any help you can offer. Thanks guys. \r\n\r\n\r\nPreferred Output\r\n```\r\n[\r\n {\r\n    &quot;id&quot;: 101,\r\n    &quot;created_at&quot;: &quot;1987-10-12 03:20:22.903&quot;,\r\n    &quot;updated_at&quot;: &quot;1987-10-12 01:20:36.019&quot;,\r\n    &quot;hero&quot;: &quot;batman&quot;,\r\n    &quot;weapon&quot;: &quot;sword&quot;,\r\n    &quot;ts&quot;: null,\r\n    &quot;remote&quot;: &quot;1&quot;,\r\n    &quot;game&quot;: &quot;joker&quot;,\r\n    &quot;image&quot;: &quot;bold&quot;\r\n  },\r\n  {\r\n    &quot;id&quot;: 102,\r\n    &quot;created_at&quot;: &quot;2022-10-12 11:20:22.903724&quot;,\r\n    &quot;updated_at&quot;: &quot;2022-10-12 11:20:36.019043&quot;,\r\n    &quot;hero&quot;: &quot;superman&quot;,\r\n    &quot;weapon&quot;: &quot;cape&quot;,\r\n    &quot;ts&quot;: null,\r\n    &quot;remote&quot;: &quot;2&quot;,\r\n    &quot;game&quot;: &quot;batman&quot;,\r\n    &quot;image&quot;: &quot;kind&quot;\r\n  }\r\n]\r\n```",
        "link": "https://stackoverflow.com/questions/74064774/parsing-string-with-fromjson-and-collapsing-into-the-parent-in-jq",
        "title": "Parsing string with fromjson and collapsing into the parent in JQ"
    },
    {
        "tags": [
            "arrays",
            "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": 0,
                "creation_date": 1665779169,
                "post_id": 74074360,
                "comment_id": 130786221,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1665779693,
                "last_edit_date": 1665779693,
                "creation_date": 1665778867,
                "answer_id": 74074493,
                "question_id": 74074360,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Convert the stream into an array either by using `-n` with `[inputs]`, or by using `-s`, then add the `last` item to all but the last `.[:-1][]`. To filter out the empty object, `select` by comparing it to `{}` or by checking its `length`.\r\n~~~sh\r\njq -n &#39;[inputs] | (.[:-1][] | select(. != {})) + last&#39;\r\n~~~\r\n[Demo](https://jqplay.org/s/Hwtn_X5gMkD)\r\n\r\n~~~sh\r\njq -s &#39;(.[:-1][] | select(length &gt; 0)) + last&#39;\r\n~~~\r\n[Demo](https://jqplay.org/s/tFVKf5EX6kM)\r\n\r\nOutput:\r\n~~~json\r\n{\r\n  &quot;name&quot;: &quot;The 24H Automatic Eye Pencil&quot;,\r\n  &quot;url&quot;: &quot;/3ina/the-24h-automatic-pencil-waterproof-brow-pencil/p-16132421/&quot;,\r\n  &quot;id&quot;: &quot;16132421&quot;,\r\n  &quot;gender&quot;: &quot;W&quot;,\r\n  &quot;brand&quot;: &quot;3INA&quot;,\r\n  &quot;cats&quot;: [\r\n    &quot;Makeup&quot;,\r\n    &quot;Eyebrows&quot;,\r\n    &quot;Eyebrow Makeup&quot;\r\n  ]\r\n}\r\n{\r\n  &quot;name&quot;: &quot;The 24H Automatic Eye Pencil&quot;,\r\n  &quot;url&quot;: &quot;/3ina/the-24h-automatic-pencil-waterproof-brow-pencil/p-16104273/&quot;,\r\n  &quot;id&quot;: &quot;16104273&quot;,\r\n  &quot;gender&quot;: &quot;W&quot;,\r\n  &quot;brand&quot;: &quot;3INA&quot;,\r\n  &quot;cats&quot;: [\r\n    &quot;Makeup&quot;,\r\n    &quot;Eyebrows&quot;,\r\n    &quot;Eyebrow Makeup&quot;\r\n  ]\r\n}\r\n~~~\r\n",
                "title": "jq how to add an element to multiple arrays"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1665781291,
                "creation_date": 1665781291,
                "answer_id": 74074830,
                "question_id": 74074360,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If the stream does not fit into your memory, you have to use the `--stream` option which breaks down the input into manageable pieces. With streamed processing, however, you cannot easily access different parts at the same time. Therefore, you&#39;d need one pass to retrieve the last item, and another one to add it to the other ones. As during processing there is no indicator for an item to being the last one, you could instead filter out those that entirely match the one being added (which conveniently happens to also filter out previously empty items).\r\n~~~sh\r\njq --argfile last &lt;(jq &#39;reduce inputs as $in (.; $in)&#39; big.json) --stream \\\r\n  -n &#39;fromstream(inputs) + $last | select(. != $last)&#39; big.json\r\n~~~\r\n~~~json\r\n{\r\n  &quot;name&quot;: &quot;The 24H Automatic Eye Pencil&quot;,\r\n  &quot;url&quot;: &quot;/3ina/the-24h-automatic-pencil-waterproof-brow-pencil/p-16132421/&quot;,\r\n  &quot;id&quot;: &quot;16132421&quot;,\r\n  &quot;gender&quot;: &quot;W&quot;,\r\n  &quot;brand&quot;: &quot;3INA&quot;,\r\n  &quot;cats&quot;: [\r\n    &quot;Makeup&quot;,\r\n    &quot;Eyebrows&quot;,\r\n    &quot;Eyebrow Makeup&quot;\r\n  ]\r\n}\r\n{\r\n  &quot;name&quot;: &quot;The 24H Automatic Eye Pencil&quot;,\r\n  &quot;url&quot;: &quot;/3ina/the-24h-automatic-pencil-waterproof-brow-pencil/p-16104273/&quot;,\r\n  &quot;id&quot;: &quot;16104273&quot;,\r\n  &quot;gender&quot;: &quot;W&quot;,\r\n  &quot;brand&quot;: &quot;3INA&quot;,\r\n  &quot;cats&quot;: [\r\n    &quot;Makeup&quot;,\r\n    &quot;Eyebrows&quot;,\r\n    &quot;Eyebrow Makeup&quot;\r\n  ]\r\n}\r\n~~~",
                "title": "jq how to add an element to multiple arrays"
            }
        ],
        "is_answered": false,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1665781291,
        "creation_date": 1665777921,
        "last_edit_date": 1665779240,
        "question_id": 74074360,
        "body_markdown": "I have an issue with such json file:\r\n\r\n```json\r\n{\r\n  &quot;name&quot;: &quot;The 24H Automatic Eye Pencil&quot;,\r\n  &quot;url&quot;: &quot;/3ina/the-24h-automatic-pencil-waterproof-brow-pencil/p-16132421/&quot;,\r\n  &quot;id&quot;: &quot;16132421&quot;,\r\n  &quot;gender&quot;: &quot;W&quot;\r\n}\r\n{\r\n  &quot;name&quot;: &quot;The 24H Automatic Eye Pencil&quot;,\r\n  &quot;url&quot;: &quot;/3ina/the-24h-automatic-pencil-waterproof-brow-pencil/p-16104273/&quot;,\r\n  &quot;id&quot;: &quot;16104273&quot;,\r\n  &quot;gender&quot;: &quot;W&quot;\r\n}\r\n{}\r\n{\r\n  &quot;brand&quot;: &quot;3INA&quot;,\r\n  &quot;cats&quot;: [\r\n    &quot;Makeup&quot;,\r\n    &quot;Eyebrows&quot;,\r\n    &quot;Eyebrow Makeup&quot;\r\n  ]\r\n}\r\n```\r\n\r\nI has 3 arrays. I would like to replicate the last array to each of the prevoius ones, so it will look like this:\r\n\r\n```json\r\n{\r\n  &quot;name&quot;: &quot;The 24H Automatic Eye Pencil&quot;,\r\n  &quot;url&quot;: &quot;/3ina/the-24h-automatic-pencil-waterproof-brow-pencil/p-16104259/&quot;,\r\n  &quot;id&quot;: &quot;16104259&quot;,\r\n  &quot;gender&quot;: &quot;W&quot;,\r\n  &quot;brand&quot;: &quot;3INA&quot;,\r\n  &quot;cats&quot;: [\r\n    &quot;Makeup&quot;,\r\n    &quot;Eyebrows&quot;,\r\n    &quot;Eyebrow Makeup&quot;\r\n  ]\r\n}\r\n{\r\n  &quot;name&quot;: &quot;The 24H Automatic Eye Pencil&quot;,\r\n  &quot;url&quot;: &quot;/3ina/the-24h-automatic-pencil-waterproof-brow-pencil/p-16132421/&quot;,\r\n  &quot;id&quot;: &quot;16132421&quot;,\r\n  &quot;gender&quot;: &quot;W&quot;,\r\n  &quot;brand&quot;: &quot;3INA&quot;,\r\n  &quot;cats&quot;: [\r\n    &quot;Makeup&quot;,\r\n    &quot;Eyebrows&quot;,\r\n    &quot;Eyebrow Makeup&quot;\r\n  ]\r\n}\r\n```\r\n\r\nI tried to just add or multiply the arrays, but it doesn&#39;t work.\r\n\r\nWhen I add specific keys ( `{name, url, id, gender} + {brand, cats}` ) it displays the key&#39;s in place, but it sets values as null.\r\n\r\nCan you help me find the solution?\r\n\r\n",
        "link": "https://stackoverflow.com/questions/74074360/jq-how-to-add-an-element-to-multiple-arrays",
        "title": "jq how to add an element to multiple arrays"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1665786270,
                "creation_date": 1665786270,
                "answer_id": 74075339,
                "question_id": 74075292,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "One way:\r\n~~~sh\r\n.data[] |= (\r\n  (.name | if test(&quot;hello1&quot;) then 18 else 24 end) as $add\r\n  | .enddate = (\r\n      .startdate | strptime(&quot;%F %T&quot;) | .[3] += $add | mktime | strftime(&quot;%F %T&quot;)\r\n    )\r\n)\r\n~~~\r\n~~~json\r\n{\r\n  &quot;data&quot;: [\r\n    {\r\n      &quot;id&quot;: 1,\r\n      &quot;startdate&quot;: &quot;2022-10-14 12:05:49&quot;,\r\n      &quot;name&quot;: &quot;hello1&quot;,\r\n      &quot;run_status_index&quot;: 29,\r\n      &quot;enddate&quot;: &quot;2022-10-15 06:05:49&quot;\r\n    },\r\n    {\r\n      &quot;id&quot;: 2,\r\n      &quot;startdate&quot;: &quot;2022-10-14 11:45:36&quot;,\r\n      &quot;name&quot;: &quot;hello2&quot;,\r\n      &quot;run_status_index&quot;: 95,\r\n      &quot;enddate&quot;: &quot;2022-10-15 11:45:36&quot;\r\n    }\r\n  ]\r\n}\r\n~~~\r\n[Demo](https://jqplay.org/s/3mw64HkciLE)\r\n\r\nNote: `test` implements a regex match. For a simple string comparison `.name == &quot;hello1&quot;` would suffice.",
                "title": "JSON+jq - if a key&#39;s value matches regex, then create a new key-value pair of existing key-value by formatting date"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1665786270,
        "creation_date": 1665785713,
        "question_id": 74075292,
        "body_markdown": "I have the following json file.\r\n\r\n```\r\n{\r\n  &quot;data&quot;: [\r\n    {\r\n      &quot;id&quot;: 1,\r\n      &quot;startdate&quot;: &quot;2022-10-14 12:05:49&quot;,\r\n      &quot;name&quot;: &quot;hello1&quot;,\r\n      &quot;run_status_index&quot;: 29\r\n    },\r\n    {\r\n      &quot;id&quot;: 2,\r\n      &quot;startdate&quot;: &quot;2022-10-14 11:45:36&quot;,\r\n      &quot;name&quot;: &quot;hello2&quot;,\r\n      &quot;run_status_index&quot;: 95\r\n    }\r\n  ]\r\n}\r\n```\r\n\r\nNow, if the name is ```hello1```, then I want to add 18hours to the startdate and create a new key called ```&quot;endate&quot;.``` For ```hello2```, I want to add 24hours to startdate and create ```&quot;endate&quot;```. \r\n\r\nSo, the output would be...\r\n\r\n```\r\n{\r\n  &quot;data&quot;: [\r\n    {\r\n      &quot;id&quot;: 1,\r\n      &quot;startdate&quot;: &quot;2022-10-14 12:05:49&quot;,\r\n      &quot;endate&quot;: &quot;2022-10-15 06:05:49&quot;,\r\n      &quot;name&quot;: &quot;hello1&quot;,\r\n      &quot;run_status_index&quot;: 29\r\n    },\r\n    {\r\n      &quot;id&quot;: 2,\r\n      &quot;startdate&quot;: &quot;2022-10-14 11:45:36&quot;,\r\n      &quot;endate&quot;: &quot;2022-10-15 11:45:36&quot;,\r\n      &quot;name&quot;: &quot;hello2&quot;,\r\n      &quot;run_status_index&quot;: 95\r\n    }\r\n  ]\r\n}\r\n```\r\n\r\nI tried the following based on my searches but I cannot wrap my head around the if statements.\r\n\r\n```jq &#39;def n: if .data == &quot;&quot; then null else . end; .endate = ((.startdate|n) // &quot;&quot;)&#39;```",
        "link": "https://stackoverflow.com/questions/74075292/jsonjq-if-a-keys-value-matches-regex-then-create-a-new-key-value-pair-of-ex",
        "title": "JSON+jq - if a key&#39;s value matches regex, then create a new key-value pair of existing key-value by formatting date"
    },
    {
        "tags": [
            "json",
            "bigdata",
            "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": 1665799541,
                "post_id": 74076187,
                "comment_id": 130789224,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 26628004,
                    "reputation": 65,
                    "user_id": 20245646,
                    "user_type": "registered",
                    "profile_image": "https://lh3.googleusercontent.com/a/ALm5wu2Sqbkz3VTCzFS6oyKOw1WNI0fLGB_z8nUSoqYVIg=k-s256",
                    "display_name": "KTK",
                    "link": "https://stackoverflow.com/users/20245646/ktk"
                },
                "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": 1665800076,
                "post_id": 74076187,
                "comment_id": 130789294,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 49492,
                    "reputation": 316217,
                    "user_id": 147356,
                    "user_type": "registered",
                    "accept_rate": 54,
                    "profile_image": "https://www.gravatar.com/avatar/b9506717d24256a090524dd5505d3207?s=256&d=identicon&r=PG",
                    "display_name": "larsks",
                    "link": "https://stackoverflow.com/users/147356/larsks"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1665800443,
                "post_id": 74076187,
                "comment_id": 130789330,
                "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": 1665801850,
                "post_id": 74076187,
                "comment_id": 130789481,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 26628004,
                    "reputation": 65,
                    "user_id": 20245646,
                    "user_type": "registered",
                    "profile_image": "https://lh3.googleusercontent.com/a/ALm5wu2Sqbkz3VTCzFS6oyKOw1WNI0fLGB_z8nUSoqYVIg=k-s256",
                    "display_name": "KTK",
                    "link": "https://stackoverflow.com/users/20245646/ktk"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1665810129,
                "post_id": 74076187,
                "comment_id": 130790348,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "reply_to_user": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1665824563,
                "post_id": 74076187,
                "comment_id": 130792391,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1668097362,
                "last_edit_date": 1668097362,
                "creation_date": 1665820428,
                "answer_id": 74077683,
                "question_id": 74076187,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I posted a related question here: https://stackoverflow.com/questions/73843868/difference-between-slurp-null-input-and-inputs-filter\r\n\r\nIf your file is huge, but the documents inside the file aren&#39;t that big (just many many smaller ones), `jq -n &#39;inputs&#39;` could get you started:\r\n\r\n```\r\njq -n &#39;inputs | keys&#39;\r\n```\r\n\r\nHere&#39;s an example (with a small file):\r\n\r\n```\r\n$ jq -n &#39;inputs | keys&#39; &lt;&lt;JSON\r\n{&quot;foo&quot;: 21, &quot;bar&quot;: &quot;less interesting data&quot;}\r\n{&quot;foo&quot;: 42, &quot;bar&quot;: &quot;more interesting data&quot;}\r\nJSON\r\n[\r\n  &quot;bar&quot;,\r\n  &quot;foo&quot;\r\n]\r\n[\r\n  &quot;bar&quot;,\r\n  &quot;foo&quot;\r\n]\r\n```\r\n\r\nThis approach will _not_ work if you have a single top-level object that is gigabytes big or has millions of keys.",
                "title": "How to read a 100+GB file with jq without running out of memory&quot;"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1677110848,
                "last_edit_date": 1677110848,
                "creation_date": 1665823442,
                "answer_id": 74077968,
                "question_id": 74076187,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "jq&#39;s streaming parser (invoked using the --stream option) can generally handle very, very large files (and even arbitrarily large files provided certain conditions are met), but it is typically very slow and often quite cumbersome.\r\n\r\nIn practice, I find that tools such as [jstream][1] and/or my own [jm][2] work very nicely in conjunction with jq when dealing with ginormous files.\r\nWhen used this way, they are both very easy to use, though installation is potentially a bit of a hassle.\r\n\r\nUnfortunately, if you know nothing at all about the contents of a JSON file except that `jq empty` takes too long or fails, then there is no CLI-tool that I know of that can produce a useful schema automagically.  However, looking at the first few bytes of the file will usually provide enough information to get going.  Or you could start with `jm count` to give a count of the top-level objects, and go from there. `jm -s | jq &#39;keys[]&#39;` will give you the list of top-level keys if the top-level is a JSON object.\r\n\r\n---\r\nHere&#39;s an example.  Suppose we have determined that the large size of the file ginormous.json is primarily because it consists of a very long top-level array.  Then assuming that [schema.jq](https://gist.github.com/pkoppstein/a5abb4ebef3b0f72a6ed) (already mentioned elsewhere on this page) is in the pwd, you have some hope of finding an informative schema by running:\r\n```\r\njm ginormous.json |\r\n  jq -n &#39;include &quot;schema&quot; {source:&quot;.&quot;}; schema(inputs)&#39;\r\n```\r\n\r\nSee also https://stackoverflow.com/questions/75501520/jq-to-recursively-profile-json-object for a simpler schema-inference engine.\r\n\r\n  [1]: https://github.com/bcicen/jstream\r\n  [2]: https://github.com/pkoppstein/jm",
                "title": "How to read a 100+GB file with jq without running out of memory&quot;"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1666062580,
                "last_edit_date": 1666062580,
                "creation_date": 1665826917,
                "answer_id": 74078333,
                "question_id": 74076187,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "One generic way to determine the structure of a very large file containing a single JSON entity would be to run the following query:\r\n```\r\njq -nc --stream -f structural-paths.jq huge.json | sort -u\r\n```\r\nwhere `structural_paths.jq` contains:\r\n```\r\ninputs\r\n| select(length == 2)\r\n| .[0]\r\n| map( if type == &quot;number&quot; then 0 else . end )\r\n```\r\n\r\nNote that the &#39;0&#39;s in the output signify that there is at least one valid array index at the corresponding position, not that &#39;0&#39; is actually a valid index at that position.\r\n\r\nNote also that for very large files, using jq --stream to process the entire file could be quite slow.\r\n\r\n### Example:\r\n\r\nGiven `{&quot;a&quot;: {&quot;b&quot;: [0,1, {&quot;c&quot;:2}]}}`, the result of the above incantation would be:\r\n```\r\n[&quot;a&quot;,&quot;b&quot;,0,&quot;c&quot;]\r\n[&quot;a&quot;,&quot;b&quot;,0]\r\n```\r\n\r\n\r\n## Top-level structure\r\n\r\nIf you just want more information about the top-level structure, you could simplify the above jq program to:\r\n```\r\ninputs | select(length==1)[0][0] | if type == &quot;number&quot; then 0 else . end\r\n```\r\n\r\n## Structure to a given depth\r\nIf the command-line `sort` fails, then you might want to limit the number of paths by considering them only to a certain depth.\r\n\r\nIf the depth is not too great, then hopefully your command-line `sort` will be able to manage; if not, then using the command-line `uniq` would at least trim the output somewhat.\r\n\r\nA better option might be to define `unique(stream)` in jq, and then use it, as illustrated here:\r\n\r\n```\r\n# Output: a stream of the distinct `tostring` values of the items in the stream\r\ndef uniques(stream):\r\n  foreach (stream|tostring) as $s ({};\r\n     if .[$s] then .emit = false else .emit = true | .item = $s | .[$s]=true end;\r\n     if .emit then .item else empty end );\r\n\r\ndef spaths($depth):\r\n  inputs\r\n  | select(length==1)[0][0:$depth]\r\n  | map(if type == &quot;number&quot; then 0 else . end);\r\n\r\nuniques(spaths($depth))\r\n```\r\nA suitable invocation of jq would then look like:\r\n```\r\njq -nr --argjson depth 3 --stream -f structural-paths.jq huge.json\r\n```\r\n\r\nBeside avoiding the costs of sorting, using `uniques/1` will preserve the ordering of paths in the original JSON.\r\n\r\n### &quot;JSON Pointer&quot; pointers\r\nIf you want to convert array path expressions to &quot;JSON Pointer&quot; strings (e.g. for use with `jm` or `jstream`), simply append the following to the relevant jq program:\r\n\r\n    | &quot;/&quot; + join(&quot;/&quot;)\r\n",
                "title": "How to read a 100+GB file with jq without running out of memory&quot;"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 5,
        "last_activity_date": 1705748123,
        "creation_date": 1665799412,
        "last_edit_date": 1705748123,
        "question_id": 74076187,
        "body_markdown": "I have a 100+GB json file and when I try to read it with jq my computer keeps running our of ram. Is there a way to read the file while limiting the memory usage or some other way to read a VERY huge json file?\r\n\r\nWhat I typed in the command: `jq &#39;keys&#39; fileName.json`",
        "link": "https://stackoverflow.com/questions/74076187/how-to-read-a-100gb-file-with-jq-without-running-out-of-memory",
        "title": "How to read a 100+GB file with jq without running out of memory&quot;"
    },
    {
        "tags": [
            "json",
            "shell",
            "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": 1666004571,
                "post_id": 74095381,
                "comment_id": 130824504,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1666000170,
                "creation_date": 1666000170,
                "answer_id": 74095418,
                "question_id": 74095381,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Use parentheses around the key expression to have it evaluated:\r\n~~~sh\r\njq -n --arg k1 &quot;Key1&quot; --arg v1 &quot;Value1&quot; &#39;{($k1): $v1}&#39;\r\n~~~\r\n~~~json\r\n{\r\n  &quot;Key1&quot;: &quot;Value1&quot;\r\n}\r\n~~~",
                "title": "Construct json through jq tool in shell script loop"
            },
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1666028636,
                "last_edit_date": 1666028636,
                "creation_date": 1666000334,
                "answer_id": 74095461,
                "question_id": 74095381,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I&#39;d suggest a totally different, but simpler, approach:\r\n\r\n```sh\r\nfor kv; do\r\n  echo &quot;$kv&quot; | jq -R &#39;./&quot;=&quot; | {key:first,value:last}&#39;\r\ndone | jq -s &#39;from_entries&#39;\r\n```\r\n\r\nIt builds `{key: …, value: …}` objects from your positional parameters (splitting them by the equal sign) and then slurping all those objects in a second `jq` process, converting them into a single object via [`from_entries`](https://stedolan.github.io/jq/manual/v1.6/#to_entries,from_entries,with_entries).\r\n\r\nAlternatively, using `-n` (`--null-input`), `--args` and then accessing via `$ARGS.positional`. This avoids the loop and the second `jq` call altogether.\r\n\r\n```\r\njq -n &#39;$ARGS.positional | map(./&quot;=&quot; | {key:first,value:last}) | from_entries&#39; --args &quot;$@&quot;\r\n```\r\n\r\nIf your values can contain `=` themselves, you have to join all but the first value of the array:\r\n\r\n```\r\njq -n &#39;$ARGS.positional\r\n| map(./&quot;=&quot; | {key:first,value:.[1:]|join(&quot;=&quot;)})\r\n| from_entries&#39; --args &quot;$@&quot;\r\n```",
                "title": "Construct json through jq tool in shell script loop"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": -1,
                "last_activity_date": 1666011418,
                "creation_date": 1666011418,
                "answer_id": 74097674,
                "question_id": 74095381,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Perhaps this, which will handle an arbitrary number of key=value arguments:\r\n\r\n```bash\r\n#!/usr/bin/env bash\r\n\r\nargs=()\r\nfor arg; do\r\n    IFS=&quot;=&quot; read -r k v &lt;&lt;&lt;&quot;$arg&quot;\r\n    args+=(&quot;$k&quot; &quot;$v&quot;)\r\ndone\r\n\r\njq -n --args &#39;\r\n    $ARGS.positional as $a\r\n    | reduce range(0; $a | length; 2) as $i ({}; .[$a[$i]] = $a[$i + 1])\r\n&#39; &quot;${args[@]}&quot;\r\n```\r\n\r\nProduces:\r\n```sh\r\n$ ./test.sh k1=v1 k2=v2 k3=v3\r\n{\r\n  &quot;k1&quot;: &quot;v1&quot;,\r\n  &quot;k2&quot;: &quot;v2&quot;,\r\n  &quot;k3&quot;: &quot;v3&quot;\r\n}\r\n```",
                "title": "Construct json through jq tool in shell script loop"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 0,
        "last_activity_date": 1666028636,
        "creation_date": 1665999991,
        "question_id": 74095381,
        "body_markdown": "json can be created using the following command.\r\n\r\n      jq -n \\\r\n      --arg v1 &quot;Value1&quot; \\\r\n      --arg v2 &quot;Value2&quot; \\\r\n      &#39;{k1: &quot;$v1&quot;, k2:$v2&#39;}\r\n\r\nBut when my key is mutable, how should I loop? For example, the script I execute is\r\n\r\n    test.sh k1=v1 k2=v2 k3=v3\r\ntest.sh is as follows\r\n      \r\n```\r\nindex=1\r\nwhile ((index &lt;= &quot;$#&quot;)); do\r\n  data_i_key=$(echo ${!index} | awk -F &quot;=&quot; &#39;{print $1}&#39;)\r\n  data_i_value=$(echo ${!index} | awk -F &quot;=&quot; &#39;{print $2}&#39;)\r\n  let index++\r\n  JSON_STRING=$(jq -n \\\r\n    --arg value &quot;$data_i_value&quot; \\\r\n    &#39;{&#39;&quot;$data_i_key&quot;&#39;: $value&#39;})\r\n    echo $JSON_STRING\r\n```\r\n\r\n The above print result is\r\n\r\n    { &quot;K3&quot;: &quot;V3&quot; }\r\n  \r\nif I replace it with\r\n```\r\nJSON_STRING+=$(jq -n \\\r\n    --arg val_value &quot;$dataValue&quot; \\\r\n    &#39;{&#39;&quot;$data_i_key&quot;&#39;: $val_value&#39;})\r\n```\r\n The print result is\r\n\r\n    { &quot;k1&quot;: &quot;v1&quot; }{ &quot;k2&quot;: &quot;v2&quot; }{ &quot;K3&quot;: &quot;V3&quot; }\r\nThe above two methods have not achieved the goal, do you have a good way to deal with it? My desired output is\r\n\r\n   { &quot;k1&quot;: &quot;v1&quot; , &quot;k2&quot;: &quot;v2&quot; ,&quot;K3&quot;: &quot;V3&quot; }\r\n\r\nhope you can help me.",
        "link": "https://stackoverflow.com/questions/74095381/construct-json-through-jq-tool-in-shell-script-loop",
        "title": "Construct json through jq tool in shell script loop"
    },
    {
        "tags": [
            "json",
            "unix",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1666041447,
                "post_id": 74103310,
                "comment_id": 130837319,
                "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": 1666041524,
                "post_id": 74103310,
                "comment_id": 130837338,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 3789809,
                    "reputation": 45,
                    "user_id": 3146711,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/22e15fffcd0ce66408024c509b6c031c?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "bunkfish",
                    "link": "https://stackoverflow.com/users/3146711/bunkfish"
                },
                "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": 1666044192,
                "post_id": 74103310,
                "comment_id": 130838039,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1666101034,
                "last_edit_date": 1666101034,
                "creation_date": 1666046223,
                "answer_id": 74103960,
                "question_id": 74103310,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I&#39;m not sure whether you want the &quot;aos&quot; field to be present in every generated object.  If not, you could do worse than:\r\n```\r\njq -c &#39;\r\n  .r1 as $r1\r\n  | .r2 as $r2\r\n  | .r3 as $r3\r\n  | .ver as $ver\r\n  | .noa1[] \r\n  | .col1 as $col1\r\n  | .noa2[] \r\n  | .aon as $aon\r\n  | .obj\r\n  | {$r1, $r2, $ver, $col1, $aon, col10, col11} \r\n    + try {aos: .aos[]} catch {} &#39;\r\n```\r\n\r\nIf you do, then you could replace the very last `{}` by `{aos: null}` or whatever. If you prefer not to use `try ... catch` then you could replace it by an `if` statement, or perhaps by:\r\n```\r\n( (.aos // [null]) | {aos: .[]} )\r\n```\r\n\r\n---\r\n\r\nThe key to preserving sanity here is, I think, to avoid creating jq variables except as needed as you &quot;drill down&quot;.  Also, jq&#39;s support for abbreviations such as {$x} and {y} makes things easier to read and review.\r\n\r\n",
                "title": "Explode Complex JSON Object (with Objects and Arrays) with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1666101034,
        "creation_date": 1666041314,
        "last_edit_date": 1666045575,
        "question_id": 74103310,
        "body_markdown": "We are receiving data from a customer and it is highly nested (the customer has done this to reduce the amount of duplicated data, thereby reducing the overall size of data transferred).\r\n\r\nThe data looks like this:\r\n```\r\n{\r\n\t&quot;r1&quot;: &quot;ex&quot;,\r\n\t&quot;r2&quot;: &quot;of&quot;,\r\n\t&quot;r3&quot;: &quot;da&quot;,\r\n\t&quot;ver&quot;: 1,\r\n\t&quot;noa1&quot;: [{\r\n\t\t&quot;col1&quot;: 380,\r\n\t\t&quot;noa2&quot;: [{\r\n\t\t\t&quot;aon&quot;: [123],\r\n\t\t\t&quot;obj&quot;: {\r\n\t\t\t\t&quot;col10&quot;: &quot;stuf&quot;,\r\n\t\t\t\t&quot;col11&quot;: &quot;here&quot;,\r\n\t\t\t\t&quot;aos&quot;: [&quot;A&quot;,\r\n\t\t\t\t\t&quot;X&quot;\r\n\t\t\t\t]\r\n\t\t\t}\r\n\t\t}, {\r\n\t\t\t&quot;aon&quot;: [],\r\n\t\t\t&quot;obj&quot;: {\r\n\t\t\t\t&quot;col10&quot;: &quot;more&quot;,\r\n\t\t\t\t&quot;col11&quot;: &quot;stuf&quot;\r\n\t\t\t}\r\n\t\t}, {\r\n\t\t\t&quot;aon&quot;: [456, 789]\r\n\t\t}, {\r\n\t\t\t&quot;obj&quot;: {\r\n\t\t\t\t&quot;col10&quot;: &quot;anon&quot;\r\n\t\t\t}\r\n\t\t}]\r\n\t}, {\r\n\t\t&quot;col1&quot;: 5676,\r\n\t\t&quot;noa2&quot;: [{\r\n\t\t\t&quot;aon&quot;: [875],\r\n\t\t\t&quot;obj&quot;: {\r\n\t\t\t\t&quot;col10&quot;: &quot;does&quot;,\r\n\t\t\t\t&quot;col11&quot;: &quot;noth&quot;,\r\n\t\t\t\t&quot;aos&quot;: [&quot;Y&quot;,\r\n\t\t\t\t\t&quot;Z&quot;\r\n\t\t\t\t]\r\n\t\t\t}\r\n\t\t}, {\r\n\t\t\t&quot;obj&quot;: {\r\n\t\t\t\t&quot;col11&quot;: &quot;phew&quot;\r\n\t\t\t}\r\n\t\t}]\r\n\t}]\r\n}\r\n```\r\nwhere there are a number of optional nested objects and arrays (around 6 levels deep IRL, but simplified here).\r\n\r\nWe have to flatten this to a CSV, where each row would be unique containing the data of the JSON object. We would not want any &quot;new rows&quot; created from a cross product join. So the above would look like:\r\n```\r\nr1|r2|r3|ver|col1|aon|col10|col11|aos\r\nex|of|da|1  |380 |123|stuf |here |A\r\nex|of|da|1  |380 |123|stuf |here |X\r\nex|of|da|1  |380 |   |more |stuf |\r\nex|of|da|1  |380 |456|     |     |\r\nex|of|da|1  |380 |789|     |     |\r\nex|of|da|1  |380 |   | anon|     |\r\nex|of|da|1  |5676|875|does |noth |Y\r\nex|of|da|1  |5676|875|does |noth |Z\r\nex|of|da|1  |5676|   |     |phew |\r\n\r\nFor brevity, we show this as a table. In reality, we would want this to be a collection of JSON documents (jq -c).\r\n```\r\nWe have been working with jq, but are getting stuck with working with nested arrays that are not objects, like an array of strings. It is causing a cross join to occur, putting values in places that do not exist in the original JSON. We also have trouble with optional nested rows (jq is currently not printing the row if an array is null, even with the ? modifier.\r\n\r\nQuestions are:\r\n1. What would be the jq filter for the original JSON?\r\n2. In general, how would one handle nested objects, arrays, and arrays of string, numbers, etc within jq?\r\n\r\nUpdated:\r\nThe following code\r\n```\r\n.r1 as $r1 | .r2 as $r2 | .r3 as $r3 | .ver as $ver | .noa1[] | . as $noa1 | .noa2[] | . as $noa2 | {$r1, $r2, $r3, $ver, &quot;col1&quot;: $noa1.col1, &quot;aon&quot;: $noa2.aon }\r\n```\r\nreturns\r\n```\r\n{&quot;r1&quot;:&quot;ex&quot;,&quot;r2&quot;:&quot;of&quot;,&quot;r3&quot;:&quot;da&quot;,&quot;ver&quot;:1,&quot;col1&quot;:380,&quot;aon&quot;:[123]}\r\n{&quot;r1&quot;:&quot;ex&quot;,&quot;r2&quot;:&quot;of&quot;,&quot;r3&quot;:&quot;da&quot;,&quot;ver&quot;:1,&quot;col1&quot;:380,&quot;aon&quot;:[]}\r\n{&quot;r1&quot;:&quot;ex&quot;,&quot;r2&quot;:&quot;of&quot;,&quot;r3&quot;:&quot;da&quot;,&quot;ver&quot;:1,&quot;col1&quot;:380,&quot;aon&quot;:[456,789]}\r\n{&quot;r1&quot;:&quot;ex&quot;,&quot;r2&quot;:&quot;of&quot;,&quot;r3&quot;:&quot;da&quot;,&quot;ver&quot;:1,&quot;col1&quot;:380,&quot;aon&quot;:null}\r\n{&quot;r1&quot;:&quot;ex&quot;,&quot;r2&quot;:&quot;of&quot;,&quot;r3&quot;:&quot;da&quot;,&quot;ver&quot;:1,&quot;col1&quot;:5676,&quot;aon&quot;:[875]}\r\n{&quot;r1&quot;:&quot;ex&quot;,&quot;r2&quot;:&quot;of&quot;,&quot;r3&quot;:&quot;da&quot;,&quot;ver&quot;:1,&quot;col1&quot;:5676,&quot;aon&quot;:null}\r\n```\r\nwhich makes sense.\r\nBut now when we try to go further and explode the &quot;aon&quot; array of numbers, it gets weird.\r\nThis code\r\n```\r\n.r1 as $r1 | .r2 as $r2 | .r3 as $r3 | .ver as $ver | .noa1[] | . as $noa1 | .noa2[] | . as $noa2 | \r\n{$r1, $r2, $r3, $ver, &quot;col1&quot;: $noa1.col1, &quot;aon&quot;: $noa2.aon[]? }\r\n```\r\nloses the rows that have a null value for &quot;aon&quot;, which I can understand, kind of (because of the ?).\r\nBut this code fails\r\n```\r\n.r1 as $r1 | .r2 as $r2 | .r3 as $r3 | .ver as $ver | .noa1[] | . as $noa1 | .noa2[] | . as $noa2 | \r\n{$r1, $r2, $r3, $ver, &quot;col1&quot;: $noa1.col1, &quot;aon&quot;: $noa2.aon[] }\r\n```\r\nwhich I also understand, because of the null values. So we try to reference it as a variable:\r\n```\r\n.r1 as $r1 \r\n| .r2 as $r2 \r\n| .r3 as $r3 \r\n| .ver as $ver \r\n| .noa1[] | . as $noa1 \r\n| .noa2[] | . as $noa2\r\n| .obj as $obj\r\n| .aon[]? | . as $aon\r\n| {$r1, $r2, $r3, $ver, &quot;col1&quot;: $noa1.col1, &quot;aon&quot;: $aon, &quot;col10&quot;: $obj.col10, &quot;col11&quot;: $obj.col11 }\r\n```\r\nand get this far. But a couple of issues: we&#39;ve lost some rows where aon is null, and we can&#39;t figure out how to access &quot;aos&quot;.",
        "link": "https://stackoverflow.com/questions/74103310/explode-complex-json-object-with-objects-and-arrays-with-jq",
        "title": "Explode Complex JSON Object (with Objects and Arrays) with jq"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1666078729,
                "last_edit_date": 1666078729,
                "creation_date": 1666074720,
                "answer_id": 74106619,
                "question_id": 74106533,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Modify the part involving generation of `.Text` to something simpler using `split()` method in `jq` that can be used to split on a single white-space. This way, you are not reliant on the length of the sub-fields you want to extract\r\n\r\n```none\r\n( .Text | split(&quot; &quot;) | .[0] + &quot;-&quot; + .[1] ) + .StringValue[0:1]\r\n```\r\n\r\ni.e. with full code\r\n\r\n```none\r\n.[] | [ select( .ClassificationNo ==&quot;500001&quot; and .StringValue != &quot;&quot; ) | \r\n{ \r\n  PartNumber, \r\n  ClassificationNo, \r\n  StringValue, \r\n  Field, \r\n  Text \r\n} ] |\r\nsort_by(.Field) |\r\nmap(\r\n  .PartNumber,\r\n  .ClassificationNo, \r\n  .Field[3:5], \r\n  ( .Text | split(&quot; &quot;) | .[0] + &quot;-&quot; + .[1] ) + .StringValue[0:1], \r\n  &quot;Test&quot;, .StringValue[1:10]\r\n) | \r\njoin(&quot;;&quot;)\r\n```\r\n\r\ndemo at [jqplay][1]\r\n\r\n\r\n\r\n  [1]: https://jqplay.org/s/McosnjNEhlu",
                "title": "jq Split value on base space and join to one string"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1666097207,
        "creation_date": 1666074109,
        "last_edit_date": 1666097207,
        "question_id": 74106533,
        "body_markdown": "I would like to ask for help. I need to split values from key &quot;Text&quot; on base space &quot; &quot; and join to one line. In actually code I calculate with exactly position but if key Text has S10 is show only S1. \r\n\r\nMy input\r\n\r\n    [   \r\n    \t{\r\n                &quot;PartNumber&quot;: &quot;5SE32DFVLG002&quot;,\r\n                &quot;ClassificationNo&quot;: &quot;500001&quot;,\r\n                &quot;StringValue&quot;: &quot;R0050SWSW&quot;,\r\n                &quot;Field&quot;: &quot;95001&quot;,\r\n                &quot;Text&quot;: &quot;S1 W1  cr.sec+colour&quot;   \r\n    },   \r\n        {\r\n                &quot;PartNumber&quot;: &quot;5SE32DFVLG002&quot;,\r\n                &quot;ClassificationNo&quot;: &quot;500001&quot;,\r\n                &quot;StringValue&quot;: &quot;R0050SWSW&quot;,\r\n                &quot;Field&quot;: &quot;95004&quot;,\r\n                &quot;Text&quot;: &quot;S1 W10 cr.sec+colour&quot;   \r\n    } \r\n    ]\r\n    \r\n\r\nMy actually condition in jq play\r\n\r\n&gt; [.Oslm[] | select(.ClassificationNo==&quot;500001&quot; and .StringValue!=&quot;&quot;)  |\r\n&gt; {PartNumber,ClassificationNo,StringValue,Field,Text}] |\r\n&gt; sort_by(.Field) | .[] | [.PartNumber,.ClassificationNo,\r\n&gt; .Field[3:5],.Text[0:2] + &quot;-&quot; + .Text[3:5] + .StringValue[0:1], &quot;Test\r\n&gt; &quot;, .StringValue[1:10]] | join(&quot;;&quot;)\r\n\r\nActual result\r\n\r\n    5SE32DFVLG002;500001;95001;S1-W1R;TEST;0050SWSW \r\n    5SE32DFVLG002;500001;95004;S1-W1R;TEST;0050SWSW\r\n\r\nI would like to have this result\r\n\r\n    5SE32DFVLG002;500001;95001;S1-W1R;TEST;0050SWSW \r\n    5SE32DFVLG002;500001;95004;S1-W10R;TEST;0050SWSW\r\n\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/74106533/jq-split-value-on-base-space-and-join-to-one-string",
        "title": "jq Split value on base space and join to one string"
    },
    {
        "tags": [
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1666115601,
                "post_id": 74115373,
                "comment_id": 130857674,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 37811,
                    "reputation": 112102,
                    "user_id": 108205,
                    "user_type": "registered",
                    "accept_rate": 86,
                    "profile_image": "https://www.gravatar.com/avatar/ef459127edc89cc575d80a73cd8c567a?s=256&d=identicon&r=PG",
                    "display_name": "jsbueno",
                    "link": "https://stackoverflow.com/users/108205/jsbueno"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1666115697,
                "post_id": 74115373,
                "comment_id": 130857707,
                "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": 1666115753,
                "post_id": 74115373,
                "comment_id": 130857733,
                "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": 37811,
                    "reputation": 112102,
                    "user_id": 108205,
                    "user_type": "registered",
                    "accept_rate": 86,
                    "profile_image": "https://www.gravatar.com/avatar/ef459127edc89cc575d80a73cd8c567a?s=256&d=identicon&r=PG",
                    "display_name": "jsbueno",
                    "link": "https://stackoverflow.com/users/108205/jsbueno"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1666115792,
                "post_id": 74115373,
                "comment_id": 130857760,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1666122922,
                "last_edit_date": 1666122922,
                "creation_date": 1666115674,
                "answer_id": 74115405,
                "question_id": 74115373,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "No, you don&#39;t need to escape anything here.\r\n\r\nUsing NULs to delimit all values, so we can correctly support titles or descriptions that contain newlines:\r\n\r\n```\r\n{\r\n  IFS= read -r -d &#39;&#39; title\r\n  IFS= read -r -d &#39;&#39; description\r\n} &lt; &lt;(jq -r &#39;.meta | (.title, .description) | (., &quot;\\u0000&quot;)&#39; )\r\n```\r\n\r\n---\r\n\r\nIf we assume that `title` and `description` cannot contain literal newlines, either of the below will do:\r\n\r\n```\r\n{\r\n  IFS= read -r title\r\n  IFS= read -r description\r\n} &lt; &lt;(jq -r &#39;.meta | .title, .description&#39; ./project.json)\r\n```\r\n\r\n...or, telling `read` to look for a terminating NUL, and thereby ensuring that it has a nonzero exit status should `jq` fail (but still using a newline to separate the two values):\r\n\r\n```\r\nIFS=$&#39;\\n&#39; read -r -d &#39;&#39; title description &lt; &lt;(\r\n  jq -r &#39;.meta | (.title, .description, &quot;\\u0000&quot;)&#39; ./project.json\r\n)\r\n```\r\n\r\n---\r\n\r\nTaking advantage of jq&#39;s support for generating `sh`-compatible eval-safe escaping, we can also do the following, which _does_ correctly handle strings with newlines:\r\n\r\n```\r\neval &quot;$(jq -r &#39;\r\n  .meta | &quot;description=\\(.description|@sh); title=\\(.title|@sh)&quot;\r\n&#39; ./project.json)&quot;\r\n```",
                "title": "Assign string with spaces to variable and escape those spaces"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1666115910,
                "creation_date": 1666115910,
                "answer_id": 74115460,
                "question_id": 74115373,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Using some parameter substitutions:\r\n\r\n    $ x=$(jq ... )\r\n    $ title=&quot;${x%$&#39;\\n&#39;*}&quot;\r\n    $ description=&quot;${x#*$&#39;\\n&#39;}&quot;\r\n    $ typeset -p title description\r\n    declare -- title=&quot;This is a title&quot;\r\n    declare -- description=&quot;Just a description&quot;\r\n\r\n",
                "title": "Assign string with spaces to variable and escape those spaces"
            },
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1666116914,
                "creation_date": 1666116914,
                "answer_id": 74115666,
                "question_id": 74115373,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "With builtin `mapfile`, `bash` and an array (title):\r\n\r\n    mapfile -t title &lt; &lt;(jq -r &#39;.meta | .title, .description&#39; project.json)\r\n    echo &quot;${title[0]}&quot;\r\n    echo &quot;${title[1]}&quot;\r\nOutput:\r\n&lt;pre&gt;\r\nThis is a title\r\nJust a description\r\n&lt;/pre&gt;\r\n",
                "title": "Assign string with spaces to variable and escape those spaces"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 1,
        "last_activity_date": 1666122922,
        "creation_date": 1666115525,
        "question_id": 74115373,
        "body_markdown": "I&#39;m trying to get some json data using `jq`:\r\n\r\n    {\r\n        &quot;meta&quot;: {\r\n            &quot;title&quot;: &quot;This is a title&quot;,\r\n            &quot;description&quot;: &quot;Just a description&quot;\r\n        }\r\n    }\r\n\r\nby running `jq -r &#39;.meta | .title, .description&#39; ./project.json`, which gives me the expected result:\r\n\r\n    This is a title\r\n    Just a description\r\n\r\nNow I need to assign the content to a variable in my bash script:\r\n\r\n    read TITLE DESCRIPTION &lt; &lt;(echo $(jq -r &#39;.meta | .title, .description&#39; ./project.json))\r\n\r\nBut this is not working because of the spaces. Also later I have to escape all spaces, which I would do with:\r\n\r\n    echo ${TITLE// /\\\\ }\r\n\r\nHow should I handle the assignment of the variable (handling space content) and escape the spaces (maybe in one step)?\r\n",
        "link": "https://stackoverflow.com/questions/74115373/assign-string-with-spaces-to-variable-and-escape-those-spaces",
        "title": "Assign string with spaces to variable and escape those spaces"
    },
    {
        "tags": [
            "linux",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 1762809,
                    "reputation": 19455,
                    "user_id": 1609428,
                    "user_type": "registered",
                    "accept_rate": 96,
                    "profile_image": "https://i.sstatic.net/TnnKE.jpg?s=256",
                    "display_name": "ℕʘʘḆḽḘ",
                    "link": "https://stackoverflow.com/users/1609428/%e2%84%95%ca%98%ca%98%e1%b8%86%e1%b8%bd%e1%b8%98"
                },
                "reply_to_user": {
                    "account_id": 6196394,
                    "reputation": 86601,
                    "user_id": 5291015,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/4tAvO.jpg?s=256",
                    "display_name": "Inian",
                    "link": "https://stackoverflow.com/users/5291015/inian"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1666160304,
                "post_id": 74120371,
                "comment_id": 130866620,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1762809,
                    "reputation": 19455,
                    "user_id": 1609428,
                    "user_type": "registered",
                    "accept_rate": 96,
                    "profile_image": "https://i.sstatic.net/TnnKE.jpg?s=256",
                    "display_name": "ℕʘʘḆḽḘ",
                    "link": "https://stackoverflow.com/users/1609428/%e2%84%95%ca%98%ca%98%e1%b8%86%e1%b8%bd%e1%b8%98"
                },
                "reply_to_user": {
                    "account_id": 6196394,
                    "reputation": 86601,
                    "user_id": 5291015,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/4tAvO.jpg?s=256",
                    "display_name": "Inian",
                    "link": "https://stackoverflow.com/users/5291015/inian"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1666160404,
                "post_id": 74120371,
                "comment_id": 130866640,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1666160320,
                "creation_date": 1666160320,
                "answer_id": 74120672,
                "question_id": 74120371,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The JSON key/value pairs need to be double quoted with `&quot;`, for the jq parser to interpret them. Fix your JSON before running with through jq\r\n\r\nYou can use the `first/1` built-in to perform this,\r\n\r\n```none\r\nfirst(.data[]? | select(.person | length &gt; 0))\r\n```\r\n\r\ndemo - [jqplay][1]\r\n\r\n\r\n  [1]: https://jqplay.org/s/rX9nXhSRZGB",
                "title": "filter and retrieve the first element with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1666160837,
        "creation_date": 1666157960,
        "last_edit_date": 1666160381,
        "question_id": 74120371,
        "body_markdown": "Consider the following json:\r\n\r\n    {&quot;document&quot;: &quot;test&quot;, &quot;data&quot; : [{&quot;color&quot; : &quot;blue&quot;, &quot;person&quot; : &quot;john&quot;},\r\n                                   {&quot;color&quot; : &quot;red&quot;, &quot;person&quot; : []},\r\n                                   {&quot;color&quot; : &quot;purple&quot;, &quot;person&quot; : &quot;alice&quot;}]}\r\n\r\nI am trying to use `jq` to filter on the `.data.person` elements and return the first `.data` item with a non-null `person`.\r\nThe following does not seem to work:\r\n\r\n    jq &#39;.data[]&#39; myjson | jq select(.person!= &quot;&quot;) | jq &#39;.[0]&#39;\r\n\r\nWhat is the proper way to do so? output should be:\r\n\r\n    {&#39;color&#39; : &#39;blue&#39;, &#39;person&#39; : &#39;john&#39;}\r\n\r\nThanks!\r\n",
        "link": "https://stackoverflow.com/questions/74120371/filter-and-retrieve-the-first-element-with-jq",
        "title": "filter and retrieve the first element with jq"
    },
    {
        "tags": [
            "json",
            "filter",
            "key",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1666254494,
                "last_edit_date": 1666254494,
                "creation_date": 1666252758,
                "answer_id": 74136304,
                "question_id": 74136190,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "    fromstream(tostream | select(length==1 or (.[0]|index(&quot;foo&quot;))))\r\n\r\nDepending on your requirements, you might be able to make things more efficient by wrapping the above expression in a call to `first()`.\r\n\r\n—-\r\n\r\nFYPI, a less obscure approach would be along the lines of:\r\n\r\n```\r\npaths as $p\r\n| select($p[-1]==&quot;foo&quot;)\r\n| getpath($p) as $v\r\n| {} | setpath($p;$v)\r\n```\r\n",
                "title": "Use jq to filter content by a certain key, but no output"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1666253872,
                "creation_date": 1666253872,
                "answer_id": 74136541,
                "question_id": 74136190,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You&#39;re looking for something like this:\r\n```\r\n. as $in\r\n| reduce (paths | select(.[-1] == &quot;foo&quot;)) as $p (\r\n    null;\r\n    setpath($p; $in | getpath($p))\r\n)\r\n```\r\n&lt;sup&gt;[Online demo](https://jqplay.org/s/6kS_d97ioqU)&lt;/sup&gt;",
                "title": "Use jq to filter content by a certain key, but no output"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1666258347,
                "creation_date": 1666258347,
                "answer_id": 74137547,
                "question_id": 74136190,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Who doesn&#39;t like obscure, inefficient solutions to problems?\r\n\r\n```\r\ndelpaths(\r\n    [paths|select(index(&quot;foo&quot;))] as $foos\r\n    | [paths|select(. as $p | $foos | map(index($p) != 0) | all)]\r\n)\r\n```\r\n\r\nFirst build a list of all paths containing a &quot;foo&quot; object/property. Then filter all paths leading to these paths. Finally, delete them.",
                "title": "Use jq to filter content by a certain key, but no output"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 0,
        "last_activity_date": 1666258347,
        "creation_date": 1666252170,
        "question_id": 74136190,
        "body_markdown": "I have similar question as [how-to-use-jq-to-find-all-paths-to-a-certain-key](https://stackoverflow.com/questions/39800718/how-to-use-jq-to-find-all-paths-to-a-certain-key/) and also checked the accepted answer.\r\n\r\nThe solution described in answer works for the exactly same input as [the ticket](https://stackoverflow.com/questions/39800718/how-to-use-jq-to-find-all-paths-to-a-certain-key/), but after I updated the json a little bit as following (remove last foo part), I can&#39;t get any output by filter:\r\n```\r\nfromstream(tostream | select(.[0]|index(&quot;foo&quot;)))\r\n```\r\nThe updated input json:\r\n\r\n```\r\n{\r\n    &quot;A&quot;: {\r\n      &quot;A1&quot;: {\r\n        &quot;foo&quot;: {\r\n          &quot;_&quot;: &quot;_&quot;\r\n        }\r\n      },\r\n      &quot;A2&quot;: {\r\n        &quot;_&quot;: &quot;_&quot;\r\n      }\r\n    },\r\n    &quot;B&quot;: {\r\n      &quot;B1&quot;: {}\r\n    }\r\n}\r\n```\r\nThe expected output should be:\r\n\r\n```\r\n{\r\n    &quot;A&quot;: {\r\n      &quot;A1&quot;: {\r\n        &quot;foo&quot;: {\r\n          &quot;_&quot;: &quot;_&quot;\r\n        }\r\n      }\r\n    }\r\n}\r\n```\r\nBut I got nothing. You can check here https://jqplay.org/s/s21FFUeoQz0.\r\n\r\nI&#39;ve also tried the filter without **fromstream**:\r\n```\r\ntostream | select(.[0]|index(&quot;foo&quot;))\r\n```\r\nThe output will be as following, it seems [work here](https://jqplay.org/s/1ZVF5p6WFu_G).\r\n```\r\n[[&quot;A&quot;,&quot;A1&quot;,&quot;foo&quot;,&quot;_&quot;],&quot;_&quot;]\r\n[[&quot;A&quot;,&quot;A1&quot;,&quot;foo&quot;,&quot;_&quot;]]\r\n[[&quot;A&quot;,&quot;A1&quot;,&quot;foo&quot;]]\r\n```\r\nSo I suspect the **fromstream** has some problem. Can anyone help me figure out? Thanks!\r\n",
        "link": "https://stackoverflow.com/questions/74136190/use-jq-to-filter-content-by-a-certain-key-but-no-output",
        "title": "Use jq to filter content by a certain key, but no output"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 39208,
                    "reputation": 267964,
                    "user_id": 112968,
                    "user_type": "registered",
                    "accept_rate": 68,
                    "profile_image": "https://i.sstatic.net/zHTaT.png?s=256",
                    "display_name": "knittl",
                    "link": "https://stackoverflow.com/users/112968/knittl"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1666258851,
                "post_id": 74137627,
                "comment_id": 130895603,
                "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": 1666258901,
                "post_id": 74137627,
                "comment_id": 130895630,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 19029549,
                    "reputation": 3,
                    "user_id": 20290237,
                    "user_type": "registered",
                    "profile_image": "https://lh6.googleusercontent.com/-LAwanNa1_8w/AAAAAAAAAAI/AAAAAAAAAAA/AMZuuckpK4CrMaOtsD5T6H0Qxd4VSb3VUA/s256-rj/photo.jpg",
                    "display_name": "LeNi1",
                    "link": "https://stackoverflow.com/users/20290237/leni1"
                },
                "reply_to_user": {
                    "account_id": 9072254,
                    "reputation": 1068,
                    "user_id": 6754986,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/IYIfl.png?s=256",
                    "display_name": "LinFelix",
                    "link": "https://stackoverflow.com/users/6754986/linfelix"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1666259322,
                "post_id": 74137627,
                "comment_id": 130895790,
                "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": 1666259562,
                "post_id": 74137627,
                "comment_id": 130895884,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 9072254,
                    "reputation": 1068,
                    "user_id": 6754986,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/IYIfl.png?s=256",
                    "display_name": "LinFelix",
                    "link": "https://stackoverflow.com/users/6754986/linfelix"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1666259597,
                "post_id": 74137627,
                "comment_id": 130895897,
                "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": 1666259671,
                "post_id": 74137627,
                "comment_id": 130895934,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 19029549,
                    "reputation": 3,
                    "user_id": 20290237,
                    "user_type": "registered",
                    "profile_image": "https://lh6.googleusercontent.com/-LAwanNa1_8w/AAAAAAAAAAI/AAAAAAAAAAA/AMZuuckpK4CrMaOtsD5T6H0Qxd4VSb3VUA/s256-rj/photo.jpg",
                    "display_name": "LeNi1",
                    "link": "https://stackoverflow.com/users/20290237/leni1"
                },
                "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": 1666261508,
                "post_id": 74137627,
                "comment_id": 130896600,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 19029549,
                    "reputation": 3,
                    "user_id": 20290237,
                    "user_type": "registered",
                    "profile_image": "https://lh6.googleusercontent.com/-LAwanNa1_8w/AAAAAAAAAAI/AAAAAAAAAAA/AMZuuckpK4CrMaOtsD5T6H0Qxd4VSb3VUA/s256-rj/photo.jpg",
                    "display_name": "LeNi1",
                    "link": "https://stackoverflow.com/users/20290237/leni1"
                },
                "reply_to_user": {
                    "account_id": 9072254,
                    "reputation": 1068,
                    "user_id": 6754986,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/IYIfl.png?s=256",
                    "display_name": "LinFelix",
                    "link": "https://stackoverflow.com/users/6754986/linfelix"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1666261611,
                "post_id": 74137627,
                "comment_id": 130896635,
                "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": 1666272226,
                "post_id": 74137627,
                "comment_id": 130900683,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 19029549,
                    "reputation": 3,
                    "user_id": 20290237,
                    "user_type": "registered",
                    "profile_image": "https://lh6.googleusercontent.com/-LAwanNa1_8w/AAAAAAAAAAI/AAAAAAAAAAA/AMZuuckpK4CrMaOtsD5T6H0Qxd4VSb3VUA/s256-rj/photo.jpg",
                    "display_name": "LeNi1",
                    "link": "https://stackoverflow.com/users/20290237/leni1"
                },
                "reply_to_user": {
                    "account_id": 4879,
                    "reputation": 248190,
                    "user_id": 7552,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/b60298053f87465641c1b1192338c8cd?s=256&d=identicon&r=PG",
                    "display_name": "glenn jackman",
                    "link": "https://stackoverflow.com/users/7552/glenn-jackman"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1666277396,
                "post_id": 74137627,
                "comment_id": 130903117,
                "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": 1666278666,
                "post_id": 74137627,
                "comment_id": 130903690,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1667904253,
                "last_edit_date": 1667904253,
                "creation_date": 1667667167,
                "answer_id": 74329672,
                "question_id": 74137627,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "It is dangerous to set variables the way you want to.\r\nAlready existing variables with the same name will be overwritten and this can damage your environment. Think about this security vulnerability beforehand.\r\n\r\nI come up with two solutions\r\n 1. using `eval`\r\n 3. avoiding `eval`\r\n\r\n\r\nSolution 1\r\n----------\r\n\r\n```bash\r\neval $(jq -r &#39;.data | to_entries | map(&quot;export &quot; + .key + &quot;=&#39;&quot;&#39;&quot;&#39;&quot; + .value + &quot;&#39;&quot;&#39;&quot;&#39;&quot;)[]&#39; &quot;$FILE&quot;)\r\n```\r\n\r\n`eval` executes the code generated by `jq`:\r\n```text\r\nexport warnings=&#39;1&#39;\r\nexport auth=&#39;no&#39;\r\n```\r\n\r\n**Remark**\r\n- the cryptic `&#39;&quot;&#39;&quot;&#39;&quot;` is not `jq` syntax. It is a way to add single quotes to a string in bash\r\n\r\n\r\nSolution 2\r\n----------\r\n```bash\r\nRESPONSE=&#39;\r\n{\r\n  &quot;data&quot;: {\r\n    &quot;warnings&quot;: &quot;1&quot;,\r\n    &quot;auth&quot;: &quot;no&quot;\r\n  }\r\n}\r\n&#39;\r\n\r\nKEYS=$(jq -r &#39;.data | keys[]&#39; &lt;&lt;&lt; &quot;$RESPONSE&quot;)\r\nfor KEY in $KEYS; do\r\n  VALUE=$(jq -r --arg key &quot;$KEY&quot; &#39;.data | .[$key]&#39; &lt;&lt;&lt; &quot;$RESPONSE&quot;)\r\n  read &quot;$KEY&quot; &lt;&lt;&lt; &quot;$VALUE&quot;\r\ndone\r\n```\r\n",
                "title": "Parse variables form json with bash"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1667904253,
        "creation_date": 1666258685,
        "last_edit_date": 1667071711,
        "question_id": 74137627,
        "body_markdown": "I have variables with JSON:\r\n\r\n```bash\r\nexport RESPONSE=$(curl -s --request POST --data &quot;$some_data&quot; $some_url)\r\nIn RESPONSE\r\n{\r\n &quot;data&quot;: {\r\n   &quot;warnings&quot;: &quot;1&quot;,\r\n   &quot;auth&quot;: &quot;no&quot;\r\n  ... and a lot of variables\r\n  }\r\n}\r\n```\r\n\r\nAnd I need to create variables how it:\r\n\r\n```bash\r\n$warnings=&quot;1&quot;\r\n$auth=&quot;no&quot;\r\n....\r\n```\r\n\r\nI only need variables from the field `&quot;data&quot;`.\r\n\r\nAnd in bash, as far as I understand, there is no `to_entries`.\r\n\r\nAnd yet, I need that the data from #RESPONSE is not written to the console while the script is running.\r\n\r\n**Update:**\r\n\r\nI have this working code but it writes all JSON to console and that&#39;s not what I want.\r\n\r\n    export ENV_SETTER=$(for i in $KEYS; do echo -n env.$i=$(echo $RESPONSE | jq -r .data.$i),;done)\r\n\r\nNext i need this\r\n\r\n    --set &quot;${ENV_SETTER}&quot;",
        "link": "https://stackoverflow.com/questions/74137627/parse-variables-form-json-with-bash",
        "title": "Parse variables form json with bash"
    },
    {
        "tags": [
            "python-3.x",
            "linux",
            "jq",
            "aws-cli"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1666267484,
                "post_id": 74139484,
                "comment_id": 130898761,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 6673685,
                    "reputation": 488,
                    "user_id": 10694247,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/82ddd981a264f6c322d0c5cef05123e7?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "user2023",
                    "link": "https://stackoverflow.com/users/10694247/user2023"
                },
                "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": 1666269534,
                "post_id": 74139484,
                "comment_id": 130899610,
                "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": 1666271024,
                "post_id": 74139484,
                "comment_id": 130900166,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 4879,
                    "reputation": 248190,
                    "user_id": 7552,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/b60298053f87465641c1b1192338c8cd?s=256&d=identicon&r=PG",
                    "display_name": "glenn jackman",
                    "link": "https://stackoverflow.com/users/7552/glenn-jackman"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1666272305,
                "post_id": 74139484,
                "comment_id": 130900719,
                "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": 1666273827,
                "post_id": 74139484,
                "comment_id": 130901456,
                "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": 1666463509,
                "post_id": 74139484,
                "comment_id": 130945148,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1666462804,
                "creation_date": 1666462804,
                "answer_id": 74166061,
                "question_id": 74139484,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "As @glenn jackman mentioned in the comment section.. you can use `&#39;&#39;&#39;` to escape.\r\n\r\nI am using below code to send an attachment and HTML view over the e-mail.\r\n\r\n\r\n    #!/usr/bin/env python3\r\n    from __future__ import print_function\r\n    from signal import signal, SIGPIPE, SIG_DFL\r\n    signal(SIGPIPE,SIG_DFL)\r\n    import os\r\n    import time\r\n    import io\r\n    import smtplib\r\n    import pandas as pd\r\n    from email.message import EmailMessage\r\n    from email.mime.application import MIMEApplication\r\n    from email.mime.multipart import MIMEMultipart\r\n    from email.mime.text import MIMEText\r\n    \r\n    #################################################################\r\n    pd.set_option(&#39;display.max_rows&#39;, None)\r\n    pd.set_option(&#39;display.max_columns&#39;, None)\r\n    pd.set_option(&#39;display.width&#39;, None)\r\n    pd.set_option(&#39;expand_frame_repr&#39;, True)\r\n    #################################################################\r\n    \r\n    # Create message container - the correct MIME type is msg/alternative.\r\n    mail_server = &#39;mail.example.nxp.com&#39;\r\n    from_addr   = &#39;someEmailAddressa@example.com&#39;\r\n    to_addr     = &#39;, &#39;.join([&#39;karn.kumar@example.com&#39;])\r\n    cc_addr     = &#39;, &#39;.join([&#39;otherAddress@example.com&#39;])\r\n    subject     = &#39;Devlopment Cost Report Seoul&#39;\r\n    \r\n    # Create mail body as template to be send\r\n    EMAIL_TEMPLATE = &quot;&quot;&quot;\\\r\n    &lt;html&gt;\r\n      &lt;head&gt;\r\n      &lt;style&gt;\r\n      table, th, td {{font-size:9pt; border:1px solid black; border-collapse:collapse; text-align:left; background-color:LightGray;}}\r\n      th, td {{padding: 5px;}}\r\n      &lt;/style&gt;\r\n      &lt;/head&gt;\r\n      &lt;body&gt;\r\n         Dear All,&lt;br&gt;&lt;br&gt;\r\n    \r\n         Please Find the attached CSV file attached along with HTML view for the diffrent AW Service cost . &lt;br&gt;&lt;br&gt;\r\n    \r\n         {} &lt;br&gt;&lt;br&gt;\r\n        Kind regards.&lt;br&gt;\r\n        Karn\r\n      &lt;/body&gt;\r\n    &lt;/html&gt;&quot;&quot;&quot;\r\n    # collect the data into Json and save it into a file under /tmp\r\n    os.system(&#39;&#39;&#39;aws ce get-cost-and-usage --profile dev --time-period Start=$(date &quot;+%Y-%m-01&quot;),End=$(date --date=&quot;$(date +&#39;%Y-%m-01&#39;) + 1 month  - 1 second&quot; -I) --granularity MONTHLY --metrics USAGE_QUANTITY BLENDED_COST  --group-by Type=DIMENSION,Key=SERVICE | jq -r &#39;[ .ResultsByTime[].Groups[] | select(.Metrics.BlendedCost.Amount &gt; &quot;0&quot;) | { (.Keys[0]): .Metrics.BlendedCost } ] | sort_by(.Amount)| add&#39;  &gt; /tmp/cost.json&#39;&#39;&#39;)\r\n    \r\n    # Once the data is created now its easy to extract using the pandas.\r\n    data = pd.read_json(&quot;/tmp/cost.json&quot;)\r\n    df = (data.T)\r\n    df = df.drop(&#39;Unit&#39;, axis=1)\r\n    df.rename(columns={&#39;Amount&#39;: &#39;Amount(USD)&#39;}, inplace=True)\r\n    \r\n    \r\n    def df_to_csv(df):\r\n        with io.StringIO() as buffer:\r\n            df.to_csv(buffer)\r\n            return buffer.getvalue()\r\n    \r\n    def send_email():\r\n        msg = MIMEMultipart()\r\n        msg[&#39;Subject&#39;] = subject\r\n        msg[&#39;From&#39;]    = from_addr\r\n        msg[&#39;To&#39;]      = to_addr\r\n        msg[&#39;Cc&#39;]      = cc_addr\r\n        attachment = MIMEApplication(df_to_csv(df))\r\n        attachment[&#39;Content-Disposition&#39;] = &#39;attachment; filename=&quot;cost-details.csv&quot;&#39;\r\n        msg.attach(attachment)\r\n        msg.attach(MIMEText(EMAIL_TEMPLATE.format(df.to_html(index=True)), &#39;html&#39;))\r\n        server = smtplib.SMTP(mail_server)\r\n        server.sendmail(to_addr, cc_addr, msg.as_string())\r\n        server.quit()\r\n    \r\n    if __name__ == &#39;__main__&#39;:\r\n        send_email()\r\n    \r\n    # remove the data file from &quot;/tmp&quot; after data parsing.\r\n    time.sleep(30)\r\n    os.unlink(&quot;/tmp/cost.json&quot;)\r\n\r\n**Result is Blow:**\r\n[![enter image description here][1]][1]\r\n\r\n\r\n  [1]: https://i.sstatic.net/0Je41.png",
                "title": "Syntax error with os module while using pipe delimeter with jq commnad"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1666462804,
        "creation_date": 1666266965,
        "last_edit_date": 1666370778,
        "question_id": 74139484,
        "body_markdown": "I am using aws-cli command within python `os` module, while using `jq` and output redirection i am getting an error .\r\n\r\n**Error:**\r\n\r\n\r\n    SyntaxError: invalid syntax\r\n\r\n\r\n**code:**\r\n\r\n    iport os\r\n    os.system(&#39;aws ce get-cost-and-usage --profile dev --time-period Start=2022-10-01,End=2022-10-31 + 1 month  - 1 second&quot; -I) --granularity MONTHLY --metrics USAGE_QUANTITY BLENDED_COST  --group-by Type=DIMENSION,Key=SERVICE | /bin/jq  &#39;[ .ResultsByTime[].Groups[] | select(.Metrics.BlendedCost.Amount &gt; &quot;0&quot;) | { (.Keys[0]): .Metrics.BlendedCost } ] | sort_by(.Amount)| add&#39; &gt; /tmp/cost.json&#39;)\r\n\r\n\r\nIs there a way to fix it, please let me know.",
        "link": "https://stackoverflow.com/questions/74139484/syntax-error-with-os-module-while-using-pipe-delimeter-with-jq-commnad",
        "title": "Syntax error with os module while using pipe delimeter with jq commnad"
    },
    {
        "tags": [
            "arrays",
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1666279650,
                "last_edit_date": 1666279650,
                "creation_date": 1666279229,
                "answer_id": 74142390,
                "question_id": 74142354,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Make the traversal and filtering all part of the assignment&#39;s LHS using parentheses:\r\n~~~sh\r\njq &#39;(.devices[] | select(.label == &quot;label2&quot;).percent) = 50&#39; file.json\r\n~~~\r\n[Demo](https://jqplay.org/s/1VVyxygosCJ)\r\n\r\nAlternatively, [update](https://stedolan.github.io/jq/manual/#Update-assignment%3A%7C%3D) `|=` to a `map` of the whole `.devices` array:\r\n~~~sh\r\njq &#39;.devices |= map(select(.label == &quot;label2&quot;).percent = 50)&#39; file.json\r\n~~~\r\n[Demo](https://jqplay.org/s/fxV9xDeuCJj)\r\n\r\nOutput:\r\n~~~json\r\n{\r\n  &quot;devices&quot;: [\r\n    {\r\n      &quot;label&quot;: &quot;label1&quot;,\r\n      &quot;percent&quot;: 10\r\n    },\r\n    {\r\n      &quot;label&quot;: &quot;label2&quot;,\r\n      &quot;percent&quot;: 50\r\n    }\r\n  ]\r\n}\r\n~~~\r\n",
                "title": "Updating a json file using jq while keep the exact same input (except changed value)"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1666279650,
        "creation_date": 1666279092,
        "question_id": 74142354,
        "body_markdown": "To keep things simple, I have that file.js:\r\n\r\n```\r\n{\r\n    &quot;devices&quot;: [\r\n      {\r\n        &quot;label&quot;: &quot;label1&quot;,\r\n        &quot;percent&quot;: 10\r\n      },\r\n      {\r\n        &quot;label&quot;: &quot;label2&quot;,\r\n        &quot;percent&quot;: 20\r\n      }\r\n    ]\r\n }\r\n```\r\n\r\nSince I browsed Google and StackOverflow a lot, I actually know how to update, let&#39;s say, the label2 from 20% to 50% :\r\n\r\n```\r\njq &#39;.devices[] | select(.label == &quot;label2&quot;).percent = 50&#39; file.json\r\n```\r\n\r\nBut here&#39;s the ouput:\r\n\r\n```\r\n{\r\n  &quot;label&quot;: &quot;label1&quot;,\r\n  &quot;percent&quot;: 10\r\n}\r\n{\r\n  &quot;label&quot;: &quot;label2&quot;,\r\n  &quot;percent&quot;: 50\r\n}\r\n```\r\nThe devices object (?) is not there anymore.\r\n\r\nI&#39;d like to find a way to keep the exact same input format.\r\nI guess I should rid of the pipe, but I don&#39;t know how. \r\nI&#39;ve browsed Google and I found the \r\nto_entries / with_entries / from_entries, that seem to keep the whole thing, but I don&#39;t know how to merge eveything together. \r\n\r\nThank you.",
        "link": "https://stackoverflow.com/questions/74142354/updating-a-json-file-using-jq-while-keep-the-exact-same-input-except-changed-va",
        "title": "Updating a json file using jq while keep the exact same input (except changed value)"
    },
    {
        "tags": [
            "json",
            "jq",
            "nested-json"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1666323212,
                "creation_date": 1666323212,
                "answer_id": 74148505,
                "question_id": 74147897,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "This works with your example input:\r\n```\r\n{field1} + (.array1[] |\r\n  {field2} + (.array2[] |\r\n    {field3} + (\r\n      if has(&quot;array3&quot;) and (.array3 | length) &gt; 0 then\r\n        {array3: .array3[]}\r\n      else\r\n        {array3: null}\r\n      end\r\n    )\r\n  )\r\n)\r\n```\r\n&lt;sup&gt;[Online demo](https://jqplay.org/s/lizC4PecA5P)&lt;/sup&gt;",
                "title": "How to print optional arrays in JQ"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1666326837,
        "creation_date": 1666316041,
        "last_edit_date": 1666326837,
        "question_id": 74147897,
        "body_markdown": "I have the following example:\r\n```\r\n{\r\n\t&quot;field1&quot;: &quot;test1&quot;,\r\n\t&quot;array1&quot;: [\r\n\t\t{\r\n\t\t\t&quot;field2&quot;: &quot;test20&quot;,\r\n\t\t\t&quot;array2&quot;: [\r\n\t\t\t\t{\r\n\t\t\t\t    &quot;field3&quot;: &quot;test30&quot;,\r\n\t\t\t\t    &quot;array3&quot;: [\r\n\t\t\t\t\t\t&quot;11&quot;,&quot;12&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\t{\r\n\t\t\t&quot;field2&quot;: &quot;test21&quot;,\r\n\t\t\t&quot;array2&quot;: [\r\n\t\t\t\t{\r\n\t\t\t\t    &quot;field3&quot;: &quot;test31&quot;,\r\n\t\t\t\t    &quot;array3&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\t{\r\n\t\t\t&quot;field2&quot;: &quot;test22&quot;,\r\n\t\t\t&quot;array2&quot;: [\r\n\t\t\t\t{\r\n\t\t\t\t    &quot;field3&quot;: &quot;test32&quot;\r\n\t\t\t\t}\r\n\t\t\t]\r\n\t\t}\r\n\t]\r\n}\r\n```\r\nI would like to get the following:\r\n```\r\n{&quot;field1&quot;:&quot;test1&quot;,&quot;field2&quot;:&quot;test20&quot;,&quot;field3&quot;:&quot;test30&quot;,&quot;array3&quot;:&quot;11&quot;}\r\n{&quot;field1&quot;:&quot;test1&quot;,&quot;field2&quot;:&quot;test20&quot;,&quot;field3&quot;:&quot;test30&quot;,&quot;array3&quot;:&quot;12&quot;}\r\n{&quot;field1&quot;:&quot;test1&quot;,&quot;field2&quot;:&quot;test21&quot;,&quot;field3&quot;:&quot;test31&quot;,&quot;array3&quot;:null}\r\n{&quot;field1&quot;:&quot;test1&quot;,&quot;field2&quot;:&quot;test22&quot;,&quot;field3&quot;:&quot;test32&quot;,&quot;array3&quot;:null}\r\n```\r\nI am currently stuck at:\r\n```\r\njq --compact-output &#39;.field1 as $field1 | .array1[] | . | .field2 as $field2 | . | .array2[] | . | .field3 as $field3 | try ({$field1, $field2, $field3, array3: .array3[]}) catch ({$field1, $field2, $field3, array3: null})&#39;\r\n```\r\nwhich prints out 3 of the 4 rows, but I lose line 3. Any suggestions?",
        "link": "https://stackoverflow.com/questions/74147897/how-to-print-optional-arrays-in-jq",
        "title": "How to print optional arrays in JQ"
    },
    {
        "tags": [
            "json",
            "parsing",
            "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": 1666349832,
                "post_id": 74152553,
                "comment_id": 130921573,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 25,
                "is_accepted": true,
                "score": 25,
                "last_activity_date": 1709383047,
                "last_edit_date": 1709383047,
                "creation_date": 1666350876,
                "answer_id": 74152813,
                "question_id": 74152553,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can multiply by a power of ten, round, then divide by the same power of ten. Use `100` for two decimal digits. Ignoring floating point inaccuracies, this should give you your expected number.\r\n\r\n```\r\njq &#39;.*100|round/100&#39;\r\n```\r\n\r\nIf you need it regularly, you can define a function and use it:\r\n\r\n```\r\ndef round(precision):.*pow(10;precision)|round/pow(10;precision);\r\n```\r\n\r\nPutting the definition inside the `~/.jq` file allows you to use it in all of your jq programs automatically:\r\n\r\n```\r\n$ echo 20.152 | jq &#39;round(2)&#39;\r\n20.15\r\n```",
                "title": "JQ round number to two decimal places"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 12,
        "last_activity_date": 1709383047,
        "creation_date": 1666349448,
        "question_id": 74152553,
        "body_markdown": "I use jq 1.6 and I try to round the number to two decimal places. How can I do it?\r\n\r\nMy code:\r\n\r\n    echo 20.152 | jq -c &#39;round&#39;\r\n\r\nMy output:\r\n\r\n    20\r\n\r\nExpected output:\r\n\r\n    20.15",
        "link": "https://stackoverflow.com/questions/74152553/jq-round-number-to-two-decimal-places",
        "title": "JQ round number to two decimal places"
    },
    {
        "tags": [
            "arrays",
            "json",
            "bash",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1666371240,
                "creation_date": 1666371240,
                "answer_id": 74156879,
                "question_id": 74156844,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Read in the numbers as raw text using `-R`, split at the `,`, use `tonumbers` to convert them to numbers, and create the structure on the fly:\r\n~~~sh\r\necho &quot;1374240, 1374241&quot; | jq -R &#39;\r\n  {version:&quot;1.0&quot;,tests:(\r\n    split(&quot;,&quot;) | map(\r\n      {id: tonumber, selector: &quot;&quot;}\r\n    )\r\n  )}\r\n&#39;\r\n~~~\r\n[Demo](https://jqplay.org/s/tSevOdHTQtL)\r\n\r\nIf you can omit the comma in the first place, it&#39;s even easier to read in numbers as they itself are JSON:\r\n~~~sh\r\necho &quot;1374240 1374241&quot; | jq -s &#39;\r\n  {version:&quot;1.0&quot;,tests: map(\r\n    {id: tonumber, selector: &quot;&quot;}\r\n  )}\r\n&#39;\r\n~~~\r\n[Demo](https://jqplay.org/s/j6mpPS3bv8d)\r\n\r\nOutput:\r\n~~~json\r\n{\r\n  &quot;version&quot;: &quot;1.0&quot;,\r\n  &quot;tests&quot;: [\r\n    {\r\n      &quot;id&quot;: 1374240,\r\n      &quot;selector&quot;: &quot;&quot;\r\n    },\r\n    {\r\n      &quot;id&quot;: 1374241,\r\n      &quot;selector&quot;: &quot;&quot;\r\n    }\r\n  ]\r\n}\r\n~~~\r\n",
                "title": "Creating json-file with json-objects array using jq in bash"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1666371240,
        "creation_date": 1666371064,
        "last_edit_date": 1666371119,
        "question_id": 74156844,
        "body_markdown": "I have an input row like this: `1374240, 1374241`. I need to make json file: \r\n```\r\n{\r\n  &quot;version&quot;: &quot;1.0&quot;,\r\n  &quot;tests&quot;: [\r\n    {\r\n      &quot;id&quot;: 1374240,\r\n      &quot;selector&quot;: &quot;&quot;\r\n    },\r\n    {\r\n      &quot;id&quot;: 1374241,\r\n      &quot;selector&quot;: &quot;&quot;\r\n    }\r\n  ]\r\n}\r\n```\r\nI maked associated array:\r\n```\r\nidRow=&#39;1374240, 1374241&#39;\r\nIFS=&#39;,&#39; read -r -a array &lt;&lt;&lt;&quot;$idRow&quot;\r\ntrimmedArray=()\r\nfor id in &quot;${array[@]}&quot;; do\r\n  trimmedId=&quot;$(echo -e &quot;${id}&quot; | xargs)&quot;\r\n  testRow=&quot;{\\&quot;id\\&quot;:${trimmedId},\\&quot;selector\\&quot;:\\&quot;\\&quot;}&quot;\r\n  trimmedArray+=(&quot;$testRow&quot;)\r\ndone\r\necho &quot;${trimmedArray[*]}&quot;\r\n```\r\nOutput:\r\n```\r\n{&quot;id&quot;:1374240,&quot;selector&quot;:&quot;&quot;} {&quot;id&quot;:1374241,&quot;selector&quot;:&quot;&quot;}\r\n```\r\nHow i can insert it in final json structure and write a file?\r\nI am tried a different variants with jq, but I can`t get finally structure.  Please, help.",
        "link": "https://stackoverflow.com/questions/74156844/creating-json-file-with-json-objects-array-using-jq-in-bash",
        "title": "Creating json-file with json-objects array using jq in bash"
    },
    {
        "tags": [
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 3,
                "creation_date": 1666410525,
                "post_id": 74160920,
                "comment_id": 130936345,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1666588452,
                "post_id": 74160920,
                "comment_id": 130964279,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1666479143,
                "creation_date": 1666479143,
                "answer_id": 74167615,
                "question_id": 74160920,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Assuming all your `Key` values are distinct, you can first convert the array into an object and then access the &quot;AccountName&quot; property directly:\r\n\r\n```\r\njq -r &#39;from_entries | .AccountName&#39; param.json\r\n```\r\n\r\n`from_entries` will generate the following object, which allows you to easily access the value for a given key:\r\n\r\n```\r\n{\r\n  &quot;AccountEmail&quot;: &quot;anshuman.ceg+Dev@gmail.com&quot;,\r\n  &quot;AccountName&quot;: &quot;DevABC&quot;,\r\n  &quot;ManagedOrganizationalUnit&quot;: &quot;Security (ou-nzx5-8ajd1561)&quot;,\r\n  &quot;SSOUserEmail&quot;: &quot;anshuman.ceg+Dev@gmail.com&quot;,\r\n  &quot;SSOUserFirstName&quot;: &quot;John&quot;,\r\n  &quot;SSOUserLastName&quot;: &quot;Smith&quot;\r\n}\r\n```",
                "title": "How to get value pairs of the objects from JSON using jq"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1666621720,
                "creation_date": 1666621720,
                "answer_id": 74182646,
                "question_id": 74160920,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If the object keys in the input happen not to be &quot;Key&quot; and &quot;Value&quot; and you can&#39;t use `from_entries`, `select` would be a good approach:\r\n```sh\r\njq --arg k &#39;AccountName&#39; -r &#39;.[] | select(.Key == $k).Value&#39;\r\n```",
                "title": "How to get value pairs of the objects from JSON using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1666621720,
        "creation_date": 1666410243,
        "question_id": 74160920,
        "body_markdown": "I have a json file named as param.json that looks as below:\r\n\r\n\r\n    [\r\n        {\r\n         &quot;Value&quot;: &quot;anshuman.ceg+Dev@gmail.com&quot;,\r\n          &quot;Key&quot;: &quot;AccountEmail&quot;\r\n        },\r\n        {\r\n          &quot;Value&quot;: &quot;DevABC&quot;,\r\n          &quot;Key&quot;: &quot;AccountName&quot;\r\n        },\r\n        {\r\n          &quot;Value&quot;: &quot;Security (ou-nzx5-8ajd1561)&quot;,\r\n          &quot;Key&quot;: &quot;ManagedOrganizationalUnit&quot;\r\n        },\r\n        {\r\n          &quot;Value&quot;: &quot;anshuman.ceg+Dev@gmail.com&quot;,\r\n          &quot;Key&quot;: &quot;SSOUserEmail&quot;\r\n        },\r\n        {\r\n          &quot;Value&quot;: &quot;John&quot;,\r\n          &quot;Key&quot;: &quot;SSOUserFirstName&quot;\r\n        },\r\n        {\r\n          &quot;Value&quot;: &quot;Smith&quot;,\r\n          &quot;Key&quot;: &quot;SSOUserLastName&quot;\r\n        }\r\n      ]\r\n\r\nI want to get only the Value for **DevABC** so that I can use while reading the -r line. I need only DevABC\r\n\r\nI am using jq as follows which doesn&#39;t seem to work\r\n\r\njq -r .[1].Value param.json\r\n\r\n",
        "link": "https://stackoverflow.com/questions/74160920/how-to-get-value-pairs-of-the-objects-from-json-using-jq",
        "title": "How to get value pairs of the objects from JSON using jq"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1666589234,
                "last_edit_date": 1666589234,
                "creation_date": 1666463073,
                "answer_id": 74166094,
                "question_id": 74165953,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "It&#39;s a bug in JQ 1.6, first reported [here](https://github.com/stedolan/jq/issues/2011) in 2019, and documented [here](https://github.com/stedolan/jq/wiki/FAQ/6a7c2d86e603b0eba2ebf55fd47995843adc376e#bugs).",
                "title": "In jq, why doesn’t `.a |= try sort` work?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1666589234,
        "creation_date": 1666462128,
        "question_id": 74165953,
        "body_markdown": "I need a jq filter that would:\r\n* when given `{&quot;a&quot;: [3, 1, 2]}`, produce `{&quot;a&quot;: [1, 2, 3]}`\r\n* when given `{&quot;b&quot;: 0}`, produce `{&quot;b&quot;: 0}`\r\n\r\n`.a |= sort` doesn’t work in the second case, because “null (null) cannot be sorted, as it is not an array”.\r\n\r\nFrom the [manual](https://stedolan.github.io/jq/manual/v1.6/) I figured `.a |= try sort` should work. When `.a` is an array, it should just `sort` it. When `.a` is null, `try` should catch the error from `sort` and produce nothing, thus deleting `&quot;a&quot;`. This works for `{&quot;b&quot;: 0}`, but for `{&quot;a&quot;: [3, 1, 2]}` it produces `{}` instead. Why?\r\n\r\nI know [other ways](https://stackoverflow.com/questions/48306264/how-do-i-sort-a-possibly-absent-array-with-jq) to accomplish this, but I want to understand why mine doesn’t work.",
        "link": "https://stackoverflow.com/questions/74165953/in-jq-why-doesn-t-a-try-sort-work",
        "title": "In jq, why doesn’t `.a |= try sort` work?"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 9629731,
                    "reputation": 51350,
                    "user_id": 10248678,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d8f818402f22d485b135a3b685ef908e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "oguz ismail",
                    "link": "https://stackoverflow.com/users/10248678/oguz-ismail"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1666615702,
                "post_id": 74181269,
                "comment_id": 130972100,
                "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": 1666615758,
                "post_id": 74181269,
                "comment_id": 130972118,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1666618549,
                "last_edit_date": 1666618549,
                "creation_date": 1666616235,
                "answer_id": 74181436,
                "question_id": 74181269,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can use [`--arg` and `--argjson`](https://stedolan.github.io/jq/manual/#Invokingjq) with null input, e.g.\r\n\r\n```\r\njq -n --arg id &quot;$appid&quot; --arg name &quot;$appname&quot; \\\r\n  --argjson groups &#39;[&quot;your&quot;, &quot;groups&quot;, &quot;here&quot;]&#39; \\\r\n&#39;{\r\n    &quot;appId&quot;: $id,\r\n    &quot;appName&quot;: $name,\r\n    &quot;authType&quot;: &quot;OIDC&quot;,\r\n    &quot;authSettings&quot;: {\r\n      &quot;applicationType&quot;: &quot;SERVICE&quot;,\r\n      &quot;clientAuthenticationType&quot;: &quot;CLIENT_SECRET&quot;,\r\n      &quot;grantTypes&quot;: [\r\n        &quot;CLIENT_CREDENTIALS&quot;\r\n      ],\r\n      &quot;groups&quot;: $groups,\r\n      &quot;responseTypes&quot;: [\r\n        &quot;TOKEN&quot;\r\n      ],\r\n      &quot;inclusion&quot;: [\r\n        &quot;&quot;,\r\n        &quot;&quot;,\r\n        &quot;&quot;,\r\n        &quot;&quot;\r\n      ],\r\n      &quot;tokenValidity&quot;: {\r\n        &quot;accessTokenLifetimeMinutes&quot;: 60,\r\n        &quot;refreshTokenLifetimeMinutes&quot;: 10080,\r\n        &quot;refreshTokenWindowMinutes&quot;: 1440\r\n      }\r\n    }\r\n}&#39;\r\n```\r\n\r\n*****\r\n\r\nOr, if you cannot modify the template file to be a jq filter/program, you can load it and then merge it with your custom arguments. Note that you need to match the structure exactly for this to work:\r\n\r\n```\r\njq --arg appId 123 --argjson groups &#39;[&quot;your&quot;,&quot;groups&quot;]&#39; \\\r\n  &#39;. * { $appId, authSettings: { $groups } }&#39; template.json\r\n```\r\n\r\nAlternatively by assigning each property:\r\n\r\n```\r\njq --arg appId 123 --argjson groups &#39;[&quot;your&quot;,&quot;groups&quot;]&#39; \\\r\n  &#39;.appId = $appId | .authSettings.groups = $groups&#39; tpl.json\r\n```",
                "title": "How can I insert multiple values into json files?"
            },
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1666622501,
                "creation_date": 1666622501,
                "answer_id": 74182847,
                "question_id": 74181269,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I&#39;d use some &quot;nested&quot; jq calls:\r\n\r\n```bash\r\nappId=1234\r\nappName=&quot;My App&quot;\r\ngroups=(g1 g2 g3)\r\ninclusion=(i1 i2 i3 i4 i5)\r\n\r\njq --arg appId &quot;$appId&quot;\\\r\n   --arg appName &quot;$appName&quot; \\\r\n   --argjson groups &quot;$(jq -n --args &#39;$ARGS.positional&#39; &quot;${groups[@]}&quot;)&quot; \\\r\n   --argjson inclusion &quot;$(jq -n --args &#39;$ARGS.positional&#39; &quot;${inclusion[@]}&quot;)&quot; \\\r\n   &#39; .appId = $appId\r\n     | .appName = $appName\r\n     | .authSettings.groups = $groups\r\n     | .authSettings.inclusion = $inclusion\r\n  &#39; template.json\r\n```\r\n\r\nIf the appId should be a number in the resulting JSON, use `--argjson` instead of `--arg`\r\n",
                "title": "How can I insert multiple values into json files?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1666622501,
        "creation_date": 1666615458,
        "last_edit_date": 1666618652,
        "question_id": 74181269,
        "body_markdown": "I&#39;m building a bash script that needs to send a json payload to an API.  The payload below is stored in `payload.json`, will be used all the time and is in the same path as the script.  The `&quot;&quot;` values are what I need to populate with variables from within the same script.\r\n\r\n```\r\n{\r\n    &quot;appId&quot;: &quot;&quot;,\r\n    &quot;appName&quot;: &quot;&quot;,\r\n    &quot;authType&quot;: &quot;OIDC&quot;,\r\n    &quot;authSettings&quot;: {\r\n      &quot;applicationType&quot;: &quot;SERVICE&quot;,\r\n      &quot;clientAuthenticationType&quot;: &quot;CLIENT_SECRET&quot;,\r\n      &quot;grantTypes&quot;: [\r\n        &quot;CLIENT_CREDENTIALS&quot;\r\n      ],\r\n      &quot;groups&quot;: [\r\n        &quot;&quot;\r\n      ],\r\n      &quot;responseTypes&quot;: [\r\n        &quot;TOKEN&quot;\r\n      ],\r\n      &quot;inclusion&quot;: [\r\n        &quot;&quot;,\r\n        &quot;&quot;,\r\n        &quot;&quot;,\r\n        &quot;&quot;\r\n      ],\r\n      &quot;tokenValidity&quot;: {\r\n        &quot;accessTokenLifetimeMinutes&quot;: 60,\r\n        &quot;refreshTokenLifetimeMinutes&quot;: 10080,\r\n        &quot;refreshTokenWindowMinutes&quot;: 1440\r\n      }\r\n    }\r\n}\r\n```\r\n\r\nI&#39;m not sure how to achieve this correctly.\r\n\r\nHow can I pass single values to `.appId`, `.appName` and multiple values to `.groups[]`, `.inclusion[]` all at the same time?\r\n\r\nI started on this path for each variable but got nowhere:\r\n```\r\nappId=31337\r\njq &#39;.appId = &quot;${appId}&quot;&#39; config.json &gt; tempfile.json\r\n```\r\n\r\nAny help is appreciated.",
        "link": "https://stackoverflow.com/questions/74181269/how-can-i-insert-multiple-values-into-json-files",
        "title": "How can I insert multiple values into json files?"
    },
    {
        "tags": [
            "json",
            "gitlab",
            "gitlab-ci",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 5775319,
                    "reputation": 1419,
                    "user_id": 4557537,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/71a1136f6d0025e59d1b0b1e42ef86cd?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Fadi",
                    "link": "https://stackoverflow.com/users/4557537/fadi"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1666647987,
                "post_id": 74187141,
                "comment_id": 130982947,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1666650107,
                "creation_date": 1666650107,
                "answer_id": 74187397,
                "question_id": 74187141,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Checking the existence of a field using `has`:\r\n~~~sh\r\n.[] | select(has(&quot;artifacts_file&quot;)).id\r\n~~~\r\n~~~\r\n3219589878\r\n3219589876\r\n~~~\r\n[Demo](https://jqplay.org/s/dDSGNUuL4w9)\r\n\r\nChecking if a field is an empty array by comparing it to `[]`:\r\n~~~sh\r\n.[] | select(.artifacts == []).id\r\n~~~\r\n~~~\r\n3219589880\r\n~~~\r\n[Demo](https://jqplay.org/s/gI9q9Em3CIp)\r\n",
                "title": "Check if a key exists and return another key"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1666650107,
        "creation_date": 1666647942,
        "last_edit_date": 1666649861,
        "question_id": 74187141,
        "body_markdown": "I need help with jq syntax on how to return the Gitlab job ID if it contains an artifact. The JSON output looks like this (removed a lot of unrelated info from it and added `[...]`):\r\n\r\n```\r\n[{\r\n\t&quot;id&quot;: 3219589880,\r\n\t&quot;status&quot;: &quot;success&quot;,\r\n\t&quot;stage&quot;: &quot;test&quot;,\r\n\t&quot;name&quot;: &quot;job_with_no_artifact&quot;,\r\n\t&quot;ref&quot;: &quot;main&quot;,\r\n\t&quot;tag&quot;: false,\r\n\t&quot;coverage&quot;: null,\r\n\t&quot;allow_failure&quot;: false,\r\n\t&quot;created_at&quot;: &quot;2022-10-24T18:21:25.119Z&quot;,\r\n\t&quot;started_at&quot;: &quot;2022-10-24T18:21:25.986Z&quot;,\r\n\t&quot;finished_at&quot;: &quot;2022-10-24T18:21:38.464Z&quot;,\r\n\t&quot;duration&quot;: 12.478682,\r\n\t&quot;queued_duration&quot;: 0.499786,\r\n\t&quot;user&quot;: {\r\n\t\t&quot;id&quot;: 123456789,\r\n\t\t[...]\r\n\t},\r\n\t&quot;commit&quot;: {\r\n\t\t&quot;id&quot;: &quot;5e0e1f287d20daf2036a3ca71c656dce55999265&quot;,\r\n\t\t[...]\r\n\t&quot;pipeline&quot;: {\r\n\t\t&quot;id&quot;: 123456789,\r\n\t\t[...]\r\n\t&quot;project&quot;: {\r\n\t\t&quot;ci_job_token_scope_enabled&quot;: false\r\n\t},\r\n\t&quot;artifacts&quot;: [],\r\n\t&quot;runner&quot;: {\r\n\t\t&quot;id&quot;: 12270859,\r\n\t\t[...]\r\n\t},\r\n\t&quot;artifacts_expire_at&quot;: null,\r\n\t&quot;tag_list&quot;: []\r\n}, {\r\n\t&quot;id&quot;: 3219589878,\r\n\t&quot;status&quot;: &quot;success&quot;,\r\n\t&quot;stage&quot;: &quot;test&quot;,\r\n\t&quot;name&quot;: &quot;create_artifact_job_2&quot;,\r\n\t&quot;ref&quot;: &quot;main&quot;,\r\n\t&quot;tag&quot;: false,\r\n\t&quot;coverage&quot;: null,\r\n\t&quot;allow_failure&quot;: false,\r\n\t&quot;created_at&quot;: &quot;2022-10-24T18:21:25.111Z&quot;,\r\n\t&quot;started_at&quot;: &quot;2022-10-24T18:21:25.922Z&quot;,\r\n\t&quot;finished_at&quot;: &quot;2022-10-24T18:21:39.090Z&quot;,\r\n\t&quot;duration&quot;: 13.168405,\r\n\t&quot;queued_duration&quot;: 0.464364,\r\n\t&quot;user&quot;: {\r\n\t\t&quot;id&quot;: 123456789,\r\n\t\t[...]\r\n\t},\r\n\t&quot;commit&quot;: {\r\n\t\t&quot;id&quot;: &quot;5e0e1f287d20daf2036a3ca71c656dce55999265&quot;,\r\n\t\t[...]\r\n\t},\r\n\t&quot;pipeline&quot;: {\r\n\t\t&quot;id&quot;: 675641982,\r\n        [...],\r\n\t&quot;project&quot;: {\r\n\t\t&quot;ci_job_token_scope_enabled&quot;: false\r\n\t},\r\n\t&quot;artifacts_file&quot;: {\r\n\t\t&quot;filename&quot;: &quot;artifacts.zip&quot;,\r\n\t\t&quot;size&quot;: 223\r\n\t},\r\n\t&quot;artifacts&quot;: [{\r\n\t\t&quot;file_type&quot;: &quot;archive&quot;,\r\n\t\t&quot;size&quot;: 223,\r\n\t\t&quot;filename&quot;: &quot;artifacts.zip&quot;,\r\n\t\t&quot;file_format&quot;: &quot;zip&quot;\r\n\t}, {\r\n\t\t&quot;file_type&quot;: &quot;metadata&quot;,\r\n\t\t&quot;size&quot;: 153,\r\n\t\t&quot;filename&quot;: &quot;metadata.gz&quot;,\r\n\t\t&quot;file_format&quot;: &quot;gzip&quot;\r\n\t}],\r\n\t&quot;runner&quot;: {\r\n\t\t&quot;id&quot;: 12270845,\r\n        [...]\r\n\t},\r\n\t&quot;artifacts_expire_at&quot;: &quot;2022-10-25T18:21:35.859Z&quot;,\r\n\t&quot;tag_list&quot;: []\r\n}, {\r\n\t&quot;id&quot;: 3219589876,\r\n\t&quot;status&quot;: &quot;success&quot;,\r\n\t&quot;stage&quot;: &quot;test&quot;,\r\n\t&quot;name&quot;: &quot;create_artifact_job_1&quot;,\r\n\t&quot;ref&quot;: &quot;main&quot;,\r\n\t&quot;tag&quot;: false,\r\n\t&quot;coverage&quot;: null,\r\n\t&quot;allow_failure&quot;: false,\r\n\t&quot;created_at&quot;: &quot;2022-10-24T18:21:25.103Z&quot;,\r\n\t&quot;started_at&quot;: &quot;2022-10-24T18:21:25.503Z&quot;,\r\n\t&quot;finished_at&quot;: &quot;2022-10-24T18:21:41.407Z&quot;,\r\n\t&quot;duration&quot;: 15.904028,\r\n\t&quot;queued_duration&quot;: 0.098837,\r\n\t&quot;user&quot;: {\r\n\t\t&quot;id&quot;: 123456789,\r\n        [...]\r\n\t},\r\n\t&quot;commit&quot;: {\r\n\t\t&quot;id&quot;: &quot;5e0e1f287d20daf2036a3ca71c656dce55999265&quot;,\r\n        [...]\r\n\t},\r\n\t&quot;pipeline&quot;: {\r\n\t\t&quot;id&quot;: 123456789,\r\n        [...]\r\n\t},\r\n\t&quot;web_url&quot;: &quot;WEB_URL&quot;,\r\n\t&quot;project&quot;: {\r\n\t\t&quot;ci_job_token_scope_enabled&quot;: false\r\n\t},\r\n\t&quot;artifacts_file&quot;: {\r\n\t\t&quot;filename&quot;: &quot;artifacts.zip&quot;,\r\n\t\t&quot;size&quot;: 217\r\n\t},\r\n\t&quot;artifacts&quot;: [{\r\n\t\t&quot;file_type&quot;: &quot;archive&quot;,\r\n\t\t&quot;size&quot;: 217,\r\n\t\t&quot;filename&quot;: &quot;artifacts.zip&quot;,\r\n\t\t&quot;file_format&quot;: &quot;zip&quot;\r\n\t}, {\r\n\t\t&quot;file_type&quot;: &quot;metadata&quot;,\r\n\t\t&quot;size&quot;: 152,\r\n\t\t&quot;filename&quot;: &quot;metadata.gz&quot;,\r\n\t\t&quot;file_format&quot;: &quot;gzip&quot;\r\n\t}],\r\n\t&quot;runner&quot;: {\r\n\t\t&quot;id&quot;: 12270857,\r\n\t},\r\n\t&quot;artifacts_expire_at&quot;: &quot;2022-10-25T18:21:37.808Z&quot;,\r\n\t&quot;tag_list&quot;: []\r\n}]\r\n```\r\n\r\nI&#39;ve been trying to do either of the following using jQ:\r\n\r\nEither:\r\n\r\n- Check if `artifacts_file` key exists in each iteration and if it does return the (job) id (so `.[].id`)\r\n\r\n- Check if `artifacts` array is empty in each iteration and if it is empty return the (job) id.\r\n\r\nIn both cases I&#39;m able to do the first part but I am not sure how to return the `.id` key.\r\n\r\nRelated stackoverflow questions that I&#39;ve been trying to utilize and adapt to my case:\r\n\r\n - https://stackoverflow.com/questions/71476198/jq-return-array-value-if-its-length-is-not-null\r\n - https://stackoverflow.com/questions/42097410/how-to-check-for-presence-of-key-in-jq-before-iterating-over-the-values\r\n\r\nWhat I have so far: `jq &#39;[.[].artifacts[]|select(length &gt; 0)] | .[]&#39;` which returns all the artifacts found (but it doesn&#39;t contain the `.id` of the job).",
        "link": "https://stackoverflow.com/questions/74187141/check-if-a-key-exists-and-return-another-key",
        "title": "Check if a key exists and return another key"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 5,
                "is_accepted": false,
                "score": 5,
                "last_activity_date": 1666658952,
                "last_edit_date": 1666658952,
                "creation_date": 1666649018,
                "answer_id": 74187272,
                "question_id": 74187236,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I guess I found an answer:\r\n\r\n```\r\n$ echo &#39;{&quot;a&quot;: {&quot;a1&quot;: 1}, &quot;b&quot;: {&quot;a1&quot;: 2}}&#39; | \\\r\n   jq -r &#39;to_entries[] | [.key, .value.a1] | @tsv&#39;\r\na\t1\r\nb\t2\r\n```",
                "title": "Iterate over JSON object keys and values with jq"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1666661097,
                "creation_date": 1666661097,
                "answer_id": 74188273,
                "question_id": 74187236,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s an alternative using [`keys` (or `keys_unsorted`)](https://stedolan.github.io/jq/manual/#keys,keys_unsorted):\r\n~~~sh\r\n$ echo &#39;{&quot;a&quot;: {&quot;a1&quot;: 1}, &quot;b&quot;: {&quot;a1&quot;: 2}}&#39; |\r\n   jq -r &#39;keys[] as $key | [$key, .[$key].a1] | @tsv&#39;\r\na\t1\r\nb\t2\r\n~~~",
                "title": "Iterate over JSON object keys and values with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 2,
        "last_activity_date": 1666661097,
        "creation_date": 1666648675,
        "question_id": 74187236,
        "body_markdown": "Here is `jq` getting field `a1`:\r\n\r\n```\r\n$ echo &#39;{&quot;a&quot;: {&quot;a1&quot;: 1}, &quot;b&quot;: {&quot;a1&quot;: 2}}&#39; | jq -r &quot;.[] | .a1&quot;\r\n1\r\n2\r\n```\r\n\r\nI&#39;d like to get the keys `a` and `b` as well, and output a flat result, i.e.\r\n\r\n```\r\n$ echo &#39;{&quot;a&quot;: {&quot;a1&quot;: 1}, &quot;b&quot;: {&quot;a1&quot;: 2}}&#39; | jq -r &quot;&lt;magic here&gt;&quot;\r\na 1\r\nb 2\r\n```\r\n\r\nSuggestions?",
        "link": "https://stackoverflow.com/questions/74187236/iterate-over-json-object-keys-and-values-with-jq",
        "title": "Iterate over JSON object keys and values 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": 1,
                "creation_date": 1666683242,
                "post_id": 74190473,
                "comment_id": 130988880,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1666684085,
                "creation_date": 1666684085,
                "answer_id": 74190661,
                "question_id": 74190473,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "jq applies the given filter to each JSON document/entity. A file can contain multiple such documents. If you want to handle a file with multiple documents as a single array document with each original document being an array element, then use `-s`/`--slurp` option which will read all JSON documents in your input file as one huge array:\r\n\r\n```\r\njq -s &#39;.&#39; input.json\r\n```\r\n\r\nOutput:\r\n\r\n```json\r\n[\r\n  {\r\n    &quot;ID&quot;: &quot;123&quot;,\r\n    &quot;Name&quot;: &quot;xyz&quot;\r\n  },\r\n  {\r\n    &quot;ID&quot;: &quot;1234&quot;,\r\n    &quot;Competitor&quot;: &quot;abc&quot;\r\n  }\r\n]\r\n```\r\n\r\nNote that jq _requires_ valid JSON, so your input _must_ be valid. The sample in the question is not. A valid JSON input would be:\r\n\r\n```json\r\n{\r\n        &quot;ID&quot;: &quot;123&quot;,\r\n        &quot;Name&quot;: &quot;xyz&quot;\r\n}\r\n{\r\n        &quot;ID&quot;: &quot;1234&quot;,\r\n        &quot;Competitor&quot;: &quot;abc&quot;\r\n}\r\n```\r\n\r\nPS Note that `. | [{ID, Name}]` is equivalent to `[{ID, Name}]` since `.` is the identity filter.",
                "title": "Convert json objects to array of objects using JQ"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1666689342,
        "creation_date": 1666683120,
        "last_edit_date": 1666689342,
        "question_id": 74190473,
        "body_markdown": "I have following JSON\r\n```\r\n{\r\n\t\t&quot;ID&quot;: &quot;123&quot;,\r\n\t\t&quot;Name&quot;: &quot;xyz&quot;\r\n}\r\n{\r\n\t\t&quot;ID&quot;: &quot;1234&quot;,\r\n\t\t&quot;Competitor&quot;: &quot;abc&quot;\r\n}\r\n```\r\nNeed to convert the json objects into a array of json objects:\r\n```\r\n[\r\n{\r\n\t\t&quot;ID&quot;: &quot;123&quot;,\r\n\t\t&quot;Name&quot;: &quot;xyz&quot;\r\n}\r\n{\r\n\t\t&quot;ID&quot;: &quot;1234&quot;,\r\n\t\t&quot;Competitor&quot;: &quot;abc&quot;\r\n}\r\n]\r\n```\r\nI have tried using:\r\n```\r\n. | [{ID, Name}]\r\n```\r\n\r\nBut this converts into multiple arrays\r\n```\r\n[\r\n{\r\n\t\t&quot;ID&quot;: &quot;123&quot;,\r\n\t\t&quot;Name&quot;: &quot;xyz&quot;\r\n}\r\n]\r\n[\r\n{\r\n\t\t&quot;ID&quot;: &quot;1234&quot;,\r\n\t\t&quot;Competitor&quot;: &quot;abc&quot;\r\n}\r\n]\r\n```\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/74190473/convert-json-objects-to-array-of-objects-using-jq",
        "title": "Convert json objects to array of objects using JQ"
    },
    {
        "tags": [
            "json",
            "shell",
            "unix",
            "config",
            "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": 1666710495,
                "post_id": 74195390,
                "comment_id": 130998628,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 26728080,
                    "reputation": 33,
                    "user_id": 20330911,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/df7bb6161d474de09649b624db654eda?s=256&d=identicon&r=PG",
                    "display_name": "Dog",
                    "link": "https://stackoverflow.com/users/20330911/dog"
                },
                "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": 1666710831,
                "post_id": 74195390,
                "comment_id": 130998759,
                "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": 1666716254,
                "post_id": 74195390,
                "comment_id": 131000684,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 11040,
                    "reputation": 7109,
                    "user_id": 21132,
                    "user_type": "registered",
                    "accept_rate": 89,
                    "profile_image": "https://www.gravatar.com/avatar/ae2e42df3bce0500e0416b38644e8e95?s=256&d=identicon&r=PG",
                    "display_name": "Fabien",
                    "link": "https://stackoverflow.com/users/21132/fabien"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1747931275,
                "post_id": 74195390,
                "comment_id": 140450100,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1666711351,
                "creation_date": 1666711351,
                "answer_id": 74196460,
                "question_id": 74195390,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I&#39;d like to propose something, but I&#39;m not sure it is something that works for your requirements: don&#39;t merge JSON documents, but write your &quot;target&quot; document as a jq program itself.\r\n\r\n**`config_new.jq`:**\r\n```jq\r\n{\r\n  &quot;name&quot;: .name,\r\n  &quot;age&quot;: .age,\r\n  &quot;properties&quot;: {\r\n      &quot;title&quot;: .properties.title,\r\n      &quot;fruits&quot;: .properties.fruits\r\n  }\r\n}\r\n```\r\n\r\nThis reads almost like &quot;real&quot; JSON.\r\n\r\nOr if you want to reduce duplication:\r\n\r\n```jq\r\n{\r\n  name,\r\n  age,\r\n  properties: .properties | {\r\n      title,\r\n      fruits\r\n  }\r\n}\r\n```\r\n\r\nand then migrate your old file to the new format:\r\n\r\n```\r\njq -f config_new.jq config.json &gt; config_new.json\r\n```\r\n\r\nA &quot;copy values from the same keys from a different document&quot; approach would be more complicated, but let&#39;s wait for other answers. I&#39;m pretty sure there&#39;s a way, but I&#39;m too dumb for it :) It probably involves `reduce` and `path`/`getpath`/`setpath` in some way.",
                "title": "JQ Library: Overriding existing keys of an JSON object with another object keys"
            },
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1666785722,
                "last_edit_date": 1666785722,
                "creation_date": 1666716885,
                "answer_id": 74197668,
                "question_id": 74195390,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s a jq answer that recursively merges objects according to your criteria:\r\n\r\n```sh\r\njq -s &#39;\r\n    def merge($source):\r\n        . as $target\r\n        | reduce ($source | keys | map(select(in($target))))[] as $key ($target;\r\n            .[$key] = if (.[$key] | type) == &quot;object&quot;\r\n                          then .[$key] | merge($source[$key])\r\n                          else $source[$key]\r\n                      end\r\n        )\r\n    ;\r\n\r\n    . as [$new, $old]\r\n    | $new | merge($old)\r\n&#39; config_new.json config.json\r\n```\r\noutputs\r\n```json\r\n{\r\n  &quot;name&quot;: &quot;testName&quot;,\r\n  &quot;age&quot;: &quot;tooYoung&quot;,\r\n  &quot;properties&quot;: {\r\n    &quot;title&quot;: &quot;Mr&quot;,\r\n    &quot;fruits&quot;: [\r\n      &quot;banana&quot;\r\n    ]\r\n  }\r\n}\r\n```\r\n\r\nThis takes config_new.json as the &quot;target&quot;  and config.json as the &quot;source&quot;. To merge $source into $target, iterate over the $source keys that are in $target, then look at the datatype of the key&#39;s value: if it&#39;s an object, then recursively merge those objects, otherwise put the $source&#39;s value into $target for that key.",
                "title": "JQ Library: Overriding existing keys of an JSON object with another object keys"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1666728060,
                "last_edit_date": 1666728060,
                "creation_date": 1666726135,
                "answer_id": 74199240,
                "question_id": 74195390,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Alright, here is the solution I figured would be possible. Please leave a comment if there is room for improvement.\r\n\r\n```\r\n$ jq --slurpfile cfg config.json &#39;. as $new\r\n| reduce (paths(scalars,arrays) | select(any(numbers)|not)) as $path (\r\n  {};\r\n  setpath($path; ($cfg[0]|getpath($path))//($new|getpath($path))))&#39; config_new.json\r\n{\r\n  &quot;name&quot;: &quot;testName&quot;,\r\n  &quot;age&quot;: &quot;tooYoung&quot;,\r\n  &quot;properties&quot;: {\r\n    &quot;title&quot;: &quot;Mr&quot;,\r\n    &quot;fruits&quot;: [\r\n      &quot;banana&quot;\r\n    ]\r\n  }\r\n}\r\n```\r\n\r\nIt reduces by iterating over all paths that do not contain an array. Breakdown:\r\n\r\n```jq\r\n. as $new # store original &quot;new&quot; json\r\n| reduce (paths(scalars,arrays) | select(any(numbers)|not)) as $path ( # reduce over all paths of input (original &quot;new&quot; json) that are leaf paths or arrays (but not array elements)!\r\n  {}; # start with an empty result\r\n  setpath( \r\n    $path; # set &quot;$path&quot; in the result\r\n    ($cfg[0]|getpath($path)) # query value from existing config (read via slurpfile)\r\n    // ($new|getpath($path)))) # if value does not exist or is null, use existing value (from original &quot;new&quot; json)\r\n```\r\n\r\nNote that a value of &quot;null&quot; or &quot;false&quot; in `config.json` will not overwrite the existing value in `config_new.json`. To handle `null` and `false`, you need to be smarter:\r\n\r\n```jq\r\n. as $new\r\n| [$cfg[0] | paths] as $cfg_paths # store all paths from config.json\r\n| reduce (paths(scalars,arrays) | select(any(numbers)|not)) as $path (\r\n  {};\r\n  setpath(\r\n    $path;\r\n    if $path|IN($cfg_paths[]) # check if $path exists in config\r\n    then $cfg[0] else $new # use old or new config\r\n    end | getpath($path) # get $path from old/new config respectively\r\n  )\r\n)\r\n```\r\n\r\nThe final `if` can also be expressed with a `select` filter:\r\n\r\n```jq\r\n. as $new\r\n| [$cfg[0] | paths] as $cfg_paths\r\n| reduce (paths(scalars,arrays) | select(any(numbers)|not)) as $path (\r\n  {};\r\n  setpath(\r\n    $path;\r\n    $cfg[0] | select($path|IN($cfg_paths[])) // $new # $cfg if path exists, otherwise $new (equivalent to &quot;if&quot; above)\r\n    | getpath($path)\r\n  )\r\n)\r\n```",
                "title": "JQ Library: Overriding existing keys of an JSON object with another object keys"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 3,
        "last_activity_date": 1666785722,
        "creation_date": 1666706803,
        "question_id": 74195390,
        "body_markdown": "I am new to the JQ Library and I cannot figure out how to replace values in config_new.json with values from keys that exist in both config.json and config_new.json, recursively, without copying any other attributes from config.json.\r\n\r\nBasically having:\r\n\r\n```\r\n// config_new.json\r\n{\r\n  &quot;name&quot;: &quot;testName&quot;,\r\n  &quot;age&quot;: &quot;tooOld&quot;,\r\n  &quot;properties&quot;: {\r\n\t  &quot;title&quot;: &quot;Mr&quot;,\r\n\t  &quot;fruits&quot;: [&quot;apple&quot;, &quot;banana&quot;]\r\n  },\r\n}\r\n```\r\n\r\n```\r\n// config.json\r\n{\r\n  &quot;newName&quot;: &quot;changedName&quot;,\r\n  &quot;age&quot;: &quot;tooYoung&quot;,\r\n  &quot;properties&quot;: {\r\n\t  &quot;title&quot;: &quot;Mr&quot;,\r\n\t  &quot;height&quot;: &quot;tooTall&quot;,\r\n\t  &quot;fruits&quot;: [&quot;banana&quot;]\r\n  },\r\n  &quot;certificate&quot;: &quot;present&quot;\r\n}\r\n```\r\n\r\n\r\n```\r\n// expected result\r\n{\r\n  &quot;name&quot;: &quot;testName&quot;,\r\n  &quot;age&quot;: &quot;tooYoung&quot;,\r\n  &quot;properties&quot;: {\r\n\t  &quot;title&quot;: &quot;Mr&quot;,\r\n\t  &quot;height&quot;: &quot;tooTall&quot;,\r\n\t  &quot;fruits&quot;: [&quot;banana&quot;]\r\n  },\r\n}\r\n```\r\n\r\nSo I am trying to override the values in config_new.json only with known values in config.json.\r\n\r\n\r\nI have tried using \r\n```\r\njq -s &#39;.[0] * .[1]&#39; config_new.json config.json\r\n```\r\nbut this works only partially, because it also copies the key-value pairs that do not exist in config_new.json:\r\n\r\n\r\n```\r\n{\r\n  &quot;name&quot;: &quot;testName&quot;,\r\n  &quot;newName&quot;: &quot;changedName&quot;, // This should not be here\r\n  &quot;age&quot;: &quot;tooYoung&quot;, // This was replaced from config.json\r\n  &quot;properties&quot;: {\r\n\t  &quot;title&quot;: &quot;Mr&quot;,\r\n\t  &quot;height&quot;: &quot;tooTall&quot;, // This should not be here\r\n\t  &quot;fruits&quot;: [&quot;banana&quot;]\r\n  },\r\n}\r\n```\r\n\r\nCould someone help me?",
        "link": "https://stackoverflow.com/questions/74195390/jq-library-overriding-existing-keys-of-an-json-object-with-another-object-keys",
        "title": "JQ Library: Overriding existing keys of an JSON object with another object keys"
    },
    {
        "tags": [
            "linux",
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 4879,
                    "reputation": 248190,
                    "user_id": 7552,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/b60298053f87465641c1b1192338c8cd?s=256&d=identicon&r=PG",
                    "display_name": "glenn jackman",
                    "link": "https://stackoverflow.com/users/7552/glenn-jackman"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1666727435,
                "post_id": 74198853,
                "comment_id": 131003963,
                "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": 1666730857,
                "post_id": 74198853,
                "comment_id": 131004910,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1666725293,
                "last_edit_date": 1666725293,
                "creation_date": 1666724842,
                "answer_id": 74199035,
                "question_id": 74198853,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Just [join](https://stedolan.github.io/jq/manual/#join(str)) them.\r\n```\r\njq -r &#39;to_entries | map(&quot;\\(.key)=\\(.value)&quot;) | join(&quot;,&quot;)&#39;\r\n```\r\n&lt;sup&gt;[Online demo](https://jqplay.org/s/NjML_ilj62E)&lt;/sup&gt;",
                "title": "Modifying JQ filter to yield comma-delimited key-value pairs"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1666728902,
                "last_edit_date": 1666728902,
                "creation_date": 1666728216,
                "answer_id": 74199609,
                "question_id": 74198853,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Just for fun, another take:\r\n```sh\r\njq -r &#39;\r\n    def values: . as $obj | keys | map($obj[.]);\r\n    def pairs: [keys, values] | transpose;\r\n    pairs | map(join(&quot;=&quot;)) | join(&quot;,&quot;)\r\n&#39;\r\n```\r\n",
                "title": "Modifying JQ filter to yield comma-delimited key-value pairs"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1666728902,
        "creation_date": 1666723814,
        "last_edit_date": 1666725244,
        "question_id": 74198853,
        "body_markdown": "I have the following bash script:\r\n```\r\n#!/bin/bash\r\njs=&quot;{\\&quot;fizz\\&quot;:\\&quot;buzz\\&quot;,\\&quot;foo\\&quot;:\\&quot;baz\\&quot;}&quot;\r\necho $js\r\n\r\njson=$(echo &quot;$js&quot; | jq -r &quot;to_entries|map(\\&quot;\\(.key)=\\(.value|tostring)\\&quot;)|.[]&quot;)\r\n\r\necho &quot;fetching secret json:&quot;\r\necho $json\r\n```\r\n\r\nWhen I run it I get this:\r\n```\r\nmyuser@mymachine myapp % bash myscript.sh\r\n{&quot;fizz&quot;:&quot;buzz&quot;,&quot;foo&quot;:&quot;baz&quot;}\r\nfetching secret json:\r\nfizz=buzz foo=baz\r\n```\r\n\r\nIn reality the JSON will be a **lot** larger than just 2 properties, but it _will_ be a flat mapping of key-value pairs (no object nesting).\r\n\r\nI actually need these map entries in comma-delimited key-value pairs. So instead of:\r\n```\r\nfizz=buzz foo=baz\r\n```\r\n\r\nI need:\r\n```\r\nfizz=buzz,foo=baz\r\n```\r\n\r\nWhat can I do to my `jq` filters (or elsewhere) to get a comma inserted in between the key-value pairs? To be clear I&#39;m **not** looking for valid JSON output, nor CSV format. I need comma-delimited KV pairs. Thanks in advance!",
        "link": "https://stackoverflow.com/questions/74198853/modifying-jq-filter-to-yield-comma-delimited-key-value-pairs",
        "title": "Modifying JQ filter to yield comma-delimited key-value pairs"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1666754454,
                "creation_date": 1666754454,
                "answer_id": 74202348,
                "question_id": 74201919,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "It seems better to play with vanilla [tag:js] (`nodejs`):\r\n\r\n    const myvar={\r\n        &quot;user1&quot;: [\r\n            &quot;action1&quot;\r\n        ],\r\n        &quot;user2&quot;: [\r\n            &quot;action2&quot;,\r\n            &quot;action3&quot;\r\n        ]\r\n    };\r\n    \r\n    for (let user in myvar) {\r\n         myvar[user].forEach((action) =&gt; {\r\n            console.log(&quot;Executing command &quot; + user + &quot;-&quot; + action);\r\n        });\r\n    }\r\n\r\n## Output\r\n\r\n    Executing command user1-action1\r\n    Executing command user2-action2\r\n    Executing command user2-action3\r\n\r\n## Usage\r\n\r\n    node script.js\r\n\r\n## Usage with bash\r\n\r\nYou can remove **Executing** string, then:\r\n\r\n    node script.js | bash",
                "title": "Create Bash loop from JSON string using jq"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1666770626,
                "creation_date": 1666770626,
                "answer_id": 74204343,
                "question_id": 74201919,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Depending on what command you want to execute, if it can be performed from within jq, it&#39;s easier to also move the loop inside. There are several ways to accomplish that. Here are some examples, all yielding the same output:\r\n~~~sh\r\njq -r &#39;to_entries[] | &quot;Executing command \\(.key)-\\(.value[])&quot;&#39; &lt;&lt;&lt; &quot;$USER_ACTIONS&quot;\r\n~~~\r\n~~~sh\r\njq -r &#39;keys[] as $user | &quot;Executing command \\($user)-\\(.[$user][])&quot;&#39; &lt;&lt;&lt; &quot;$USER_ACTIONS&quot;\r\n~~~\r\n~~~sh\r\njq -r --stream &#39;&quot;Executing command \\(.[0][0])-\\(.[1]? // empty)&quot;&#39; &lt;&lt;&lt; &quot;$USER_ACTIONS&quot;\r\n~~~\r\nOutput:\r\n~~~\r\nExecuting command user1-action1\r\nExecuting command user2-action2\r\nExecuting command user2-action3\r\n~~~",
                "title": "Create Bash loop from JSON string using jq"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1666782819,
                "creation_date": 1666782819,
                "answer_id": 74206821,
                "question_id": 74201919,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Would you please try the following:\r\n```\r\n#!/bin/bash\r\n\r\ndeclare -a users                        # array of users\r\ndeclare -A actions                      # array of actions indexed by user\r\n\r\nread -r -d &#39;&#39; user_actions &lt;&lt; EOM\r\n{\r\n    &quot;user1&quot;: [\r\n        &quot;action1&quot;\r\n    ],\r\n    &quot;user2&quot;: [\r\n        &quot;action2&quot;,\r\n        &quot;action3&quot;\r\n    ]\r\n}\r\nEOM\r\n\r\nwhile IFS=$&#39;\\t&#39; read -r key val; do\r\n    users+=( &quot;$key&quot; )                   # add the user to the array &quot;users&quot;\r\n    actions[$key]=&quot;$val&quot;                # associate the actions with the user\r\ndone &lt; &lt;(jq -r &#39;to_entries[] | [.key, .value[]] | @tsv&#39; &lt;&lt;&lt; &quot;$user_actions&quot;)\r\n\r\nfor user in &quot;${users[@]}&quot;; do           # loop over &quot;users&quot;\r\n    IFS=$&#39;\\t&#39; read -r -a vals &lt;&lt;&lt; &quot;${actions[$user]}&quot;\r\n    for action in &quot;${vals[@]}&quot;; do\r\n        echo yourcommand &quot;$user&quot; &quot;$action&quot;\r\n    done\r\ndone\r\n```\r\nOutput:\r\n```\r\nyourcommand user1 action1\r\nyourcommand user2 action2\r\nyourcommand user2 action3\r\n```\r\n**[Explanations]**\r\n- The `jq` command outputs TSV which looks like:\r\n```\r\nuser1\\taction1\r\nuser2\\taction2\\taction3\r\n```\r\nwhere `\\t` represents a tab character used as a field delimiter.\r\n\r\n- The first `read` builtin command assigns `key` to the first field and `val`\r\n  to the remaining field(s). If `val` contains two or more fields,\r\n  it will be splitted with tne next `read` builtin in the next loop.\r\n- if the output looks good, drop `echo` and replace the string `yourcommand` with the command name.\r\n",
                "title": "Create Bash loop from JSON string using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 0,
        "last_activity_date": 1666782819,
        "creation_date": 1666749672,
        "last_edit_date": 1666749992,
        "question_id": 74201919,
        "body_markdown": "I am writing a bash script that reads a JSON string then loop based on the JSON values to execute a CLI command.\r\n\r\n```\r\n#!/usr/bin/env bash\r\n\r\njq --version &gt; /dev/null 2&gt;&amp;1 || { echo &gt;&amp;2 &quot;jq is required but it&#39;s not installed. Aborting.&quot;; exit 1; }\r\n\r\nread -r -d &#39;&#39; USER_ACTIONS &lt;&lt; EOM\r\n{\r\n    &quot;user1&quot;: [\r\n        &quot;action1&quot;\r\n    ],\r\n    &quot;user2&quot;: [\r\n        &quot;action2&quot;,\r\n        &quot;action3&quot;\r\n    ]\r\n    \r\n}\r\nEOM\r\n\r\nUSERS= #TODO\r\nfor user in USERS; do\r\n   ACTIONS= #TODO\r\n   for action in ACTIONS; do\r\n       echo &quot;Executing ${command} ${user}-${action}&quot;\r\n   done   \r\ndone\r\n```\r\n\r\nIf jq is present in the server, how do I populate the USERS and ACTIONS variable?\r\n\r\n",
        "link": "https://stackoverflow.com/questions/74201919/create-bash-loop-from-json-string-using-jq",
        "title": "Create Bash loop from JSON string using jq"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 6,
                "is_accepted": true,
                "score": 6,
                "last_activity_date": 1666791229,
                "last_edit_date": 1666791229,
                "creation_date": 1666754654,
                "answer_id": 74202364,
                "question_id": 74202060,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You don&#39;t need a loop for that\r\n```\r\njq --arg order lasagna &#39;.foods.menu |= if index($order) then . else . + [$order] end&#39; response.json\r\n```\r\nBut you may need one for inserting multiple orders\r\n```\r\njq &#39;reduce $ARGS.positional[] as $order (.;\r\n  .foods.menu |= if index($order) then . else . + [$order] end\r\n)&#39; response.json --args apple banana sushi",
                "title": "Insert value into JSON array if it is not already present"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1666810958,
                "last_edit_date": 1666810958,
                "creation_date": 1666772020,
                "answer_id": 74204578,
                "question_id": 74202060,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s another way using the [alternative operator](https://stedolan.github.io/jq/manual/#Alternativeoperator%3A%2F%2F) `//` to default to the array&#39;s `length` for the item&#39;s index:\r\n~~~sh\r\njq --arg order &#39;lasagna&#39; &#39;\r\n  (.foods.menu | .[index($order) // length]) = $order\r\n&#39; response.json\r\n~~~\r\n\r\nAdding a list of items in the same manner:\r\n~~~sh\r\njq &#39;.foods.menu |= reduce $ARGS.positional[] as $order (.;\r\n  .[index($order) // length] = $order\r\n)&#39; response.json --args &#39;lasagna&#39; &#39;sushi&#39; &#39;milk&#39;\r\n~~~",
                "title": "Insert value into JSON array if it is not already present"
            },
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1666786602,
                "creation_date": 1666786602,
                "answer_id": 74207626,
                "question_id": 74202060,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I don&#39;t know if this fits with any unspoken requirements.\r\n\r\nAdd the item regardless, and then `unique` the results:\r\n\r\n```sh\r\necho &quot;$result&quot; | jq --arg order pizza &#39;.foods.menu |= (. + [$order] | unique)&#39;\r\n```\r\n```json\r\n{\r\n  &quot;foods&quot;: {\r\n    &quot;menu&quot;: [\r\n      &quot;bacon_cheeseburge&quot;,\r\n      &quot;chicken_florentine&quot;,\r\n      &quot;chocolate&quot;,\r\n      &quot;chow_mein&quot;,\r\n      &quot;pizza&quot;,\r\n      &quot;spaghetti&quot;,\r\n      &quot;sushi&quot;,\r\n      &quot;tacos&quot;,\r\n      &quot;whiskey&quot;\r\n    ]\r\n  }\r\n}\r\n```\r\nThe resulting array is sorted. If there were any duplicates in the input, those are gone.",
                "title": "Insert value into JSON array if it is not already present"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 3,
        "last_activity_date": 1666810958,
        "creation_date": 1666751203,
        "last_edit_date": 1666759190,
        "question_id": 74202060,
        "body_markdown": "I&#39;m building a bash script that will read the response from an API and insert a value within a [] list (not {} array) if the value isn&#39;t present.  Fake example response from API:\r\n\r\n```\r\n#response.json contains:\r\n\r\n{\r\n\t&quot;foods&quot;: {\r\n\t\t&quot;menu&quot;: [\r\n\t\t\t&quot;tacos&quot;,\r\n\t\t\t&quot;spaghetti&quot;,\r\n\t\t\t&quot;pizza&quot;,\r\n\t\t\t&quot;chicken_florentine&quot;,\r\n\t\t\t&quot;bacon_cheeseburge&quot;,\r\n\t\t\t&quot;chow_mein&quot;,\r\n\t\t\t&quot;sushi&quot;,\r\n\t\t\t&quot;chocolate&quot;,\r\n\t\t\t&quot;whiskey&quot;\r\n\t\t]\r\n\t}\r\n}\r\n```\r\n\r\nThe variable from my bash script is `order=&quot;lasagna&quot;`.  If `&#39;foods.menu[]&#39;` contains `$order` then do nothing, else insert `$order` value into `&#39;foods.menu[]&#39;`.\r\n\r\nUsing bash variable `order=&quot;lasagna&quot;` which currently doesn&#39;t exist in `&#39;foods.menu[]&#39;`, the resulting json should be:\r\n\r\n```\r\n{\r\n    &quot;foods&quot;: {\r\n        &quot;menu&quot;: [\r\n            &quot;tacos&quot;,\r\n            &quot;spaghetti&quot;,\r\n            &quot;pizza&quot;,\r\n            &quot;chicken_florentine&quot;,\r\n            &quot;bacon_cheeseburge&quot;,\r\n            &quot;chow_mein&quot;,\r\n            &quot;sushi&quot;,\r\n            &quot;chocolate&quot;,\r\n            &quot;whiskey&quot;,\r\n            &quot;lasagna&quot; &lt;----\r\n        ]\r\n    }\r\n}\r\n```\r\n\r\nI started with trying a bash `for` loop and variations of jq&#39;s `if-then-else`, `select`, and `contains` but went down a rabbit hole.  Any help is appreciated.\r\n\r\n",
        "link": "https://stackoverflow.com/questions/74202060/insert-value-into-json-array-if-it-is-not-already-present",
        "title": "Insert value into JSON array if it is not already present"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1666764167,
                "creation_date": 1666764167,
                "answer_id": 74203289,
                "question_id": 74203127,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The following produces the answer you want, but may not meet your expectations in every respect:\r\n```\r\ndef hoist:\r\n  with_entries(if (.key | endswith(&quot;List&quot;)) \r\n                  and (.value | type == &quot;object&quot;)\r\n                  and (.value | keys_unsorted | length==1)\r\n               then (.value | keys_unsorted[0]) as $k \r\n               | .key = $k\r\n               | .value |= .[$k]\r\n\t           else . end);\r\n\r\nwalk(if type == &quot;object&quot; then hoist else . end)\r\n```  ",
                "title": "`jq` filter to selectively replace parent field with child"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1666775095,
                "creation_date": 1666775095,
                "answer_id": 74205166,
                "question_id": 74203127,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If the input is &quot;hoistable&quot; structurally, you could also operate on its stream representation:\r\n~~~sh\r\n[fromstream(tostream | del(.[0][] | select(endswith(&quot;List&quot;)?)))] | add\r\n~~~\r\n[Demo](https://jqplay.org/s/b1dIgP1y676)\r\n",
                "title": "`jq` filter to selectively replace parent field with child"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1666775095,
        "creation_date": 1666762808,
        "question_id": 74203127,
        "body_markdown": "I have many JSON objects where I would like to transform some objects to reduce redundancy and limit some depth.\r\n\r\nFor example, given:\r\n```json\r\n{\r\n  &quot;foo&quot;: [\r\n    {\r\n      &quot;foobarList&quot;: {\r\n        &quot;foobar&quot;: 2\r\n      }\r\n    },\r\n    {\r\n      &quot;raboofList&quot;: {\r\n        &quot;raboof&quot;: [3, 5, 7]\r\n      }\r\n    }\r\n  ],\r\n  &quot;bazList&quot;: {\r\n    &quot;baz&quot;: 11\r\n  },\r\n  &quot;foobar&quot;: {\r\n    &quot;barbazList&quot;: {\r\n      &quot;barbaz&quot;: [13, 17, 19]\r\n    },\r\n    &quot;foobazList&quot;: {\r\n      &quot;foobaz&quot;: {\r\n        &quot;barfooList&quot;: {\r\n          &quot;barfoo&quot;: [23, 29]\r\n        }\r\n      }\r\n    }\r\n  }\r\n}\r\n```\r\n... I&#39;d like to &quot;hoist&quot; the values of all the fields that end in &quot;List&quot;, e.g., `&quot;foobarList&quot;`.\r\n\r\nSo, the above would be transformed to:\r\n```json\r\n{\r\n  &quot;foo&quot;: [\r\n    {\r\n      &quot;foobar&quot;: 2\r\n    },\r\n    {\r\n      &quot;raboof&quot;: [3, 5, 7]\r\n    }\r\n  ],\r\n  &quot;baz&quot;: 11,\r\n  &quot;foobar&quot;: {\r\n    &quot;barbaz&quot;: [13, 17, 19],\r\n    &quot;foobaz&quot;: {\r\n      &quot;barfoo&quot;: [23, 29]\r\n    }\r\n  }\r\n}\r\n```\r\nI&#39;ve tried various filters, but so far I can only identify the &quot;List$&quot; fields with:\r\n```jq\r\njq &#39;.. |iterables |to_entries[] |select((has(&quot;key&quot;)) and (.key|type == &quot;string&quot;) and (.key|test(&quot;List$&quot;)) )&#39;\r\n```\r\nHow can this transformation be accomplished with `jq`?\r\n\r\nHere&#39;s a [jqplay.org](https://jqplay.org/s/9Cem8wiMuMw &quot;Click me!&quot;) to help getting started.\r\n",
        "link": "https://stackoverflow.com/questions/74203127/jq-filter-to-selectively-replace-parent-field-with-child",
        "title": "`jq` filter to selectively replace parent field with child"
    },
    {
        "tags": [
            "bash",
            "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": 3,
                "creation_date": 1666784252,
                "post_id": 74206388,
                "comment_id": 131016679,
                "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": 1666786118,
                "post_id": 74206388,
                "comment_id": 131017317,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2931566,
                    "reputation": 839,
                    "user_id": 2511672,
                    "user_type": "registered",
                    "accept_rate": 40,
                    "profile_image": "https://i.sstatic.net/C9Wzc.jpg?s=256",
                    "display_name": "ggonmar",
                    "link": "https://stackoverflow.com/users/2511672/ggonmar"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1666792181,
                "post_id": 74206388,
                "comment_id": 131019692,
                "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": 1666804844,
                "post_id": 74206388,
                "comment_id": 131024611,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "is_answered": false,
        "answer_count": 0,
        "score": 0,
        "last_activity_date": 1666780682,
        "creation_date": 1666780682,
        "question_id": 74206388,
        "body_markdown": "I&#39;ve put together a replacement script of [Espanso](https://espanso.org/), so a call to an API is done and it returns a url contained on the response to the API.  \r\nThis is the .yml chunk I&#39;ve created:\r\n\r\n```\r\n  - regex: &quot;:spongebob\\\\((?P&lt;meme&gt;.*)\\\\)&quot;\r\n    replace: &quot;{{meme_result}}&quot;\r\n    vars:\r\n      - name: meme_result\r\n        type: shell\r\n        params:\r\n          cmd: &quot;curl -s --request POST &#39;https://api.imgflip.com/caption_image?template_id=182442076&amp;text0={{meme}}&amp;username=user&amp;password=paswword&#39; | jq -r &#39;.data.url&#39;&quot;\r\n```\r\n\r\nThe `curl` command returns something like: \r\n```\r\n{&quot;success&quot;:true,&quot;data&quot;:{&quot;url&quot;:&quot;https:\\/\\/i.imgflip.com\\/6yblu0.jpg&quot;,&quot;page_url&quot;:&quot;https:\\/\\/imgflip.com\\/i\\/6yblu0&quot;}}\r\n```\r\n\r\nand running it with jq does return a valid url:\r\n```\r\n&gt;&gt; curl -s --request POST &#39;https://api.imgflip.com/caption_image?template_id=182442076&amp;text0=test&amp;username=user&amp;password=password&#39; | jq -r &#39;.data.url&#39;\r\n&lt;&lt;https://i.imgflip.com/6ybmkf.jpg\r\n```\r\n\r\nNot sure where the problem is (jq? bash? espanso?), but if I run the espanso command on a terminal, then the url is returned correctly:  \r\n`https://i.imgflip.com/6ybmkf.jpg`\r\n\r\nHowever, if I run it anywhere else (this form, for example), typing `:spongebob(sd)` \r\nthen I get the url without the `:` on it:  \r\n`https//i.imgflip.com/6ybxtu.jpg`  \r\nObviously destroying the usage of it.\r\n\r\n\r\nWhy is this happening? How can I solve it?\r\n\r\n",
        "link": "https://stackoverflow.com/questions/74206388/espanso-replacement-not-working-outside-of-terminal",
        "title": "Espanso replacement not working outside of terminal"
    },
    {
        "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": 0,
                "creation_date": 1666816480,
                "post_id": 74213717,
                "comment_id": 131028256,
                "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": 1666817043,
                "post_id": 74213717,
                "comment_id": 131028424,
                "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": 1666817635,
                "post_id": 74213717,
                "comment_id": 131028561,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 4879,
                    "reputation": 248190,
                    "user_id": 7552,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/b60298053f87465641c1b1192338c8cd?s=256&d=identicon&r=PG",
                    "display_name": "glenn jackman",
                    "link": "https://stackoverflow.com/users/7552/glenn-jackman"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1666827988,
                "post_id": 74213717,
                "comment_id": 131030663,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1666817122,
                "last_edit_date": 1666817122,
                "creation_date": 1666816565,
                "answer_id": 74213935,
                "question_id": 74213717,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You _can_ make jq print items in one line, but it&#39;s much more sensible (and makes you more robust to things like ISP names with spaces) to configure `read` to read things that have newlines between them.\r\n\r\n```\r\nIFS=$&#39;\\n&#39; read -r -d &#39;&#39; var1 var2 var3 var4 _ &lt; &lt;(\r\n  curl -s &quot;https://example.com/api/json/APIKEY/$ip&quot; |\r\n  jq -r &#39;.proxy, .vpn, .ISP, .timezone, &quot;\\u0000&quot;&#39;\r\n)\r\n```\r\n\r\nOne can also include four _different_ `read`s, all reading the output of just one copy of `jq`:\r\n\r\n```\r\n{ read -r var1 &amp;&amp; read -r var2 &amp;&amp; read -r var3 &amp;&amp; read -r var4; } &lt; &lt;(\r\n  curl -s &quot;https://example.com/api/json/APIKEY/$ip&quot; |\r\n  jq -r &#39;.proxy, .vpn, .ISP, .timezone&#39;\r\n)\r\n```\r\n\r\n...which can in turn be extended into a more robust approach that NUL-terminates each and every item, so they work properly even when the data items being extracted contain newlines:\r\n\r\n```\r\n{ for v in var{1,2,3,4}; do IFS= read -r -d &#39;&#39; &quot;$v&quot;; done; } &lt; &lt;(\r\n  curl -s &quot;https://example.com/api/json/APIKEY/$ip&quot; |\r\n  jq -r &#39;(.proxy, .vpn, .ISP, .timezone) | (., &quot;\\u0000&quot;)&#39;\r\n)\r\n",
                "title": "Print JSON two word output in JQ one line"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1666817122,
        "creation_date": 1666815184,
        "question_id": 74213717,
        "body_markdown": "I&#39;m using JQ to print out the output I get from a curl request.\r\n\r\nNow, while the bash script works fine, I can&#39;t seem to be able to get JQ to print multiple returns in one line.\r\n\r\nFor example, if I do this:\r\n```\r\nvar1 var2 var3 var4 &lt; &lt;(echo $(curl -s &#39;https://example.com/api/json/APIKEY/&#39;$ip&#39; | jq &quot;.proxy,.vpn,.ISP,.timezone&quot;))\r\n```\r\nI do get the results. But, if ISP&#39;s value is &quot;Google Severs&quot;, the output would be\r\n\r\n```\r\nvar3: Google\r\nvar4: Servers\r\n```\r\n\r\nThanks for any help you can give me.\r\n\r\nI&#39;ve tried leaving space between the results, to see if that&#39;s the issue. But not much else, to be honest.\r\n\r\nThis is the actual result from CLI command:\r\n`curl -s (...) | jq &quot;.proxy,.vpn,.ISP,.timezone&quot;\r\ntrue\r\ntrue\r\n&quot;Google Servers&quot;\r\n&quot;America/Los_Angeles&quot;`\r\n\r\nThis is the actual result from the script, using the same code:\r\n**./script.sh**\r\n```\r\ncurl -s (...) | jq &quot;.proxy,.vpn,.ISP,.timezone&quot;\r\ntrue\r\ntrue\r\n&quot;Google\r\nServers&quot;\r\n```",
        "link": "https://stackoverflow.com/questions/74213717/print-json-two-word-output-in-jq-one-line",
        "title": "Print JSON two word output in JQ one line"
    },
    {
        "tags": [
            "json",
            "shell",
            "sed",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1666825153,
                "last_edit_date": 1666825153,
                "creation_date": 1666824494,
                "answer_id": 74215028,
                "question_id": 74214912,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "This turns the attributes array into an object using `from_entries`, filters according to the presence of both keys using `select` and `has`, and extracts the values required using [string interpolation](https://stedolan.github.io/jq/manual/#Stringinterpolation-%5C%28foo%29):\r\n~~~sh\r\njq -r &#39;\r\n  .[].attributes | from_entries\r\n  | select(has(&quot;JOB_TITLE&quot;) and has(&quot;EMAIL&quot;))\r\n  | &quot;\\&quot;\\(.EMAIL)\\&quot;: \\&quot;\\(.JOB_TITLE)\\&quot;&quot;\r\n&#39;\r\n~~~\r\n~~~json\r\n&quot;john.doe@contoso.com&quot;: &quot;SALESMAN&quot;\r\n&quot;lorraine.doe@contoso.com&quot;: &quot;SECRETARY&quot;\r\n~~~\r\n[Demo](https://jqplay.org/s/TxSfaILGvfh)\r\n",
                "title": "Create a list from json file, with multiple values"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1666825153,
        "creation_date": 1666823516,
        "question_id": 74214912,
        "body_markdown": "I&#39;m trying to get all the data from a json file however I have problems to filter out missing objects without one out of two values (EMAIL,JOB_TITLE).\r\n\r\nHere&#39;s the json :\r\n`[{&quot;primary&quot;: &quot;JOHN DOE&quot;, &quot;attributes&quot;: [{&quot;type&quot;: &quot;double&quot;, &quot;name&quot;:&quot;BUILDING_NUMBER&quot;, &quot;value&quot;: &quot;123&quot;}, {&quot;type&quot;: &quot;double&quot;, &quot;name&quot;: &quot;FLOOR&quot;, &quot;value&quot;: 10}, {&quot;type&quot;: &quot;string&quot;, &quot;name&quot;: &quot;EMAIL&quot;, &quot;value&quot;:&quot;john.doe@contoso.com&quot;}, {&quot;type&quot;: &quot;string&quot;, &quot;name&quot;: &quot;JOB_TITLE&quot;, &quot;value&quot;: &quot;SALESMAN&quot;} ], &quot;aliases&quot;: [{&quot;alias&quot;: &quot;joao.doe@contoso.com&quot;}]},{&quot;primary&quot;: &quot;LORRAINE DOE&quot;, &quot;attributes&quot;: [{&quot;type&quot;: &quot;double&quot;, &quot;name&quot;: &quot;BUILDING_NUMBER&quot;, &quot;value&quot;: 456}, {&quot;type&quot;: &quot;double&quot;, &quot;name&quot;: &quot;FLOOR&quot;, &quot;value&quot;: 10}, {&quot;type&quot;: &quot;string&quot;, &quot;name&quot;: &quot;STATUS&quot;, &quot;value&quot;: &quot;Unavaliable&quot;}, {&quot;type&quot;: &quot;string&quot;, &quot;name&quot;: &quot;EMAIL&quot;, &quot;value&quot;: &quot;lorraine.doe@contoso.com&quot;}, {&quot;type&quot;: &quot;string&quot;, &quot;name&quot;: &quot;JOB_TITLE&quot;, &quot;value&quot;: &quot;SECRETARY&quot;} ], &quot;aliases&quot;: [{&quot;alias&quot;: &quot;lorris.doe@contoso.com&quot;}, {&quot;alias&quot;: &quot;lorris2.doe@contoso.com&quot;}]},{&quot;primary&quot;: &quot;JACK DOE&quot;, &quot;attributes&quot;: [{&quot;type&quot;: &quot;double&quot;, &quot;name&quot;: &quot;BUILDING_NUMBER&quot;, &quot;value&quot;: &quot;123&quot;}, {&quot;type&quot;: &quot;double&quot;, &quot;name&quot;: &quot;FLOOR&quot;, &quot;value&quot;: 10}, {&quot;type&quot;: &quot;string&quot;, &quot;name&quot;:&quot;JOB_TITLE&quot;, &quot;value&quot;: &quot;OWNER&quot;}], &quot;aliases&quot;: [{&quot;alias&quot;:&quot;jack.doe@contoso.com&quot;},{&quot;alias&quot;: &quot;jackson.doe@contoso.com&quot;}]}, {&quot;primary&quot;: &quot;NOAH DOE&quot;, &quot;attributes&quot;: [{&quot;type&quot;: &quot;double&quot;, &quot;name&quot;: &quot;BUILDING_NUMBER&quot;, &quot;value&quot;: &quot;123&quot;}, {&quot;type&quot;: &quot;double&quot;, &quot;name&quot;: &quot;FLOOR&quot;, &quot;value&quot;: 10}, {&quot;type&quot;: &quot;string&quot;, &quot;name&quot;: &quot;EMAIL&quot;, &quot;value&quot;: &quot;noah.doe@contoso.com&quot;}], &quot;aliases&quot;: [{&quot;alias&quot;: &quot;noah.doe95@contoso.com&quot;}]}]`\r\n\r\n\r\n\r\nThe list that I try to create:\r\n\r\n```\r\n&quot;john.doe@contoso.com&quot;: &quot;SALESMAN&quot;,\r\n&quot;lorraine.doe@contoso.com&quot;: &quot;SECRETARY&quot;\r\n```\r\n\r\nThe code that I used:\r\n\r\n&gt; echo &#39;\\[{&quot;primary&quot;: &quot;JOHN DOE&quot;, &quot;attributes&quot;: \\[{&quot;type&quot;: &quot;double&quot;, &quot;name&quot;:&quot;BUILDING_NUMBER&quot;, &quot;value&quot;: &quot;123&quot;}, {&quot;type&quot;: &quot;double&quot;, &quot;name&quot;: &quot;FLOOR&quot;, &quot;value&quot;: 10}, {&quot;type&quot;: &quot;string&quot;, &quot;name&quot;: &quot;EMAIL&quot;, &quot;value&quot;:&quot;john.doe@contoso.com&quot;}, {&quot;type&quot;: &quot;string&quot;, &quot;name&quot;: &quot;JOB_TITLE&quot;, &quot;value&quot;: &quot;SALESMAN&quot;} \\], &quot;aliases&quot;: \\[{&quot;alias&quot;: &quot;joao.doe@contoso.com&quot;}\\]},{&quot;primary&quot;: &quot;LORRAINE DOE&quot;, &quot;attributes&quot;: \\[{&quot;type&quot;: &quot;double&quot;, &quot;name&quot;: &quot;BUILDING_NUMBER&quot;, &quot;value&quot;: 456}, {&quot;type&quot;: &quot;double&quot;, &quot;name&quot;: &quot;FLOOR&quot;, &quot;value&quot;: 10}, {&quot;type&quot;: &quot;string&quot;, &quot;name&quot;: &quot;STATUS&quot;, &quot;value&quot;: &quot;Unavaliable&quot;}, {&quot;type&quot;: &quot;string&quot;, &quot;name&quot;: &quot;EMAIL&quot;, &quot;value&quot;: &quot;lorraine.doe@contoso.com&quot;}, {&quot;type&quot;: &quot;string&quot;, &quot;name&quot;: &quot;JOB_TITLE&quot;, &quot;value&quot;: &quot;SECRETARY&quot;} \\], &quot;aliases&quot;: \\[{&quot;alias&quot;: &quot;lorris.doe@contoso.com&quot;}, {&quot;alias&quot;: &quot;lorris2.doe@contoso.com&quot;}\\]},{&quot;primary&quot;: &quot;JACK DOE&quot;, &quot;attributes&quot;: \\[{&quot;type&quot;: &quot;double&quot;, &quot;name&quot;: &quot;BUILDING_NUMBER&quot;, &quot;value&quot;: &quot;123&quot;}, {&quot;type&quot;: &quot;double&quot;, &quot;name&quot;: &quot;FLOOR&quot;, &quot;value&quot;: 10}, {&quot;type&quot;: &quot;string&quot;, &quot;name&quot;:&quot;JOB_TITLE&quot;, &quot;value&quot;: &quot;OWNER&quot;}\\], &quot;aliases&quot;: \\[{&quot;alias&quot;:&quot;jack.doe@contoso.com&quot;},{&quot;alias&quot;: &quot;jackson.doe@contoso.com&quot;}\\]}, {&quot;primary&quot;: &quot;NOAH DOE&quot;, &quot;attributes&quot;: \\[{&quot;type&quot;: &quot;double&quot;, &quot;name&quot;: &quot;BUILDING_NUMBER&quot;, &quot;value&quot;: &quot;123&quot;}, {&quot;type&quot;: &quot;double&quot;, &quot;name&quot;: &quot;FLOOR&quot;, &quot;value&quot;: 10}, {&quot;type&quot;: &quot;string&quot;, &quot;name&quot;: &quot;EMAIL&quot;, &quot;value&quot;: &quot;noah.doe@contoso.com&quot;}\\], &quot;aliases&quot;: \\[{&quot;alias&quot;: &quot;noah.doe95@contoso.com&quot;}\\]}\\]&#39; | jq &#39;.\\[\\].attributes\\[\\]|select(.name|contains(&quot;JOB_TITLE&quot;), contains (&quot;EMAIL&quot;))&#39; | jq .value | sed &#39;N;s/\\\\n/:/&#39; | sed &#39;s/$/,/&#39;",
        "link": "https://stackoverflow.com/questions/74214912/create-a-list-from-json-file-with-multiple-values",
        "title": "Create a list from json file, with multiple values"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 4879,
                    "reputation": 248190,
                    "user_id": 7552,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/b60298053f87465641c1b1192338c8cd?s=256&d=identicon&r=PG",
                    "display_name": "glenn jackman",
                    "link": "https://stackoverflow.com/users/7552/glenn-jackman"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1666874744,
                "post_id": 74215374,
                "comment_id": 131041758,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1666828956,
                "creation_date": 1666828956,
                "answer_id": 74215409,
                "question_id": 74215374,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Just move what you create as `blob` directly into the other filter, ending up with just one jq call:\r\n~~~sh\r\njq --arg username &quot;$username&quot; &#39;. + {heading: {user: [$username]}}&#39; sample.json\r\n~~~",
                "title": "Add JSON object to JSON file using JQ"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1666829064,
        "creation_date": 1666828533,
        "last_edit_date": 1666829064,
        "question_id": 74215374,
        "body_markdown": "Given the following JSON file (sample.json) \r\n\r\n\r\n```\r\n{\r\n  &quot;api&quot;: &quot;3.0.0&quot;,\r\n  &quot;data&quot;: {\r\n    &quot;description&quot;: &quot;something&quot;,\r\n    &quot;title&quot;: &quot;hello&quot;,\r\n    &quot;version&quot;: &quot;1.0&quot;,\r\n    &quot;app&quot;: {\r\n      &quot;name&quot;: &quot;abc&quot;,\r\n      &quot;id&quot;: &quot;xyz&quot;\r\n    }\r\n  }\r\n}\r\n```\r\n\r\nI wish to add the following JSON object at root level to the file above:\r\n\r\n\r\n```\r\n{\r\n  &quot;heading&quot;: {\r\n    &quot;user&quot;: [&quot;$username&quot;]\r\n  }\r\n}\r\n```\r\n\r\nWhere `$username` is a Bash variable.\r\n\r\n\r\nIs there a better way to achieve this than the following?\r\n\r\n```blob=$(jq -n --arg foo API_NAME &#39;{&quot;heading&quot;: {&quot;user&quot;: [env.username]}}&#39;)```\r\n\r\n```jq --argjson obj &quot;$(echo $blob)&quot; &#39;. + $obj&#39; &lt; sample.json```\r\n\r\n",
        "link": "https://stackoverflow.com/questions/74215374/add-json-object-to-json-file-using-jq",
        "title": "Add JSON object to JSON file using JQ"
    },
    {
        "tags": [
            "json",
            "jq",
            "tee"
        ],
        "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": 1666847377,
                "post_id": 74216761,
                "comment_id": 131033348,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 9629731,
                    "reputation": 51350,
                    "user_id": 10248678,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d8f818402f22d485b135a3b685ef908e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "oguz ismail",
                    "link": "https://stackoverflow.com/users/10248678/oguz-ismail"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1666847808,
                "post_id": 74216761,
                "comment_id": 131033422,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 12001544,
                    "reputation": 131,
                    "user_id": 8781330,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/14b745afc237a7a154ce13863becf793?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "tonywl",
                    "link": "https://stackoverflow.com/users/8781330/tonywl"
                },
                "reply_to_user": {
                    "account_id": 9629731,
                    "reputation": 51350,
                    "user_id": 10248678,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d8f818402f22d485b135a3b685ef908e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "oguz ismail",
                    "link": "https://stackoverflow.com/users/10248678/oguz-ismail"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1666848051,
                "post_id": 74216761,
                "comment_id": 131033458,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 12001544,
                    "reputation": 131,
                    "user_id": 8781330,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/14b745afc237a7a154ce13863becf793?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "tonywl",
                    "link": "https://stackoverflow.com/users/8781330/tonywl"
                },
                "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": 1666848235,
                "post_id": 74216761,
                "comment_id": 131033482,
                "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": 1666848392,
                "post_id": 74216761,
                "comment_id": 131033503,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 9629731,
                    "reputation": 51350,
                    "user_id": 10248678,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d8f818402f22d485b135a3b685ef908e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "oguz ismail",
                    "link": "https://stackoverflow.com/users/10248678/oguz-ismail"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1666848443,
                "post_id": 74216761,
                "comment_id": 131033512,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 12001544,
                    "reputation": 131,
                    "user_id": 8781330,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/14b745afc237a7a154ce13863becf793?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "tonywl",
                    "link": "https://stackoverflow.com/users/8781330/tonywl"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1666848636,
                "post_id": 74216761,
                "comment_id": 131033546,
                "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": 1666859694,
                "post_id": 74216761,
                "comment_id": 131036582,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1666861481,
                "creation_date": 1666861481,
                "answer_id": 74219416,
                "question_id": 74216761,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Assuming each JSON log item occurs on a separate line:\r\n\r\nFor the JSON logs:\r\n\r\n    jq -nR -c &#39;inputs|fromjson?&#39;\r\n\r\nFor the others, you could use:\r\n\r\n    jq -nRr  &#39;inputs | . as $in | try (fromjson|empty) catch $in&#39;",
                "title": "Separate JSON and non-JSON logs with jq?"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1666864575,
                "creation_date": 1666864575,
                "answer_id": 74220159,
                "question_id": 74216761,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If you only want to linewise separate the input into different files, go with @peak&#39;s solution. But if you want to further process the lines on conditions, you could turn them into an array using `-Rn` and `[inputs]`, and go from there. For instance, if you need the according line numbers (e.g. to feed them into another tool, e.g. `sed`), use `from_entries` which for arrays provides them in the `.key` field:\r\n~~~sh\r\njq -Rn &#39;reduce ([inputs] | to_entries[]) as $in ({};\r\n  .[($in.value | fromjson? | &quot;json&quot;) // &quot;plain&quot;] += [$in.key]\r\n)&#39;\r\n~~~\r\n~~~json\r\n{\r\n  &quot;json&quot;: [\r\n    0,\r\n    2\r\n  ],\r\n  &quot;plain&quot;: [\r\n    1\r\n  ]\r\n}\r\n~~~\r\n[Demo](https://jqplay.org/s/FF_IoNawfrd)",
                "title": "Separate JSON and non-JSON logs with jq?"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1666922196,
                "creation_date": 1666922196,
                "answer_id": 74229900,
                "question_id": 74216761,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If each JSON log entry can be spread over multiple lines, then some assumptions about the non-JSON log entries must be made.  Here is an example based on reasonable assumptions about the non-JSON entries.  A bash or bash-like environment is also assumed for the sake of convenience.\r\n```\r\nfunction log {\r\n    cat&lt;&lt;EOF\r\n{ &quot;name&quot;: \r\n &quot;joe&quot;}\r\ntext line, this can be \r\nmulti-line too\r\n{ \r\n&quot;xyz&quot;: 123 }\r\nEOF\r\n}\r\n\r\nlog | sed &#39;/^[^&quot;{[ ]/ { s/&quot;/\\\\&quot;/g ; s/^/&quot;/; s/$/&quot;/;}&#39; |\r\n    tee &gt;(jq -rc &#39;select(type == &quot;string&quot;)&#39; &gt; strings.log) |\r\n    jq -rc &#39;select(type != &quot;string&quot;)&#39; &gt; json.log\r\n```",
                "title": "Separate JSON and non-JSON logs with jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 0,
        "last_activity_date": 1666997588,
        "creation_date": 1666844255,
        "last_edit_date": 1666997588,
        "question_id": 74216761,
        "body_markdown": "I have some log files which contain mixed of JSON and non-JSON logs, I&#39;d like to separate them into two files, one contains JSON logs only and the other contains non-JSON logs, I get some ideas from [this][1] to extract JSON logs with `jq`, here are what I have tried using `tee` to split log into two files (usage from [here][2] &amp; [here][3]) and `jq` to extract logs:\r\n\r\n```\r\ncat $logfile | tee  &gt;(jq -R -c &#39;fromjson? | select(type == &quot;object&quot;) | not&#39;) &gt; $plain_log_file) &gt;(jq -R -c &#39;fromjson? | select(type == &quot;object&quot;)&#39; &gt; $json_log_file)\r\n```\r\nThis extracts JSON logs correctly but returns `false` for each non-JSON log instead of the log content itself.\r\n\r\n```\r\ncat $logfile | tee  &gt;(jq -R -c &#39;try fromjson catch .&#39;) &gt; $plain_log_file) &gt;(jq -R -c &#39;fromjson? | select(type == &quot;object&quot;)&#39; &gt; $json_log_file)\r\n```\r\nthis gets jq syntax error &quot;catch .&quot;\r\n\r\nI do this so I can view the logs in [lnav][4] (an excellent log view/navigation tool).\r\n\r\nAny suggestion on how to achieve this? Appreciate your help!\r\n\r\nsample input:\r\n```\r\n{ &quot;name&quot;: &quot;joe&quot;}\r\ntext line, this can be multi-line too\r\n{ &quot;xyz&quot;: 123 }\r\n```\r\n\r\n\r\n  [1]: https://github.com/stedolan/jq/issues/884#issuecomment-128439361\r\n  [2]: https://unix.stackexchange.com/questions/28503/how-can-i-send-stdout-to-multiple-commands\r\n  [3]: https://unix.stackexchange.com/questions/41246/how-to-redirect-output-to-multiple-log-files\r\n  [4]: https://github.com/tstack/lnav",
        "link": "https://stackoverflow.com/questions/74216761/separate-json-and-non-json-logs-with-jq",
        "title": "Separate JSON and non-JSON logs with jq?"
    },
    {
        "tags": [
            "c",
            "function",
            "math",
            "jq",
            "libraries"
        ],
        "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": 1666890732,
                "post_id": 74225724,
                "comment_id": 131047857,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": false,
                "score": 4,
                "last_activity_date": 1666890795,
                "last_edit_date": 1666890795,
                "creation_date": 1666890559,
                "answer_id": 74225831,
                "question_id": 74225724,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The error message gives it away:\r\n\r\n&gt; _pow/1_ is not defined […]\r\n\r\nhuh, but you are calling it with 2 arguments – why does it try to call the unary function? Nope, you are not. jq uses semicolons to separate call arguments. commas separate the elements in a stream.\r\n\r\n```\r\njq -n &#39;pow(2;4)&#39;\r\n```\r\n\r\nThis will call `pow/2` which you are after.\r\n\r\nThen where do commas come into play? Consider:\r\n\r\n```\r\n$ jq -n &#39;pow(2,3;4,5)&#39;\r\n16  # 2**4 or pow(2;4)\r\n81  # 3**4 or pow(3;4)\r\n32  # 2**5 or pow(2;5)\r\n243 # 3**5 or pow(3;5)\r\n```",
                "title": "How do you load the math libraries to be used with jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1666890795,
        "creation_date": 1666890055,
        "question_id": 74225724,
        "body_markdown": "According to the manual, all the standard math libraries should be available to me for jq. But, not even the simple functions are available.\r\n\r\nHow do I add the math libraries on Ubuntu or include them when I run jq?\r\n\r\n`jq -n &#39;pow(2,4)&#39;`\r\n\r\nreturns\r\n\r\n\r\n`jq: error: pow/1 is not defined at &lt;top-level&gt;, line 1:\r\npow(2,4)\r\njq: 1 compile error`\r\n",
        "link": "https://stackoverflow.com/questions/74225724/how-do-you-load-the-math-libraries-to-be-used-with-jq",
        "title": "How do you load the math libraries to be used with jq?"
    },
    {
        "tags": [
            "bash",
            "amazon-web-services",
            "shell",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 7712415,
                    "reputation": 65767,
                    "user_id": 5841306,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/Civ0G.jpg?s=256",
                    "display_name": "Barbaros &#214;zhan",
                    "link": "https://stackoverflow.com/users/5841306/barbaros-%c3%96zhan"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1666948326,
                "post_id": 74232966,
                "comment_id": 131060074,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 26758292,
                    "reputation": 13,
                    "user_id": 20356611,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/fef94c8ab15c33b2a9b8de1c506c9642?s=256&d=identicon&r=PG",
                    "display_name": "Bindu",
                    "link": "https://stackoverflow.com/users/20356611/bindu"
                },
                "reply_to_user": {
                    "account_id": 7712415,
                    "reputation": 65767,
                    "user_id": 5841306,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/Civ0G.jpg?s=256",
                    "display_name": "Barbaros &#214;zhan",
                    "link": "https://stackoverflow.com/users/5841306/barbaros-%c3%96zhan"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1666949547,
                "post_id": 74232966,
                "comment_id": 131060481,
                "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": 1666964901,
                "post_id": 74232966,
                "comment_id": 131065510,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1666948837,
                "last_edit_date": 1666948837,
                "creation_date": 1666948535,
                "answer_id": 74233123,
                "question_id": 74232966,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "As of this writing, the posted JSON is invalid, so it&#39;s not clear exactly what is needed, but the following is illustrative:\r\n\r\n```\r\njq --arg newvalue xyz &#39;\r\n  (.. | objects | select(has(&quot;TargetOriginId&quot;)) | .TargetOriginId) |= $newvalue\r\n&#39;\r\n```\r\n\r\n",
                "title": "Change entry in json file that matches the condition in CloudFront Update Distribution"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1666967794,
                "last_edit_date": 1666967794,
                "creation_date": 1666965520,
                "answer_id": 74236471,
                "question_id": 74232966,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Fixed (i.e. made valid) and reduced your JSON input down to the necessary minimum (the M in [MRE](https://stackoverflow.com/help/minimal-reproducible-example)), that is 50 lines.\r\n\r\n```json\r\n{\r\n  &quot;CacheBehaviors&quot;: {\r\n    &quot;Quantity&quot;: 2,\r\n    &quot;Items&quot;: [\r\n      {\r\n        &quot;PathPattern&quot;: &quot;jkl/*&quot;,\r\n        &quot;TargetOriginId&quot;: [\r\n          &quot;nkl&quot;\r\n        ],\r\n        &quot;TrustedSigners&quot;: {\r\n          &quot;Enabled&quot;: false,\r\n          &quot;Quantity&quot;: 0\r\n        },\r\n        &quot;TrustedKeyGroups&quot;: {\r\n          &quot;Enabled&quot;: false,\r\n          &quot;Quantity&quot;: 0\r\n        },\r\n        &quot;ViewerProtocolPolicy&quot;: &quot;redirect-to-https&quot;\r\n      },\r\n      {\r\n        &quot;PathPattern&quot;: &quot;fgh/*&quot;,\r\n        &quot;TargetOriginId&quot;: [\r\n          &quot;xyz&quot;\r\n        ],\r\n        &quot;TrustedSigners&quot;: {\r\n          &quot;Enabled&quot;: false,\r\n          &quot;Quantity&quot;: 0\r\n        },\r\n        &quot;TrustedKeyGroups&quot;: {\r\n          &quot;Enabled&quot;: false,\r\n          &quot;Quantity&quot;: 0\r\n        },\r\n        &quot;ViewerProtocolPolicy&quot;: &quot;redirect-to-https&quot;\r\n      }\r\n    ]\r\n  },\r\n  &quot;CustomErrorResponses&quot;: {\r\n    &quot;Quantity&quot;: 0\r\n  },\r\n  &quot;Comment&quot;: &quot;vvvv&quot;,\r\n  &quot;Logging&quot;: {\r\n    &quot;Enabled&quot;: true,\r\n    &quot;IncludeCookies&quot;: false,\r\n    &quot;Bucket&quot;: &quot;abc.s3.amazonaws.com&quot;,\r\n    &quot;Prefix&quot;: &quot;std&quot;\r\n  },\r\n  &quot;WebACLId&quot;: &quot;&quot;,\r\n  &quot;HttpVersion&quot;: &quot;http2&quot;,\r\n  &quot;IsIPV6Enabled&quot;: true\r\n}\r\n```\r\n\r\nYou probably want to run a jq program similar to the following:\r\n\r\n```\r\n(.CacheBehaviors.Items[].TargetOriginId | select(. as $id | &quot;nkl&quot; | IN($id[]))) = [&quot;wkl&quot;]\r\n```\r\n\r\nIt selects all `TargetOriginId`s which contain the value `&quot;nkl&quot;` and changes the list to only contain `&quot;wkl&quot;`.\r\n\r\nOutput:\r\n\r\n```json\r\n{\r\n  &quot;CacheBehaviors&quot;: {\r\n    &quot;Quantity&quot;: 2,\r\n    &quot;Items&quot;: [\r\n      {\r\n        &quot;PathPattern&quot;: &quot;jkl/*&quot;,\r\n        &quot;TargetOriginId&quot;: [\r\n          &quot;wkl&quot;\r\n        ],\r\n        &quot;TrustedSigners&quot;: {\r\n          &quot;Enabled&quot;: false,\r\n          &quot;Quantity&quot;: 0\r\n        },\r\n        &quot;TrustedKeyGroups&quot;: {\r\n          &quot;Enabled&quot;: false,\r\n          &quot;Quantity&quot;: 0\r\n        },\r\n        &quot;ViewerProtocolPolicy&quot;: &quot;redirect-to-https&quot;\r\n      },\r\n      {\r\n        &quot;PathPattern&quot;: &quot;fgh/*&quot;,\r\n        &quot;TargetOriginId&quot;: [\r\n          &quot;xyz&quot;\r\n        ],\r\n        &quot;TrustedSigners&quot;: {\r\n          &quot;Enabled&quot;: false,\r\n          &quot;Quantity&quot;: 0\r\n        },\r\n        &quot;TrustedKeyGroups&quot;: {\r\n          &quot;Enabled&quot;: false,\r\n          &quot;Quantity&quot;: 0\r\n        },\r\n        &quot;ViewerProtocolPolicy&quot;: &quot;redirect-to-https&quot;\r\n      }\r\n    ]\r\n  },\r\n  &quot;CustomErrorResponses&quot;: {\r\n    &quot;Quantity&quot;: 0\r\n  },\r\n  &quot;Comment&quot;: &quot;vvvv&quot;,\r\n  &quot;Logging&quot;: {\r\n    &quot;Enabled&quot;: true,\r\n    &quot;IncludeCookies&quot;: false,\r\n    &quot;Bucket&quot;: &quot;abc.s3.amazonaws.com&quot;,\r\n    &quot;Prefix&quot;: &quot;std&quot;\r\n  },\r\n  &quot;WebACLId&quot;: &quot;&quot;,\r\n  &quot;HttpVersion&quot;: &quot;http2&quot;,\r\n  &quot;IsIPV6Enabled&quot;: true\r\n}\r\n```\r\n\r\nFrom the question it is unclear if `&quot;TargetOriginId&quot;: [&quot;nkl&quot;, &quot;xyz&quot;]` should become `[&quot;wkl&quot;]` or `[&quot;wkl&quot;, &quot;xyz&quot;]`. Or whether `[&quot;nkl&quot;, &quot;xyz&quot;]` is a match because it contains different values too. Maybe you only want to select those where the full `TargetOriginId` array matches?\r\n\r\nIf you only want to match items with single-valued target origin ids, the program becomes a bit simpler:\r\n\r\n```\r\n(.CacheBehaviors.Items[].TargetOriginId | select(. == [&quot;nkl&quot;])) = [&quot;wkl&quot;]\r\n```\r\n\r\nIf your target origin ids are always an array and you want to change say &quot;[abc,nkl,xyz]&quot; to &quot;[abc,REPLACED,xyz]&quot;, then select only those array elements and assign them the new value.\r\n\r\nNew input (as I understood it, the Q is quite vague on this):\r\n\r\n```json\r\n{\r\n  &quot;CacheBehaviors&quot;: {\r\n    &quot;Quantity&quot;: 2,\r\n    &quot;Items&quot;: [\r\n      {\r\n        &quot;PathPattern&quot;: &quot;jkl/*&quot;,\r\n        &quot;TargetOriginId&quot;: [\r\n          &quot;nkl&quot;,\r\n          &quot;something else&quot;\r\n        ]\r\n      },\r\n      {\r\n        &quot;PathPattern&quot;: &quot;fgh/*&quot;,\r\n        &quot;TargetOriginId&quot;: [\r\n          &quot;xyz&quot;,\r\n          &quot;abc&quot;\r\n        ]\r\n      }\r\n    ]\r\n  },\r\n  &quot;IsIPV6Enabled&quot;: true\r\n}\r\n```\r\n\r\njq:\r\n\r\n```\r\n(.CacheBehaviors.Items[].TargetOriginId[] | select(. == &quot;nkl&quot;)) = &quot;wkl&quot;\r\n```\r\n\r\nOutput:\r\n\r\n```json\r\n{\r\n  &quot;CacheBehaviors&quot;: {\r\n    &quot;Quantity&quot;: 2,\r\n    &quot;Items&quot;: [\r\n      {\r\n        &quot;PathPattern&quot;: &quot;jkl/*&quot;,\r\n        &quot;TargetOriginId&quot;: [\r\n          &quot;wkl&quot;,\r\n          &quot;something else&quot;\r\n        ]\r\n      },\r\n      {\r\n        &quot;PathPattern&quot;: &quot;fgh/*&quot;,\r\n        &quot;TargetOriginId&quot;: [\r\n          &quot;xyz&quot;,\r\n          &quot;abc&quot;\r\n        ]\r\n      }\r\n    ]\r\n  },\r\n  &quot;IsIPV6Enabled&quot;: true\r\n}\r\n```",
                "title": "Change entry in json file that matches the condition in CloudFront Update Distribution"
            },
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1667202511,
                "last_edit_date": 1667202511,
                "creation_date": 1666996406,
                "answer_id": 74241498,
                "question_id": 74232966,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Providing a second answer with some assumption. Let&#39;s start with a minimal example input:\r\n\r\n```json\r\n{\r\n  &quot;CacheBehaviors&quot;: {\r\n    &quot;Quantity&quot;: 2,\r\n    &quot;Items&quot;: [\r\n      {\r\n        &quot;PathPattern&quot;: &quot;jkl/*&quot;,\r\n        &quot;TargetOriginId&quot;: [\r\n          &quot;nkl&quot;,\r\n          &quot;something else&quot;\r\n        ]\r\n      },\r\n      {\r\n        &quot;PathPattern&quot;: &quot;fgh/*&quot;,\r\n        &quot;TargetOriginId&quot;: [\r\n          &quot;xyz&quot;,\r\n          &quot;abc&quot;\r\n        ]\r\n      }\r\n    ]\r\n  },\r\n  &quot;IsIPV6Enabled&quot;: true\r\n}\r\n```\r\n\r\nAssuming you want to define a mapping &quot;{old1: new1, old2: new2, old3: new3, …}&quot;, the following program could work and is easily extendable:\r\n\r\n```\r\n(.CacheBehaviors.Items[].TargetOriginId[]) |= ({\r\n  nkl: &quot;wkl&quot;,\r\n  xyz: &quot;123&quot;,\r\n  &quot;something else&quot;: &quot;is changed too&quot;,\r\n  &quot;not found&quot;: &quot;never replaced&quot;\r\n}[.] // .)\r\n```\r\n\r\nAnd if you like to have your mapping at the top/start of your program, bind it to a variable:\r\n\r\n```\r\n{\r\n  nkl: &quot;wkl&quot;,\r\n  xyz: &quot;123&quot;,\r\n  &quot;something else&quot;: &quot;is changed too&quot;,\r\n  &quot;not found&quot;: &quot;rever replaced&quot;\r\n} as $mapping\r\n| (.CacheBehaviors.Items[].TargetOriginId[]) |= ($mapping[.] // .)\r\n```\r\n\r\nOutput after running through above&#39;s program:\r\n\r\n```json\r\n{\r\n  &quot;CacheBehaviors&quot;: {\r\n    &quot;Quantity&quot;: 2,\r\n    &quot;Items&quot;: [\r\n      {\r\n        &quot;PathPattern&quot;: &quot;jkl/*&quot;,\r\n        &quot;TargetOriginId&quot;: [\r\n          &quot;wkl&quot;,\r\n          &quot;is changed too&quot;\r\n        ]\r\n      },\r\n      {\r\n        &quot;PathPattern&quot;: &quot;fgh/*&quot;,\r\n        &quot;TargetOriginId&quot;: [\r\n          &quot;123&quot;,\r\n          &quot;abc&quot;\r\n        ]\r\n      }\r\n    ]\r\n  },\r\n  &quot;IsIPV6Enabled&quot;: true\r\n}\r\n```\r\n\r\nIs that what you are after? This chooses the new value by key from an object/dictionary/map and falls back to the current value if no mapping was found.\r\n\r\n```\r\n… |= ({ old: &quot;new&quot; }[.] // .)\r\n```\r\n\r\nThe mapping itself could be provided as an argument to jq from a separate file:\r\n\r\n```\r\njq --slurpfile mapping old_to_new_ids.json \\\r\n  &#39;(.CacheBehaviors.Items[].TargetOriginId[]) |= ($mapping[0][.] // .)&#39;\r\n```\r\n\r\nWith the contents of file `old_to_new_ids.json` simply being:\r\n\r\n```json\r\n{\r\n  &quot;nkl&quot;: &quot;wkl&quot;,\r\n  &quot;xyz&quot;: &quot;123&quot;,\r\n  &quot;something else&quot;: &quot;is changed too&quot;,\r\n  &quot;not found&quot;: &quot;never replaced&quot;\r\n}\r\n```",
                "title": "Change entry in json file that matches the condition in CloudFront Update Distribution"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 0,
        "last_activity_date": 1667202511,
        "creation_date": 1666947754,
        "last_edit_date": 1666977674,
        "question_id": 74232966,
        "body_markdown": "We have a scenario where we need to replace the TargetOriginID of CacheBehaviour in the distribution of a json file. We need to replace the Existing TargetOriginID with New Values. I have tried with below jq command but not getting any closer\r\n\r\n```\r\nfor targetoriginID in $(jq &#39;(.CacheBehaviors.Items[].TargetOriginId)&#39; distconfig.json);\r\n\r\n         do \r\n                  \r\n                 \r\n                 echo &quot;#######fetch the new value from change behaviour json file&quot;#######\r\n                 NewValue=$(jq -r &quot;map(select(.targetoriginid == &quot;&quot;$targetoriginID&quot;&quot;))[].targetorigindr&quot; changebehaviour.json)\r\n\r\n\r\necho &quot;#########replace value in dist config json file with new value from change behaviour###########&quot;\r\njq -r &#39;(.CacheBehaviors.Items[].TargetOriginId | select(. == &quot;$targetoriginID&quot;)) = &quot;$NewValue&quot;&#39; distconfig.json &gt; &quot;tmp&quot; &amp;&amp; mv &quot;tmp&quot; distconfig.json\r\n```\r\n\r\n\r\n\r\n```json\r\n{\r\n\r\n      &quot;CachedMethods&quot;: {\r\n        &quot;Quantity&quot;: 3,\r\n        &quot;Items&quot;: [\r\n          &quot;HEAD&quot;,\r\n          &quot;GET&quot;,\r\n          &quot;OPTIONS&quot;\r\n        ]\r\n      }\r\n    },\r\n    &quot;SmoothStreaming&quot;: false,\r\n    &quot;Compress&quot;: false,\r\n    &quot;LambdaFunctionAssociations&quot;: {\r\n      &quot;Quantity&quot;: 0\r\n    },\r\n    &quot;FunctionAssociations&quot;: {\r\n      &quot;Quantity&quot;: 0\r\n    },\r\n    &quot;FieldLevelEncryptionId&quot;: &quot;&quot;,\r\n    &quot;ForwardedValues&quot;: {\r\n      &quot;QueryString&quot;: true,\r\n      &quot;Cookies&quot;: {\r\n        &quot;Forward&quot;: &quot;none&quot;\r\n      },\r\n      &quot;Headers&quot;: {\r\n        &quot;Quantity&quot;: 9,\r\n        &quot;Items&quot;: [\r\n          &quot;Authorization&quot;,\r\n          &quot;Origin&quot;,\r\n          &quot;access-control-allow-credentials&quot;,\r\n          &quot;expires&quot;,\r\n          &quot;access-control-max-age&quot;,\r\n          &quot;access-control-allow-headers&quot;,\r\n          &quot;cache-control&quot;,\r\n          &quot;access-control-allow-methods&quot;,\r\n          &quot;pragma&quot;\r\n        ]\r\n      },\r\n      &quot;QueryStringCacheKeys&quot;: {\r\n        &quot;Quantity&quot;: 1,\r\n        &quot;Items&quot;: [\r\n          &quot;*&quot;\r\n        ]\r\n      }\r\n    },\r\n    &quot;MinTTL&quot;: 0,\r\n    &quot;DefaultTTL&quot;: 86400,\r\n    &quot;MaxTTL&quot;: 31536000\r\n  },\r\n  &quot;CacheBehaviors&quot;: {\r\n    &quot;Quantity&quot;: 2,\r\n    &quot;Items&quot;: [\r\n      {\r\n        &quot;PathPattern&quot;: &quot;jkl/*&quot;,\r\n        &quot;TargetOriginId&quot;: &quot;nkl/Prod&quot;,\r\n        &quot;TrustedSigners&quot;: {\r\n          &quot;Enabled&quot;: false,\r\n          &quot;Quantity&quot;: 0\r\n        },\r\n        &quot;TrustedKeyGroups&quot;: {\r\n          &quot;Enabled&quot;: false,\r\n          &quot;Quantity&quot;: 0\r\n        },\r\n        &quot;ViewerProtocolPolicy&quot;: &quot;redirect-to-https&quot;,\r\n        &quot;AllowedMethods&quot;: {\r\n          &quot;Quantity&quot;: 7,\r\n          &quot;Items&quot;: [\r\n            &quot;HEAD&quot;,\r\n            &quot;DELETE&quot;,\r\n            &quot;POST&quot;,\r\n            &quot;GET&quot;,\r\n            &quot;OPTIONS&quot;,\r\n            &quot;PUT&quot;,\r\n            &quot;PATCH&quot;\r\n          ],\r\n          &quot;CachedMethods&quot;: {\r\n            &quot;Quantity&quot;: 3,\r\n            &quot;Items&quot;: [\r\n              &quot;HEAD&quot;,\r\n              &quot;GET&quot;,\r\n              &quot;OPTIONS&quot;\r\n            ]\r\n          }\r\n        },\r\n        &quot;SmoothStreaming&quot;: false,\r\n        &quot;Compress&quot;: false,\r\n        &quot;LambdaFunctionAssociations&quot;: {\r\n          &quot;Quantity&quot;: 0\r\n        },\r\n        &quot;FunctionAssociations&quot;: {\r\n          &quot;Quantity&quot;: 0\r\n        },\r\n        &quot;FieldLevelEncryptionId&quot;: &quot;&quot;,\r\n        &quot;ForwardedValues&quot;: {\r\n          &quot;QueryString&quot;: true,\r\n          &quot;Cookies&quot;: {\r\n            &quot;Forward&quot;: &quot;all&quot;\r\n          },\r\n          &quot;Headers&quot;: {\r\n            &quot;Quantity&quot;: 9,\r\n            &quot;Items&quot;: [\r\n              &quot;Authorization&quot;,\r\n              &quot;Origin&quot;,\r\n              &quot;access-control-allow-credentials&quot;,\r\n              &quot;access-control-max-age&quot;,\r\n              &quot;access-control-allow-headers&quot;,\r\n              &quot;cache-control&quot;,\r\n              &quot;access-control-allow-methods&quot;,\r\n              &quot;expirers&quot;,\r\n              &quot;pragma&quot;\r\n            ]\r\n          },\r\n          &quot;QueryStringCacheKeys&quot;: {\r\n            &quot;Quantity&quot;: 1,\r\n            &quot;Items&quot;: [\r\n              &quot;*&quot;\r\n            ]\r\n          }\r\n        },\r\n        &quot;MinTTL&quot;: 0,\r\n        &quot;DefaultTTL&quot;: 86400,\r\n        &quot;MaxTTL&quot;: 31536000\r\n      },\r\n      {\r\n        &quot;PathPattern&quot;: &quot;fgh/*&quot;,\r\n        &quot;TargetOriginId&quot;:&quot;xyz/Prod&quot;,\r\n        &quot;TrustedSigners&quot;: {\r\n          &quot;Enabled&quot;: false,\r\n          &quot;Quantity&quot;: 0\r\n        },\r\n        &quot;TrustedKeyGroups&quot;: {\r\n          &quot;Enabled&quot;: false,\r\n          &quot;Quantity&quot;: 0\r\n        },\r\n        &quot;ViewerProtocolPolicy&quot;: &quot;redirect-to-https&quot;,\r\n        &quot;AllowedMethods&quot;: {\r\n          &quot;Quantity&quot;: 7,\r\n          &quot;Items&quot;: [\r\n            &quot;HEAD&quot;,\r\n            &quot;DELETE&quot;,\r\n            &quot;POST&quot;,\r\n            &quot;GET&quot;,\r\n            &quot;OPTIONS&quot;,\r\n            &quot;PUT&quot;,\r\n            &quot;PATCH&quot;\r\n          ],\r\n          &quot;CachedMethods&quot;: {\r\n            &quot;Quantity&quot;: 3,\r\n            &quot;Items&quot;: [\r\n              &quot;HEAD&quot;,\r\n              &quot;GET&quot;,\r\n              &quot;OPTIONS&quot;\r\n            ]\r\n          }\r\n        },\r\n        &quot;SmoothStreaming&quot;: false,\r\n        &quot;Compress&quot;: false,\r\n        &quot;LambdaFunctionAssociations&quot;: {\r\n          &quot;Quantity&quot;: 0\r\n        },\r\n        &quot;FunctionAssociations&quot;: {\r\n          &quot;Quantity&quot;: 0\r\n        },\r\n        &quot;FieldLevelEncryptionId&quot;: &quot;&quot;,\r\n        &quot;ForwardedValues&quot;: {\r\n          &quot;QueryString&quot;: true,\r\n          &quot;Cookies&quot;: {\r\n            &quot;Forward&quot;: &quot;none&quot;\r\n          },\r\n          &quot;Headers&quot;: {\r\n            &quot;Quantity&quot;: 10,\r\n            &quot;Items&quot;: [\r\n              &quot;access-control-allow-origin&quot;,\r\n              &quot;authorization&quot;,\r\n              &quot;Origin&quot;,\r\n              &quot;access-control-allow-credentials&quot;,\r\n              &quot;access-control-max-age&quot;,\r\n              &quot;access-control-allow-headers&quot;,\r\n              &quot;cache-control&quot;,\r\n              &quot;access-control-allow-methods&quot;,\r\n              &quot;expirers&quot;,\r\n              &quot;pragma&quot;\r\n            ]\r\n          },\r\n          &quot;QueryStringCacheKeys&quot;: {\r\n            &quot;Quantity&quot;: 1,\r\n            &quot;Items&quot;: [\r\n              &quot;*&quot;\r\n            ]\r\n          }\r\n        },\r\n        &quot;MinTTL&quot;: 0,\r\n        &quot;DefaultTTL&quot;: 0,\r\n        &quot;MaxTTL&quot;: 0\r\n      }\r\n    ]\r\n  }\r\n```\r\n\r\n\r\nLooking for a solution to make bulk change in CacheBehaviour for all TargetOriginID&#39;s",
        "link": "https://stackoverflow.com/questions/74232966/change-entry-in-json-file-that-matches-the-condition-in-cloudfront-update-distri",
        "title": "Change entry in json file that matches the condition in CloudFront Update Distribution"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1667030114,
                "last_edit_date": 1667030114,
                "creation_date": 1666974904,
                "answer_id": 74238353,
                "question_id": 74237495,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The efficient way to make the selection while forming an array is to use `inputs` with the -n command-line option, along the lines of:\r\n\r\n    jq -n &#39;[inputs | select(.&quot;level&quot; != &quot;INFO&quot;) ]&#39; my_log_file.txt\r\n\r\nSo your query could be:\r\n\r\n    [inputs | select(.&quot;level&quot; != &quot;INFO&quot;) | .message] | unique\r\n\r\nor to avoid the `sort` entailed by the call to `unique` and assuming all the .message values are strings:\r\n\r\n    INDEX(inputs | select(.level != &quot;INFO&quot;); .message)\r\n    | keys_unsorted\r\n\r\nor even better:\r\n\r\n    INDEX(inputs | select(.level != &quot;INFO&quot;) | .message; .)[]\r\n\r\nIf you want the array to be splatted, just append `[]`.\r\n\r\n",
                "title": "jq: How to slurp mid-filter (convert separate json objects to an array)"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1666994783,
                "last_edit_date": 1666994783,
                "creation_date": 1666974934,
                "answer_id": 74238361,
                "question_id": 74237495,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "&gt; I can&#39;t use slurp, because it doesn&#39;t work with this command\r\n\r\nIf you use slurp, you&#39;ll need to wrap the `select` in a `map()` to make it work:\r\n```\r\njq -s &#39;map(select(.level != &quot;INFO&quot;))&#39; my_log_file.txt\r\n```\r\n\r\n\r\n----------\r\n\r\nSo to get all the unique `message` where `level != &quot;INFO&quot;`, you can use:\r\n```\r\njq -s &#39;map(select(.level != &quot;INFO&quot;).message) | unique[]&#39; my_log_file.txt\r\n```\r\n\r\nThat will output:\r\n```none\r\n&quot;bar&quot;\r\n&quot;baz&quot;\r\n```\r\n\r\nAs you can test in [this online demo](https://jqplay.org/s/U43lZfKS48R).\r\n",
                "title": "jq: How to slurp mid-filter (convert separate json objects to an array)"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1740292623,
                "last_edit_date": 1740292623,
                "creation_date": 1714244184,
                "answer_id": 78396059,
                "question_id": 74237495,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "```\r\njq -c &#39;select(.&quot;level&quot; != &quot;INFO&quot;)|reduce inputs as $i ([.];[.]+[$i])&#39; my_log_file.txt\r\n```",
                "title": "jq: How to slurp mid-filter (convert separate json objects to an array)"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 0,
        "last_activity_date": 1740292623,
        "creation_date": 1666970514,
        "question_id": 74237495,
        "body_markdown": "I am parsing Elastic logs that look like \r\n```\r\n$ cat my_log_file.txt:\r\n{&quot;level&quot;: &quot;INFO&quot;, &quot;message&quot;: &quot;foo&quot;}\r\n{&quot;level&quot;: &quot;WARN&quot;, &quot;message&quot;: &quot;bar&quot;}\r\n{&quot;level&quot;: &quot;WARN&quot;, &quot;message&quot;: &quot;baz&quot;}\r\n```\r\nBecause they&#39;re one per line, formerly I have used `jq -s` to slurp them into an actual array that I can run `map` on:\r\n```\r\njq -s &#39;map(.message) | unique&#39; my_log_file.txt\r\n```\r\n\r\nNow I want to select out only lines that have level != &quot;INFO&quot;. I should be able to just use [this cookbook recipe][1], but again `jq` is having trouble with each line being a separate object and not in an array. \r\n\r\nI can&#39;t use slurp, because it doesn&#39;t work with this command:\r\n```\r\njq &#39;select(.&quot;level&quot; != &quot;INFO&quot;)&#39; my_log_file.txt\r\n```\r\nBut when I want to map to .message again, I get the same error I got before when I wasn&#39;t using slurp:\r\n```\r\n$ jq &#39;select(.&quot;level&quot; != &quot;INFO&quot;) | map(.message) | unique&#39; my_log_file.txt\r\njq: error (at &lt;stdin&gt;:90): Cannot index string with string &quot;message&quot;\r\n```\r\nHow can I convert my records midstream -- after the select is done, to convert the result from\r\n```\r\n{&quot;level&quot;: &quot;WARN&quot;, &quot;message&quot;: &quot;bar&quot;}\r\n{&quot;level&quot;: &quot;WARN&quot;, &quot;message&quot;: &quot;bar&quot;}\r\n```\r\nto \r\n```\r\n[\r\n  {&quot;level&quot;: &quot;WARN&quot;, &quot;message&quot;: &quot;bar&quot;},\r\n  {&quot;level&quot;: &quot;WARN&quot;, &quot;message&quot;: &quot;bar&quot;}\r\n]\r\n```\r\nI heard that `inputs` was designed to replace slurp, but when I tried \r\n```\r\n$ jq &#39;select(.&quot;level&quot; != &quot;INFO&quot;) | [inputs]&#39; my_log_file.txt\r\n```\r\nthat ignored my `select` and I had a list of every message again.\r\n\r\n\r\n  [1]: https://github.com/stedolan/jq/wiki/Cookbook#filter-objects-based-on-the-contents-of-a-key",
        "link": "https://stackoverflow.com/questions/74237495/jq-how-to-slurp-mid-filter-convert-separate-json-objects-to-an-array",
        "title": "jq: How to slurp mid-filter (convert separate json objects to an array)"
    },
    {
        "tags": [
            "json",
            "bash",
            "loops",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1666987889,
                "post_id": 74240376,
                "comment_id": 131072804,
                "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": 1666987963,
                "post_id": 74240376,
                "comment_id": 131072815,
                "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": 1666987980,
                "post_id": 74240376,
                "comment_id": 131072817,
                "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": 1666988021,
                "post_id": 74240376,
                "comment_id": 131072828,
                "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": 1666988121,
                "post_id": 74240376,
                "comment_id": 131072851,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1666988518,
                "post_id": 74240376,
                "comment_id": 131072941,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 26759804,
                    "reputation": 3,
                    "user_id": 20357942,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/9c192db7b46b0f0d1550e907a6158d84?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "user327344212",
                    "link": "https://stackoverflow.com/users/20357942/user327344212"
                },
                "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": 1666989688,
                "post_id": 74240376,
                "comment_id": 131073242,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 26759804,
                    "reputation": 3,
                    "user_id": 20357942,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/9c192db7b46b0f0d1550e907a6158d84?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "user327344212",
                    "link": "https://stackoverflow.com/users/20357942/user327344212"
                },
                "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": 1666990281,
                "post_id": 74240376,
                "comment_id": 131073381,
                "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": 1666990374,
                "post_id": 74240376,
                "comment_id": 131073407,
                "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": 1666990811,
                "post_id": 74240376,
                "comment_id": 131073494,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 26759804,
                    "reputation": 3,
                    "user_id": 20357942,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/9c192db7b46b0f0d1550e907a6158d84?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "user327344212",
                    "link": "https://stackoverflow.com/users/20357942/user327344212"
                },
                "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": 1667004827,
                "post_id": 74240376,
                "comment_id": 131075603,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 26759804,
                    "reputation": 3,
                    "user_id": 20357942,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/9c192db7b46b0f0d1550e907a6158d84?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "user327344212",
                    "link": "https://stackoverflow.com/users/20357942/user327344212"
                },
                "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": 1667004856,
                "post_id": 74240376,
                "comment_id": 131075604,
                "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": 1667006909,
                "post_id": 74240376,
                "comment_id": 131075791,
                "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": 1667007468,
                "post_id": 74240376,
                "comment_id": 131075845,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 26759804,
                    "reputation": 3,
                    "user_id": 20357942,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/9c192db7b46b0f0d1550e907a6158d84?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "user327344212",
                    "link": "https://stackoverflow.com/users/20357942/user327344212"
                },
                "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": 1667046267,
                "post_id": 74240376,
                "comment_id": 131080539,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 26759804,
                    "reputation": 3,
                    "user_id": 20357942,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/9c192db7b46b0f0d1550e907a6158d84?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "user327344212",
                    "link": "https://stackoverflow.com/users/20357942/user327344212"
                },
                "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": 1667048614,
                "post_id": 74240376,
                "comment_id": 131081011,
                "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": 1667053016,
                "post_id": 74240376,
                "comment_id": 131081964,
                "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": 1667057013,
                "post_id": 74240376,
                "comment_id": 131082789,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 26759804,
                    "reputation": 3,
                    "user_id": 20357942,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/9c192db7b46b0f0d1550e907a6158d84?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "user327344212",
                    "link": "https://stackoverflow.com/users/20357942/user327344212"
                },
                "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": 1667227747,
                "post_id": 74240376,
                "comment_id": 131114428,
                "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": 1667229494,
                "post_id": 74240376,
                "comment_id": 131115120,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1667057643,
                "last_edit_date": 1667057643,
                "creation_date": 1667057178,
                "answer_id": 74246512,
                "question_id": 74240376,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Consider doing the filtering inside of jq itself:\r\n\r\n```\r\n jq \\\r\n  --arg now_epoch &quot;$(date +%s --date=&#39;30 days ago&#39;)&quot; &#39;\r\n  ($now_epoch | strptime(&quot;%s&quot;)) as $now\r\n| .[]\r\n| (.notafter | strptime(&quot;%d %b %Y %H:%M:%S GMT&quot;)) as $expire_time\r\n| if $now &gt; $expire_time\r\n  then &quot;Expired cert for \\(.subject)&quot;\r\n  else &quot;Valid cert for \\(.subject)&quot;\r\n  end&#39;\r\n```\r\n\r\nOutput as\r\n```none\r\n&quot;Valid cert for CN=Valid Certificate B&quot;\r\n&quot;Expired cert for CN=Expired Certificate B&quot;\r\n&quot;Valid cert for CN=Valid Certificate A&quot;\r\n&quot;Expired cert for CN=Expired Certificate A&quot;\r\n```\r\n\r\n---\r\n\r\nTo add the sorting, one might change it to:\r\n\r\n```\r\njq -n   --arg now_epoch &quot;$(date +%s --date=&#39;30 days ago&#39;)&quot; &#39;\r\n  ($now_epoch | strptime(&quot;%s&quot;)) as $now\r\n| [ inputs[]\r\n    | (.notafter | strptime(&quot;%d %b %Y %H:%M:%S GMT&quot;)) as $expire_time\r\n    | [ $expire_time,\r\n         if $now &gt; $expire_time\r\n         then &quot;Expired cert for \\(.subject)&quot;\r\n         else &quot;Valid cert for \\(.subject)&quot;\r\n         end\r\n       ]\r\n  ]\r\n| sort[]\r\n| .[1]\r\n&#39;\r\n```\r\n\r\n(this is certainly more complicated than it needs to be; if I don&#39;t get the time to simplify it myself, I&#39;m sure one of the jq-tag elders will come by and show how to achieve this end more simply).",
                "title": "How can I filter and order data extracted by JQ?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1667057643,
        "creation_date": 1666987510,
        "last_edit_date": 1667056838,
        "question_id": 74240376,
        "body_markdown": "I have input data with data on a list of JSON certificates; my goal is to determine which of them have been expired for \r\nI&#39;m currently converting this into a list of strings stored in a shell variable and then trying to loop over those strings, but it isn&#39;t working correctly:\r\n\r\n```\r\njsoninput=&#39;\r\n[\r\n {&quot;notafter&quot;:&quot;1 May 2024 14:21:51 GMT&quot;, &quot;subject&quot;:&quot;CN=Valid Certificate B&quot;},\r\n {&quot;notafter&quot;:&quot;2 Jan 2000 00:00:00 GMT&quot;, &quot;subject&quot;:&quot;CN=Expired Certificate B&quot;},\r\n {&quot;notafter&quot;:&quot;30 Apr 2024 14:21:51 GMT&quot;, &quot;subject&quot;:&quot;CN=Valid Certificate A&quot;},\r\n {&quot;notafter&quot;:&quot;1 Jan 2000 00:00:00 GMT&quot;, &quot;subject&quot;:&quot;CN=Expired Certificate A&quot;}\r\n]\r\n&#39;\r\njsondata=$(jq --raw-output &#39;keys[] as $i | &quot;Certificate \\(.[$i].subject): expiryDate: \\(.[$i].notafter | strptime(&quot;%d %b %Y %H:%M:%S GMT&quot;) | mktime )&quot;&#39; &lt;&lt;&lt;&quot;$jsoninput&quot;)\r\n\r\nnowDate=$(date +%s --date=&#39;30 days ago&#39;)\r\n\r\n# this part doesn&#39;t work right\r\nfor i in $myjsondata; do\r\n   if (( $i &gt; $nowDate ));\r\n        then echo &quot;Certs are expired!&quot; $i;\r\n        else echo &quot;Certs are good&quot; $i;\r\nfi\r\ndone\r\n```\r\n\r\nWhen the above is run, `echo &quot;$jsondata&quot;` looks like:\r\n\r\n```none\r\nCertificate CN=Valid Certificate B: expiryDate: 1714576911\r\nCertificate CN=Expired Certificate B: expiryDate: 946771200\r\nCertificate CN=Valid Certificate A: expiryDate: 1714490511\r\nCertificate CN=Expired Certificate A: expiryDate: 946684800\r\n```\r\n\r\n...so each certificate has its own line for the `for` loop to iterate over.\r\n\r\nObviously, what I _want_ to do is have `$i &gt; $nowDate` compare only the `expireyDate` field, but then to be able to print the full string describing the certificate depending on how that comparison goes; but I don&#39;t know how to make bash look at only the `expireyDate`.\r\n\r\nWith JQ I can parse out only the expiryDate and that works just fine, however the Output I get is `Certs are expired! 1542649223` -- there&#39;s no listing of _which_ certificate was expired, only of its expiration date.\r\n\r\n**How can I separate into valid and expired certificates?** (As a stretch goal, I&#39;d like to sort the expired certificates to print in output first).",
        "link": "https://stackoverflow.com/questions/74240376/how-can-i-filter-and-order-data-extracted-by-jq",
        "title": "How can I filter and order data extracted by JQ?"
    },
    {
        "tags": [
            "shell",
            "awk",
            "yaml",
            "jq",
            "yq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 25897050,
                    "reputation": 99,
                    "user_id": 19623474,
                    "user_type": "registered",
                    "profile_image": "https://lh3.googleusercontent.com/a/AItbvmluF4RbeQRnsI6ff9vfQQ4WnRO3Dp2tAkJMpXKS=k-s256",
                    "display_name": "Clair",
                    "link": "https://stackoverflow.com/users/19623474/clair"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1667014076,
                "post_id": 74242155,
                "comment_id": 131076378,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1667346098,
                "last_edit_date": 1667346098,
                "creation_date": 1667014216,
                "answer_id": 74242621,
                "question_id": 74242155,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "\r\nFirst, convert to JSON, then use the jq command.\r\n```\r\nyq eval -o json includelist.yml | \\\r\n    jq -r &#39;.ProductLine.ADO_FeedsList[]|&quot;\\(.ProjectName),\\(.FeedsName[])&quot;&#39;\r\n```",
                "title": "How to format the yaml file to a csv format?"
            },
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1667187541,
                "creation_date": 1667187541,
                "answer_id": 74258518,
                "question_id": 74242155,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If you are using [mikefarah/yq](https://github.com/mikefarah/yq) anyway, you could directly output CSV using `-o csv` (instead of using `-o json` and calling `jq`):\r\n~~~sh\r\nyq -o csv &#39;.ProductLine.ADO_FeedsList[] | [.ProjectName] + (.FeedsName[] | [.])&#39; includelist.yml\r\n~~~\r\n~~~none\r\nIT,test\r\nIT,test2\r\norganization,hello\r\norganization,world\r\nFin,good\r\nFin,aaaa\r\norganization,bbb\r\norganization,ccc\r\n~~~",
                "title": "How to format the yaml file to a csv format?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 3,
        "last_activity_date": 1667346098,
        "creation_date": 1667005363,
        "last_edit_date": 1667186714,
        "question_id": 74242155,
        "body_markdown": "I have used the yq command to format a yaml file:\r\n\r\n**cat includelist.yml |yq -r &#39;.ProductLine.ADO_FeedsList&#39;**\r\n\r\noutput:\r\n\r\n```\r\n---\r\nProductLine:\r\n  ProductLineName: AAAAA\r\n  ADO_FeedsList:\r\n  - ProjectName: IT\r\n    FeedsName:\r\n    - test\r\n    - test2\r\n  - ProjectName: organization\r\n    FeedsName:\r\n    - hello\r\n    - world\r\n---\r\nProductLine:\r\n  ProductLineName: BBBBB\r\n  ADO_FeedsList:\r\n  - ProjectName: Fin\r\n    FeedsName:\r\n    - good\r\n    - aaaa\r\n  - ProjectName: organization\r\n    FeedsName:\r\n    - bbb\r\n    - ccc\r\n\r\n```\r\n\r\nCould somebody give me some suggestion,I don&#39;t known how to convert to csv format.\r\n\r\n\r\n\r\n\r\n\r\nMy question: how to convert the content to the following format:\r\n\r\nIT,test\r\n\r\nIT,test2\r\n\r\norginazation,hello\r\n\r\norginazation,world\r\n\r\nFin,good\r\n\r\nFin,aaaa\r\n\r\norganization,bbb\r\n\r\norganization,ccc\r\n\r\n--------------------------------------------------------------\r\n\r\nThanks a ton.&#128578;",
        "link": "https://stackoverflow.com/questions/74242155/how-to-format-the-yaml-file-to-a-csv-format",
        "title": "How to format the yaml file to a csv format?"
    }
]