[
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1646686417,
                "post_id": 71387033,
                "comment_id": 126180965,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 9853256,
                    "reputation": 490,
                    "user_id": 7298643,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/2D13T.png?s=256",
                    "display_name": "Jengels",
                    "link": "https://stackoverflow.com/users/7298643/jengels"
                },
                "reply_to_user": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1646686479,
                "post_id": 71387033,
                "comment_id": 126180992,
                "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": 1646686558,
                "post_id": 71387033,
                "comment_id": 126181011,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1646687198,
                "creation_date": 1646687198,
                "answer_id": 71387268,
                "question_id": 71387033,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Based on your snippet, the relevant jq would be:\r\n\r\n    .data |= .[:4]",
                "title": "How would you collect the first few entries of a list from a large json file using jq?"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1646706667,
                "last_edit_date": 1646706667,
                "creation_date": 1646687754,
                "answer_id": 71387356,
                "question_id": 71387033,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s an example using the `--stream` option:\r\n\r\n~~~sh\r\n$ cat input.json\r\n{\r\n  &quot;info&quot;: {&quot;name&quot;: &quot;some-name&quot;},\r\n  &quot;data&quot;: [\r\n    {&quot;a&quot;:1},\r\n    {&quot;b&quot;:2},\r\n    {&quot;c&quot;:3},\r\n    {&quot;d&quot;:4},\r\n    {&quot;e&quot;:5},\r\n    {&quot;f&quot;:6},\r\n    {&quot;g&quot;:7}\r\n  ]\r\n}\r\n~~~\r\n~~~sh\r\njq --stream -n &#39;\r\n  reduce (\r\n    inputs | select(has(1) and (.[0] | .[0] == &quot;data&quot; and .[1] &lt; 4))\r\n  ) as $in (\r\n    {}; .[$in[0][-1]] = $in[1]\r\n  )\r\n&#39; input.json\r\n~~~\r\n~~~json\r\n{\r\n  &quot;a&quot;: 1,\r\n  &quot;b&quot;: 2,\r\n  &quot;c&quot;: 3,\r\n  &quot;d&quot;: 4\r\n}\r\n~~~\r\n\r\nNote: Using `limit` would have been more efficient in this case, but I tried to be more generic for the purpose of scalability.",
                "title": "How would you collect the first few entries of a list from a large json file using jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1646706667,
        "creation_date": 1646685857,
        "question_id": 71387033,
        "body_markdown": "I am trying to process a large json file for testing purposes that has a few thousand entries. The json contains a long list of ```data``` to is too large for me to process in one go. Using a jq, is there an easy way to get a valid snippet of the json that only contains the first few entries from the ```data``` list? For example is there a query that would look at the whole json file and return to me a valid json that only contains the first 4 entries from ```data```? Thank you! \r\n\r\n```\r\n{\r\n&quot;info&quot;:{\r\n&quot;name&quot;:&quot;some-name&quot;\r\n},\r\n&quot;data&quot;:[\r\n{...},\r\n{...},\r\n{...},\r\n{...}\r\n}\r\n```",
        "link": "https://stackoverflow.com/questions/71387033/how-would-you-collect-the-first-few-entries-of-a-list-from-a-large-json-file-usi",
        "title": "How would you collect the first few entries of a list from a large json file using jq?"
    },
    {
        "tags": [
            "json",
            "jq",
            "negation"
        ],
        "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": 1646728056,
                "post_id": 71391823,
                "comment_id": 126189425,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1646727546,
                "creation_date": 1646727546,
                "answer_id": 71391888,
                "question_id": 71391823,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Use `not`, which is a [builtin](https://stedolan.github.io/jq/manual/#and%2For%2Fnot) rather than an operator:\r\n~~~none\r\n.results[] | select(.name | contains(&quot;dev&quot;) and (contains(&quot;master&quot;) | not)) | .name\r\n~~~\r\n~~~json\r\n&quot;package-dev_0.0.1-dev.er56ut.pkg&quot;\r\n&quot;package_0.9.1-dev.til39aw.pkg&quot;\r\n~~~\r\n[Demo](https://jqplay.org/s/i1SJlwqT9q)\r\n\r\nAlternatively, you can collect your tests in an array and test against that\r\n~~~\r\n.results[] | select([.name | contains(&quot;dev&quot;, &quot;master&quot;)] == [true, false]) | .name\r\n~~~\r\n~~~json\r\n&quot;package-dev_0.0.1-dev.er56ut.pkg&quot;\r\n&quot;package_0.9.1-dev.til39aw.pkg&quot;\r\n~~~\r\n[Demo](https://jqplay.org/s/UxKZQLtree)",
                "title": "jq combine positive and negative filters with select"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1646795413,
        "creation_date": 1646727207,
        "last_edit_date": 1646795413,
        "question_id": 71391823,
        "body_markdown": "Given the following JSON object &quot;test.json&quot;:\r\n\r\n```\r\n{\r\n\t&quot;results&quot;: [\r\n\t\t{&quot;name&quot;: &quot;package-dev_0.0.1-dev.er56ut.pkg&quot;},\r\n\t\t{&quot;name&quot;: &quot;package-dev_0.0.23-master.qwk89mo.pkg&quot;},\r\n\t\t{&quot;name&quot;: &quot;package_0.9.1-dev.til39aw.pkg&quot;},\r\n\t\t{&quot;name&quot;: &quot;package_0.3.3-master.mbw80lk.pkg&quot;}\r\n\t\r\n\t]\r\n}\r\n```\r\nI am trying to use jq to filter for instances where the key &quot;name&quot; contains &quot;dev&quot; but does not contain &quot;master&quot; and output the value of &quot;name&quot;.\r\n\r\nFiltering for instances where the key &quot;name&quot; contains &quot;dev&quot; is fine:\r\n\r\n```\r\ncat test.json | jq &#39;.results[]|select(.name|contains(&quot;dev&quot;)) | .name&#39;\r\n&quot;package-dev_0.0.1-dev.er56ut.pkg&quot;\r\n&quot;package-dev_0.0.23-master.qwk89mo.pkg&quot;\r\n&quot;package_0.9.1-dev.til39aw.pkg&quot;\r\n```\r\nBut I haven&#39;t been successful in removing instances where the key &quot;name&quot; contains &quot;master&quot;:\r\n\r\n```\r\ncat test.json | jq &#39;.results[]|select(.name|contains(&quot;dev&quot;)) | select(.name|contains(&quot;master&quot;))|not&#39;\r\nfalse\r\n```",
        "link": "https://stackoverflow.com/questions/71391823/jq-combine-positive-and-negative-filters-with-select",
        "title": "jq combine positive and negative filters with select"
    },
    {
        "tags": [
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 19118721,
                    "reputation": 12134,
                    "user_id": 13963086,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/9df2c3c4c87d8050b8fd6a59c88c7133?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "k314159",
                    "link": "https://stackoverflow.com/users/13963086/k314159"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1646741606,
                "post_id": 71394745,
                "comment_id": 126194131,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 20074217,
                    "reputation": 87,
                    "user_id": 14718292,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/SmU9U.jpg?s=256",
                    "display_name": "Rather Vi",
                    "link": "https://stackoverflow.com/users/14718292/rather-vi"
                },
                "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": 1646741984,
                "post_id": 71394745,
                "comment_id": 126194274,
                "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": 1646742087,
                "post_id": 71394745,
                "comment_id": 126194314,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1646742591,
                "creation_date": 1646742591,
                "answer_id": 71395084,
                "question_id": 71394745,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "No, don&#39;t inject shell variables into your jq filter! Rather use options provided by jq to introduce them as variables inside jq. In your case, when using a variable that holds a number, `--argjson` will do:\r\n~~~sh\r\ni=1\r\ntest2=$(/bin/lshw -quiet -json -C network|/bin/jq --argjson i $i &#39;.[$i] | .logicalname&#39;)\r\n~~~",
                "title": "How to use jq syntax within a bash script?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -2,
        "last_activity_date": 1646747985,
        "creation_date": 1646741052,
        "last_edit_date": 1646747985,
        "question_id": 71394745,
        "body_markdown": "The following command works fine if launched in a console:\r\n\r\n```/bin/lshw -quiet -json -C network|/bin/jq &#39;.[1] | .logicalname&#39;```\r\n\r\nPlease, note the 1 in square brackets.\r\n\r\nOn my computer this command delivers:\r\n\r\n```\r\nroot@t15:/home/hmb# /bin/lshw -quiet -json -C network|/bin/jq &#39;.[1] | .logicalname&#39;\r\n&quot;wlp9s0&quot;\r\nroot@t15:/home/hmb# \r\n```\r\n\r\nWhen I tried to use this syntax within a bash script like this:\r\n\r\n```\r\n#!/bin/bash\r\n# The next line works:\r\ntest1=$(/bin/lshw -quiet -json -C network|/bin/jq &#39;.[1] | .logicalname&#39;)\r\n/bin/echo &quot;test1 = $test1&quot;\r\ni=1\r\n# This line doesn&#39;t:\r\ntest2=$(/bin/lshw -quiet -json -C network|/bin/jq &#39;.[$i] | .logicalname&#39;)\r\n/bin/echo &quot;test2 = $test2&quot;\r\n```\r\n\r\n... things don&#39;t work as expected:\r\n\r\n```\r\nroot@t15:/home/hmb/HPT/playground/hmbnetwatch# ./question.sh \r\ntest1 = &quot;wlp9s0&quot;\r\njq: error: $i is not defined at &lt;top-level&gt;, line 1:\r\n.[$i] | .logicalname  \r\njq: 1 compile error\r\ntest2 = \r\nroot@t15:/home/hmb/HPT/playground/hmbnetwatch# \r\n```\r\nI&#39;ve tested all methods of escaping for the single quotes which occur in the jq command, but I wasn&#39;t able to use a script variable within these squared brackets.\r\n\r\nI managed to find a way getting the needed information out of lshw by using an array, but out of curiosity and since I invested hours of trial and error without any success, I&#39;d really like to know whether it is impossible to use a variable here or if there is a way.\r\n\r\nIt is said this is a duplicate of https://stackoverflow.com/questions/40027395/passing-bash-variable-to-jq, but I don&#39;t think so. The question is why one should not inject a shell variable in the square brackets of `jq`, which is not really answered elsewhere.",
        "link": "https://stackoverflow.com/questions/71394745/how-to-use-jq-syntax-within-a-bash-script",
        "title": "How to use jq syntax within a bash script?"
    },
    {
        "tags": [
            "kubernetes",
            "jq",
            "jsonpath"
        ],
        "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": 1646758946,
                "post_id": 71398800,
                "comment_id": 126201183,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1646760181,
                "creation_date": 1646760181,
                "answer_id": 71399106,
                "question_id": 71398800,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You could base a jq solution on:\r\n\r\n\r\n```.spec.versions[] | select(.name | contains(&quot;v1beta1&quot;))```\r\n\r\nor similar, e.g.\r\n\r\n```.spec.versions[] | select(.name | startswith(&quot;v1beta1&quot;))```\r\n\r\n\r\n",
                "title": "parsing kubectl json output with jq or jsonpath"
            },
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1646796282,
                "creation_date": 1646796282,
                "answer_id": 71403972,
                "question_id": 71398800,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "This will show the name using jsonpath: `kubectl get crd -o jsonpath=&#39;{range .items[?(@.spec.versions[].name==&quot;v1beta1&quot;)].metadata}{.name}{&quot;\\n&quot;}&#39;`",
                "title": "parsing kubectl json output with jq or jsonpath"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1646796282,
        "creation_date": 1646758838,
        "question_id": 71398800,
        "body_markdown": "I would like to select, and list the crds which are containing the &quot;v1beta1&quot; in the \r\n\r\n&gt; .spec.versions.*.name\r\n\r\nThe versions part of the crd object looks similar like this\r\n```\r\n    &quot;versions&quot;: [\r\n      {\r\n        &quot;name&quot;: &quot;v1alpha2&quot;,\r\n        &quot;served&quot;: true,\r\n        &quot;storage&quot;: true,\r\n        &quot;subresources&quot;: {\r\n          &quot;status&quot;: {}\r\n        },\r\n        &quot;name&quot;: &quot;v1beta1&quot;\r\n        &quot;served&quot;: true,\r\n        &quot;storage&quot;: true,\r\n        &quot;subresources&quot;: {\r\n          &quot;status&quot;: {}\r\n        }\r\n      }\r\n    ]\r\n\r\n```\r\n\r\nI tried some different queries like the following, but no success.\r\n```\r\n$ kubectl get crd -ojson | jq -r &#39;.items[] | map(select(.spec.versions[] | contains(&quot;v1beta1&quot;))).metadata.name&#39;\r\njq: error (at &lt;stdin&gt;:250345): Cannot index string with string &quot;spec&quot;\r\n```\r\n\r\nJsonpath solution would be also great. I tried something like this without success.\r\n```\r\n$ kubectl get crd -ojsonpath=&quot;{range .items.*.spec.versions.*}{.name[?(@==&#39;v1beta1&#39;)].metadata.name}{&#39;\\n&#39;}{end}&quot;\r\n```\r\n\r\nCould someone help me please?\r\n",
        "link": "https://stackoverflow.com/questions/71398800/parsing-kubectl-json-output-with-jq-or-jsonpath",
        "title": "parsing kubectl json output with jq or jsonpath"
    },
    {
        "tags": [
            "bash",
            "shell",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1646761529,
                "post_id": 71399346,
                "comment_id": 126202197,
                "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": 1646761559,
                "post_id": 71399346,
                "comment_id": 126202207,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 24494290,
                    "reputation": 1,
                    "user_id": 18410849,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f2b5a7a5c841e3fe84f3a65e9a7d89af?s=256&d=identicon&r=PG",
                    "display_name": "Gokul",
                    "link": "https://stackoverflow.com/users/18410849/gokul"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1646761943,
                "post_id": 71399346,
                "comment_id": 126202339,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1646762562,
                "last_edit_date": 1646762562,
                "creation_date": 1646761950,
                "answer_id": 71399475,
                "question_id": 71399346,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I&#39;m not getting the same error, but:\r\n```sh\r\n$ jq &#39;.components.1[0].x&#39; file.json\r\njq: error: syntax error, unexpected LITERAL, expecting $end (Unix shell quoting issues?) at &lt;top-level&gt;, line 1:\r\n.components.1[0].x\r\njq: 1 compile error\r\n```\r\nYou can use brackets:\r\n```sh\r\n$ jq &#39;.components[&quot;1&quot;][0].x&#39; file.json\r\n14\r\n```",
                "title": "Could not able to penetrate array object name which is in number in jq"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1646761993,
                "creation_date": 1646761993,
                "answer_id": 71399482,
                "question_id": 71399346,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "`.components` is an object, not an array, thus the field names are strings, not numbers (as an arrays keys would be). Yet, you can have numbers (in strings) as object filed names, but you have to treat them as strings.\r\n~~~sh\r\njq &#39;.components[&quot;1&quot;]&#39;\r\n# or\r\njq &#39;.components.&quot;1&quot;&#39;\r\n~~~\r\n~~~json\r\n[\r\n  {\r\n    &quot;x&quot;: 14,\r\n    &quot;y&quot;: 15\r\n  },\r\n  {\r\n    &quot;A&quot;: 5,\r\n    &quot;B&quot;: 6\r\n  }\r\n]\r\n~~~\r\n[Demo](https://jqplay.org/s/MWM-M9Owan)\r\n\r\nIn contrast, `.components[&quot;1&quot;]` is an array and you can access its elements by numbers.\r\n~~~sh\r\njq &#39;.components[&quot;1&quot;][1]&#39;\r\n# or\r\njq &#39;.components.&quot;1&quot;[1]&#39;\r\n~~~\r\n~~~json\r\n{\r\n  &quot;A&quot;: 5,\r\n  &quot;B&quot;: 6\r\n}\r\n~~~\r\n[Demo](https://jqplay.org/s/x6wqll8U6J)\r\n\r\nTherefore, this should be what you are trying to do:\r\n~~~sh\r\njq &#39;.components.&quot;1&quot;[ ].x&#39;\r\n~~~\r\n~~~json\r\n14\r\nnull\r\n~~~\r\n[Demo](https://jqplay.org/s/GOk211ZJX-)",
                "title": "Could not able to penetrate array object name which is in number in jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1646762562,
        "creation_date": 1646761394,
        "last_edit_date": 1646761543,
        "question_id": 71399346,
        "body_markdown": "    {\r\n    \t&quot;components&quot;: {\r\n    \t\t&quot;1&quot;: [{\r\n    \t\t\t\t&quot;x&quot;: 14,\r\n    \t\t\t\t&quot;y&quot;: 15\r\n    \t\t\t},\r\n    \t\t\t{\r\n    \t\t\t\t&quot;A&quot;: 5,\r\n    \t\t\t\t&quot;B&quot;: 6\r\n    \t\t\t}\r\n    \t\t]\r\n    \t}\r\n    }\r\n \r\nWhen I try to access this json via `jq` command. I&#39;m getting an error stating cannot iterate over null (null).\r\n\r\nIf I change that object array ( `&quot;1&quot;` to alphabet say `&quot;X&quot;`) then it is working fine.\r\n    \r\nCould you guide me what i&#39;m doing wrong here.**",
        "link": "https://stackoverflow.com/questions/71399346/could-not-able-to-penetrate-array-object-name-which-is-in-number-in-jq",
        "title": "Could not able to penetrate array object name which is in number in jq"
    },
    {
        "tags": [
            "select",
            "null",
            "jq",
            "is-empty"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1646796957,
                "creation_date": 1646796957,
                "answer_id": 71404028,
                "question_id": 71403976,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If a part of a filter produces `empty`, it will suck in everything that is compund to it.\r\n\r\nSolution: Don&#39;t let it produce `empty`. One way would be to give the `select` filter an alternative: `select(.Key==&quot;hash&quot;) // null`\r\n\r\n~~~sh\r\njq &#39;{&quot;name&quot;: .Name, &quot;hash&quot;: (.Tags[] | select(.Key==&quot;hash&quot;) // null | .Value)}&#39;\r\n~~~\r\n~~~json\r\n{\r\n  &quot;name&quot;: &quot;NAME&quot;,\r\n  &quot;hash&quot;: null\r\n}\r\n~~~\r\n[Demo](https://jqplay.org/s/sWVjUpH-xz)",
                "title": "Unexpected action of jq select filter"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1646814681,
        "creation_date": 1646796346,
        "last_edit_date": 1646814681,
        "question_id": 71403976,
        "body_markdown": "I have been using jq for quite a while, but some behaviour today has surprised me:\r\n\r\nI expected this:\r\n\r\n     echo &#39;{&quot;Name&quot;:&quot;NAME&quot;,&quot;Tags&quot;:[{&quot;Key&quot;:&quot;KEY&quot;,&quot;Value&quot;:&quot;HASH&quot;}]}&#39; \\\r\n     | jq &#39;{&quot;name&quot;: .Name, &quot;hash&quot;: (.Tags[]|select(.Key==&quot;hash&quot;)|.Value)}&#39;\r\n\r\nto produce this:\r\n\r\n    {\r\n       &quot;name&quot;: &quot;NAME&quot;,\r\n       &quot;hash&quot;: null\r\n    }\r\n\r\nbut instead, it filters out the entire object from the output completely. \r\n\r\nAs a sanity check changing the filter to a value that does match as follows::\r\n\r\n     echo &#39;{&quot;Name&quot;:&quot;NAME&quot;,&quot;Tags&quot;:[{&quot;Key&quot;:&quot;KEY&quot;,&quot;Value&quot;:&quot;HASH&quot;}]}&#39; \\\r\n    | jq &#39;{&quot;name&quot;: .Name, &quot;hash&quot;: (.Tags[]|select(.Key==&quot;KEY&quot;)|.Value)}&#39;\r\n\r\nproduces the expected output:\r\n\r\n    {\r\n       &quot;name&quot;: &quot;NAME&quot;,\r\n       &quot;hash&quot;: &quot;HASH&quot;\r\n    }\r\n\r\nThe output of the first case, `select(.Key==&quot;hash&quot;)`, is surprising to me since the select filter is meant to be acting on the stream produced by .Tags[] and not the entire input stream.\r\n\r\nHow do I express what I want to express, which is if there is no matching Tag, the &quot;hash&quot; property of the output object should be set to null?\r\n\r\nI am using jq 1.6 on OSX\r\n\r\n\r\n  ",
        "link": "https://stackoverflow.com/questions/71403976/unexpected-action-of-jq-select-filter",
        "title": "Unexpected action of jq select filter"
    },
    {
        "tags": [
            "macos",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 92315,
                    "reputation": 213831,
                    "user_id": 253056,
                    "user_type": "registered",
                    "accept_rate": 88,
                    "profile_image": "https://www.gravatar.com/avatar/1977cbe0ac5ffec4f6ee5ee24363988a?s=256&d=identicon&r=PG",
                    "display_name": "Paul R",
                    "link": "https://stackoverflow.com/users/253056/paul-r"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1646818295,
                "post_id": 71406984,
                "comment_id": 126215775,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 18837983,
                    "reputation": 47,
                    "user_id": 13740202,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/98ad840e4240fe261a68ed44bb242b1d?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Mursel A",
                    "link": "https://stackoverflow.com/users/13740202/mursel-a"
                },
                "reply_to_user": {
                    "account_id": 92315,
                    "reputation": 213831,
                    "user_id": 253056,
                    "user_type": "registered",
                    "accept_rate": 88,
                    "profile_image": "https://www.gravatar.com/avatar/1977cbe0ac5ffec4f6ee5ee24363988a?s=256&d=identicon&r=PG",
                    "display_name": "Paul R",
                    "link": "https://stackoverflow.com/users/253056/paul-r"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1646913979,
                "post_id": 71406984,
                "comment_id": 126243971,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 5584988,
                    "reputation": 1692,
                    "user_id": 4425676,
                    "user_type": "registered",
                    "accept_rate": 29,
                    "profile_image": "https://i.sstatic.net/KL6HZ.jpg?s=256",
                    "display_name": "Jerrod Horton",
                    "link": "https://stackoverflow.com/users/4425676/jerrod-horton"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1695298274,
                "post_id": 71406984,
                "comment_id": 136007514,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1646818967,
                "creation_date": 1646818967,
                "answer_id": 71407253,
                "question_id": 71406984,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You&#39;ll need to let your Mac know that you trust the developer of `jq-osx-amd64`\r\n\r\n\r\n----------\r\n\r\n\r\nAfter the *cannot be opened because the developer cannot be verified*, follow these steps:\r\n\r\n1. Open settings\r\n2. Go to `Security &amp; Privacy`\r\n3. Go to the `General` Tab\r\n4. You&#39;ll see something like \r\n   &gt;`jq-osx-amd64` was blocked from use bevause it is not from an identified developer  \r\n\r\n    To Allow this, press the `Allow Anyway` button\r\n\r\n    [![enter image description here][1]][1]\r\n5. Invoke `jq-osx-amd64` once again from your terminal\r\n6. Accept the `unknown developer` popup by pressing `Open`  \r\n    [Picture showing popup][2]\r\n7. Invoke `jq-osx-amd64` once again\r\n    \r\n\r\n\r\n  [1]: https://i.sstatic.net/4XLah.png\r\n  [2]: https://i.sstatic.net/xeYR7.png",
                "title": "How to instal JQ without homebrew?"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": -1,
                "last_activity_date": 1646868571,
                "last_edit_date": 1646868571,
                "creation_date": 1646832273,
                "answer_id": 71410075,
                "question_id": 71406984,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You could use [tag:macports] or 0install or [tag:asdf-vm] or ...\r\nSee https://github.com/stedolan/jq/wiki/Installation",
                "title": "How to instal JQ without homebrew?"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1646919412,
                "last_edit_date": 1646919412,
                "creation_date": 1646914162,
                "answer_id": 71423932,
                "question_id": 71406984,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I found the answer , you need to run this command :           \r\n\r\n    xattr -dr com.apple.quarantine /usr/local/bin/jq\r\n\r\nBut might want to change file name with this command : \r\n\r\n    mv /usr/local/bin/jq-oxs-amd64 /usr/local/bin/jq",
                "title": "How to instal JQ without homebrew?"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1708980115,
                "creation_date": 1708980115,
                "answer_id": 78063750,
                "question_id": 71406984,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Since the other fine answers here involve bypassing Apple&#39;s security for unknown executables, it&#39;s a good idea to **compare the SHA checksum** of the jq binary that you download to the published checksum in Github.  \r\n\r\n`shasum -a 256 &lt;downloaded jq&gt;` should generate a value that you can find in the most recent sha256 page (currently \r\nhttps://github.com/jqlang/jq/blob/master/sig/v1.7.1/sha256sum.txt ) \r\n\r\nFor example,\r\n\r\n```\r\n% shasum -a 256 jq-macos-arm64\r\n0bbe619e663e0de2c550be2fe0d240d076799d6f8a652b70fa04aea8a8362e8a  jq-macos-arm64\r\n```\r\nmatches https://github.com/jqlang/jq/blob/913b26469f47351a9f75a1bc4145f45421115e37/sig/v1.7.1/sha256sum.txt#L22C1-L22C81 ",
                "title": "How to instal JQ without homebrew?"
            }
        ],
        "is_answered": true,
        "answer_count": 4,
        "score": 1,
        "last_activity_date": 1708980115,
        "creation_date": 1646817799,
        "last_edit_date": 1646818515,
        "question_id": 71406984,
        "body_markdown": "I use Mac , how can I install JQ without home brew ? I installed &#39;jq-osx-amd64 &#39;and executed this comments :\r\n```none\r\nchmod +x ~/Downloads/*jq-osx-amd64* cp ~/Downloads/jq-osx-amd64 /usr/local/bin\r\n```\r\nAfter that when I try the open/execute jq-osx-amd64 the terminal pop up with :\r\n\r\n&gt; “jq-osx-amd64” cannot be opened because the developer cannot be verified.\r\n\r\nI opened the system preferences and allowed it but still doesn’t accept the permission and I couldn’t use the jq. Any help will be appreciated . Thank you",
        "link": "https://stackoverflow.com/questions/71406984/how-to-instal-jq-without-homebrew",
        "title": "How to instal JQ without homebrew?"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1646836989,
                "creation_date": 1646836989,
                "answer_id": 71411139,
                "question_id": 71410229,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "[![enter image description here][1]][1]\r\n\r\n\r\n  [1]: https://i.sstatic.net/hbGc1.png\r\n\r\nThere is error in the json (red highlighted commas)(that commas are not needed)&lt;br&gt;\r\n&lt;br&gt;\r\n&lt;hr&gt;\r\n\r\n```bash\r\n$\r\n$ cat j.json | jq -r &#39;.data[] | &quot;\\(.name)█\\(.mac)█\\(.ip)█\\(._id)&quot;&#39;\r\nTest-Accesspoint█ff:ec:ff:89:ff:58█10.19.31.120█61a0da77f730e404af0edc3c\r\n$ cat j.json\r\n{\r\n  &quot;meta&quot;: {\r\n    &quot;rc&quot;: &quot;ok&quot;\r\n  },\r\n  &quot;data&quot;: [\r\n    {\r\n      &quot;_id&quot;: &quot;61a0da77f730e404af0edc3c&quot;,\r\n      &quot;ip&quot;: &quot;10.19.31.120&quot;,\r\n      &quot;mac&quot;: &quot;ff:ec:ff:89:ff:58&quot;,\r\n      &quot;name&quot;: &quot;Test-Accesspoint&quot;\r\n    }\r\n  ]\r\n}\r\n$\r\n\r\n```\r\n\r\nIf the api have given this json you should probably edit it, before piping it into ```jq``` [maybe with ```sed``` or something like it]",
                "title": "Using jq with an unknown amount of arguments from shell script?"
            },
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1646943781,
                "last_edit_date": 1646943781,
                "creation_date": 1646856243,
                "answer_id": 71415377,
                "question_id": 71410229,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "&gt; I want to pass $@ to jq.\r\n\r\nThere are actually many ways to do this, but the simplest might be using the `--args` command-line option, as illustrated here:\r\n\r\nFile: check\r\n```\r\n#/bin/bash\r\necho &quot;${@}&quot;\r\njq -n &#39;$ARGS.positional&#39; --args &quot;${@}&quot; \r\n```\r\n\r\nExample run:\r\n```\r\n./check 1 2 3\r\n1 2 3\r\n[\r\n  &quot;1&quot;,\r\n  &quot;2&quot;,\r\n  &quot;3&quot;\r\n]\r\n```\r\n\r\n**Projection**\r\n\r\nHere&#39;s an example that might be closer to what you&#39;re looking for.\r\nUsing your sample JSON:\r\n\r\nFile: check2\r\n```\r\n#/bin/bash\r\njq -r &#39;\r\n  def project($array):\r\n    . as $in | reduce $array[] as $k ([]; . + [$in[$k]]);\r\n  $ARGS.positional,\r\n  (.data[] | project($ARGS.positional))\r\n  | @csv\r\n&#39; input.json --args &quot;${@}&quot; \r\n```\r\n```\r\n./check2 name mac\r\n&quot;name&quot;,&quot;mac&quot;\r\n&quot;Test-Accesspoint&quot;,&quot;ff:ec:ff:89:ff:58&quot;\r\n\r\n```\r\n\r\n",
                "title": "Using jq with an unknown amount of arguments from shell script?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1646943781,
        "creation_date": 1646833104,
        "last_edit_date": 1646850751,
        "question_id": 71410229,
        "body_markdown": "I&#39;m about to lose my mind working with jq for the first time today. I&#39;ve tried every ever so dirty way to make this work somehow. Let&#39;s get down to business:\r\n\r\nI&#39;m trying to further develop the pretty barebones API for Unifi Controllers for some use cases:\r\nhttps://dl.ui.com/unifi/6.0.41/unifi_sh_api\r\n\r\nHere&#39;s some mock up data (the real json data is thousands of lines):\r\n\r\n    {\r\n      &quot;meta&quot;: {\r\n        &quot;rc&quot;: &quot;ok&quot;\r\n      },\r\n      &quot;data&quot;: [\r\n        {\r\n          &quot;_id&quot;: &quot;61a0da77f730e404af0edc3c&quot;,\r\n          &quot;ip&quot;: &quot;10.19.31.120&quot;,\r\n          &quot;mac&quot;: &quot;ff:ec:ff:89:ff:58&quot;,\r\n          &quot;name&quot;: &quot;Test-Accesspoint&quot;\r\n        }\r\n      ]\r\n    }\r\n\r\nHere is my advancedapi.sh\r\n\r\n    #!/bin/bash\r\n    source unifiapi.sh\r\n    unifi_login 1&gt;dev/null\r\n\r\n    if [ &quot;$1&quot; ];\r\n    then\r\n    command=$1\r\n    shift\r\n    else\r\n    echo &quot;Please enter command&quot;\r\n    exit\r\n    fi\r\n    #jq -r &#39;.data[] | &quot;\\(.name),\\(.mac)&quot;&#39;\r\n\r\n    assembleKeys(){\r\n    c=&quot;0&quot;\r\n    seperator=&quot;;&quot;\r\n    keys=$(for i in &quot;$@&quot;\r\n    do\r\n            c=$(expr $c + 1)\r\n            if [ $c -gt 1 ];\r\n            then\r\n                    echo -n &quot;${seperator}\\(.${i})&quot;\r\n            else\r\n                    echo -n &quot;\\(.${i})&quot;\r\n            fi\r\n    done\r\n    echo)\r\n    }\r\n    \r\n    assembleJQ(){\r\n    c=0\r\n    jq=$(echo -en &#39;jq -r -j \\x27.data[] | &#39;\r\n    for i in &quot;$@&quot;\r\n    do\r\n            if [ &quot;$c&quot; != &quot;0&quot; ];\r\n            then\r\n            echo -en &quot;,\\x22 \\x22,&quot;\r\n            fi\r\n    c=1\r\n    echo -en &quot;.$i&quot;\r\n    done\r\n    echo -en &quot;,\\x22\\\\\\n\\x22\\x27&quot;)\r\n    echo &quot;$jq&quot;\r\n    }\r\n    \r\n    \r\n    getDeviceKeys(){\r\n    assembleJQ &quot;$@&quot;\r\n    \r\n    \r\n    \r\n    #unifi_list_devices | jq -r &#39;.data[]&#39; | jq -r &quot;${keys}&quot;\r\n    #export keys=mac\r\n    #export second=name\r\n    #unifi_list_devices | jq -r -j --arg KEYS &quot;$keys&quot; --arg SECOND &quot;$second&quot; &#39;.data[] | .[$KEYS],&quot; &quot;,.[$SECOND],&quot;\\n&quot;&#39;\r\n    \r\n    unifi_list_devices | $jq\r\n    #unifi_list_devices | jq -r -j &#39;.data[] | .mac,&quot; &quot;,.name,&quot;\\n&quot;&#39;\r\n    }\r\n    \r\n    &quot;$command&quot; $@\r\n\r\nUsers should be able to call any function from the API with as many arguments as they want.\r\nSo basically this:\r\n\r\n    #export keys=mac\r\n    #export second=name\r\n    #unifi_list_devices | jq -r -j --arg KEYS &quot;$keys&quot; --arg SECOND &quot;$second&quot; &#39;.data[] | .[$KEYS],&quot; &quot;,.[$SECOND],&quot;\\n&quot;&#39;\r\n\r\nwhich works, but only with a limited number of arguments. I want to pass $@ to jq.\r\n\r\nI&#39;m trying to get the name and mac-address of a device by calling:\r\n\r\n    ./advancedapi.sh getDeviceKeys mac name\r\nthis should return the mac-address and name of the device. But it only gives me this:\r\n\r\n    jq -r -j &#39;.data[] | .mac,&quot; &quot;,.name,&quot;\\n&quot;&#39;\r\n    jq: error: syntax error, unexpected INVALID_CHARACTER, expecting $end (Unix shell quoting issues?) at &lt;top-level&gt;, line 1:\r\n    &#39;.data[]\r\n    jq: 1 compile error\r\n\r\nThe top-most line being the jq command, which works perfectly fine when called manually.\r\n\r\nThe assembleKeys function was my attempt at generating a string that looks like this:\r\n\r\n    jq -r &#39;.data[] | &quot;\\(.name),\\(.mac)&quot;&#39;\r\n\r\n\r\nCan anyone explain to me, preferably in-depth, how to do this? I&#39;m going insane here!\r\n\r\nThanks!",
        "link": "https://stackoverflow.com/questions/71410229/using-jq-with-an-unknown-amount-of-arguments-from-shell-script",
        "title": "Using jq with an unknown amount of arguments from shell script?"
    },
    {
        "tags": [
            "json",
            "bash",
            "shell",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 3,
                "creation_date": 1646840511,
                "post_id": 71411942,
                "comment_id": 126224269,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1143565,
                    "reputation": 535973,
                    "user_id": 1126841,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/fa05233b2357f8d11c22ef4cfc7bb85c?s=256&d=identicon&r=PG",
                    "display_name": "chepner",
                    "link": "https://stackoverflow.com/users/1126841/chepner"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1646840601,
                "post_id": 71411942,
                "comment_id": 126224317,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1143565,
                    "reputation": 535973,
                    "user_id": 1126841,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/fa05233b2357f8d11c22ef4cfc7bb85c?s=256&d=identicon&r=PG",
                    "display_name": "chepner",
                    "link": "https://stackoverflow.com/users/1126841/chepner"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1646840654,
                "post_id": 71411942,
                "comment_id": 126224346,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 331012,
                    "reputation": 2905,
                    "user_id": 655436,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/98da4e7757d5f0e8596fd832bebee3d0?s=256&d=identicon&r=PG",
                    "display_name": "fukanchik",
                    "link": "https://stackoverflow.com/users/655436/fukanchik"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1646840688,
                "post_id": 71411942,
                "comment_id": 126224359,
                "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": 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": 1646852552,
                "post_id": 71411942,
                "comment_id": 126228927,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": -1,
                "last_activity_date": 1646841128,
                "creation_date": 1646841128,
                "answer_id": 71412176,
                "question_id": 71411942,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "`jq` provides “object multiplication” feature:\r\n\r\n    jq &#39;. * input&#39; file1.json file2.json\r\n\r\nSee the manual:\r\n\r\n&gt; # Multiplication, division, modulo: *, /, and %\r\n&gt; […]\r\n&gt;\r\n&gt; Multiplying two objects will merge them recursively: this works like addition but if both objects contain a value for the same key, and the values are objects, the two are merged with the same strategy.\r\n",
                "title": "How to merge two JSON files using jq?"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1646841128,
        "creation_date": 1646840131,
        "last_edit_date": 1646840433,
        "question_id": 71411942,
        "body_markdown": "I need to merge two JSON files into one. The requirement is to replace values of keys existing in both files by values from second file. And add keys doesn&#39;t exist in first should be appended to the output JSON.\r\n\r\nIs it possible to use `jq` to perform this operation?\r\n\r\nFirst JSON:\r\n```\r\n{\r\n    &quot;foo&quot;: &quot;bar&quot;,\r\n    &quot;aaa&quot;: &quot;aaa&quot;,\r\n    &quot;count&quot;: 0\r\n}\r\n```\r\n\r\nSecond JSON:\r\n```\r\n{\r\n    &quot;bbb&quot;: &quot;bbb&quot;,\r\n    &quot;count&quot;: 1\r\n}\r\n```\r\n\r\nExpected output:\r\n```\r\n{\r\n    &quot;foo&quot;: &quot;bar&quot;,\r\n    &quot;aaa&quot;: &quot;aaa&quot;,\r\n    &quot;count&quot;: 1,\r\n    &quot;bbb&quot;: &quot;bbb&quot;\r\n}\r\n```\r\n",
        "link": "https://stackoverflow.com/questions/71411942/how-to-merge-two-json-files-using-jq",
        "title": "How to merge two JSON files using jq?"
    },
    {
        "tags": [
            "json",
            "jq",
            "key-value"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1646895976,
                "last_edit_date": 1646895976,
                "creation_date": 1646893281,
                "answer_id": 71419673,
                "question_id": 71418708,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You could use `with_entries` (which itself is a shortcut to `to_entries | map(…) | from_entries`) to deconstruct each field into a key-value pair, manipulate to your liking with access to key and value, and reconstruct it again.\r\nThe inner filter saves the key into a variable, descends into each value&#39;s `fruit` and updates `|=` its name, according to the key and its cuurent name `.`. \r\n~~~sh\r\njq &#39;with_entries(.key as $key | .value[].fruit |= $key + &quot;_&quot; + .)&#39;\r\n~~~\r\n~~~json\r\n{\r\n  &quot;red&quot;: [\r\n    {\r\n      &quot;fruit&quot;: &quot;red_apple&quot;,\r\n      &quot;grows_on&quot;: &quot;tree&quot;\r\n    },\r\n    {\r\n      &quot;fruit&quot;: &quot;red_raspberry&quot;,\r\n      &quot;grows_on&quot;: &quot;vine&quot;\r\n    }\r\n  ],\r\n  &quot;green&quot;: [\r\n    {\r\n      &quot;fruit&quot;: &quot;green_apple&quot;,\r\n      &quot;grows_on&quot;: &quot;tree&quot;\r\n    },\r\n    {\r\n      &quot;fruit&quot;: &quot;green_gooseberry&quot;,\r\n      &quot;grows_on&quot;: &quot;bush&quot;\r\n    }\r\n  ]\r\n}\r\n~~~\r\n[Demo](https://jqplay.org/s/6UA-sMYk32)\r\n\r\nIf you only want to update a top-level object&#39;s fields named `red` or `green`, and the value array&#39;s object item&#39;s field named `fruit` (this is what your checks are doing), you can employ `objects` (which is a shortcut to `select(type == &quot;object&quot;)`) in combination with appropriate checks.\r\n~~~sh\r\njq &#39;\r\n  objects |= with_entries(.key as $key | if IN(&quot;red&quot;, &quot;green&quot;; $key) then\r\n    (.value[] | objects.fruit // empty) |= $key + &quot;_&quot; + . \r\n  else . end)\r\n&#39;\r\n~~~\r\n[Demo](https://jqplay.org/s/claeVxFKXj)",
                "title": "Modify value in JSON with jq: prepend value with name of parent key"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1646895976,
        "creation_date": 1646885074,
        "question_id": 71418708,
        "body_markdown": "The idea is that I have an object that is part of an array that itself is the value of a parent key. I want to use the value of that key to alter the values in the original child object. \r\n\r\nThis is what I came up with, and while it works, I can&#39;t help but think there is a better way. It&#39;s so unintuitive, it took me at least 3 hours of trial end error to nail down the syntax and remove errors. \r\n\r\n```\r\necho &#39;{&quot;red&quot;: [{&quot;fruit&quot;: &quot;apple&quot;, &quot;grows_on&quot;:&quot;tree&quot;}, {&quot;fruit&quot;:&quot;raspberry&quot;,&quot;grows_on&quot;:&quot;vine&quot;}], &quot;green&quot;: [{&quot;fruit&quot;: &quot;apple&quot;, &quot;grows_on&quot;:&quot;tree&quot;}, {&quot;fruit&quot;:&quot;gooseberry&quot;,&quot;grows_on&quot;:&quot;bush&quot;}]}&#39; | \r\njq &#39;\r\n  walk(\r\n    if type==&quot;object&quot; then \r\n      with_entries(\r\n        if .key == &quot;red&quot; then\r\n          with_entries(\r\n            walk(\r\n              if type==&quot;object&quot; then \r\n                with_entries(\r\n                  if .key==&quot;fruit&quot; then \r\n                    .value= &quot;red&quot; + &quot;_&quot; + .value \r\n                  else . end\r\n                ) \r\n              else . end\r\n            )\r\n          )\r\n        elif .key == &quot;green&quot; then\r\n          with_entries(\r\n            walk(\r\n              if type==&quot;object&quot; then \r\n                with_entries(\r\n                  if .key==&quot;fruit&quot; then \r\n                    .value= &quot;green&quot; + &quot;_&quot; + .value \r\n                  else . end\r\n                ) \r\n              else . end\r\n            )\r\n          ) \r\n        else . end\r\n      )\r\n    else . end\r\n  )&#39;\r\n\r\n{\r\n  &quot;red&quot;: [\r\n    {\r\n      &quot;fruit&quot;: &quot;red_apple&quot;,\r\n      &quot;grows_on&quot;: &quot;tree&quot;\r\n    },\r\n    {\r\n      &quot;fruit&quot;: &quot;red_raspberry&quot;,\r\n      &quot;grows_on&quot;: &quot;vine&quot;\r\n    }\r\n  ],\r\n  &quot;green&quot;: [\r\n    {\r\n      &quot;fruit&quot;: &quot;green_apple&quot;,\r\n      &quot;grows_on&quot;: &quot;tree&quot;\r\n    },\r\n    {\r\n      &quot;fruit&quot;: &quot;green_gooseberry&quot;,\r\n      &quot;grows_on&quot;: &quot;bush&quot;\r\n    }\r\n  ]\r\n}\r\n```",
        "link": "https://stackoverflow.com/questions/71418708/modify-value-in-json-with-jq-prepend-value-with-name-of-parent-key",
        "title": "Modify value in JSON with jq: prepend value with name of parent key"
    },
    {
        "tags": [
            "bash",
            "variables",
            "jq",
            "expansion"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 983403,
                    "reputation": 23,
                    "user_id": 1002494,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d79fa0336d605548be2db8bcc89786bc?s=256&d=identicon&r=PG",
                    "display_name": "Stefan Kraxberger",
                    "link": "https://stackoverflow.com/users/1002494/stefan-kraxberger"
                },
                "reply_to_user": {
                    "account_id": 2244313,
                    "reputation": 17526,
                    "user_id": 3387716,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/bcad6c8d7a64b0e16fd59996e3835ee9?s=256&d=identicon&r=PG",
                    "display_name": "Fravadona",
                    "link": "https://stackoverflow.com/users/3387716/fravadona"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1646906770,
                "post_id": 71421978,
                "comment_id": 126241352,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2244313,
                    "reputation": 17526,
                    "user_id": 3387716,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/bcad6c8d7a64b0e16fd59996e3835ee9?s=256&d=identicon&r=PG",
                    "display_name": "Fravadona",
                    "link": "https://stackoverflow.com/users/3387716/fravadona"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1646907283,
                "post_id": 71421978,
                "comment_id": 126241542,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 32384,
                    "reputation": 127026,
                    "user_id": 89817,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/df253c3b6533949ea94f31f328f3e769?s=256&d=identicon&r=PG",
                    "display_name": "Gordon Davisson",
                    "link": "https://stackoverflow.com/users/89817/gordon-davisson"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1646909377,
                "post_id": 71421978,
                "comment_id": 126242287,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 983403,
                    "reputation": 23,
                    "user_id": 1002494,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d79fa0336d605548be2db8bcc89786bc?s=256&d=identicon&r=PG",
                    "display_name": "Stefan Kraxberger",
                    "link": "https://stackoverflow.com/users/1002494/stefan-kraxberger"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1646909770,
                "post_id": 71421978,
                "comment_id": 126242435,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1646933640,
                "creation_date": 1646933640,
                "answer_id": 71428442,
                "question_id": 71421978,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "\r\nProgrammatically producing code that is being executed (here, a bash script producing and running a jq filter) is generally considered not only less readable (what happens in jq is very fragmented), more error-prone (this has actually brought you here), but also a principal safety risk (in a complex chain of dependencies you might not have full control over what is being executed in the end).\r\n\r\nTherefore, you should try to modify your approach in a way that the only thing variable is the data that is being input, while the code is formulated in a way that it can react on the varying data but by itself is just a literal invariable string.\r\n\r\nGiven your sample (I presume, the code above is just a small snippet relevant to the actual question, so let this be more a hinting guide rather than a general solution), you are trying to reduce an input stream of JSON objects from `file.json` by comparing their `words` field&#39;s numeric content to a list of numbers stored in the bash array `wordDupArray`. More specifically, given a single input object, you want to pass it through to the output if `.words` holds a number that is not present in a list of numbers provided, or else drop it if the number *is* present in the list. Let&#39;s implement that.\r\n\r\nIf jq is given a stream of objects, it will process them one by one, so breaking down the input stream to a single object already happens automatically. For the comparison part, jq needs to be given the list of numbers from the bash array. As jq is a JSON processor, it&#39;d be best to provide the list as a JSON array, thus the task at hand is to convert the bash array into a JSON array.\r\n\r\nThere are many ways to accomplish this. As the array contains only numbers, you can cash in on the fact that a number by itself is already a valid JSON document, so one approach could be to have another jq call which takes a stream of numbers and outputs them as a JSON-ecoded array using the `--slurp` (or `-s`) option, and to then, back in bash, store that output in a variable and provide it to the actual jq call using the `--argjson` option, which lets you access that JSON array as a variable inside jq.\r\n\r\n~~~sh\r\nwordDupArray=(6 1173 1 8 9 27)                   # dummy init of your bash array\r\njsonarray=&quot;$(jq -sc &lt;&lt;&lt; &quot;${wordDupArray[@]}&quot;)&quot;   # will contain &quot;[6,1173,1,8,9,27]&quot;\r\njq --argjson list &quot;$jsonarray&quot; &#39; … jq filter using the array in $list … &#39; file.json\r\n~~~\r\n\r\nFor the sake of variation, another way could be to use the `--slurpfile` option which by itself already combines a stream of JSON documents to a JSON array, and similarly lets you access that array using a variable. But as a major difference, it requires the document to be provided as a file rather than a JSON-encoded string. This can be mimicked by using [Process Substitution](https://www.gnu.org/software/bash/manual/html_node/Process-Substitution.html) in bash:\r\n\r\n~~~sh\r\nwordDupArray=(6 1173 1 8 9 27)                   # dummy init of your bash array\r\njq --slurpfile list &lt;(cat &lt;&lt;&lt; &quot;${wordDupArray[@]}&quot;) &#39; … using $list … &#39; file.json\r\n~~~\r\n\r\nFor the main task, filtering the input objects from `file.json` according to a match in the `$list` array, you can check for inequality just as you did before but now using the array&#39;s items `$list[]` instead, and have the `all` [function](https://stedolan.github.io/jq/manual/#all%2Call%28condition%29%2Call%28generator%3Bcondition%29) check whether the given condition holds for *all* items or not (all hold true means none did match).\r\n\r\n~~~sh\r\njq --slurpfile list &lt;(cat &lt;&lt;&lt; &quot;${wordDupArray[@]}&quot;) \\\r\n  &#39;select([.words != $list[]] | all)&#39; file.json\r\n~~~\r\n[Demo](https://jqplay.org/s/COPG8PrW02)\r\n\r\nAgain, for the sake of variation, you could also use the `IN` [function](https://stedolan.github.io/jq/manual/#SQL-StyleOperators) which returns whether or not a given value appears in a given stream (not to be confused with the `in` [function](https://stedolan.github.io/jq/manual/#in) which is for checking keys in objects), and the `not` [function](https://stedolan.github.io/jq/manual/#and%2For%2Fnot) to `select` the cases where a match could *not* be found.\r\n\r\n~~~sh\r\njq --slurpfile list &lt;(cat &lt;&lt;&lt; &quot;${wordDupArray[@]}&quot;) \\\r\n  &#39;select(.words | IN($list[]) | not)&#39; file.json\r\n~~~\r\n[Demo](https://jqplay.org/s/u6lsHxqyB4)\r\n\r\nAll in all, these solutions are more stable and robust as the code is invariable and self-contained, also more comprehensible as a contiguous code is easier to follow, and even in the case of a failure you can expect more convenient error messages than the generic &quot;compile error&quot; which is even harder to trace if the actual code executed is unknown because of its volatility.",
                "title": "jq variable substituion works in shell but not in script"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1646933640,
        "creation_date": 1646905479,
        "last_edit_date": 1646909832,
        "question_id": 71421978,
        "body_markdown": "The following command works in the shell just fine, but when executed via an script it doesn&#39;t. What am I missing.\r\n\r\n    jsonSelectWords=&#39;select(.words!=6) | select(.words!=1173) | select(.words!=1) | select(.words!=8) | select(.words!=9) | select(.words!=27)&#39;\r\n\r\n    cat file.json | jq &quot;$jsonSelectWords&quot;\r\n\r\nIn the script the select statement is created dynamically, thus I am not able to directly provide it. \r\n\r\n    input=file.json\r\n\r\n    local jsonSelectWords=&quot;&#39;&quot;\r\n    for word in &quot;${wordDupArray[@]}&quot;\r\n    do\r\n    \tjsonSelectWords+=&quot;select(.words!=$word) | &quot;\r\n    done\r\n    jsonSelectWords=&quot;${jsonSelectWords::-3}&quot;\r\n    jsonSelectWords+=&quot;&#39;&quot;\r\n    \r\n    \r\n    cat $input | jq &quot;$jsonSelectWords&quot;\r\n\r\nThe execution of the last line gives the following error.\r\n\r\n    jq: error: syntax error, unexpected INVALID_CHARACTER, expecting $end (Unix shell quoting issues?) at &lt;top-level&gt;, line 1:\r\n\r\n    &#39;select(.words!=6) | select(.words!=1173) | select(.words!=1) | select(.words!=8) | select(.words!=9) | select(.words!=27)&#39;\r\n\r\n    jq: 1 compile error\r\n\r\nAny hints. It tried different variations as well as the whole statement in `$(cat $input | jq &quot;$jsonSelectWords&quot;)`\r\n\r\nI have also used the following\r\n`cat $input | jq --args JSW &quot;$jsonSelectWords&quot; &#39;$JSW&#39;` (with single quotes removed from the initial string, with `&#39;[$JSW]&#39;` and so on). This just outputs the content of jsonSelectWords.\r\n\r\nThe following lines are examples of the content of `file.json` aka `$input`.\r\n\r\n    {&quot;timestamp&quot;:&quot;2022-03-09T12:30:23.329630917+01:00&quot;,&quot;scheme&quot;:&quot;http&quot;,&quot;port&quot;:&quot;80&quot;,&quot;path&quot;:&quot;/&quot;,&quot;body-sha256&quot;:&quot;0bfc0bdeb920ce4701f130e6e6a33c8aaf558fae44c7479cc1629930cb0f4535&quot;,&quot;header-sha256&quot;:&quot;d9522b92bb09e71b719804f522f0b3b49aa77974c8d79e644fb45a7b3327f73e&quot;,&quot;a&quot;:[&quot;81.91.86.14&quot;],&quot;url&quot;:&quot;http://01.akce.omv.com:80&quot;,&quot;input&quot;:&quot;01.akce.omv.com&quot;,&quot;location&quot;:&quot;https://01.akce.omv.com/&quot;,&quot;webserver&quot;:&quot;openresty&quot;,&quot;content-type&quot;:&quot;text/html&quot;,&quot;method&quot;:&quot;GET&quot;,&quot;host&quot;:&quot;81.91.86.14&quot;,&quot;content-length&quot;:95,&quot;status-code&quot;:301,&quot;response-time&quot;:&quot;194.004475ms&quot;,&quot;failed&quot;:false,&quot;lines&quot;:3,&quot;words&quot;:6}\r\n    {&quot;timestamp&quot;:&quot;2022-03-09T12:30:23.355007661+01:00&quot;,&quot;scheme&quot;:&quot;http&quot;,&quot;port&quot;:&quot;80&quot;,&quot;path&quot;:&quot;/&quot;,&quot;body-sha256&quot;:&quot;d6285599bd6f2851fc17e0244ad212a58d8d539231f804f81b5b98289197afa0&quot;,&quot;header-sha256&quot;:&quot;96884ec058c78d0ea282a2d51be4ce0f5c7bc05d8fe3e8dd8f6fb73dd4fa2cd6&quot;,&quot;a&quot;:[&quot;81.91.86.14&quot;,&quot;40.90.4.7&quot;,&quot;64.4.48.7&quot;,&quot;2603:1061::7&quot;,&quot;2620:1ec:8ec::7&quot;],&quot;url&quot;:&quot;http://09-mail2.akce.omv.com:80&quot;,&quot;input&quot;:&quot;09-mail2.akce.omv.com&quot;,&quot;location&quot;:&quot;https://09-mail2.akce.omv.com/&quot;,&quot;webserver&quot;:&quot;openresty&quot;,&quot;content-type&quot;:&quot;text/html&quot;,&quot;method&quot;:&quot;GET&quot;,&quot;host&quot;:&quot;81.91.86.14&quot;,&quot;content-length&quot;:101,&quot;status-code&quot;:301,&quot;response-time&quot;:&quot;233.377898ms&quot;,&quot;failed&quot;:false,&quot;lines&quot;:3,&quot;words&quot;:6}\r\n    {&quot;timestamp&quot;:&quot;2022-03-09T12:30:23.450849812+01:00&quot;,&quot;scheme&quot;:&quot;http&quot;,&quot;port&quot;:&quot;80&quot;,&quot;path&quot;:&quot;/&quot;,&quot;body-sha256&quot;:&quot;c186820e328bf631a2943f77e52e9e8319ddfefade6d308a2a22ef996176bbe6&quot;,&quot;header-sha256&quot;:&quot;61e4f3139518b49cac86b77a4f9f06da98d53f2eb12dbff574b5a0ea66327478&quot;,&quot;a&quot;:[&quot;81.91.86.14&quot;],&quot;url&quot;:&quot;http://09-server2.akce.omv.com:80&quot;,&quot;input&quot;:&quot;09-server2.akce.omv.com&quot;,&quot;location&quot;:&quot;https://09-server2.akce.omv.com/&quot;,&quot;webserver&quot;:&quot;openresty&quot;,&quot;content-type&quot;:&quot;text/html&quot;,&quot;method&quot;:&quot;GET&quot;,&quot;host&quot;:&quot;81.91.86.14&quot;,&quot;content-length&quot;:103,&quot;status-code&quot;:301,&quot;response-time&quot;:&quot;268.856986ms&quot;,&quot;failed&quot;:false,&quot;lines&quot;:3,&quot;words&quot;:6}\r\n\r\nSolution\r\n--------\r\n    local jsonSelectWords=&quot;&quot;\r\n    for word in &quot;${wordDupArray[@]}&quot;\r\n    do\r\n    \tjsonSelectWords+=&quot;select(.words!=$word) | &quot;\r\n    done\r\n    jsonSelectWords=&quot;${jsonSelectWords::-3}&quot;\r\n    \r\n    cat $input | jq &quot;$jsonSelectWords&quot;",
        "link": "https://stackoverflow.com/questions/71421978/jq-variable-substituion-works-in-shell-but-not-in-script",
        "title": "jq variable substituion works in shell but not in script"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1646934669,
                "creation_date": 1646934669,
                "answer_id": 71428646,
                "question_id": 71428557,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Pull the `del` command up front to include the whole selection as its own filter\r\n~~~sh\r\ndel(.resources[] | select(.type==&quot;google_dns_record_set&quot;).instances[].attributes.timeouts)\r\n~~~\r\n[Demo](https://jqplay.org/s/FIdvIf115i)",
                "title": "select and delete attributes with JQ"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1646934669,
        "creation_date": 1646934222,
        "question_id": 71428557,
        "body_markdown": "# Info\r\n\r\nI have a terraform state file (json) with some deprecated attributes.\r\n\r\nI would like to remove theses deprecated attributes.\r\n\r\nI try to use `jq` and `select()` &amp;&amp; `del()` but did not succeed to get back my full json without the deprecated attribue timeouts.\r\n\r\n# Problem\r\n\r\nHow to get my full json without the attribute `timeouts` for only one type of resources `google_dns_record_set`.\r\n\r\n# Data\r\n\r\n```json\r\n{\r\n  &quot;version&quot;: 4,\r\n  &quot;terraform_version&quot;: &quot;1.0.6&quot;,\r\n  &quot;serial&quot;: 635,\r\n  &quot;lineage&quot;: &quot;6a9c2392-fdae-2b54-adcc-7366f262ffa4&quot;,\r\n  &quot;outputs&quot;: {&quot;test&quot;:&quot;test1&quot;},\r\n  &quot;resources&quot;: [\r\n  {\r\n      &quot;module&quot;: &quot;module.resources&quot;,\r\n      &quot;mode&quot;: &quot;data&quot;,\r\n      &quot;type&quot;: &quot;google_client_config&quot;\r\n  },\r\n  {\r\n      &quot;module&quot;: &quot;module.xxx.module.module1[\\&quot;cluster\\&quot;]&quot;,\r\n      &quot;mode&quot;: &quot;managed&quot;,\r\n      &quot;type&quot;: &quot;google_dns_record_set&quot;,\r\n      &quot;name&quot;: &quot;public_ip_ic_dns&quot;,\r\n      &quot;provider&quot;: &quot;module.xxx.provider[\\&quot;registry.terraform.io/hashicorp/google\\&quot;]&quot;,\r\n      &quot;instances&quot;: [\r\n        {\r\n          &quot;schema_version&quot;: 0,\r\n          &quot;attributes&quot;: {\r\n            &quot;id&quot;: &quot;projects/xxx-xxx/managedZones/xxx--public/rrsets/*.net1.cluster.xxx--public.net.com./A&quot;,\r\n            &quot;managed_zone&quot;: &quot;xxx--public&quot;,\r\n            &quot;name&quot;: &quot;*.net1.cluster.xxx--public.net.com.&quot;,\r\n            &quot;project&quot;: &quot;xxx-xxx&quot;,\r\n            &quot;rrdatas&quot;: [\r\n              &quot;11.22.33.44&quot;\r\n            ],\r\n            &quot;timeouts&quot;: null,\r\n            &quot;ttl&quot;: 300,\r\n            &quot;type&quot;: &quot;A&quot;\r\n          },\r\n          &quot;sensitive_attributes&quot;: [],\r\n          &quot;private&quot;: &quot;xxx&quot;,\r\n          &quot;dependencies&quot;: [\r\n            &quot;xxx&quot;\r\n          ]\r\n        }\r\n      ]\r\n    }\r\n  ]\r\n}\r\n\r\n```\r\n\r\n# Command\r\n\r\n```bash\r\njq -r &#39;.resources[] | select(.type==&quot;google_dns_record_set&quot;).instances[].attributes | del(.timeouts)&#39; data.json\r\n```\r\n",
        "link": "https://stackoverflow.com/questions/71428557/select-and-delete-attributes-with-jq",
        "title": "select and delete attributes with JQ"
    },
    {
        "tags": [
            "linux",
            "bash",
            "shell",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 8,
                "is_accepted": true,
                "score": 8,
                "last_activity_date": 1646951548,
                "creation_date": 1646951548,
                "answer_id": 71431556,
                "question_id": 71431490,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Using the `--arg` option to import content as variables is preferred over injecting shell variables into the actual filter code. This also saves you from dealing with single or double quotes.\r\n\r\n~~~sh\r\n#!/bin/bash\r\n\r\nmyvar=&quot;data1&quot;\r\ndata=&#39;[\r\n  {\r\n    &quot;resource_name&quot;: &quot;data1.something&quot;,\r\n    &quot;resource_type&quot;: &quot;Topic&quot;\r\n  },\r\n  {\r\n    &quot;resource_name&quot;: &quot;data2.something&quot;,\r\n    &quot;resource_type&quot;: &quot;Topic&quot;\r\n  }\r\n]&#39;\r\nquery=&#39;.[] | select((.resource_type==$type) and (.resource_name | startswith($var) | not))&#39;\r\necho &quot;${data}&quot; | jq --arg type &quot;Topic&quot; --arg var &quot;${myvar}&quot; &quot;${query}&quot;\r\n~~~\r\n~~~json\r\n{\r\n  &quot;resource_name&quot;: &quot;data2.something&quot;,\r\n  &quot;resource_type&quot;: &quot;Topic&quot;\r\n}\r\n~~~\r\n[Demo](https://jqplay.org/s/cK1kPzR9I7)",
                "title": "jq with single quotes bash script"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 4,
        "last_activity_date": 1646951548,
        "creation_date": 1646951004,
        "question_id": 71431490,
        "body_markdown": "I tried to use bash to run the following script:\r\n\r\n    #!/bin/bash\r\n\r\n    myvar=&quot;data1&quot;\r\n    data=&#39;[\r\n      {\r\n        &quot;resource_name&quot;: &quot;data1.something&quot;,\r\n        &quot;resource_type&quot;: &quot;Topic&quot;\r\n      },\r\n      {\r\n        &quot;resource_name&quot;: &quot;data2.something&quot;,\r\n        &quot;resource_type&quot;: &quot;Topic&quot;\r\n      }\r\n    ]&#39;\r\n    query=$(echo &quot;.[] | select((.resource_type==\\&quot;Topic\\&quot;) and (.resource_name | startswith(\\&quot;${myvar}\\&quot;) | not))&quot;)\r\n    echo ${data} | jq ${query}\r\n\r\nIt doesn&#39;t work becasue of line :\r\n\r\n    echo ${data} | jq ${query}\r\n\r\nBut if I run the same script in zsh, it works. and gives me the following error:\r\n\r\n    jq: error: Could not open file |: No such file or directory\r\n\r\n    jq: error: Could not open file select((.resource_type==&quot;Topic&quot;): No such file or directory\r\n    jq: error: Could not open file and: No such file or directory\r\n    jq: error: Could not open file (.resource_name: No such file or directory\r\n    jq: error: Could not open file |: No such file or directory\r\n    jq: error: Could not open file startswith(&quot;data1&quot;): No such file or directory\r\n    jq: error: Could not open file |: No such file or directory\r\n    jq: error: Could not open file not)): No such file or directory\r\n\r\nI was unable to understand what exactly is the issue here, I can only think that I somehow need to add single quotes when using with bash.\r\n\r\nFor example, if I use single quotes:\r\n\r\n    echo ${data} | jq \\&#39;${query}\\&#39;\r\nit gives an error:\r\n\r\n    jq: error: syntax error, unexpected INVALID_CHARACTER, expecting $end (Unix shell quoting issues?) at &lt;top-level&gt;, line 1:\r\n&#39;.[]\r\njq: 1 compile error",
        "link": "https://stackoverflow.com/questions/71431490/jq-with-single-quotes-bash-script",
        "title": "jq with single quotes bash script"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1646955195,
                "last_edit_date": 1646955195,
                "creation_date": 1646954550,
                "answer_id": 71431932,
                "question_id": 71431880,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "`to_entries` deconstructs an object into an array of key-value pairs. Use `map(…)` to modify its items without decomposing the array, and `from_entries` to reconstruct the original object from the modified array:\r\n~~~sh\r\n… | jq &#39;to_entries | map(select(.key | startswith(&quot;vault&quot;))) | from_entries&#39;\r\n~~~\r\nOr use `with_entries(…)` which is a builtin shortcut to `to_entries | map(…) | from_entries`:\r\n~~~sh\r\n… | jq &#39;with_entries(select(.key | startswith(&quot;vault&quot;)))&#39;\r\n~~~\r\n~~~json\r\n{\r\n  &quot;vault.hashicorp.com/agent-cache-enable&quot;: &quot;true&quot;,\r\n  &quot;vault.hashicorp.com/agent-cache-use-auto-auth-token&quot;: &quot;force&quot;,\r\n  &quot;vault.hashicorp.com/agent-init-first&quot;: &quot;true&quot;,\r\n  &quot;vault.hashicorp.com/agent-inject&quot;: &quot;true&quot;,\r\n  &quot;vault.hashicorp.com/ca-cert&quot;: &quot;/run/secrets/kubernetes.io/serviceaccount/ca.crt&quot;,\r\n  &quot;vault.hashicorp.com/preserve-secret-case&quot;: &quot;true&quot;,\r\n  &quot;vault.hashicorp.com/role&quot;: &quot;my-role&quot;,\r\n  &quot;vault.hashicorp.com/secret-volume-path-a&quot;: &quot;/var/path&quot;,\r\n  &quot;vault.hashicorp.com/secret-volume-path-b&quot;: &quot;/var/path&quot;,\r\n  &quot;vault.hashicorp.com/secret-volume-path-c&quot;: &quot;/var/path&quot;,\r\n  &quot;vault.hashicorp.com/secret-volume-path-d&quot;: &quot;/var/path&quot;,\r\n  &quot;vault.hashicorp.com/secret-volume-path-e&quot;: &quot;/var/path&quot;\r\n}\r\n~~~\r\n[Demo](https://jqplay.org/s/Cmv32vaX48)",
                "title": "Using jq to filter and keep original json structure"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1646955195,
        "creation_date": 1646954180,
        "question_id": 71431880,
        "body_markdown": "I have a json structure, which contains a list of annotations from kubectl - `jsonpath=&#39;{.spec.template.metadata.annotations}`\r\n\r\n```\r\n{\r\n  &quot;kubectl.kubernetes.io/restartedAt&quot;: &quot;2022-03-09T16:09:47-08:00&quot;,\r\n  &quot;sidecar.istio.io/proxyCPU&quot;: &quot;100m&quot;,\r\n  &quot;sidecar.istio.io/proxyCPULimit&quot;: &quot;2&quot;,\r\n  &quot;sidecar.istio.io/proxyMemory&quot;: &quot;128Mi&quot;,\r\n  &quot;sidecar.istio.io/proxyMemoryLimit&quot;: &quot;1Gi&quot;,\r\n  &quot;traffic.sidecar.istio.io/excludeOutboundPorts&quot;: &quot;8200&quot;,\r\n  &quot;vault.hashicorp.com/agent-cache-enable&quot;: &quot;true&quot;,\r\n  &quot;vault.hashicorp.com/agent-cache-use-auto-auth-token&quot;: &quot;force&quot;,\r\n  &quot;vault.hashicorp.com/agent-init-first&quot;: &quot;true&quot;,\r\n  &quot;vault.hashicorp.com/agent-inject&quot;: &quot;true&quot;,\r\n  &quot;vault.hashicorp.com/ca-cert&quot;: &quot;/run/secrets/kubernetes.io/serviceaccount/ca.crt&quot;,\r\n  &quot;vault.hashicorp.com/preserve-secret-case&quot;: &quot;true&quot;,\r\n  &quot;vault.hashicorp.com/role&quot;: &quot;my-role&quot;,\r\n  &quot;vault.hashicorp.com/secret-volume-path-a&quot;: &quot;/var/path&quot;,\r\n  &quot;vault.hashicorp.com/secret-volume-path-b&quot;: &quot;/var/path&quot;,\r\n  &quot;vault.hashicorp.com/secret-volume-path-c&quot;: &quot;/var/path&quot;,\r\n  &quot;vault.hashicorp.com/secret-volume-path-d&quot;: &quot;/var/path&quot;,\r\n  &quot;vault.hashicorp.com/secret-volume-path-e&quot;: &quot;/var/path&quot;\r\n}\r\n```\r\n\r\nI am looking to use jq to only grab the keys that contain &quot;vault&quot;, so the output should be:\r\n\r\n```\r\n{\r\n  &quot;vault.hashicorp.com/agent-cache-enable&quot;: &quot;true&quot;,\r\n  &quot;vault.hashicorp.com/agent-cache-use-auto-auth-token&quot;: &quot;force&quot;,\r\n  &quot;vault.hashicorp.com/agent-init-first&quot;: &quot;true&quot;,\r\n  &quot;vault.hashicorp.com/agent-inject&quot;: &quot;true&quot;,\r\n  &quot;vault.hashicorp.com/ca-cert&quot;: &quot;/run/secrets/kubernetes.io/serviceaccount/ca.crt&quot;,\r\n  &quot;vault.hashicorp.com/preserve-secret-case&quot;: &quot;true&quot;,\r\n  &quot;vault.hashicorp.com/role&quot;: &quot;my-role&quot;,\r\n  &quot;vault.hashicorp.com/secret-volume-path-a&quot;: &quot;/var/path&quot;,\r\n  &quot;vault.hashicorp.com/secret-volume-path-b&quot;: &quot;/var/path&quot;,\r\n  &quot;vault.hashicorp.com/secret-volume-path-c&quot;: &quot;/var/path&quot;,\r\n  &quot;vault.hashicorp.com/secret-volume-path-d&quot;: &quot;/var/path&quot;,\r\n  &quot;vault.hashicorp.com/secret-volume-path-e&quot;: &quot;/var/path&quot;\r\n}\r\n```\r\nI&#39;ve tried using something like \r\n```\r\n$ kubectl get deployment test -n test -o jsonpath=&#39;{.spec.template.metadata.annotations}&#39; |jq &#39;. | to_entries[] | select(.key | startswith(&quot;vault&quot;))&#39;\r\n\r\n{\r\n  &quot;key&quot;: &quot;vault.hashicorp.com/agent-cache-enable&quot;,\r\n  &quot;value&quot;: &quot;true&quot;\r\n}\r\n{\r\n  &quot;key&quot;: &quot;vault.hashicorp.com/agent-cache-use-auto-auth-token&quot;,\r\n  &quot;value&quot;: &quot;force&quot;\r\n}\r\n```\r\nbut I don&#39;t know how to convert that output back to the original json format.",
        "link": "https://stackoverflow.com/questions/71431880/using-jq-to-filter-and-keep-original-json-structure",
        "title": "Using jq to filter and keep original json structure"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1646958498,
                "creation_date": 1646958498,
                "answer_id": 71432355,
                "question_id": 71432160,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "i worked it a bit and was able to extract what i needed\r\n\r\n```\r\nexport BUILD_NUMBER=&#39;72&#39;\r\nexport STAGE1=&quot;CLEANUP WORKSTATION&quot;\r\n\r\ncat file.json | jq &#39;.[] | select(.id==env.BUILD_NUMBER) | .stages | .[] | select(.name | contains(env.STAGE1)) | .durationMillis&#39;\r\n```",
                "title": "how do i retrieve specific value from json with jq"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1646958498,
        "creation_date": 1646956653,
        "question_id": 71432160,
        "body_markdown": "i have a json file containing data about Jenkins stages.\r\nassuming i have the stage name stored in a variable how do i retrieve the &quot;durationMillis&quot; value from that stage\r\n\r\nSTAGE1=&quot;CLEANUP WORKSTATION&quot;\r\n\r\nso far i was able to dissect the last job (json containing 3 last Jenkins jobs)\r\n```\r\ncat file.json | jq &#39;.[] | select(.id==&#39;\\&quot;$BUILD_NUMBER\\&quot;&#39;)&#39;\r\n```\r\n**outcome should present &quot;157&quot;**\r\n```\r\n[\r\n    {\r\n      &quot;_links&quot;: {\r\n        &quot;self&quot;: {\r\n          &quot;href&quot;: &quot;/jenkins/cag-sw-jenkins/job/test/job/test-hagay-elk-kv/72/wfapi/describe&quot;\r\n        }\r\n      },\r\n      &quot;id&quot;: &quot;72&quot;,\r\n      &quot;name&quot;: &quot;#72&quot;,\r\n      &quot;status&quot;: &quot;SUCCESS&quot;,\r\n      &quot;startTimeMillis&quot;: 1646952992850,\r\n      &quot;endTimeMillis&quot;: 1646953018448,\r\n      &quot;durationMillis&quot;: 25598,\r\n      &quot;queueDurationMillis&quot;: 24,\r\n      &quot;pauseDurationMillis&quot;: 0,\r\n      &quot;stages&quot;: [\r\n        {\r\n          &quot;_links&quot;: {\r\n            &quot;self&quot;: {\r\n              &quot;href&quot;: &quot;/jenkins/cag-sw-jenkins/job/test/job/test-hagay-elk-kv/72/execution/node/8/wfapi/describe&quot;\r\n            }\r\n          },\r\n          &quot;id&quot;: &quot;8&quot;,\r\n          &quot;name&quot;: &quot;CLEANUP WORKSTATION&quot;,\r\n          &quot;execNode&quot;: &quot;&quot;,\r\n          &quot;status&quot;: &quot;SUCCESS&quot;,\r\n          &quot;startTimeMillis&quot;: 1646953001559,\r\n          &quot;durationMillis&quot;: 157,\r\n          &quot;pauseDurationMillis&quot;: 0\r\n        },\r\n        {\r\n          &quot;_links&quot;: {\r\n            &quot;self&quot;: {\r\n              &quot;href&quot;: &quot;/jenkins/cag-sw-jenkins/job/test/job/test-hagay-elk-kv/72/execution/node/12/wfapi/describe&quot;\r\n            }\r\n          },\r\n          &quot;id&quot;: &quot;12&quot;,\r\n          &quot;name&quot;: &quot;GIT CLONE&quot;,\r\n          &quot;execNode&quot;: &quot;&quot;,\r\n          &quot;status&quot;: &quot;SUCCESS&quot;,\r\n          &quot;startTimeMillis&quot;: 1646953001716,\r\n          &quot;durationMillis&quot;: 302,\r\n          &quot;pauseDurationMillis&quot;: 0\r\n        },\r\n        {\r\n          &quot;_links&quot;: {\r\n            &quot;self&quot;: {\r\n              &quot;href&quot;: &quot;/jenkins/cag-sw-jenkins/job/test/job/test-hagay-elk-kv/72/execution/node/25/wfapi/describe&quot;\r\n            }\r\n          },\r\n          &quot;id&quot;: &quot;25&quot;,\r\n          &quot;name&quot;: &quot;ALL STAGES&quot;,\r\n          &quot;execNode&quot;: &quot;&quot;,\r\n          &quot;status&quot;: &quot;SUCCESS&quot;,\r\n          &quot;startTimeMillis&quot;: 1646953002199,\r\n          &quot;durationMillis&quot;: 893,\r\n          &quot;pauseDurationMillis&quot;: 0\r\n        },\r\n        {\r\n          &quot;_links&quot;: {\r\n            &quot;self&quot;: {\r\n              &quot;href&quot;: &quot;/jenkins/cag-sw-jenkins/job/test/job/test-hagay-elk-kv/72/execution/node/33/wfapi/describe&quot;\r\n            }\r\n          },\r\n          &quot;id&quot;: &quot;33&quot;,\r\n          &quot;name&quot;: &quot;STAGE1&quot;,\r\n          &quot;execNode&quot;: &quot;&quot;,\r\n          &quot;status&quot;: &quot;SUCCESS&quot;,\r\n          &quot;startTimeMillis&quot;: 1646953003092,\r\n          &quot;durationMillis&quot;: 3760,\r\n          &quot;pauseDurationMillis&quot;: 0\r\n        },\r\n        {\r\n          &quot;_links&quot;: {\r\n            &quot;self&quot;: {\r\n              &quot;href&quot;: &quot;/jenkins/cag-sw-jenkins/job/test/job/test-hagay-elk-kv/72/execution/node/35/wfapi/describe&quot;\r\n            }\r\n          },\r\n          &quot;id&quot;: &quot;35&quot;,\r\n          &quot;name&quot;: &quot;STAGE2&quot;,\r\n          &quot;execNode&quot;: &quot;&quot;,\r\n          &quot;status&quot;: &quot;SUCCESS&quot;,\r\n          &quot;startTimeMillis&quot;: 1646953003196,\r\n          &quot;durationMillis&quot;: 7348,\r\n          &quot;pauseDurationMillis&quot;: 0\r\n        },\r\n        {\r\n          &quot;_links&quot;: {\r\n            &quot;self&quot;: {\r\n              &quot;href&quot;: &quot;/jenkins/cag-sw-jenkins/job/test/job/test-hagay-elk-kv/72/execution/node/37/wfapi/describe&quot;\r\n            }\r\n          },\r\n          &quot;id&quot;: &quot;37&quot;,\r\n          &quot;name&quot;: &quot;STAGE3&quot;,\r\n          &quot;execNode&quot;: &quot;&quot;,\r\n          &quot;status&quot;: &quot;SUCCESS&quot;,\r\n          &quot;startTimeMillis&quot;: 1646953003241,\r\n          &quot;durationMillis&quot;: 5522,\r\n          &quot;pauseDurationMillis&quot;: 0\r\n        },\r\n        {\r\n          &quot;_links&quot;: {\r\n            &quot;self&quot;: {\r\n              &quot;href&quot;: &quot;/jenkins/cag-sw-jenkins/job/test/job/test-hagay-elk-kv/72/execution/node/90/wfapi/describe&quot;\r\n            }\r\n          },\r\n          &quot;id&quot;: &quot;90&quot;,\r\n          &quot;name&quot;: &quot;Declarative: Post Actions&quot;,\r\n          &quot;execNode&quot;: &quot;&quot;,\r\n          &quot;status&quot;: &quot;SUCCESS&quot;,\r\n          &quot;startTimeMillis&quot;: 1646953010757,\r\n          &quot;durationMillis&quot;: 7430,\r\n          &quot;pauseDurationMillis&quot;: 0\r\n        }\r\n      ]\r\n    },\r\n    {\r\n      &quot;_links&quot;: {\r\n        &quot;self&quot;: {\r\n          &quot;href&quot;: &quot;/jenkins/cag-sw-jenkins/job/test/job/test-hagay-elk-kv/71/wfapi/describe&quot;\r\n        }\r\n      },\r\n      &quot;id&quot;: &quot;71&quot;,\r\n      &quot;name&quot;: &quot;#71&quot;,\r\n      &quot;status&quot;: &quot;SUCCESS&quot;,\r\n      &quot;startTimeMillis&quot;: 1646952745744,\r\n      &quot;endTimeMillis&quot;: 1646952770031,\r\n      &quot;durationMillis&quot;: 24287,\r\n      &quot;queueDurationMillis&quot;: 19,\r\n      &quot;pauseDurationMillis&quot;: 0,\r\n      &quot;stages&quot;: [\r\n        {\r\n          &quot;_links&quot;: {\r\n            &quot;self&quot;: {\r\n              &quot;href&quot;: &quot;/jenkins/cag-sw-jenkins/job/test/job/test-hagay-elk-kv/71/execution/node/8/wfapi/describe&quot;\r\n            }\r\n          },\r\n          &quot;id&quot;: &quot;8&quot;,\r\n          &quot;name&quot;: &quot;CLEANUP WORKSTATION&quot;,\r\n          &quot;execNode&quot;: &quot;&quot;,\r\n          &quot;status&quot;: &quot;SUCCESS&quot;,\r\n          &quot;startTimeMillis&quot;: 1646952754330,\r\n          &quot;durationMillis&quot;: 203,\r\n          &quot;pauseDurationMillis&quot;: 0\r\n        },\r\n        {\r\n          &quot;_links&quot;: {\r\n            &quot;self&quot;: {\r\n              &quot;href&quot;: &quot;/jenkins/cag-sw-jenkins/job/test/job/test-hagay-elk-kv/71/execution/node/12/wfapi/describe&quot;\r\n            }\r\n          },\r\n          &quot;id&quot;: &quot;12&quot;,\r\n          &quot;name&quot;: &quot;GIT CLONE&quot;,\r\n          &quot;execNode&quot;: &quot;&quot;,\r\n          &quot;status&quot;: &quot;SUCCESS&quot;,\r\n          &quot;startTimeMillis&quot;: 1646952754533,\r\n          &quot;durationMillis&quot;: 457,\r\n          &quot;pauseDurationMillis&quot;: 0\r\n        },\r\n        {\r\n          &quot;_links&quot;: {\r\n            &quot;self&quot;: {\r\n              &quot;href&quot;: &quot;/jenkins/cag-sw-jenkins/job/test/job/test-hagay-elk-kv/71/execution/node/25/wfapi/describe&quot;\r\n            }\r\n          },\r\n          &quot;id&quot;: &quot;25&quot;,\r\n          &quot;name&quot;: &quot;ALL STAGES&quot;,\r\n          &quot;execNode&quot;: &quot;&quot;,\r\n          &quot;status&quot;: &quot;SUCCESS&quot;,\r\n          &quot;startTimeMillis&quot;: 1646952756222,\r\n          &quot;durationMillis&quot;: 536,\r\n          &quot;pauseDurationMillis&quot;: 0\r\n        },\r\n        {\r\n          &quot;_links&quot;: {\r\n            &quot;self&quot;: {\r\n              &quot;href&quot;: &quot;/jenkins/cag-sw-jenkins/job/test/job/test-hagay-elk-kv/71/execution/node/33/wfapi/describe&quot;\r\n            }\r\n          },\r\n          &quot;id&quot;: &quot;33&quot;,\r\n          &quot;name&quot;: &quot;STAGE1&quot;,\r\n          &quot;execNode&quot;: &quot;&quot;,\r\n          &quot;status&quot;: &quot;SUCCESS&quot;,\r\n          &quot;startTimeMillis&quot;: 1646952756758,\r\n          &quot;durationMillis&quot;: 4344,\r\n          &quot;pauseDurationMillis&quot;: 0\r\n        },\r\n        {\r\n          &quot;_links&quot;: {\r\n            &quot;self&quot;: {\r\n              &quot;href&quot;: &quot;/jenkins/cag-sw-jenkins/job/test/job/test-hagay-elk-kv/71/execution/node/35/wfapi/describe&quot;\r\n            }\r\n          },\r\n          &quot;id&quot;: &quot;35&quot;,\r\n          &quot;name&quot;: &quot;STAGE2&quot;,\r\n          &quot;execNode&quot;: &quot;&quot;,\r\n          &quot;status&quot;: &quot;SUCCESS&quot;,\r\n          &quot;startTimeMillis&quot;: 1646952756811,\r\n          &quot;durationMillis&quot;: 6175,\r\n          &quot;pauseDurationMillis&quot;: 0\r\n        },\r\n        {\r\n          &quot;_links&quot;: {\r\n            &quot;self&quot;: {\r\n              &quot;href&quot;: &quot;/jenkins/cag-sw-jenkins/job/test/job/test-hagay-elk-kv/71/execution/node/37/wfapi/describe&quot;\r\n            }\r\n          },\r\n          &quot;id&quot;: &quot;37&quot;,\r\n          &quot;name&quot;: &quot;STAGE3&quot;,\r\n          &quot;execNode&quot;: &quot;&quot;,\r\n          &quot;status&quot;: &quot;SUCCESS&quot;,\r\n          &quot;startTimeMillis&quot;: 1646952756842,\r\n          &quot;durationMillis&quot;: 4167,\r\n          &quot;pauseDurationMillis&quot;: 0\r\n        },\r\n        {\r\n          &quot;_links&quot;: {\r\n            &quot;self&quot;: {\r\n              &quot;href&quot;: &quot;/jenkins/cag-sw-jenkins/job/test/job/test-hagay-elk-kv/71/execution/node/90/wfapi/describe&quot;\r\n            }\r\n          },\r\n          &quot;id&quot;: &quot;90&quot;,\r\n          &quot;name&quot;: &quot;Declarative: Post Actions&quot;,\r\n          &quot;execNode&quot;: &quot;&quot;,\r\n          &quot;status&quot;: &quot;SUCCESS&quot;,\r\n          &quot;startTimeMillis&quot;: 1646952763230,\r\n          &quot;durationMillis&quot;: 6588,\r\n          &quot;pauseDurationMillis&quot;: 0\r\n        }\r\n      ]\r\n    },\r\n    {\r\n      &quot;_links&quot;: {\r\n        &quot;self&quot;: {\r\n          &quot;href&quot;: &quot;/jenkins/cag-sw-jenkins/job/test/job/test-hagay-elk-kv/70/wfapi/describe&quot;\r\n        }\r\n      },\r\n      &quot;id&quot;: &quot;70&quot;,\r\n      &quot;name&quot;: &quot;#70&quot;,\r\n      &quot;status&quot;: &quot;FAILED&quot;,\r\n      &quot;startTimeMillis&quot;: 1646952648485,\r\n      &quot;endTimeMillis&quot;: 1646952669992,\r\n      &quot;durationMillis&quot;: 21507,\r\n      &quot;queueDurationMillis&quot;: 16,\r\n      &quot;pauseDurationMillis&quot;: 0,\r\n      &quot;stages&quot;: [\r\n        {\r\n          &quot;_links&quot;: {\r\n            &quot;self&quot;: {\r\n              &quot;href&quot;: &quot;/jenkins/cag-sw-jenkins/job/test/job/test-hagay-elk-kv/70/execution/node/8/wfapi/describe&quot;\r\n            }\r\n          },\r\n          &quot;id&quot;: &quot;8&quot;,\r\n          &quot;name&quot;: &quot;CLEANUP WORKSTATION&quot;,\r\n          &quot;execNode&quot;: &quot;&quot;,\r\n          &quot;status&quot;: &quot;SUCCESS&quot;,\r\n          &quot;startTimeMillis&quot;: 1646952657661,\r\n          &quot;durationMillis&quot;: 177,\r\n          &quot;pauseDurationMillis&quot;: 0\r\n        },\r\n        {\r\n          &quot;_links&quot;: {\r\n            &quot;self&quot;: {\r\n              &quot;href&quot;: &quot;/jenkins/cag-sw-jenkins/job/test/job/test-hagay-elk-kv/70/execution/node/12/wfapi/describe&quot;\r\n            }\r\n          },\r\n          &quot;id&quot;: &quot;12&quot;,\r\n          &quot;name&quot;: &quot;GIT CLONE&quot;,\r\n          &quot;execNode&quot;: &quot;&quot;,\r\n          &quot;status&quot;: &quot;SUCCESS&quot;,\r\n          &quot;startTimeMillis&quot;: 1646952657838,\r\n          &quot;durationMillis&quot;: 349,\r\n          &quot;pauseDurationMillis&quot;: 0\r\n        },\r\n        {\r\n          &quot;_links&quot;: {\r\n            &quot;self&quot;: {\r\n              &quot;href&quot;: &quot;/jenkins/cag-sw-jenkins/job/test/job/test-hagay-elk-kv/70/execution/node/25/wfapi/describe&quot;\r\n            }\r\n          },\r\n          &quot;id&quot;: &quot;25&quot;,\r\n          &quot;name&quot;: &quot;ALL STAGES&quot;,\r\n          &quot;execNode&quot;: &quot;&quot;,\r\n          &quot;status&quot;: &quot;SUCCESS&quot;,\r\n          &quot;startTimeMillis&quot;: 1646952658407,\r\n          &quot;durationMillis&quot;: 198,\r\n          &quot;pauseDurationMillis&quot;: 0\r\n        },\r\n        {\r\n          &quot;_links&quot;: {\r\n            &quot;self&quot;: {\r\n              &quot;href&quot;: &quot;/jenkins/cag-sw-jenkins/job/test/job/test-hagay-elk-kv/70/execution/node/33/wfapi/describe&quot;\r\n            }\r\n          },\r\n          &quot;id&quot;: &quot;33&quot;,\r\n          &quot;name&quot;: &quot;STAGE1&quot;,\r\n          &quot;execNode&quot;: &quot;&quot;,\r\n          &quot;status&quot;: &quot;FAILED&quot;,\r\n          &quot;error&quot;: {\r\n            &quot;message&quot;: &quot;script returned exit code 2&quot;,\r\n            &quot;type&quot;: &quot;hudson.AbortException&quot;\r\n          },\r\n          &quot;startTimeMillis&quot;: 1646952658605,\r\n          &quot;durationMillis&quot;: 3434,\r\n          &quot;pauseDurationMillis&quot;: 0\r\n        },\r\n        {\r\n          &quot;_links&quot;: {\r\n            &quot;self&quot;: {\r\n              &quot;href&quot;: &quot;/jenkins/cag-sw-jenkins/job/test/job/test-hagay-elk-kv/70/execution/node/35/wfapi/describe&quot;\r\n            }\r\n          },\r\n          &quot;id&quot;: &quot;35&quot;,\r\n          &quot;name&quot;: &quot;STAGE2&quot;,\r\n          &quot;execNode&quot;: &quot;&quot;,\r\n          &quot;status&quot;: &quot;FAILED&quot;,\r\n          &quot;error&quot;: {\r\n            &quot;message&quot;: &quot;script returned exit code 2&quot;,\r\n            &quot;type&quot;: &quot;hudson.AbortException&quot;\r\n          },\r\n          &quot;startTimeMillis&quot;: 1646952658638,\r\n          &quot;durationMillis&quot;: 5948,\r\n          &quot;pauseDurationMillis&quot;: 0\r\n        },\r\n        {\r\n          &quot;_links&quot;: {\r\n            &quot;self&quot;: {\r\n              &quot;href&quot;: &quot;/jenkins/cag-sw-jenkins/job/test/job/test-hagay-elk-kv/70/execution/node/37/wfapi/describe&quot;\r\n            }\r\n          },\r\n          &quot;id&quot;: &quot;37&quot;,\r\n          &quot;name&quot;: &quot;STAGE3&quot;,\r\n          &quot;execNode&quot;: &quot;&quot;,\r\n          &quot;status&quot;: &quot;FAILED&quot;,\r\n          &quot;error&quot;: {\r\n            &quot;message&quot;: &quot;script returned exit code 2&quot;,\r\n            &quot;type&quot;: &quot;hudson.AbortException&quot;\r\n          },\r\n          &quot;startTimeMillis&quot;: 1646952658669,\r\n          &quot;durationMillis&quot;: 3969,\r\n          &quot;pauseDurationMillis&quot;: 0\r\n        },\r\n        {\r\n          &quot;_links&quot;: {\r\n            &quot;self&quot;: {\r\n              &quot;href&quot;: &quot;/jenkins/cag-sw-jenkins/job/test/job/test-hagay-elk-kv/70/execution/node/90/wfapi/describe&quot;\r\n            }\r\n          },\r\n          &quot;id&quot;: &quot;90&quot;,\r\n          &quot;name&quot;: &quot;Declarative: Post Actions&quot;,\r\n          &quot;execNode&quot;: &quot;&quot;,\r\n          &quot;status&quot;: &quot;SUCCESS&quot;,\r\n          &quot;startTimeMillis&quot;: 1646952664887,\r\n          &quot;durationMillis&quot;: 4873,\r\n          &quot;pauseDurationMillis&quot;: 0\r\n        }\r\n      ]\r\n    }\r\n  ]\r\n```",
        "link": "https://stackoverflow.com/questions/71432160/how-do-i-retrieve-specific-value-from-json-with-jq",
        "title": "how do i retrieve specific value from json with jq"
    },
    {
        "tags": [
            "arrays",
            "json",
            "linux",
            "csv",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1647000861,
                "post_id": 71438278,
                "comment_id": 126268655,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1647001756,
                "creation_date": 1647001756,
                "answer_id": 71438530,
                "question_id": 71438278,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If no keys collide, you could integrate the `.metric` subarray&#39;s items into the actual record:\r\n~~~sh\r\njq -r &#39;\r\n  .observations[] |= (. + .metric | del(.metric))\r\n  | (.observations[0] | keys_unsorted), (.observations[] | map(values))\r\n  | @csv\r\n&#39; file.json\r\n~~~\r\n~~~csv\r\n&quot;stationID&quot;,&quot;tz&quot;,&quot;obsTimeUtc&quot;,&quot;obsTimeLocal&quot;,&quot;epoch&quot;,&quot;lat&quot;,&quot;lon&quot;,&quot;solarRadiationHigh&quot;,&quot;uvHigh&quot;,&quot;winddirAvg&quot;,&quot;humidityHigh&quot;,&quot;humidityLow&quot;,&quot;humidityAvg&quot;,&quot;qcStatus&quot;,&quot;tempHigh&quot;,&quot;tempLow&quot;,&quot;tempAvg&quot;,&quot;windspeedHigh&quot;,&quot;windspeedLow&quot;,&quot;windspeedAvg&quot;,&quot;windgustHigh&quot;,&quot;windgustLow&quot;,&quot;windgustAvg&quot;,&quot;dewptHigh&quot;,&quot;dewptLow&quot;,&quot;dewptAvg&quot;,&quot;windchillHigh&quot;,&quot;windchillLow&quot;,&quot;windchillAvg&quot;,&quot;heatindexHigh&quot;,&quot;heatindexLow&quot;,&quot;heatindexAvg&quot;,&quot;pressureMax&quot;,&quot;pressureMin&quot;,&quot;pressureTrend&quot;,&quot;precipRate&quot;,&quot;precipTotal&quot;\r\n&quot;IBONIE3&quot;,&quot;Europe/Warsaw&quot;,&quot;2021-07-31T21:59:50Z&quot;,&quot;2021-07-31 23:59:50&quot;,1627768790,52.203785,20.618021,0,0,257,74,71,71,1,20,20,20,8,0,2,12,0,3,15,15,15,20,20,20,20,20,20,994.58,993.91,0,0,0\r\n~~~\r\n[Demo](https://jqplay.org/s/P5CRJn5LZA)\r\n\r\nIf they happen to collide, add some prefix to their names to disambiguate:\r\n~~~sh\r\njq -r &#39;\r\n  .observations[] |= (. + (.metric | with_entries(.key |= &quot;metric_\\(.)&quot;)) | del(.metric))\r\n  | (.observations[0] | keys_unsorted), (.observations[] | map(values))\r\n  | @csv\r\n&#39; file.json\r\n~~~\r\n~~~csv\r\n&quot;stationID&quot;,&quot;tz&quot;,&quot;obsTimeUtc&quot;,&quot;obsTimeLocal&quot;,&quot;epoch&quot;,&quot;lat&quot;,&quot;lon&quot;,&quot;solarRadiationHigh&quot;,&quot;uvHigh&quot;,&quot;winddirAvg&quot;,&quot;humidityHigh&quot;,&quot;humidityLow&quot;,&quot;humidityAvg&quot;,&quot;qcStatus&quot;,&quot;metric_tempHigh&quot;,&quot;metric_tempLow&quot;,&quot;metric_tempAvg&quot;,&quot;metric_windspeedHigh&quot;,&quot;metric_windspeedLow&quot;,&quot;metric_windspeedAvg&quot;,&quot;metric_windgustHigh&quot;,&quot;metric_windgustLow&quot;,&quot;metric_windgustAvg&quot;,&quot;metric_dewptHigh&quot;,&quot;metric_dewptLow&quot;,&quot;metric_dewptAvg&quot;,&quot;metric_windchillHigh&quot;,&quot;metric_windchillLow&quot;,&quot;metric_windchillAvg&quot;,&quot;metric_heatindexHigh&quot;,&quot;metric_heatindexLow&quot;,&quot;metric_heatindexAvg&quot;,&quot;metric_pressureMax&quot;,&quot;metric_pressureMin&quot;,&quot;metric_pressureTrend&quot;,&quot;metric_precipRate&quot;,&quot;metric_precipTotal&quot;\r\n&quot;IBONIE3&quot;,&quot;Europe/Warsaw&quot;,&quot;2021-07-31T21:59:50Z&quot;,&quot;2021-07-31 23:59:50&quot;,1627768790,52.203785,20.618021,0,0,257,74,71,71,1,20,20,20,8,0,2,12,0,3,15,15,15,20,20,20,20,20,20,994.58,993.91,0,0,0\r\n~~~\r\n[Demo](https://jqplay.org/s/BZg_YdJeq2)",
                "title": "jq - converting json to csv issue. Unable to convert sub-array"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1647185281,
        "creation_date": 1647000430,
        "last_edit_date": 1647185281,
        "question_id": 71438278,
        "body_markdown": "I was fighting to understand jq syntax but i have issues with it. I&#39;m trying as some other people to convert json to csv. I found many entries on the forum but none of them seem to work for me. I always get some error or partial result when i narrow down the filter.\r\n\r\nGoal:\r\n 1. I grab data from https://www.wunderground.com/ using\r\n https://api.weather.com/v2/pws/history/hourly?stationId=IBONIE3&amp;format=json&amp;units=m&amp;date=20210731&amp;apiKey=&lt;APIKEY&gt;&quot;\r\n2. I want convert this data into csv\r\n\r\n\r\nWhat i get from source is data for 1 day in 1h time jumps. Data is stored under &#39;observations&#39;. That looks like this:\r\n```\r\n{&quot;observations&quot;:[\r\n    {\r\n      &quot;stationID&quot;: &quot;IBONIE3&quot;,\r\n      &quot;tz&quot;: &quot;Europe/Warsaw&quot;,\r\n      &quot;obsTimeUtc&quot;: &quot;2021-07-31T21:59:50Z&quot;,\r\n      &quot;obsTimeLocal&quot;: &quot;2021-07-31 23:59:50&quot;,\r\n      &quot;epoch&quot;: 1627768790,\r\n      &quot;lat&quot;: 52.203785,\r\n      &quot;lon&quot;: 20.618021,\r\n      &quot;solarRadiationHigh&quot;: 0,\r\n      &quot;uvHigh&quot;: 0,\r\n      &quot;winddirAvg&quot;: 257,\r\n      &quot;humidityHigh&quot;: 74,\r\n      &quot;humidityLow&quot;: 71,\r\n      &quot;humidityAvg&quot;: 71,\r\n      &quot;qcStatus&quot;: 1,\r\n      &quot;metric&quot;: {\r\n        &quot;tempHigh&quot;: 20,\r\n        &quot;tempLow&quot;: 20,\r\n        &quot;tempAvg&quot;: 20,\r\n        &quot;windspeedHigh&quot;: 8,\r\n        &quot;windspeedLow&quot;: 0,\r\n        &quot;windspeedAvg&quot;: 2,\r\n        &quot;windgustHigh&quot;: 12,\r\n        &quot;windgustLow&quot;: 0,\r\n        &quot;windgustAvg&quot;: 3,\r\n        &quot;dewptHigh&quot;: 15,\r\n        &quot;dewptLow&quot;: 15,\r\n        &quot;dewptAvg&quot;: 15,\r\n        &quot;windchillHigh&quot;: 20,\r\n        &quot;windchillLow&quot;: 20,\r\n        &quot;windchillAvg&quot;: 20,\r\n        &quot;heatindexHigh&quot;: 20,\r\n        &quot;heatindexLow&quot;: 20,\r\n        &quot;heatindexAvg&quot;: 20,\r\n        &quot;pressureMax&quot;: 994.58,\r\n        &quot;pressureMin&quot;: 993.91,\r\n        &quot;pressureTrend&quot;: 0,\r\n        &quot;precipRate&quot;: 0,\r\n        &quot;precipTotal&quot;: 0\r\n      }\r\n\r\n}]}\r\n```\r\nobviously this is just 1 entry out of 24 in single file. \r\n\r\nWhen i do this:\r\n```\r\ncat file.json | jq &#39;.observations[0],.observations[0].metric | keys_unsorted | @csv&#39;\r\n\r\n&quot;\\&quot;stationID\\&quot;,\\&quot;tz\\&quot;,\\&quot;obsTimeUtc\\&quot;,\\&quot;obsTimeLocal\\&quot;,\\&quot;epoch\\&quot;,\\&quot;lat\\&quot;,\\&quot;lon\\&quot;,\\&quot;solarRadiationHigh\\&quot;,\\&quot;uvHigh\\&quot;,\\&quot;winddirAvg\\&quot;,\\&quot;humidityHigh\\&quot;,\\&quot;humidityLow\\&quot;,\\&quot;humidityAvg\\&quot;,\\&quot;qcStatus\\&quot;,\\&quot;metric\\&quot;&quot;\r\n&quot;\\&quot;tempHigh\\&quot;,\\&quot;tempLow\\&quot;,\\&quot;tempAvg\\&quot;,\\&quot;windspeedHigh\\&quot;,\\&quot;windspeedLow\\&quot;,\\&quot;windspeedAvg\\&quot;,\\&quot;windgustHigh\\&quot;,\\&quot;windgustLow\\&quot;,\\&quot;windgustAvg\\&quot;,\\&quot;dewptHigh\\&quot;,\\&quot;dewptLow\\&quot;,\\&quot;dewptAvg\\&quot;,\\&quot;windchillHigh\\&quot;,\\&quot;windchillLow\\&quot;,\\&quot;windchillAvg\\&quot;,\\&quot;heatindexHigh\\&quot;,\\&quot;heatindexLow\\&quot;,\\&quot;heatindexAvg\\&quot;,\\&quot;pressureMax\\&quot;,\\&quot;pressureMin\\&quot;,\\&quot;pressureTrend\\&quot;,\\&quot;precipRate\\&quot;,\\&quot;precipTotal\\&quot;&quot;\r\n\r\n```\r\nI do get header in proper format, but when i do this\r\n```\r\ncat file.json | jq -r &#39;.observations[] | map(values) | @csv\r\n\r\njq: error (at &lt;stdin&gt;:1): object ({&quot;tempHigh&quot;...) is not valid in a csv row\r\n```\r\ni get error. Which is obvious for me as this goes into sub-array called metric and this is where error is being displayed. I can only get these metrics by running this:\r\n```\r\ncat file.json | jq -r &#39;.observations[].metric | map(values) | @csv\r\n20,18,19,0,0,0,0,0,0,15,14,14,20,18,19,20,18,19,994.58,994.24,0.34,0,0\r\n```\r\nskipping all the other data, but this is not what i want.\r\n\r\nHow i can convert this metric array into the non-array object? \r\nIs there any way to do that in single query?\r\n\r\nObviously header cannot have also variable &quot;metric&quot; and instead all the items from that sub-array - metric. I can fix header manually or even skip it, but how to get whole data, not only metric?",
        "link": "https://stackoverflow.com/questions/71438278/jq-converting-json-to-csv-issue-unable-to-convert-sub-array",
        "title": "jq - converting json to csv issue. Unable to convert sub-array"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1647003093,
                "creation_date": 1647003093,
                "answer_id": 71438812,
                "question_id": 71438490,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The iteration inside your selection `.IpPermissions[] | .IpRanges[]` produces as many results as there are items in those arrays. For each `true` outcome, your `select` passes on the input in question (maybe several times). You need an aggregator like `any` or `all` to combine all the outcomes to one boolean result, so that `select` can pass on just either 1 or 0 copies of the corresponding input.\r\n\r\nFurthermore, you iterate over `.IpPermissions[]` on **both** sides of the `and` in your condition which will produce a cartesian product of the outcomes.\r\n\r\nHere is a solution that selects a group if there is **at least one** item in the `.IpPermissions` array that has a match for `.FromPort` **and at least one** match for `.CidrIp` in the `.IpRanges` array:\r\n\r\n~~~sh\r\njq &#39;\r\n  .SecurityGroups[] | select(\r\n    any(.IpPermissions[]; .FromPort == 80 and\r\n      any(.IpRanges[]; .CidrIp == &quot;0.0.0.0/0&quot;)\r\n    )\r\n  )\r\n&#39; data.json\r\n~~~\r\n~~~json\r\n{\r\n  &quot;GroupName&quot;: &quot;Group3&quot;,\r\n  &quot;IpPermissions&quot;: [\r\n    {\r\n      &quot;FromPort&quot;: 80,\r\n      &quot;IpProtocol&quot;: &quot;tcp&quot;,\r\n      &quot;IpRanges&quot;: [\r\n        {\r\n          &quot;CidrIp&quot;: &quot;1.2.3.4/24&quot;\r\n        },\r\n        {\r\n          &quot;CidrIp&quot;: &quot;0.0.0.0/0&quot;\r\n        }\r\n      ]\r\n    },\r\n    {\r\n      &quot;FromPort&quot;: 6789,\r\n      &quot;IpProtocol&quot;: &quot;tcp&quot;,\r\n      &quot;IpRanges&quot;: [\r\n        {\r\n          &quot;CidrIp&quot;: &quot;1.2.3.4/24&quot;\r\n        }\r\n      ]\r\n    }\r\n  ]\r\n}\r\n~~~\r\n[Demo](https://jqplay.org/s/xIWRZ_UDdN)",
                "title": "jq: Select using 2x seperate-level keys"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1651547262,
                "last_edit_date": 1651547262,
                "creation_date": 1651545732,
                "answer_id": 72094315,
                "question_id": 71438490,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can use parenthesis `()` and `and` appropriately to filter like this: `(.FromPort==80 and (.IpRanges[] | .CidrIp==&quot;0.0.0.0/0&quot; ))`. By doing this, we make sure that **both** conditions are matched by an entry in `IpPermissions`. \r\n\r\nFilter\r\n```\r\n.SecurityGroups | map(select(.IpPermissions[] \r\n| (.FromPort==80 and (.IpRanges[] | .CidrIp==&quot;0.0.0.0/0&quot; ))))\r\n```\r\n\r\nInput\r\n```\r\n{\r\n  &quot;SecurityGroups&quot;: [\r\n    {\r\n      &quot;GroupName&quot;: &quot;Group1&quot;,\r\n      &quot;IpPermissions&quot;: [\r\n        {\r\n          &quot;FromPort&quot;: 80,\r\n          &quot;IpProtocol&quot;: &quot;tcp&quot;,\r\n          &quot;IpRanges&quot;: [\r\n            {\r\n              &quot;CidrIp&quot;: &quot;1.2.3.4/24&quot;\r\n            }\r\n          ]\r\n        },\r\n        {\r\n          &quot;FromPort&quot;: 6789,\r\n          &quot;IpProtocol&quot;: &quot;tcp&quot;,\r\n          &quot;IpRanges&quot;: [\r\n            {\r\n              &quot;CidrIp&quot;: &quot;1.2.3.4/24&quot;\r\n            },\r\n            {\r\n              &quot;CidrIp&quot;: &quot;0.0.0.0/0&quot;\r\n            }\r\n          ]\r\n        }\r\n      ]\r\n    },\r\n    {\r\n      &quot;GroupName&quot;: &quot;Group2&quot;,\r\n      &quot;IpPermissions&quot;: [\r\n        {\r\n          &quot;FromPort&quot;: 443,\r\n          &quot;IpProtocol&quot;: &quot;tcp&quot;,\r\n          &quot;IpRanges&quot;: [\r\n            {\r\n              &quot;CidrIp&quot;: &quot;1.2.3.4/24&quot;\r\n            },\r\n            {\r\n              &quot;CidrIp&quot;: &quot;0.0.0.0/0&quot;\r\n            }\r\n          ]\r\n        },\r\n        {\r\n          &quot;FromPort&quot;: 6788,\r\n          &quot;IpProtocol&quot;: &quot;tcp&quot;,\r\n          &quot;IpRanges&quot;: [\r\n            {\r\n              &quot;CidrIp&quot;: &quot;1.2.3.4/24&quot;\r\n            }\r\n          ]\r\n        }\r\n      ]\r\n    },\r\n    {\r\n      &quot;GroupName&quot;: &quot;Group3&quot;,\r\n      &quot;IpPermissions&quot;: [\r\n        {\r\n          &quot;FromPort&quot;: 80,\r\n          &quot;IpProtocol&quot;: &quot;tcp&quot;,\r\n          &quot;IpRanges&quot;: [\r\n            {\r\n              &quot;CidrIp&quot;: &quot;1.2.3.4/24&quot;\r\n            },\r\n            {\r\n              &quot;CidrIp&quot;: &quot;0.0.0.0/0&quot;\r\n            }\r\n          ]\r\n        },\r\n        {\r\n          &quot;FromPort&quot;: 6789,\r\n          &quot;IpProtocol&quot;: &quot;tcp&quot;,\r\n          &quot;IpRanges&quot;: [\r\n            {\r\n              &quot;CidrIp&quot;: &quot;1.2.3.4/24&quot;\r\n            }\r\n          ]\r\n        }\r\n      ]\r\n    }\r\n  ]\r\n}\r\n```\r\n\r\nOutput\r\n```\r\n[\r\n  {\r\n    &quot;GroupName&quot;: &quot;Group3&quot;,\r\n    &quot;IpPermissions&quot;: [\r\n      {\r\n        &quot;FromPort&quot;: 80,\r\n        &quot;IpProtocol&quot;: &quot;tcp&quot;,\r\n        &quot;IpRanges&quot;: [\r\n          {\r\n            &quot;CidrIp&quot;: &quot;1.2.3.4/24&quot;\r\n          },\r\n          {\r\n            &quot;CidrIp&quot;: &quot;0.0.0.0/0&quot;\r\n          }\r\n        ]\r\n      },\r\n      {\r\n        &quot;FromPort&quot;: 6789,\r\n        &quot;IpProtocol&quot;: &quot;tcp&quot;,\r\n        &quot;IpRanges&quot;: [\r\n          {\r\n            &quot;CidrIp&quot;: &quot;1.2.3.4/24&quot;\r\n          }\r\n        ]\r\n      }\r\n    ]\r\n  }\r\n]\r\n```\r\n\r\nNow you can see only `Group3` is outputted.\r\n\r\nDemo\r\n\r\nhttps://jqplay.org/s/qZvARp_5LE\r\n\r\nOr you could use `any/2` as pmf suggested.\r\n\r\nFilter\r\n```\r\n.SecurityGroups[] \r\n| select(any(.IpPermissions[]; .FromPort==80 \r\nand any(.IpRanges[]; .CidrIp==&quot;0.0.0.0/0&quot;)))\r\n```\r\n\r\nDemo\r\n\r\nhttps://jqplay.org/s/Rw2_dtzwUA",
                "title": "jq: Select using 2x seperate-level keys"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1651547262,
        "creation_date": 1647001531,
        "question_id": 71438490,
        "body_markdown": "Using jq on JSON data ...\r\n\r\nI&#39;m trying to select records where FromPort is 80 and CidrIp is 0.0.0.0/0 within the same element of the record.\r\n\r\nHere is the query:\r\n\r\n    cat data.json |jq -r &#39;.SecurityGroups | .[] | select((.IpPermissions[] | .IpRanges[] | .CidrIp == &quot;0.0.0.0/0&quot;) and (.IpPermissions[] | .FromPort == 80))&#39;\r\n\r\nThe data is below.\r\n\r\nThe results should only select Group3 but instead selects Group1 and Group3. I&#39;ve tried various google searches but am unable to find the answer yet.\r\n\r\nVery grateful for any help.\r\n\r\nData (data.json):\r\n\r\n    {\r\n        &quot;SecurityGroups&quot;: [\r\n            {\r\n                &quot;GroupName&quot;: &quot;Group1&quot;,\r\n                &quot;IpPermissions&quot;: [\r\n                    {\r\n                        &quot;FromPort&quot;: 80,\r\n                        &quot;IpProtocol&quot;: &quot;tcp&quot;,\r\n                        &quot;IpRanges&quot;: [\r\n                            {\r\n                                &quot;CidrIp&quot;: &quot;1.2.3.4/24&quot;\r\n                            }\r\n                        ]\r\n                    },\r\n                    {\r\n                        &quot;FromPort&quot;: 6789,\r\n                        &quot;IpProtocol&quot;: &quot;tcp&quot;,\r\n                        &quot;IpRanges&quot;: [\r\n                            {\r\n                                &quot;CidrIp&quot;: &quot;1.2.3.4/24&quot;\r\n                            },\r\n                            {\r\n                                &quot;CidrIp&quot;: &quot;0.0.0.0/0&quot;\r\n                            }\r\n                        ]\r\n                    }\r\n                ]\r\n            },\r\n            {\r\n                &quot;GroupName&quot;: &quot;Group2&quot;,\r\n                &quot;IpPermissions&quot;: [\r\n                    {\r\n                        &quot;FromPort&quot;: 443,\r\n                        &quot;IpProtocol&quot;: &quot;tcp&quot;,\r\n                        &quot;IpRanges&quot;: [\r\n                            {\r\n                                &quot;CidrIp&quot;: &quot;1.2.3.4/24&quot;\r\n                            },\r\n                            {\r\n                                &quot;CidrIp&quot;: &quot;0.0.0.0/0&quot;\r\n                            }\r\n                        ]\r\n                    },\r\n                    {\r\n                        &quot;FromPort&quot;: 6788,\r\n                        &quot;IpProtocol&quot;: &quot;tcp&quot;,\r\n                        &quot;IpRanges&quot;: [\r\n                            {\r\n                                &quot;CidrIp&quot;: &quot;1.2.3.4/24&quot;\r\n                            }\r\n                        ]\r\n                    }\r\n                ]\r\n            },\r\n            {\r\n                &quot;GroupName&quot;: &quot;Group3&quot;,\r\n                &quot;IpPermissions&quot;: [\r\n                    {\r\n                        &quot;FromPort&quot;: 80,\r\n                        &quot;IpProtocol&quot;: &quot;tcp&quot;,\r\n                        &quot;IpRanges&quot;: [\r\n                            {\r\n                                &quot;CidrIp&quot;: &quot;1.2.3.4/24&quot;\r\n                            },\r\n                            {\r\n                                &quot;CidrIp&quot;: &quot;0.0.0.0/0&quot;\r\n                            }\r\n                        ]\r\n                    },\r\n                    {\r\n                        &quot;FromPort&quot;: 6789,\r\n                        &quot;IpProtocol&quot;: &quot;tcp&quot;,\r\n                        &quot;IpRanges&quot;: [\r\n                            {\r\n                                &quot;CidrIp&quot;: &quot;1.2.3.4/24&quot;\r\n                            }\r\n                        ]\r\n                    }\r\n                ]\r\n            }\r\n        ]\r\n    }\r\n\r\n",
        "link": "https://stackoverflow.com/questions/71438490/jq-select-using-2x-seperate-level-keys",
        "title": "jq: Select using 2x seperate-level keys"
    },
    {
        "tags": [
            "json",
            "elasticsearch",
            "mapping",
            "jq",
            "roles"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1647005901,
                "post_id": 71438815,
                "comment_id": 126270429,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1647005394,
                "last_edit_date": 1647005394,
                "creation_date": 1647004839,
                "answer_id": 71439171,
                "question_id": 71438815,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can use [`has`](https://stedolan.github.io/jq/manual/#has%28key%29) to check for the existence of a key called `all`:\r\n\r\n~~~sh\r\njq &#39;del(.rules) + {\r\n  GROUPS: (.rules | if has(&quot;all&quot;) then .all[] else . end | .field.groups)\r\n}&#39; input.json\r\n~~~\r\n~~~json\r\n{\r\n  &quot;MAPPING_NAME&quot;: &quot;FOO_MAPPING&quot;,\r\n  &quot;roles&quot;: [\r\n    &quot;FOO_ROLE&quot;\r\n  ],\r\n  &quot;GROUPS&quot;: &quot;CN=FO_SEC_GROUP,OU=foo,OU=example,DC=com&quot;\r\n}\r\n{\r\n  &quot;MAPPING_NAME&quot;: &quot;BAR_MAPPING&quot;,\r\n  &quot;roles&quot;: [\r\n    &quot;BAR_ROLE&quot;,\r\n    &quot;builtin_role&quot;\r\n  ],\r\n  &quot;GROUPS&quot;: &quot;CN=BAR_SEC_GROUP,OU=bar,OU=example,DC=com&quot;\r\n}\r\n~~~\r\n[Demo](https://jqplay.org/s/jhx1jgPjfk)\r\n\r\nAnother approach would be to make use of the [Error Suppression Operator](https://stedolan.github.io/jq/manual/#ErrorSuppression%2FOptionalOperator%3A%3F) `?` in combination with the [Alternative Operator](https://stedolan.github.io/jq/manual/#Alternativeoperator%3A%2F%2F) `//`:\r\n\r\n~~~sh\r\njq &#39;del(.rules) + {GROUPS: (.rules | .all[]? // . | .field.groups)}&#39;\r\n~~~\r\n~~~json\r\n{\r\n  &quot;MAPPING_NAME&quot;: &quot;FOO_MAPPING&quot;,\r\n  &quot;roles&quot;: [\r\n    &quot;FOO_ROLE&quot;\r\n  ],\r\n  &quot;GROUPS&quot;: &quot;CN=FO_SEC_GROUP,OU=foo,OU=example,DC=com&quot;\r\n}\r\n{\r\n  &quot;MAPPING_NAME&quot;: &quot;BAR_MAPPING&quot;,\r\n  &quot;roles&quot;: [\r\n    &quot;BAR_ROLE&quot;,\r\n    &quot;builtin_role&quot;\r\n  ],\r\n  &quot;GROUPS&quot;: &quot;CN=BAR_SEC_GROUP,OU=bar,OU=example,DC=com&quot;\r\n}\r\n~~~\r\n[Demo](https://jqplay.org/s/bNod8bfEyY)\r\n\r\nA similar, yet another approach would be to make use of the [Destructuring Alternative Operator](https://stedolan.github.io/jq/manual/#DestructuringAlternativeOperator%3A%3F%2F%2F) `?//`...\r\n",
                "title": "Parse inconsistent JSON file with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1647010305,
        "creation_date": 1647003114,
        "last_edit_date": 1647010305,
        "question_id": 71438815,
        "body_markdown": "I want to parse a json file that is the output for the elasticsearch roles I configured on the cluster. Unfortunatelly its structure is different in some places, due to the fact that some role mappings were added manually and some roles mapping were added with API.\r\n\r\nexample JSON: \r\n```\r\n{\r\n  &quot;MAPPING_NAME&quot;: &quot;FOO_MAPPING&quot;,\r\n  &quot;roles&quot;: [\r\n    &quot;FOO_ROLE&quot;\r\n  ],\r\n  &quot;rules&quot;: {\r\n    &quot;field&quot;: {\r\n      &quot;groups&quot;: &quot;CN=FO_SEC_GROUP,OU=foo,OU=example,DC=com&quot;\r\n    }\r\n  }\r\n}\r\n{\r\n  &quot;MAPPING_NAME&quot;: &quot;BAR_MAPPING&quot;,\r\n  &quot;roles&quot;: [\r\n    &quot;BAR_ROLE&quot;,\r\n    &quot;builtin_role&quot;\r\n  ],\r\n  &quot;rules&quot;: {\r\n    &quot;all&quot;: [\r\n      {\r\n        &quot;field&quot;: {\r\n          &quot;groups&quot;: &quot;CN=BAR_SEC_GROUP,OU=bar,OU=example,DC=com&quot;\r\n        }\r\n      }\r\n    ]\r\n  }\r\n}\r\n```\r\n\r\nI want to transform the above json to look like below, but the the 1st section has &quot;rules -&gt; fields -&gt; groups&quot; and the 2nd section has &quot;rules -&gt; all -&gt; fields -&gt; groups&quot;\r\n\r\n```\r\n{\r\n  &quot;MAPPING_NAME&quot;: &quot;FOO_MAPPING&quot;,\r\n  &quot;roles&quot;: [ \r\n    &quot;FOO_ROLE&quot;\r\n  ],\r\n  &quot;GROUPS&quot;: &quot;CN=FO_SEC_GROUP,OU=foo,OU=example,DC=com&quot;\r\n}\r\n{\r\n  &quot;MAPPING_NAME&quot;: &quot;BAR_MAPPING&quot;,\r\n  &quot;roles&quot;: [\r\n    &quot;BAR_ROLE&quot;,\r\n    &quot;builtin_role&quot;\r\n  ],\r\n  &quot;GROUPS&quot;: &quot;CN=BAR_SEC_GROUP,OU=bar,OU=example,DC=com&quot;\r\n}\r\n```\r\nIs there any way to parse with jq and eventually to transform to CSV format?\r\nThank you. ",
        "link": "https://stackoverflow.com/questions/71438815/parse-inconsistent-json-file-with-jq",
        "title": "Parse inconsistent JSON file with jq"
    },
    {
        "tags": [
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 2435703,
                    "reputation": 27493,
                    "user_id": 2125671,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/13a492143ab4a2575b5a1f500691193c?s=256&d=identicon&r=PG",
                    "display_name": "Philippe",
                    "link": "https://stackoverflow.com/users/2125671/philippe"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1647164703,
                "post_id": 71450728,
                "comment_id": 126297900,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1647123777,
                "last_edit_date": 1647123777,
                "creation_date": 1647117568,
                "answer_id": 71452808,
                "question_id": 71450728,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "&gt; can i define a variable and call the function name contained in the value of that variable?\r\n\r\n\r\nNo. You’d have to write a dispatcher.",
                "title": "jq how to call function by value in variable"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1647123777,
        "creation_date": 1647097788,
        "question_id": 71450728,
        "body_markdown": " here i defined 2 functions and call the second directly:\r\n\r\n    $ jq -n &#39;def f1: &quot;here f1&quot; ; def f2: &quot;here f2&quot;; f2&#39;\r\n    &quot;here f2&quot;\r\n\r\ncan i define a variable and call the function name contained in the value of that variable?  for example:\r\n\r\n    $ jq --arg fp f1 -n &#39;def f1: &quot;here f1&quot; ; def f2: &quot;here f2&quot;; &quot;fp is \\($fp)&quot;&#39;\r\n    &quot;fp is f1&quot;\r\n\r\nI want to call the function that is defined by the fp variable. so the result would be\r\n&quot;fp is here f1&quot;\r\n\r\n",
        "link": "https://stackoverflow.com/questions/71450728/jq-how-to-call-function-by-value-in-variable",
        "title": "jq how to call function by value in variable"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1647191438,
                "last_edit_date": 1647191438,
                "creation_date": 1647188081,
                "answer_id": 71458575,
                "question_id": 71458511,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Put your (dynamic) jq expression inside `\\(…)`, which in turn is part of a (static) string expression `&quot;…&quot;`. If all you want is passing on the input, use the identity function `.`, and your example should read\r\n~~~sh\r\njq -r -e &#39;&quot;my string \\(.)&quot;&#39; &lt;&lt;&lt; &#39;&quot;x&quot;&#39;\r\n~~~\r\n~~~none\r\nmy string x\r\n~~~\r\n[Demo](https://jqplay.org/s/8J3qqLxUcy)\r\n\r\n---\r\nHaving `&quot;my string %s&quot;` as a parameter string, you cannot use it for string interpolation, as string interpolation is a language construct, and `jq` does not provide an `eval` (or similar) function to evaluate a variable&#39;s content as code.\r\n\r\nWhat you can do instead is to (naively) replace `%s` with something else using `sub` or `gsub`:\r\n~~~sh\r\njq -r -e -n --arg f &quot;my string %s&quot; &#39;$f | sub(&quot;%s&quot;; input)&#39; &lt;&lt;&lt; &#39;&quot;x&quot;&#39;\r\n~~~\r\n~~~none\r\nmy string x\r\n~~~\r\n[Demo](https://jqplay.org/s/LRUkgSQoQc)\r\n",
                "title": "How to take string format from command line?"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1647191438,
        "creation_date": 1647187583,
        "last_edit_date": 1647188879,
        "question_id": 71458511,
        "body_markdown": "```\r\nhttps://stedolan.github.io/jq/manual/#Stringinterpolation-%5C(foo)\r\n```\r\n\r\nI want to pass string format from the command line of jq, instead of embedding the format in string interpolation.\r\n\r\nLet&#39;s say the format string is &quot;my string %s&quot;. How to modify the following jq command to take the format string in its argument so that the output will be &quot;my string x&quot;?\r\n\r\n\r\n```\r\njq --arg format &quot;my string %s&quot; -r -e . &lt;&lt;&lt; &#39;&quot;x&quot;&#39;\r\n```",
        "link": "https://stackoverflow.com/questions/71458511/how-to-take-string-format-from-command-line",
        "title": "How to take string format from command line?"
    },
    {
        "tags": [
            "terraform",
            "jq",
            "github-actions"
        ],
        "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": 1647230170,
                "post_id": 71462777,
                "comment_id": 126310387,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 7640818,
                    "reputation": 2608,
                    "user_id": 6084948,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/e2e5d032c08808069ed37e38ff8e81e4?s=256&d=identicon&r=PG",
                    "display_name": "briancaffey",
                    "link": "https://stackoverflow.com/users/6084948/briancaffey"
                },
                "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": 1647231618,
                "post_id": 71462777,
                "comment_id": 126310564,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 7640818,
                    "reputation": 2608,
                    "user_id": 6084948,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/e2e5d032c08808069ed37e38ff8e81e4?s=256&d=identicon&r=PG",
                    "display_name": "briancaffey",
                    "link": "https://stackoverflow.com/users/6084948/briancaffey"
                },
                "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": 1647233650,
                "post_id": 71462777,
                "comment_id": 126310848,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 7,
                "is_accepted": false,
                "score": 7,
                "last_activity_date": 1647234772,
                "creation_date": 1647234772,
                "answer_id": 71463233,
                "question_id": 71462777,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I was able to fix this issue by adding the following setting to the `setup-terraform/@v1` action:\r\n\r\n```\r\n      - uses: hashicorp/setup-terraform@v1\r\n        with:\r\n          terraform_version: 1.1.7\r\n          terraform_wrapper: false &lt;-- added this\r\n```\r\n\r\nMore documentation about this setting can be found here: https://github.com/hashicorp/setup-terraform#inputs",
                "title": "parse error when trying to parse terraform output in GitHub Actions workflow with jq"
            },
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1700570879,
                "last_edit_date": 1700570879,
                "creation_date": 1661163810,
                "answer_id": 73443588,
                "question_id": 71462777,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Whilst @briancaffey&#39;s answer is exactly right, if you need to use the `terraform_wrapper` for other parts of your workflow (e.g. using the output), you can switch out the problematic terraform calls with **terraform-bin** instead.\r\n\r\nIf you also want to run the script outside GitHub Actions, the following workaround will do the trick:\r\n\r\n```bash\r\ntf=terraform-bin\r\ntype &quot;$tf&quot; &gt;/dev/null 2&gt;&amp;1 || tf=terraform\r\n\r\n$tf output -json &gt; /tmp/output.json\r\n```\r\n\r\nSee https://github.com/hashicorp/setup-terraform/issues/167#issuecomment-1090760365 for an issue that mentions the same workaround.\r\n\r\nThis issue is also [fixed in v3.0.0](https://github.com/hashicorp/setup-terraform/releases/tag/v3.0.0).",
                "title": "parse error when trying to parse terraform output in GitHub Actions workflow with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 5,
        "last_activity_date": 1700570879,
        "creation_date": 1647229389,
        "last_edit_date": 1647232357,
        "question_id": 71462777,
        "body_markdown": "I have a GitHub Actions workflow that reads output from a terraform configuration. I&#39;m trying to do this: \r\n\r\n```bash\r\nterraform -chdir=terraform/live/dev output -json &gt; /tmp/output.json\r\n\r\nAPP_URL=$(cat /tmp/output.json | jq -r &#39;.app_url.value&#39;)\r\n```\r\n\r\nI&#39;m getting the following error in the GitHub Action logs: \r\n\r\n```\r\nparse error: Invalid numeric literal at line 1, column 9\r\n```\r\n\r\nI added the following to debug this: \r\n\r\n```bash\r\n# debugging output.json file\r\necho &quot;output.json:&quot;\r\ncat /tmp/output.json\r\n```\r\n\r\nAnd I&#39;m finding that output of `cat /tmp/output.json` is: \r\n\r\n```json\r\n/home/runner/work/_temp/2b622f60-be99-4a29-a295-593b06dde9a8/terraform-bin -chdir=terraform/live/dev output -json\r\n{\r\n  &quot;app_url&quot;: {\r\n    &quot;sensitive&quot;: false,\r\n    &quot;type&quot;: &quot;string&quot;,\r\n    &quot;value&quot;: &quot;https://app.example.com&quot;\r\n  }\r\n}\r\n```\r\n\r\nThis tells me that `jq` can&#39;t parse the temporary file that I wrote the terraform JSON output to because it seems to be adding the command to the file itself: \r\n\r\n```bash\r\n/home/runner/work/_temp/2b622f60-be99-4a29-a295-593b06dde9a8/terraform-bin -chdir=terraform/live/dev output -json\r\n```\r\n\r\nHow can I get the terraform output as JSON and write it to a file without the extra header line that is causing the parse error?\r\n\r\nWhen I run the same commands locally, I do not get this parse error.\r\n\r\nHere&#39;s the code for the section of my GitHub Action workflow that is producing this error: https://github.com/briancaffey/django-step-by-step/blob/main/.github/workflows/terraform_frontend_update.yml#L72-L74\r\n\r\n## Things I have tried\r\n\r\n- using `cd terraform/live/dev` instead of `-chdir=terraform/live/dev` - this resulted in the same error",
        "link": "https://stackoverflow.com/questions/71462777/parse-error-when-trying-to-parse-terraform-output-in-github-actions-workflow-wit",
        "title": "parse error when trying to parse terraform output in GitHub Actions workflow with jq"
    },
    {
        "tags": [
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 16528196,
                    "reputation": 14048,
                    "user_id": 11942268,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/E9Bzv.png?s=256",
                    "display_name": "stackprotector",
                    "link": "https://stackoverflow.com/users/11942268/stackprotector"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1647268544,
                "post_id": 71465246,
                "comment_id": 126322138,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 126762,
                    "reputation": 2054,
                    "user_id": 200509,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/5c1a14b44dbd1ef2af0e264b6417333c?s=256&d=identicon&r=PG",
                    "display_name": "eMPee584",
                    "link": "https://stackoverflow.com/users/200509/empee584"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1655197224,
                "post_id": 71465246,
                "comment_id": 128268892,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1647249771,
                "creation_date": 1647249771,
                "answer_id": 71465413,
                "question_id": 71465246,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "There are two issues with your filter. Firstly, you need to separate parameters to a function with semicolon `;`, not comma `,`:\r\n~~~\r\nscan(&quot;([0-9A-Za-z_]+) == &#39;([0-9A-Za-z_]+)&quot;; &quot;g&quot;)\r\n~~~\r\nSecondly, `scan` with two parameters is not implemented (in contradiction to the [manual](https://stedolan.github.io/jq/manual/#scan%28regex%29%2Cscan%28regex%3Bflags%29)).\r\n~~~\r\njq: error: scan/2 is not defined at &lt;top-level&gt;, line 1:\r\n~~~\r\n\r\nBut as you are using `scan`, your regex will match multiple occurrences anyway, so you may as well just drop it :\r\n~~~\r\n.spec.selector | [scan(&quot;([0-9A-Za-z_]+) == &#39;([0-9A-Za-z_]+)&quot;) | {(.[0]): .[1]}]\r\n~~~\r\n~~~json\r\n[\r\n  {\r\n    &quot;app&quot;: &quot;nginx&quot;\r\n  }\r\n]\r\n~~~\r\n[Demo](https://jqplay.org/s/AVwv7kisxW)\r\n",
                "title": "JQ error Cannot index string with number with scan"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -2,
        "last_activity_date": 1647249771,
        "creation_date": 1647248855,
        "question_id": 71465246,
        "body_markdown": "I have error with scan function, why?\r\n\r\nhttps://jqplay.org/s/E-0qbbzRPS\r\n\r\nI need do this without -r",
        "link": "https://stackoverflow.com/questions/71465246/jq-error-cannot-index-string-with-number-with-scan",
        "title": "JQ error Cannot index string with number with scan"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 10901190,
                    "reputation": 1030,
                    "user_id": 8013411,
                    "user_type": "registered",
                    "accept_rate": 75,
                    "profile_image": "https://lh3.googleusercontent.com/-O9cmovOvunk/AAAAAAAAAAI/AAAAAAAAAEE/i3dHsYf5k8w/s256-rj/photo.jpg",
                    "display_name": "plalanne",
                    "link": "https://stackoverflow.com/users/8013411/plalanne"
                },
                "reply_to_user": {
                    "account_id": 289134,
                    "reputation": 389369,
                    "user_id": 589924,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/b2cf53d5a3d25f95c0db4e025aed4153?s=256&d=identicon&r=PG",
                    "display_name": "ikegami",
                    "link": "https://stackoverflow.com/users/589924/ikegami"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1647291503,
                "post_id": 71472327,
                "comment_id": 126330375,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1647291637,
                "last_edit_date": 1647291637,
                "creation_date": 1647282726,
                "answer_id": 71472605,
                "question_id": 71472327,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "One approach is to transform the document to end up with lines that can be sorted by a tool that handles limited memory, such as the  `sort` unix command-line utility.\r\n\r\nYou can use the following:\r\n\r\n```sh\r\njq -r &#39;&quot;\\( .username )\\u0000\\( tojson )&quot;&#39; a.json |\r\nsort |\r\njq -Rc &#39;. / &quot;\\u0000&quot; | .[-1] | fromjson&#39;\r\n```\r\n\r\nFor the provided input, the above produces the following output:\r\n\r\n```json\r\n{&quot;username&quot;:&quot;user1&quot;,&quot;email&quot;:&quot;email1&quot;,&quot;value&quot;:&quot;10&quot;}\r\n{&quot;username&quot;:&quot;user1&quot;,&quot;email&quot;:&quot;email1&quot;,&quot;value&quot;:&quot;40&quot;}\r\n{&quot;username&quot;:&quot;user1&quot;,&quot;email&quot;:&quot;email1&quot;,&quot;value&quot;:&quot;5&quot;}\r\n{&quot;username&quot;:&quot;user2&quot;,&quot;email&quot;:&quot;email2&quot;,&quot;value&quot;:&quot;30&quot;}\r\n{&quot;username&quot;:&quot;user2&quot;,&quot;email&quot;:&quot;email2&quot;,&quot;value&quot;:&quot;30&quot;}\r\n{&quot;username&quot;:&quot;user3&quot;,&quot;email&quot;:&quot;email1&quot;,&quot;value&quot;:&quot;40&quot;}\r\n{&quot;username&quot;:&quot;user3&quot;,&quot;email&quot;:&quot;email3&quot;,&quot;value&quot;:&quot;15&quot;}\r\n```\r\n\r\nAlong the same lines, you could produce a TSV (`jq -r &#39;&quot;\\( .username )\\t\\( tojson )&quot;&#39;`) you could [inject into a database](https://stackoverflow.com/q/1711631/589924). Then it&#39;s a simple SQL query to extract the sorted JSON documents.\r\n",
                "title": "How to sort a jsonl file by value with the lowest RAM consumption?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1647291637,
        "creation_date": 1647281286,
        "last_edit_date": 1647291491,
        "question_id": 71472327,
        "body_markdown": "I have a very big jsonl file (several million lines).  \r\nI want to sort this file on a given value, but I don&#39;t want to load it entirely in RAM.  \r\nWould you have a solution to suggest ?  \r\n\r\nI had a look at `jq` with a `sort_by` option, but I think the file is not streamed.  \r\n\r\n**Extra note :**  \r\n - The order among a group does not matter\r\n - Having as many outputs as username is also good to me, if the method requires splitting the file.\r\n\r\n**Example :**\r\n\r\nHere is a dummy example of what my input file looks like :  \r\n```jsonl\r\n{&quot;username&quot;: &quot;user1&quot;, &quot;email&quot;: &quot;email1&quot;, &quot;value&quot;: &quot;10&quot;}\r\n{&quot;username&quot;: &quot;user2&quot;, &quot;email&quot;: &quot;email2&quot;, &quot;value&quot;: &quot;30&quot;}\r\n{&quot;username&quot;: &quot;user2&quot;, &quot;email&quot;: &quot;email2&quot;, &quot;value&quot;: &quot;30&quot;}\r\n{&quot;username&quot;: &quot;user1&quot;, &quot;email&quot;: &quot;email1&quot;, &quot;value&quot;: &quot;5&quot;}\r\n{&quot;username&quot;: &quot;user3&quot;, &quot;email&quot;: &quot;email3&quot;, &quot;value&quot;: &quot;15&quot;}\r\n{&quot;username&quot;: &quot;user1&quot;, &quot;email&quot;: &quot;email1&quot;, &quot;value&quot;: &quot;40&quot;}\r\n{&quot;username&quot;: &quot;user3&quot;, &quot;email&quot;: &quot;email1&quot;, &quot;value&quot;: &quot;40&quot;}\r\n```\r\n\r\nHere is the output I would like :  \r\n```jsonl\r\n{&quot;username&quot;: &quot;user1&quot;, &quot;email&quot;: &quot;email1&quot;, &quot;value&quot;: &quot;10&quot;}\r\n{&quot;username&quot;: &quot;user1&quot;, &quot;email&quot;: &quot;email1&quot;, &quot;value&quot;: &quot;5&quot;}\r\n{&quot;username&quot;: &quot;user1&quot;, &quot;email&quot;: &quot;email1&quot;, &quot;value&quot;: &quot;40&quot;}\r\n{&quot;username&quot;: &quot;user2&quot;, &quot;email&quot;: &quot;email2&quot;, &quot;value&quot;: &quot;30&quot;}\r\n{&quot;username&quot;: &quot;user2&quot;, &quot;email&quot;: &quot;email2&quot;, &quot;value&quot;: &quot;30&quot;}\r\n{&quot;username&quot;: &quot;user3&quot;, &quot;email&quot;: &quot;email3&quot;, &quot;value&quot;: &quot;15&quot;}\r\n{&quot;username&quot;: &quot;user3&quot;, &quot;email&quot;: &quot;email1&quot;, &quot;value&quot;: &quot;40&quot;}\r\n```",
        "link": "https://stackoverflow.com/questions/71472327/how-to-sort-a-jsonl-file-by-value-with-the-lowest-ram-consumption",
        "title": "How to sort a jsonl file by value with the lowest RAM consumption?"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq",
            "cicd"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 13789219,
                    "reputation": 53538,
                    "user_id": 9952196,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/cd1a3f93172eb89e221c98e35e6e22b3?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Shawn",
                    "link": "https://stackoverflow.com/users/9952196/shawn"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1647311588,
                "post_id": 71476198,
                "comment_id": 126334199,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1647315260,
                "last_edit_date": 1647315260,
                "creation_date": 1647311865,
                "answer_id": 71476404,
                "question_id": 71476198,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Just use `.` filter to identify the object `vulnerabilities`.\r\n\r\nthese is some cases below\r\n\r\n```bash\r\n$ jq &#39;.vulnerabilities&#39; &lt;&lt;END\r\nheredoc&gt; {&quot;version&quot;:&quot;14.0.4&quot;,&quot;vulnerabilities&quot;:[{&quot;id&quot;:&quot;64e69d1185ecc48a1943141dcb6dbd628548e725f7cef70d57403c412321aaa0&quot;,&quot;category&quot;:&quot;secret_detection&quot;}]}\r\nheredoc&gt; END\r\n[\r\n  {\r\n    &quot;id&quot;: &quot;64e69d1185ecc48a1943141dcb6dbd628548e725f7cef70d57403c412321aaa0&quot;,\r\n    &quot;category&quot;: &quot;secret_detection&quot;\r\n  }\r\n]\r\n```\r\n\r\nif `vulnerabilities` null, then jq will return null\r\n\r\n```bash\r\n$ jq &#39;.vulnerabilities&#39; &lt;&lt;END\r\n{&quot;version&quot;:&quot;14.0.4&quot;,&quot;vulnerabilities&quot;:null}\r\nEND\r\nnull\r\n```\r\n\r\nthen with pipe `|`, you can change it to any output you wanted.\r\n\r\n\r\n- change null to []: `.vulnerabilities | if . == null then [] else . end`\r\n\r\n- filter empty array: `.vulnerabilities | select(length &gt; 0)`\r\n\r\n\r\n\r\nFor further information about jq filters, you can read the [jq manual](https://stedolan.github.io/jq/manual/).",
                "title": "jq - return array value if its length is not null"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1647347472,
                "last_edit_date": 1647347472,
                "creation_date": 1647311875,
                "answer_id": 71476407,
                "question_id": 71476198,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Firstly, please note that in the JSON world, it is important to distinguish\r\nbetween `[]` (the empty array), the values `0` and `null`, and the absence of a value (e.g. as the result of the absence of a key in an object).\r\n\r\nIn the following, I&#39;ll assume that the output should be the value of .vulnerabilities\r\nif it is not `[]&#39;, or nothing otherwise:\r\n```\r\n&lt; sample.json jq &#39;\r\n  select(.vulnerabilities != []).vulnerabilities\r\n&#39;\r\n```\r\n---\r\n\r\nIf the goal were to differentiate between two cases based on the return code from jq, you could use the -e command-line option.\r\n",
                "title": "jq - return array value if its length is not null"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1647332237,
                "creation_date": 1647332237,
                "answer_id": 71478953,
                "question_id": 71476198,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "- Assuming, by &quot;print the value of the vulnerabilities key&quot; you mean the value of an item&#39;s `id` field. You can retrieve it using `.id` and have it extracted to bash with the `-r` option.\r\n- If in case the array is not empty you want *all* of the &quot;keys&quot;, iterate over  the array using `.[]`. If you just wanted a specific key, let&#39;s say the first, address it using a 0-based index: `.[0]`.\r\n- To check the length of an array there is a dedicated `length` builtin. However, as your final goal is to extract, you can also attempt to do so right anyway, suppress a potential unreachability error using the `?` operator, and have your bash script read an appropriate exit status using the `-e` option.\r\n\r\nYour bash script then could include the following snippet\r\n~~~sh\r\nif key=$(jq -re &#39;.vulnerabilities[0].id?&#39; report.json)\r\nthen\r\n  # If the array was not empty, $key contains the first key\r\n  echo &quot;There is a vulnerability in key $key.&quot;\r\nfi\r\n\r\n# or\r\n\r\nif keys=$(jq -re &#39;.vulnerabilities[].id?&#39; report.json)\r\nthen\r\n  # If the array was not empty, $keys contains all the keys\r\n  for k in $keys\r\n  do echo &quot;There is a vulnerability in key $k.&quot;\r\n  done\r\nfi\r\n~~~",
                "title": "jq - return array value if its length is not null"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1651228821,
                "creation_date": 1651228821,
                "answer_id": 72056669,
                "question_id": 71476198,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can use `if-then-else`.\r\n\r\nFilter\r\n```\r\nif (.vulnerabilities | length) &gt; 0 then {vulnerabilities} else empty end\r\n```\r\nInput\r\n```\r\n{\r\n  &quot;version&quot;: &quot;1.1.1&quot;,\r\n  &quot;vulnerabilities&quot;: [\r\n    {\r\n      &quot;id&quot;: &quot;111&quot;,\r\n      &quot;category&quot;: &quot;secret_detection&quot;\r\n    },\r\n    {\r\n      &quot;id&quot;: &quot;112&quot;,\r\n      &quot;category&quot;: &quot;secret_detection&quot;\r\n    }\r\n  ]\r\n}\r\n{\r\n  &quot;version&quot;: &quot;1.2.1&quot;,\r\n  &quot;vulnerabilities&quot;: [\r\n    {\r\n      &quot;id&quot;: &quot;121&quot;,\r\n      &quot;category&quot;: &quot;secret_detection 2&quot;\r\n    }\r\n  ]\r\n}\r\n{\r\n  &quot;version&quot;: &quot;3.1.1&quot;,\r\n  &quot;vulnerabilities&quot;: []\r\n}\r\n{\r\n  &quot;version&quot;: &quot;4.1.1&quot;,\r\n  &quot;vulnerabilities&quot;: [\r\n    {\r\n      &quot;id&quot;: &quot;411&quot;,\r\n      &quot;category&quot;: &quot;secret_detection 4&quot;\r\n    },\r\n    {\r\n      &quot;id&quot;: &quot;412&quot;,\r\n      &quot;category&quot;: &quot;secret_detection&quot;\r\n    },\r\n    {\r\n      &quot;id&quot;: &quot;413&quot;,\r\n      &quot;category&quot;: &quot;secret_detection&quot;\r\n    }\r\n  ]\r\n}\r\n```\r\nOutput\r\n```\r\n{\r\n  &quot;vulnerabilities&quot;: [\r\n    {\r\n      &quot;id&quot;: &quot;111&quot;,\r\n      &quot;category&quot;: &quot;secret_detection&quot;\r\n    },\r\n    {\r\n      &quot;id&quot;: &quot;112&quot;,\r\n      &quot;category&quot;: &quot;secret_detection&quot;\r\n    }\r\n  ]\r\n}\r\n{\r\n  &quot;vulnerabilities&quot;: [\r\n    {\r\n      &quot;id&quot;: &quot;121&quot;,\r\n      &quot;category&quot;: &quot;secret_detection 2&quot;\r\n    }\r\n  ]\r\n}\r\n{\r\n  &quot;vulnerabilities&quot;: [\r\n    {\r\n      &quot;id&quot;: &quot;411&quot;,\r\n      &quot;category&quot;: &quot;secret_detection 4&quot;\r\n    },\r\n    {\r\n      &quot;id&quot;: &quot;412&quot;,\r\n      &quot;category&quot;: &quot;secret_detection&quot;\r\n    },\r\n    {\r\n      &quot;id&quot;: &quot;413&quot;,\r\n      &quot;category&quot;: &quot;secret_detection&quot;\r\n    }\r\n  ]\r\n}\r\n```\r\n\r\nDemo\r\n\r\nhttps://jqplay.org/s/wicmr4uVRm\r\n\r\n\r\n",
                "title": "jq - return array value if its length is not null"
            }
        ],
        "is_answered": true,
        "answer_count": 4,
        "score": 4,
        "last_activity_date": 1722498451,
        "creation_date": 1647309675,
        "last_edit_date": 1722498451,
        "question_id": 71476198,
        "body_markdown": "I have a report.json generated by a gitlab pipeline. \r\nIt looks like:\r\n\r\n    {&quot;version&quot;:&quot;14.0.4&quot;,&quot;vulnerabilities&quot;:[{&quot;id&quot;:&quot;64e69d1185ecc48a1943141dcb6dbd628548e725f7cef70d57403c412321aaa0&quot;,&quot;category&quot;:&quot;secret_detection&quot;....and so on\r\n\r\nIf no vulnerabilities found, then &quot;vulnerabilities&quot;:[]. I&#39;m trying to come up with a bash script that would check if vulnerabilities length is null or not. If not, print the value of the vulnerabilities key. Sadly, I&#39;m very far from scripting genius, so it&#39;s been a struggle.\r\nWhile searching web for a solution to this, I&#39;ve come across jq. It seems like select() should do the job.\r\nI&#39;ve tried:\r\n\r\n    jq &quot;select(.vulnerabilities!= null)&quot; report.json\r\nbut it returned `{&quot;version&quot;:&quot;14.0.4&quot;,&quot;vulnerabilities&quot;:[{&quot;id&quot;:&quot;64e69d1185ecc48a194314...` instead of expected `&quot;vulnerabilities&quot;:[{&quot;id&quot;:&quot;64e69d1185ecc48a194314...`\r\nand \r\n\r\n    map(select(.vulnerabilities != null)) report.json\r\n\r\nreturns &quot;No matches found&quot;\r\n\r\nWould you mind pointing out what&#39;s wrong apart from my 0 experience with bash and JSON parsing?",
        "link": "https://stackoverflow.com/questions/71476198/jq-return-array-value-if-its-length-is-not-null",
        "title": "jq - return array value if its length is not null"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 3959308,
                    "reputation": 53394,
                    "user_id": 3266847,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/U0oyt.png?s=256",
                    "display_name": "Benjamin W.",
                    "link": "https://stackoverflow.com/users/3266847/benjamin-w"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1647312608,
                "post_id": 71476376,
                "comment_id": 126334390,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 3959308,
                    "reputation": 53394,
                    "user_id": 3266847,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/U0oyt.png?s=256",
                    "display_name": "Benjamin W.",
                    "link": "https://stackoverflow.com/users/3266847/benjamin-w"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1647312666,
                "post_id": 71476376,
                "comment_id": 126334397,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 3959308,
                    "reputation": 53394,
                    "user_id": 3266847,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/U0oyt.png?s=256",
                    "display_name": "Benjamin W.",
                    "link": "https://stackoverflow.com/users/3266847/benjamin-w"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1647312731,
                "post_id": 71476376,
                "comment_id": 126334414,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 7682495,
                    "reputation": 488,
                    "user_id": 6246475,
                    "user_type": "registered",
                    "accept_rate": 57,
                    "profile_image": "https://lh6.googleusercontent.com/-5AO-AY4sOtc/AAAAAAAAAAI/AAAAAAAAAVc/3igN9St85II/s256-rj/photo.jpg",
                    "display_name": "Koshur",
                    "link": "https://stackoverflow.com/users/6246475/koshur"
                },
                "reply_to_user": {
                    "account_id": 3959308,
                    "reputation": 53394,
                    "user_id": 3266847,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/U0oyt.png?s=256",
                    "display_name": "Benjamin W.",
                    "link": "https://stackoverflow.com/users/3266847/benjamin-w"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1647313018,
                "post_id": 71476376,
                "comment_id": 126334467,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1647320588,
                "creation_date": 1647320588,
                "answer_id": 71477292,
                "question_id": 71476376,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "For the first task:\r\n\r\n    jq -s . vf.json\r\n\r\nThe second task seems somewhat misguided as it would almost certainly be wiser to combine the same-key values into an array, which can be done like so:\r\n\r\n    jq -n &#39;reduce inputs as $in ({}; ($in|keys[0]) as $k | .[$k] += [$in[$k]] )&#39;  vf.json\r\n\r\nThis solution is, however, easily modified to achieve the string-valued result if that is really what you want:\r\n\r\n    jq -n &#39;\r\n      reduce inputs as $in ({};\r\n        ($in|keys[0]) as $k | .[$k] += [$in[$k]] )\r\n      | map_values(join(&quot;,&quot;))\r\n    &#39; vf.json",
                "title": "Convert a file with json on each line to single json and add values with same keys as comma separated with JQ"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1647320588,
        "creation_date": 1647311590,
        "last_edit_date": 1647315784,
        "question_id": 71476376,
        "body_markdown": "I have a file `vf.json` that looks like below:\r\n\r\n    {&quot;ens1f0&quot;: &quot;ens1f0v1&quot;}\r\n    {&quot;ens1f0&quot;: &quot;ens1f0v0&quot;}\r\n    {&quot;ens1f1&quot;: &quot;ens1f1v1&quot;}\r\n    {&quot;ens1f1&quot;: &quot;ens1f1v0&quot;}\r\n    {&quot;ens2f1&quot;: &quot;ens2f1v0&quot;}\r\n\r\nI want to transform it into a single json structure like this:\r\n\r\n    {\r\n        {&quot;ens1f0&quot;: &quot;ens1f0v1&quot;},\r\n        {&quot;ens1f0&quot;: &quot;ens1f0v0&quot;},\r\n        {&quot;ens1f1&quot;: &quot;ens1f1v1&quot;},\r\n        {&quot;ens1f1&quot;: &quot;ens1f1v0&quot;}\r\n    }\r\n\r\nI also want to add values with same keys as comma separated inside same key, so that will make above json look this this\r\n\r\n    {\r\n        {&quot;ens1f0&quot;: &quot;ens1f0v1, ens1f0v0&quot;},\r\n        {&quot;ens1f1&quot;: &quot;ens1f1v1, ens1f1v0&quot;}\r\n    }\r\n\r\nSo far, I have only been able to do this\r\n\r\n    # jq -s &#39;.&#39; vf.json\r\n    [\r\n      {\r\n        &quot;ens1f0&quot;: &quot;ens1f0v1&quot;\r\n      },\r\n      {\r\n        &quot;ens1f0&quot;: &quot;ens1f0v0&quot;\r\n      },\r\n      {\r\n        &quot;ens1f1&quot;: &quot;ens1f1v1&quot;\r\n      },\r\n      {\r\n        &quot;ens1f1&quot;: &quot;ens1f1v0&quot;\r\n      },\r\n      {\r\n        &quot;ens2f1&quot;: &quot;ens2f1v0&quot;\r\n      },\r\n      {\r\n        &quot;ens2f0&quot;: &quot;ens2f0v0&quot;\r\n      }\r\n    ]\r\n\r\nThis gives a list of those elements, I do not want a list. I want a json so that i can query it with the key to get the value.\r\n\r\nEDIT:\r\n\r\nWith reduce filters, I am able to merge multiple objects into one:\r\n\r\n```jq -s &#39;. | add&#39; vf.json ```\r\n\r\n    {\r\n      &quot;ens1f0&quot;: &quot;ens1f0v0&quot;,\r\n      &quot;ens1f1&quot;: &quot;ens1f1v0&quot;,\r\n      &quot;ens2f1&quot;: &quot;ens2f1v0&quot;,\r\n      &quot;ens2f0&quot;: &quot;ens2f0v0&quot;\r\n    }\r\n\r\nBut I am losing data with this..as there are duplicate keys with differing values. How do I add it like:\r\n\r\n    {\r\n        &quot;ens1f0&quot;: &quot;ens1f0v1,ens1f0v0&quot;,\r\n        &quot;ens1f1&quot;: &quot;ens1f1v1,ens1f1v0&quot;,\r\n        &quot;ens2f1&quot;: &quot;ens2f1v0&quot;\r\n    }",
        "link": "https://stackoverflow.com/questions/71476376/convert-a-file-with-json-on-each-line-to-single-json-and-add-values-with-same-ke",
        "title": "Convert a file with json on each line to single json and add values with same keys as comma separated with JQ"
    },
    {
        "tags": [
            "shell",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1647387195,
                "post_id": 71490175,
                "comment_id": 126357417,
                "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": 1647387294,
                "post_id": 71490175,
                "comment_id": 126357435,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 24509533,
                    "reputation": 1,
                    "user_id": 18424040,
                    "user_type": "registered",
                    "profile_image": "https://lh3.googleusercontent.com/a/AATXAJwBh8bySl9fcmLN47SuECsNZK053mnjCwzRt9iv=k-s256",
                    "display_name": "Shae Eastman",
                    "link": "https://stackoverflow.com/users/18424040/shae-eastman"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1647393564,
                "post_id": 71490175,
                "comment_id": 126358474,
                "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": 1660465375,
                "post_id": 71490175,
                "comment_id": 129535748,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1663855518,
                "last_edit_date": 1663855518,
                "creation_date": 1663703190,
                "answer_id": 73791904,
                "question_id": 71490175,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "It&#39;s not entirely clear where the value for `name` in the output comes from in your question, but let&#39;s assume for a moment that it is the first part until the underscore of the `name` from the input. The the following produces your required output:\r\n\r\n```\r\n.items | map(\r\n  .metadata\r\n  | select(.random_field.&quot;foo/foo&quot; == &quot;true&quot;)\r\n  | { name: .name|split(&quot;_&quot;)|first, data: .name }\r\n)\r\n```\r\n\r\nOutput:\r\n\r\n```json\r\n[\r\n  {\r\n    &quot;name&quot;: &quot;test&quot;,\r\n    &quot;data&quot;: &quot;test_data&quot;\r\n  }\r\n]\r\n```",
                "title": "jq - generate list of dictionaries instead of list of strings"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1663855518,
        "creation_date": 1647387135,
        "last_edit_date": 1647395129,
        "question_id": 71490175,
        "body_markdown": "The following command: \r\n\r\n`cat foo | jq -r &#39;[.items[] | select(.metadata.random_field[&quot;foo/foo&quot;] == &quot;true&quot;) | .metadata.name]&#39;`\r\nresults in\r\n```\r\n[\r\n  &quot;test_data&quot;\r\n]\r\n```\r\nI would like the following output to be:\r\n\r\n```\r\n[\r\n  {&quot;name&quot;:&quot;test&quot;, &quot;data&quot;:&quot;test_data&quot;}\r\n]\r\n```\r\n\r\nfoo\r\n```\r\n{\r\n    &quot;apiVersion&quot;: &quot;v1&quot;,\r\n    &quot;items&quot;:[\r\n              {\r\n                 &quot;metadata&quot;: {\r\n                 &quot;random_field&quot;: {\r\n                    &quot;foo/foo&quot;: &quot;true&quot;\r\n                 },\r\n                &quot;creationTimestamp&quot;: &quot;2022-03-09T21:54:08Z&quot;,\r\n                &quot;name&quot;: &quot;test_data&quot;\r\n                }\r\n              }\r\n    ]\r\n}\r\n```\r\n\r\nUPDATE: added test data so the point can be illustrated properly.\r\n",
        "link": "https://stackoverflow.com/questions/71490175/jq-generate-list-of-dictionaries-instead-of-list-of-strings",
        "title": "jq - generate list of dictionaries instead of list of strings"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1647387774,
                "creation_date": 1647387774,
                "answer_id": 71490246,
                "question_id": 71490218,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "[Construct](https://stedolan.github.io/jq/manual/#ObjectConstruction%3A%7B%7D) a new object using `{x}` which is a shorthand for `{x: .x}`.\r\n\r\n~~~sh\r\njq &#39;{apps}&#39; sample.json\r\n~~~\r\n~~~json\r\n{\r\n  &quot;apps&quot;: [\r\n    {\r\n      &quot;name&quot;: &quot;app1&quot;\r\n    },\r\n    {\r\n      &quot;name&quot;: &quot;app2&quot;\r\n    },\r\n    {\r\n      &quot;name&quot;: &quot;app3&quot;\r\n    }\r\n  ]\r\n}\r\n~~~\r\n[Demo](https://jqplay.org/s/YoOjENRFVu)\r\n\r\nAnd likewise with `{test}`.",
                "title": "Extract JSON including key with jq command"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1649558567,
                "creation_date": 1649558567,
                "answer_id": 71813390,
                "question_id": 71490218,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can do\r\n\r\n```\r\n{apps}, {test}\r\n```\r\n\r\nDemo\r\n\r\nhttps://jqplay.org/s/P_9cc2uANV",
                "title": "Extract JSON including key with jq command"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1649558567,
        "creation_date": 1647387536,
        "last_edit_date": 1647390740,
        "question_id": 71490218,
        "body_markdown": "\r\nHERE is sample json file.\r\n\r\nsample.json\r\n```\r\n{\r\n  &quot;apps&quot;: [\r\n    {\r\n      &quot;name&quot;: &quot;app1&quot;\r\n    },\r\n    {\r\n      &quot;name&quot;: &quot;app2&quot;\r\n    },\r\n    {\r\n      &quot;name&quot;: &quot;app3&quot;\r\n    }\r\n  ],\r\n  &quot;test&quot;: [\r\n    {\r\n      &quot;name&quot;: &quot;test1&quot;\r\n    },\r\n    {\r\n      &quot;name&quot;: &quot;test2&quot;\r\n    }\r\n  ]\r\n}\r\n```\r\n\r\nI want to divide the above JSON file into the following two files.\r\nI want to manage the entire configuration file with one JSON, divide the file when necessary and give it to the tool.\r\n\r\napps.json\r\n```\r\n{\r\n  &quot;apps&quot;: [\r\n    {\r\n      &quot;name&quot;: &quot;app1&quot;\r\n    },\r\n    {\r\n      &quot;name&quot;: &quot;app2&quot;\r\n    },\r\n    {\r\n      &quot;name&quot;: &quot;app3&quot;\r\n    }\r\n}\r\n```\r\n\r\ntest.json\r\n```\r\n{\r\n  &quot;test&quot;: [\r\n    {\r\n      &quot;name&quot;: &quot;test1&quot;\r\n    },\r\n    {\r\n      &quot;name&quot;: &quot;test1&quot;\r\n    }\r\n  ]\r\n}\r\n```\r\n\r\n--- \r\n`jq .apps sample.json` outputs only value.\r\n\r\n```\r\n[\r\n// Not contain the key\r\n  {\r\n    &quot;name&quot;: &quot;app1&quot;\r\n  },\r\n  {\r\n    &quot;name&quot;: &quot;app2&quot;\r\n  },\r\n  {\r\n    &quot;name&quot;: &quot;app3&quot;\r\n  }\r\n]\r\n```\r\n\r\nCan you have any idea?\r\n",
        "link": "https://stackoverflow.com/questions/71490218/extract-json-including-key-with-jq-command",
        "title": "Extract JSON including key with jq command"
    },
    {
        "tags": [
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 289134,
                    "reputation": 389369,
                    "user_id": 589924,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/b2cf53d5a3d25f95c0db4e025aed4153?s=256&d=identicon&r=PG",
                    "display_name": "ikegami",
                    "link": "https://stackoverflow.com/users/589924/ikegami"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1647388981,
                "post_id": 71490304,
                "comment_id": 126357723,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 3377022,
                    "reputation": 13682,
                    "user_id": 2834978,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/ff9af10001f37bc0de566ca2caf2f558?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "LMC",
                    "link": "https://stackoverflow.com/users/2834978/lmc"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1647390403,
                "post_id": 71490304,
                "comment_id": 126357948,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1526413,
                    "reputation": 13993,
                    "user_id": 1424739,
                    "user_type": "registered",
                    "accept_rate": 17,
                    "profile_image": "https://www.gravatar.com/avatar/19d3c927744b5ad3b94afbf88e1c3844?s=256&d=identicon&r=PG",
                    "display_name": "user1424739",
                    "link": "https://stackoverflow.com/users/1424739/user1424739"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1647391444,
                "post_id": 71490304,
                "comment_id": 126358108,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1647389269,
                "last_edit_date": 1647389269,
                "creation_date": 1647388961,
                "answer_id": 71490373,
                "question_id": 71490304,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "`2022-03-14T04:00:00Z` is `1647230400`, not `1647234000`.\r\n\r\nI get the correct result with jq 1.6 on Ubuntu:\r\n\r\n```none\r\n$ jq fromdateiso8601 &lt;&lt;&lt;&#39;&quot;2022-03-14T04:00:00Z&quot;&#39;\r\n1647230400\r\n```\r\n\r\nI get the same incorrect result with jq 1.6 on Cygwin:\r\n\r\n```none\r\n$ jq fromdateiso8601 &lt;&lt;&lt;&#39;&quot;2022-03-14T04:00:00Z&quot;&#39;\r\n1647234000\r\n```\r\n\r\n(`fromdateiso8601` is simply not supported on Windows.)\r\n\r\nThere&#39;s a bug somewhere, but I don&#39;t know where.",
                "title": "How to interprete an iso8601 string with daylight saving info?"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1647391378,
        "creation_date": 1647388324,
        "last_edit_date": 1647391378,
        "question_id": 71490304,
        "body_markdown": "The following two iso8601 strings both mean the beginning of the respective day. But since EST has been changed to EDT between the two dates, the second time string is interpreted as 1am instead of 0am. Is there a way to let jq be aware of the daylight saving when processing an iso8601 string?\r\n\r\n```\r\n$ jq fromdateiso8601 &lt;&lt;&lt; &#39;&quot;2022-03-11T05:00:00Z&quot;&#39;\r\n1646974800\r\n$ jq fromdateiso8601 &lt;&lt;&lt; &#39;&quot;2022-03-14T04:00:00Z&quot;&#39;\r\n1647234000\r\n$ TZ=America/New_York date --date=@1646974800\r\nFri Mar 11 00:00:00 EST 2022\r\n$ TZ=America/New_York date --date=@1647234000\r\nMon Mar 14 01:00:00 EDT 2022\r\n$ jq --version\r\njq-1.6\r\n```\r\n\r\nI run jq on macOSX.\r\n\r\nEDIT:\r\n\r\n```\r\n$ jq -r todateiso8601 &lt;&lt;&lt;&#39;1647230400&#39;\r\n2022-03-14T04:00:00Z\r\n$ date -d &#39;2022-03-14T04:00:00Z&#39; &#39;+%s&#39;\r\n1647230400\r\n$ date -d @1647230400 --iso=seconds --utc\r\n2022-03-14T04:00:00+00:00\r\n```",
        "link": "https://stackoverflow.com/questions/71490304/how-to-interprete-an-iso8601-string-with-daylight-saving-info",
        "title": "How to interprete an iso8601 string with daylight saving info?"
    },
    {
        "tags": [
            "sed",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 166270,
                    "reputation": 135171,
                    "user_id": 390278,
                    "user_type": "registered",
                    "accept_rate": 86,
                    "profile_image": "https://www.gravatar.com/avatar/84715fec547362389d02f5be0ed12814?s=256&d=identicon&r=PG",
                    "display_name": "Jeff Mercado",
                    "link": "https://stackoverflow.com/users/390278/jeff-mercado"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1647395392,
                "post_id": 71490575,
                "comment_id": 126358746,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1647396074,
                "last_edit_date": 1647396074,
                "creation_date": 1647395726,
                "answer_id": 71490983,
                "question_id": 71490575,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Json objects are inherently unordered so it doesn&#39;t make sense to sort one. However jq does treat it ordered so if you want to restructure this object so keys are ordered by some condition, you could do this:\r\n\r\n```\r\nto_entries | sort_by(.value.amount) | from_entries\r\n```\r\n\r\nReread the object as a collection of key/value pairs, sort the pairs by what you want, then recreate the object.",
                "title": "How to sort this json file with either jq or sed"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1748012595,
                "creation_date": 1748012595,
                "answer_id": 79635764,
                "question_id": 71490575,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Found a solution that works recursively:\r\n\r\n```shell\r\n$ jq --sort-keys \\. data.json\r\n```\r\n\r\nIf also wish to sort the arrays use:\r\n\r\n```shell\r\n$ jq --sort-keys &#39;walk(if type == &quot;array&quot; then sort else . end)&#39; data.json\r\n```",
                "title": "How to sort this json file with either jq or sed"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1748012595,
        "creation_date": 1647391303,
        "question_id": 71490575,
        "body_markdown": "    {\r\n      &quot;adfdasfdafdfds&quot;: {\r\n        &quot;amount&quot;: 43,\r\n        &quot;mints&quot;: [\r\n          &quot;adfdasffd&quot;,\r\n          &quot;dsafdsafdsfds&quot;\r\n        ]\r\n      },\r\n      &quot;dfsfsdfdsf&quot;: {\r\n        &quot;amount&quot;: 1020,\r\n        &quot;mints&quot;: [\r\n          &quot;dfsfsads&quot;\r\n        ]\r\n      },\r\n      &quot;sdfsdfdfgf&quot;: {\r\n        &quot;amount&quot;: 1,\r\n        &quot;mints&quot;: [\r\n          &quot;fsfdsfdfds&quot;\r\n        ]\r\n\r\nHow to sort this code by amount in either jq or sed/awk ?\r\n\r\nThe problem is that the first part isn&#39;t defined. \r\n",
        "link": "https://stackoverflow.com/questions/71490575/how-to-sort-this-json-file-with-either-jq-or-sed",
        "title": "How to sort this json file with either jq or sed"
    },
    {
        "tags": [
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 106364,
                    "reputation": 165516,
                    "user_id": 283366,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/9ad213d8adabe4b64c2d53c5e0e3cab4?s=256&d=identicon&r=PG",
                    "display_name": "Phil",
                    "link": "https://stackoverflow.com/users/283366/phil"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1647402950,
                "post_id": 71491565,
                "comment_id": 126359893,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 16219645,
                    "reputation": 133,
                    "user_id": 11711488,
                    "user_type": "registered",
                    "profile_image": "https://lh5.googleusercontent.com/-b4PcVTkV1sg/AAAAAAAAAAI/AAAAAAAAAAA/ACHi3rd7cJIqVaDUmh3UOq6vidDpP0_v9g/s256-rj/photo.jpg",
                    "display_name": "deals my",
                    "link": "https://stackoverflow.com/users/11711488/deals-my"
                },
                "reply_to_user": {
                    "account_id": 106364,
                    "reputation": 165516,
                    "user_id": 283366,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/9ad213d8adabe4b64c2d53c5e0e3cab4?s=256&d=identicon&r=PG",
                    "display_name": "Phil",
                    "link": "https://stackoverflow.com/users/283366/phil"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1647452056,
                "post_id": 71491565,
                "comment_id": 126377102,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 106364,
                    "reputation": 165516,
                    "user_id": 283366,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/9ad213d8adabe4b64c2d53c5e0e3cab4?s=256&d=identicon&r=PG",
                    "display_name": "Phil",
                    "link": "https://stackoverflow.com/users/283366/phil"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1647462009,
                "post_id": 71491565,
                "comment_id": 126380473,
                "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": 1660465465,
                "post_id": 71491565,
                "comment_id": 129535763,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1689948509,
                "creation_date": 1689948509,
                "answer_id": 76738727,
                "question_id": 71491565,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I assume that you want to parse a string like `&quot;Key=a,Value=b Key=c,Value=d&quot;` into a JSON object. The assumptions are that key-value pairs are separated by a single space, the key is separated from the value by a comma and that there are no spaces or commas in either the key or value. You are allowed to have as many key-value pairs as you want. The key and the value don&#39;t have to appear in that order, e.g. a key-value pair may be encoded as `Value=a,Key=b`\r\n\r\nGiven these assumptions, the following snippet parses a string in the above format into a JSON object:\r\n\r\n```bash\r\nKEY_VALUE_PAIRS=&quot;Key=a,Value=b Key=c,Value=d&quot;\r\necho &quot;\\&quot;$KEY_VALUE_PAIRS\\&quot;&quot; |\r\n    jq &#39;[\r\n        split(&quot; &quot;) | .[] | split(&quot;,&quot;) |\r\n            { (.[]|select(startswith(&quot;Key=&quot;))[4:]) :\r\n                .[]|select(startswith(&quot;Value=&quot;))[6:]}\r\n    ] | add | . // {}&#39;\r\n```\r\nResult:\r\n```json\r\n{\r\n  &quot;a&quot;: &quot;b&quot;,\r\n  &quot;c&quot;: &quot;d&quot;\r\n}\r\n```\r\n\r\nDetails for the different parts:\r\n\r\n* `split(&quot; &quot;) | .[] | split(&quot;,&quot;)` - split the whole string into an array of arrays. Each inner array has two string elements, one for the key, one for the value.\r\n* `{ (.[]|select(startswith(&quot;Key=&quot;))[4:]) : .[]|select(startswith(&quot;Value=&quot;))[6:]}` - convert each inner array into an object with a single element, where the key is taken from the array element that starts with `Key=` and the value is taken from the array element that starts with `Value=`. The `Key=` and `Value=` prefixes are stripped.\r\n* `[ ... ] | add` - merge all objects into a single object containing all key-value pairs\r\n* `. // {}` - if the string doesn&#39;t contain any pairs, return an empty object instead of `null`\r\n\r\nIntegrating the above snippet into the original script is left as an exercise to the reader.",
                "title": "Parse dynamic key value pair object in JQ"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1689948509,
        "creation_date": 1647401993,
        "last_edit_date": 1647462053,
        "question_id": 71491565,
        "body_markdown": "I would like to parse the following object\r\n\r\n```lang-js\r\n{\r\n  &quot;test_account&quot;: {\r\n    &quot;us_east_1&quot;: {\r\n      &quot;i-a023adfa2&quot;: &quot;Key=a,Value=c key=2,Value=3&quot;,\r\n      &quot;i-23adfw34r&quot;: &quot;Key=t,Value=n&quot;\r\n    }\r\n  }\r\n}\r\n```\r\nI pass account and region as arguments to the script and am able to get the object but not able to parse the returned object. I want to extract key which is ec2-instance id and value which is combination of tags that needs to be added. I am using shell script to parse this json using Jquery.\r\n\r\nHere is partial script..\r\n```lang-shell\r\ninstances = ${jq -r &quot;.$1 | select .${2//[-]/_} != null) | .${2//[-]/_}&quot;. &lt;path of json file&gt; | tr &#39;\\n&#39; &#39; &#39;)\r\n\r\n```\r\nI call this with  &quot;sh &amp;lt;scriptname&amp;gt; test-account us-west-2&quot; ...\r\n\r\nI couldn&#39;t parse the returned object to get key and value into respective variables. Can someone please help ?\r\n\r\nThanks.\r\n\r\n",
        "link": "https://stackoverflow.com/questions/71491565/parse-dynamic-key-value-pair-object-in-jq",
        "title": "Parse dynamic key value pair object in JQ"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1647413159,
                "last_edit_date": 1647413159,
                "creation_date": 1647412687,
                "answer_id": 71492705,
                "question_id": 71492517,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Using a combination of string interpolation and two variants of string join operations, one using the `@csv` filter and other using `join(&quot;,&quot;)`\r\n\r\n```none\r\njq --raw-output &#39;\r\n  .[]| to_entries | map(.key) as $k | map(.value) as $v | \r\n    &quot;INSERT INTO mytab (\\($k | join(&quot;,&quot;))) VALUES (\\($v | @csv ));&quot;&#39; \r\n```\r\n\r\n[jqplay demo][1]\r\n\r\n\r\n  [1]: https://jqplay.org/s/Ro_9xJzz0Y",
                "title": "How to format my JSON input to SQL insert statements"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1647469527,
        "creation_date": 1647411337,
        "last_edit_date": 1647469527,
        "question_id": 71492517,
        "body_markdown": "How can I (generically) transform the input file below to output file below, using jq:\r\n\r\n**Input file:**\r\n```\r\n[{&quot;a&quot;: 1, &quot;b&quot;: 10},\r\n {&quot;a&quot;: 2, &quot;d&quot;: &quot;fred&quot;, &quot;e&quot;: 30}]\r\n```\r\n**Output file:**\r\n```\r\nINSERT INTO mytab (a,b) VALUES (1,10);\r\nINSERT INTO mytab (a,d,e) VALUES (2,&quot;fred&quot;,30);\r\n```\r\n",
        "link": "https://stackoverflow.com/questions/71492517/how-to-format-my-json-input-to-sql-insert-statements",
        "title": "How to format my JSON input to SQL insert statements"
    },
    {
        "tags": [
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 289134,
                    "reputation": 389369,
                    "user_id": 589924,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/b2cf53d5a3d25f95c0db4e025aed4153?s=256&d=identicon&r=PG",
                    "display_name": "ikegami",
                    "link": "https://stackoverflow.com/users/589924/ikegami"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1647413864,
                "post_id": 71492865,
                "comment_id": 126361714,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1647460029,
                "last_edit_date": 1647460029,
                "creation_date": 1647447431,
                "answer_id": 71500624,
                "question_id": 71492865,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Um. Technically, yes. I don&#39;t think I could recommend it, but it does appear to be possible.\r\n\r\nFirst of all, you need to understand that `@csv`, `@sh` etc aren&#39;t separate functions from jq&#39;s point of view. They&#39;re all implemented by the `format/1` function. This function takes a single string argument that is the name of the format to use, e.g. `&quot;csv&quot;` or `&quot;sh&quot;`. You can redefine this function, and lo and behold jq will use it for formatting!\r\n\r\n```bash\r\njq -n &#39;def format(fstring): &quot;XXX&quot;;[1,2,3]|@json&#39;\r\n```\r\n```json\r\n&quot;XXX&quot;\r\n```\r\n\r\nOkay, that&#39;s not very useful. How about this?\r\n```bash\r\njq -n &#39;\r\n    def format(fstring):\r\n        if fstring==&quot;sparkle&quot; then\r\n            &quot;.:!&quot; + (tostring) + &quot;!:.&quot;\r\n        else\r\n            oldformat(fstring)\r\n        end\r\n    ;\r\n    [1,2,3]|@sparkle\r\n&#39;\r\n```\r\n```json\r\n&quot;.:![1,2,3]!:.&quot;\r\n```\r\nIt worked! But don&#39;t get too excited...\r\n```bash\r\njq -n &#39;\r\n    def format(fstring):\r\n        if fstring==&quot;sparkle&quot; then\r\n            &quot;.:!&quot; + (tostring) + &quot;!:.&quot;\r\n        else\r\n            oldformat(fstring)\r\n        end\r\n    ;\r\n    [1,2,3]|@json\r\n&#39;\r\n```\r\nUh oh, that just hangs. Although we were hoping to delegate to the original format when we don&#39;t know what to do with the format, we actually called our new format function recursively. It just keeps calling itself forever. It looks like we might be out of luck on our extremely cursed quest. However, if we read the jq manual carefully, there is a glimmer of hope:\r\n\r\n&gt; Multiple definitions using the same function name are allowed. Each re-definition replaces the previous one for the same number of function arguments, but only for references from functions (or main program) subsequent to the re-definition. See also the section below on scoping.\r\n\r\nGreat! We can use this to save the old format function:\r\n```bash\r\njq -n &#39;\r\n    def oldformat(fstring):\r\n        format(fstring);\r\n    def format(fstring):\r\n        if fstring==&quot;sparkle&quot; then\r\n            &quot;.:!&quot; + (tostring) + &quot;!:.&quot;\r\n        else\r\n            oldformat(fstring)\r\n        end\r\n    ;\r\n    [1,2,3]|(@sparkle,@json,@sh)\r\n&#39;\r\n```\r\n```json\r\n&quot;.:![1,2,3]!:.&quot;\r\n&quot;[1,2,3]&quot;\r\n&quot;1 2 3&quot;\r\n```\r\n\r\nI really don&#39;t recommend this: it&#39;s awkward to do, not terribly useful, and I have no idea if it&#39;s going to break something else. The `format` function doesn&#39;t appear to be documented so it&#39;s likely an unsupported implementation detail. But it was fascinating to find out that this _is_ technically possible.",
                "title": "Is it possible to define a custom &quot;@&quot; escape functions in jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1647460029,
        "creation_date": 1647413807,
        "question_id": 71492865,
        "body_markdown": "We have a number of builtin format/escape functions: `@csv`, `@sh`, etc\r\n\r\n```jq\r\n… | @sh\r\n```\r\n\r\n```jq\r\n@sh &quot;\\( … )&quot;\r\n```\r\n\r\nIt is possible to define a custom format/escape function, say `@sql`?\r\n",
        "link": "https://stackoverflow.com/questions/71492865/is-it-possible-to-define-a-custom-escape-functions-in-jq",
        "title": "Is it possible to define a custom &quot;@&quot; escape functions in jq?"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1647416182,
                "creation_date": 1647416182,
                "answer_id": 71493233,
                "question_id": 71492946,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Extract the common path to a new field, group the objects by the new field, and select the one with the maximal `modified` field.\r\n```\r\njq -r &#39;[.results[]\r\n          | .short = .path[0:(.path | rindex(&quot;/&quot;))]\r\n       ]\r\n       | group_by(.short)[]\r\n       | max_by(.modified).path\r\n      &#39; file.json\r\n```",
                "title": "jq - reduce array of paths using subpaths"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1647417765,
                "creation_date": 1647417765,
                "answer_id": 71493498,
                "question_id": 71492946,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I came up with a solution using `foreach` and regular expressions, based on this answer https://stackoverflow.com/a/29829035/1851290\r\n\r\n    jq -n -r &#39;foreach (inputs | .results| .[]) as $k (\r\n                 {};\r\n    \r\n                 .[$k.path | sub(&quot;/[^/]*$&quot;; &quot;&quot;)]+=1;\r\n    \r\n                 if .[$k.path | sub(&quot;/[^/]*$&quot;; &quot;&quot;)]==1 then\r\n                     $k.path\r\n                 else\r\n                     empty\r\n                 end\r\n             )&#39;",
                "title": "jq - reduce array of paths using subpaths"
            }
        ],
        "is_answered": false,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1647417765,
        "creation_date": 1647414382,
        "last_edit_date": 1647415243,
        "question_id": 71492946,
        "body_markdown": "Assume the following JSON data:\r\n\r\n```\r\n{\r\n  &quot;results&quot;: [\r\n    {\r\n      &quot;path&quot;: &quot;other/foo/1.15.1&quot;,\r\n      &quot;modified&quot;: &quot;2022-02-09T13:45:34.638Z&quot;\r\n    },\r\n    {\r\n      &quot;path&quot;: &quot;other/foo/1.15.0&quot;,\r\n      &quot;modified&quot;: &quot;2022-02-09T10:00:40.681Z&quot;\r\n    },\r\n    {\r\n      &quot;path&quot;: &quot;a/b/foo/1.0.3-SNAPSHOT&quot;,\r\n      &quot;modified&quot;: &quot;2022-03-04T19:07:30.262Z&quot;\r\n    },\r\n    {\r\n      &quot;path&quot;: &quot;a/b/c/0.1.1&quot;,\r\n      &quot;modified&quot;: &quot;2022-01-10T15:12:00.597Z&quot;\r\n    },\r\n    {\r\n      &quot;path&quot;: &quot;a/b/c/0.1.0&quot;,\r\n      &quot;modified&quot;: &quot;2022-01-07T18:05:23.158Z&quot;\r\n    },\r\n    {\r\n      &quot;path&quot;: &quot;a/b/c/0.0.9&quot;,\r\n      &quot;modified&quot;: &quot;2021-12-06T10:29:31.161Z&quot;\r\n    }\r\n  ]\r\n}\r\n```\r\n\r\nAnd also assume, that it is descendingly sorted first per `path` then per `modified`.\r\n\r\nNow, for every path without its last part, I would like to find only the latest ones according to the `modified` field (which are always on the top because of the sorting). Then, output that path including its last part again.\r\n\r\nIn other words, for this example data the output should be:\r\n\r\n```\r\nother/foo/1.15.1\r\na/b/foo/1.0.3-SNAPSHOT\r\na/b/c/0.1.1\r\n```",
        "link": "https://stackoverflow.com/questions/71492946/jq-reduce-array-of-paths-using-subpaths",
        "title": "jq - reduce array of paths using subpaths"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1647424548,
                "last_edit_date": 1647424548,
                "creation_date": 1647419268,
                "answer_id": 71493777,
                "question_id": 71493664,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "```\r\necho &#39;{&quot;tags&quot;: [],\r\n  &quot;servers&quot;: [],\r\n  &quot;components&quot;: {\r\n    &quot;securitySchemes&quot;: {\r\n      &quot;cookie&quot;: {\r\n        &quot;type&quot;: &quot;apiKey&quot;,\r\n        &quot;in&quot;: &quot;cookie&quot;,\r\n        &quot;name&quot;: &quot;store&quot;,\r\n        &quot;description&quot;: &quot;Store API&quot;\r\n      }\r\n    }\r\n}}&#39; | jq &#39;.servers = [{url:&quot;http://localhost:5000&quot;, description: &quot;Localhost server&quot;}]&#39;\r\n```\r\nOr, for a fixed json file (adding missing `}`):\r\n```\r\njq &#39;.servers = [{url:&quot;http://localhost:5000&quot;, description: &quot;Localhost server&quot;}]&#39; file.json\r\n```\r\n\r\n\r\n",
                "title": "Change json object with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1647424548,
        "creation_date": 1647418645,
        "question_id": 71493664,
        "body_markdown": "how can I update servers object in my json using jq? \r\n\r\n    &quot;tags&quot;: [],\r\n      &quot;servers&quot;: [],\r\n      &quot;components&quot;: {\r\n        &quot;securitySchemes&quot;: {\r\n          &quot;cookie&quot;: {\r\n            &quot;type&quot;: &quot;apiKey&quot;,\r\n            &quot;in&quot;: &quot;cookie&quot;,\r\n            &quot;name&quot;: &quot;store&quot;,\r\n            &quot;description&quot;: &quot;Store API&quot;\r\n          }\r\n        },\r\n\r\nI need to have servers like that:\r\n\r\n          &quot;servers&quot;: [\r\n        {\r\n          &quot;url&quot;: &quot;http://localhost:5000&quot;,\r\n          &quot;description&quot;: &quot;Localhost server&quot;\r\n        }\r\n      ],",
        "link": "https://stackoverflow.com/questions/71493664/change-json-object-with-jq",
        "title": "Change json object with jq"
    },
    {
        "tags": [
            "csv",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1647477277,
                "last_edit_date": 1647477277,
                "creation_date": 1647476924,
                "answer_id": 71505734,
                "question_id": 71505606,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "In general, you should try breaking out each &quot;group&quot; and testing separately, to see if it is mapping as you expect it to.\r\n\r\n`$cols` maps out all the keys across all records while `$rows` are all the values of the records. You already have the rows and records you wanted so pass to `@csv`. Though keep in mind arrays passed to `@csv` must be all strings.\r\n\r\n```\r\n(map(keys) | add | unique) as $cols\r\n  | map(. as $row | $cols | map($row[.] | tostring)) as $rows\r\n  | $cols, $rows[]\r\n  | @csv\r\n```\r\n\r\nThis however selects all mapped columns. If you only want a subset of them, just change the `$cols` variable to be what columns you want from the data. You might want to separate the value mapping from this since you have some nested values.\r\n\r\n```\r\n[&quot;oracle_id&quot;, &quot;id&quot;, &quot;rarity&quot;, &quot;set&quot;, &quot;price&quot;, &quot;scryfall_uri&quot;, &quot;image_uri&quot;, &quot;digital&quot;, &quot;promo&quot;, &quot;variation&quot;],\r\n(.[] | [.oracle_id, .id, .rarity, .set, .prices.usd, .scryfall_uri, .image_uris.art_crop, .digital, .promo, .variation])\r\n  | @csv\r\n```\r\n\r\n[jqplay](https://jqplay.org/s/HjafYv4i58)",
                "title": "Can&#39;t combine col selection with CSV conversion"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1647477277,
        "creation_date": 1647475384,
        "last_edit_date": 1647476660,
        "question_id": 71505606,
        "body_markdown": "I&#39;ve successfully been using jq for a while now, to take a JSON payload, select some of the columns, re-name the columns, and finally, create a JSON file. This is awesome bc I do not need a majority of the columns in the input dataset. Here is an example of one of those working commands:\r\n\r\n```\r\ncurl -s https://c2.scryfall.com/file/scryfall-bulk/default-cards/default-cards-20220314210303.json\r\n| jq &#39;[.[] | {oracle_id: .oracle_id, scryfall_id: .id, rarity: .rarity, set_code: .set, latest_price: .prices.usd, scryfall_url: .scryfall_uri, art_crop_url: .image_uris.art_crop, is_digital: .digital, is_promo: .promo, is_variation: .variation}]&#39; &gt; Desktop/printings.json\r\n```\r\n\r\nHowever, what I really need is to have this data in CSV format. I have been manually working around this by feeding the output of the command above into a free web tool for converting to CSV. But I recently learned that jq can output CSV itself, so I would like to streamline this so I can just get CSV data from jq in the first place. I read the jq documentation, and reviewed several Stack Overflow threads to learn how this works. But none of the examples I&#39;ve found for generating CSV data with jq involve selecting specific columns or re-naming those columns. So I&#39;ve not been able to get this to work.\r\n\r\nI tried this command below, where I am attempting to 1) read in the JSON file from the scryfall.com endpoint, then 2) map the keys as rows and columns to prep to convert to the CSV format, and 3) apply a filter selecting each of the 10 columns I need. (I could not figure out the column re-naming part, so I removed that part for now, for the sake of simplicity):\r\n\r\n```\r\ncurl -s https://c2.scryfall.com/file/scryfall-bulk/default-cards/default-cards-20220314210303.json\r\n| jq -r &#39;(map(keys) | add | unique) as $cols | map(. as $row | $cols | map($row[.])) as $rows | $cols, $rows[] | .oracle_id | .id | .rarity | .set | .prices.usd | .scryfall_uri | .image_uris.art_crop | .digital | .promo | .variation |  @csv&#39; &gt; Desktop/printings.csv\r\n```\r\n\r\nThe result is this error: \r\n```\r\njq: error (at &lt;stdin&gt;:67121): Cannot index array with string &quot;oracle_id&quot;\r\n```\r\n\r\nI&#39;m not sure why &quot;| .oracle_id&quot; would be indexing anything. My intent is to filter the data. However, I think my struggle is an algorithmic one. Should I try to use pipes to sequence the different steps of selecting columns and generating the csv? Or should I combine them? If I need to separate the steps, what order do they  need to come in? I understnad that the @csv filter at the end must take an array as input, but that&#39;s where I start to lose the plot.\r\n\r\nSince the input JSON file is a freely-available, public dataset, you should be able to try this out to see if you get the same error output I showed above.\r\n",
        "link": "https://stackoverflow.com/questions/71505606/cant-combine-col-selection-with-csv-conversion",
        "title": "Can&#39;t combine col selection with CSV conversion"
    },
    {
        "tags": [
            "json",
            "variables",
            "arguments",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 6,
                "is_accepted": true,
                "score": 6,
                "last_activity_date": 1647496690,
                "last_edit_date": 1647496690,
                "creation_date": 1647494952,
                "answer_id": 71507461,
                "question_id": 71507448,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Use `--argjson` (instead of `--arg`) for JSON input. Note, however, that `{&quot;uid&quot;: &quot;foo&quot; }, {&quot;uid&quot;: &quot;bar&quot;}` by itself is not (yet) valid JSON. You need to wrap it into brackets to make it an array (otherwise, `jq` will (rightfully) complain about a superfluous comma between the two objects).\r\n\r\nBrackets added to the string provided for `--argjson`:\r\n~~~sh\r\narray=&#39;{&quot;uid&quot;: &quot;foo&quot; }, {&quot;uid&quot;: &quot;bar&quot;}&#39;\r\n\r\njq --arg title &quot;$t&quot; --argjson array &quot;[$array]&quot; \\\r\n  &#39;select(.title == $title) | .alert.notifications = $array&#39;\r\n~~~\r\n\r\nBrackets added to the shell variable called `array`:\r\n~~~sh\r\narray=&#39;[{&quot;uid&quot;: &quot;foo&quot; }, {&quot;uid&quot;: &quot;bar&quot;}]&#39;\r\n\r\njq --arg title &quot;$t&quot; --argjson array &quot;$array&quot; \\\r\n  &#39;select(.title == $title) | .alert.notifications = $array&#39;\r\n~~~\r\n\r\nAlso note that if your output is JSON, you don&#39;t need the `-r` option.\r\n~~~json\r\n{\r\n  &quot;alert&quot;: {\r\n    &quot;notifications&quot;: [\r\n      {\r\n        &quot;uid&quot;: &quot;foo&quot;\r\n      },\r\n      {\r\n        &quot;uid&quot;: &quot;bar&quot;\r\n      }\r\n    ]\r\n  },\r\n  &quot;title&quot;: &quot;Test&quot;\r\n}\r\n~~~\r\n\r\n---\r\n\r\nIf you don&#39;t have the option to use `--argjson` instead of `--arg` (because, for example, the input may or may not be JSON and you can only test it *after* populating the variables), you can use the `fromjson` builtin to convert a JSON-encoded string into actual JSON (said &quot;testing&quot; is not included in these examples).\r\n\r\nBrackets added inline just before applying `fromjson`:\r\n~~~sh\r\narray=&#39;{&quot;uid&quot;: &quot;foo&quot; }, {&quot;uid&quot;: &quot;bar&quot;}&#39;\r\n\r\njq --arg title &quot;$t&quot; --arg array &quot;$array&quot; \\\r\n  &#39;select(.title == $title) | .alert.notifications = (&quot;[\\($array)]&quot; | fromjson)&#39;\r\n~~~\r\n\r\nBrackets added to the string provided for `--arg`:\r\n~~~sh\r\narray=&#39;{&quot;uid&quot;: &quot;foo&quot; }, {&quot;uid&quot;: &quot;bar&quot;}&#39;\r\n\r\njq --arg title &quot;$t&quot; --arg array &quot;[$array]&quot; \\\r\n  &#39;select(.title == $title) | .alert.notifications = ($array | fromjson)&#39;\r\n~~~\r\n\r\nBrackets added to the shell variable called `array`:\r\n~~~sh\r\narray=&#39;[{&quot;uid&quot;: &quot;foo&quot; }, {&quot;uid&quot;: &quot;bar&quot;}]&#39;\r\n\r\njq --arg title &quot;$t&quot; --arg array &quot;$array&quot; \\\r\n  &#39;select(.title == $title) | .alert.notifications = ($array | fromjson)&#39;\r\n~~~\r\n",
                "title": "JQ How to replace entire array with a variable arg"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 6,
        "last_activity_date": 1647496690,
        "creation_date": 1647494771,
        "question_id": 71507448,
        "body_markdown": "So I can do this\r\n\r\n```\r\njq --arg title &quot;Test&quot; &#39;select(.title == $title) | .alert.notifications = [{&quot;uid&quot;:&quot;foo&quot;},{&quot;uid&quot;:&quot;bar&quot;}]&#39; json\r\n```\r\n\r\nWhich outputs the desired results:\r\n\r\n```\r\n{\r\n  &quot;alert&quot;: {\r\n    &quot;notifications&quot;: [\r\n      { \r\n        &quot;uid&quot;: &quot;foo&quot; \r\n      },\r\n      { \r\n        &quot;uid&quot;: &quot;bar&quot; \r\n      }\r\n    ]\r\n  },\r\n  &quot;title&quot;: &quot;Test&quot;\r\n}\r\n```\r\n\r\nHowever, I need to put the array in a var and supply it on the fly instead, like:\r\n\r\n```\r\narray=&#39;{ &quot;uid&quot;: &quot;foo&quot; },{ &quot;uid&quot;: &quot;bar&quot;}&#39;\r\n\r\njq -r --arg title &quot;$t&quot; --arg array &quot;$array&quot; &#39;select(.title == $title) | .alert.notifications = [$array]&#39;\r\n```\r\n\r\nBut that results in this undesired output\r\n\r\n```\r\n{\r\n  &quot;alert&quot;: {\r\n    &quot;notifications&quot;: [\r\n      &quot;{ \\&quot;uid\\&quot;: \\&quot;foo\\&quot; },{ \\&quot;uid\\&quot;: \\&quot;bar\\&quot; }&quot;\r\n    ]\r\n  },\r\n  &quot;title&quot;: &quot;Test&quot;\r\n}\r\n```\r\n\r\nAny way to get around this? Much appreciated!!",
        "link": "https://stackoverflow.com/questions/71507448/jq-how-to-replace-entire-array-with-a-variable-arg",
        "title": "JQ How to replace entire array with a variable arg"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1647530697,
                "creation_date": 1647530697,
                "answer_id": 71514903,
                "question_id": 71513261,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If each account contains only one code, you can do :\r\n\r\n```\r\n#!/usr/bin/env bash\r\n\r\ndeclare -A accounts\r\nwhile read account code; do\r\n    accounts[$account]=$code\r\ndone &lt; &lt;(jq -r &#39;.block       |\r\n                to_entries[] |\r\n                &quot;\\(.key) \\(.value[0].CODE)&quot;&#39; input.json)\r\ndeclare -p accounts\r\n```",
                "title": "JQ pull value from key searched by related key"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1647530697,
        "creation_date": 1647524215,
        "last_edit_date": 1647524590,
        "question_id": 71513261,
        "body_markdown": "Im bashing my head against a wall - aim pull value from key searched by related\r\n\r\nJSON SNIPPIT\r\n```\r\n{\r\n  &quot;block&quot;: {\r\n    &quot;000545342981&quot;: [\r\n      {\r\n        &quot;CODE&quot;: &quot;xdxd3456532fok234sss0&quot;\r\n      },\r\n      {\r\n        &quot;STATE&quot;: &quot;COMPLETE&quot;\r\n      }\r\n    ],\r\n   &quot;000545341211&quot;: [\r\n      {\r\n        &quot;CODE&quot;: &quot;xdff3678223frt244swe4&quot;\r\n      },\r\n      {\r\n        &quot;STATE&quot;: &quot;RUNNING&quot;\r\n      }\r\n    ]\r\n}}\r\n```\r\n\r\nI wish to retrieve the `CODE` value for each ACCOUNT\r\n\r\nie for \r\n`000545342981` i wish to have `xdxd3456532fok234sss0` returned and \r\n`xdff3678223frt244swe4` for `000545341211`\r\n\r\nthen place in bash as \r\n```\r\naccounts+=(\r\n[&quot;000545342981&quot;]=xdxd3456532fok234sss0\r\n[&quot;000545341211&quot;]=xdff3678223frt244swe4\r\n)\r\n```\r\n\r\n\r\nSO FAR\r\ni have returned the accounts with \r\n`jq --slurp &#39;.?|.[][]|keys&#39; | jq -r &#39;.[]&#39;`\r\n\r\nthen i tried `jq --arg code &quot;ACCOUNT&quot; &#39;select ( .&quot;block&quot;.key==$code) | .&quot;block&quot;.$stack.&quot;CODE&quot;&#39;` ----&gt; no errors :/ so suspect it may not of found anything\r\n\r\nthis will kind of work `.&quot;block&quot;.&quot;000545341211&quot;[].&quot;CODE&quot;` \r\nbut i know i cant input a var in jq from a for each so need arg input (unless im very wrong)\r\nits the `select ( .&quot;block&quot;.key==$code)` i think?? what do i need :(\r\n\r\n",
        "link": "https://stackoverflow.com/questions/71513261/jq-pull-value-from-key-searched-by-related-key",
        "title": "JQ pull value from key searched by related key"
    },
    {
        "tags": [
            "json",
            "jq",
            "vault"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1647534930,
                "last_edit_date": 1647534930,
                "creation_date": 1647534428,
                "answer_id": 71515852,
                "question_id": 71515734,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If you are trying to extract a stream of ojects with just the `name` field:\r\n~~~sh\r\n… | jq -c &quot;.data.key_info[] | .aliases[] | {name}&quot;\r\n~~~\r\n~~~json\r\n{&quot;name&quot;:&quot;John Doe&quot;}\r\n{&quot;name&quot;:&quot;Jane Smith&quot;}\r\n~~~\r\n[Demo](https://jqplay.org/s/tOnsxMqvFF)\r\n\r\nIf you are trying to extract them as an array, use `map`:\r\n~~~sh\r\n… | jq &quot;.data.key_info | map(.aliases[] | {name})&quot;\r\n~~~\r\n~~~json\r\n[\r\n  {\r\n    &quot;name&quot;: &quot;John Doe&quot;\r\n  },\r\n  {\r\n    &quot;name&quot;: &quot;Jane Smith&quot;\r\n  }\r\n]\r\n~~~\r\n[Demo](https://jqplay.org/s/mcyiPRRAX8)\r\n\r\nIf you just need the values, use the `-r` option:\r\n~~~sh\r\n… | jq -r &quot;.data.key_info[].aliases[].name&quot;\r\n~~~\r\n~~~none\r\nJohn Doe\r\nJane Smith\r\n~~~\r\n[Demo](https://jqplay.org/s/AnGIQ9KVA2)\r\n\r\n",
                "title": "jq to extract specific data with different map name of same type"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -1,
        "last_activity_date": 1647534930,
        "creation_date": 1647533927,
        "question_id": 71515734,
        "body_markdown": "I&#39;m performing a query on vault API to list all the entities by their Ids and trying extract alias name from `aliases.name`, however, due to the different map name in each iteration I&#39;m not able to extract the value.\r\n\r\n**Command**\r\n\r\n    curl -s --header &quot;X-Vault-Token: $TOKEN&quot; --request LIST http://localhost:8200/v1/identity/entity/id | jq &quot;.data.key_info&quot;\r\n\r\n**Result**\r\n\r\n    {\r\n      &quot;923104b3-910c-05b1-b448-fcg3d67276e1&quot;: {\r\n        &quot;aliases&quot;: [\r\n          {\r\n            &quot;id&quot;: &quot;6a6f2dc4-2cd8-1881-662f-b5955e765e0d&quot;,\r\n            &quot;mount_accessor&quot;: &quot;auth_oidc_053b2418&quot;,\r\n            &quot;mount_path&quot;: &quot;auth/oidc/&quot;,\r\n            &quot;mount_type&quot;: &quot;oidc&quot;,\r\n            &quot;name&quot;: &quot;John Doe&quot;\r\n          }\r\n        ],\r\n        &quot;name&quot;: &quot;entity_402ea123&quot;\r\n      },\r\n      &quot;ba6b00c4-36gg-gd86-86bf-13d731588241&quot;: {\r\n        &quot;aliases&quot;: [\r\n          {\r\n            &quot;id&quot;: &quot;3ji408b2-4548-75f7-8c41-9901b77af7d1&quot;,\r\n            &quot;mount_accessor&quot;: &quot;auth_oidc_053b2418&quot;,\r\n            &quot;mount_path&quot;: &quot;auth/oidc/&quot;,\r\n            &quot;mount_type&quot;: &quot;oidc&quot;,\r\n            &quot;name&quot;: &quot;Jane Smith&quot;\r\n          }\r\n        ],\r\n        &quot;name&quot;: &quot;entity_98746ae4&quot;\r\n      }\r\n    }\r\n\r\n**Expected output**\r\n\r\n    &quot;name&quot;: &quot;John Doe&quot;\r\n    &quot;name&quot;: &quot;Jane Smith&quot;",
        "link": "https://stackoverflow.com/questions/71515734/jq-to-extract-specific-data-with-different-map-name-of-same-type",
        "title": "jq to extract specific data with different map name of same type"
    },
    {
        "tags": [
            "linux",
            "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": 2,
                "creation_date": 1647535534,
                "post_id": 71516052,
                "comment_id": 126401126,
                "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": 1647535591,
                "post_id": 71516052,
                "comment_id": 126401147,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 13921089,
                    "reputation": 153,
                    "user_id": 10085782,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/457f3b1c4b3381c0a552f6cbdadfbf09?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "rr0ss0rr",
                    "link": "https://stackoverflow.com/users/10085782/rr0ss0rr"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1647535851,
                "post_id": 71516052,
                "comment_id": 126401254,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 13921089,
                    "reputation": 153,
                    "user_id": 10085782,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/457f3b1c4b3381c0a552f6cbdadfbf09?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "rr0ss0rr",
                    "link": "https://stackoverflow.com/users/10085782/rr0ss0rr"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1647536477,
                "post_id": 71516052,
                "comment_id": 126401520,
                "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"
                },
                "reply_to_user": {
                    "account_id": 13921089,
                    "reputation": 153,
                    "user_id": 10085782,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/457f3b1c4b3381c0a552f6cbdadfbf09?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "rr0ss0rr",
                    "link": "https://stackoverflow.com/users/10085782/rr0ss0rr"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1647536572,
                "post_id": 71516052,
                "comment_id": 126401549,
                "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"
                },
                "reply_to_user": {
                    "account_id": 13921089,
                    "reputation": 153,
                    "user_id": 10085782,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/457f3b1c4b3381c0a552f6cbdadfbf09?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "rr0ss0rr",
                    "link": "https://stackoverflow.com/users/10085782/rr0ss0rr"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1647536631,
                "post_id": 71516052,
                "comment_id": 126401571,
                "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": 1613587,
                    "reputation": 786618,
                    "user_id": 1491895,
                    "user_type": "registered",
                    "accept_rate": 69,
                    "profile_image": "https://www.gravatar.com/avatar/82f9e178a16364bf561d0ed4da09a35d?s=256&d=identicon&r=PG",
                    "display_name": "Barmar",
                    "link": "https://stackoverflow.com/users/1491895/barmar"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1647540074,
                "post_id": 71516052,
                "comment_id": 126402765,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1647555528,
                "last_edit_date": 1647555528,
                "creation_date": 1647554928,
                "answer_id": 71519594,
                "question_id": 71516052,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Add `-r` to the jq command (for raw-output).  Your code can only handle `limit=1` The following worked for me\r\n```\r\nkey=LIVDSRZULELA #key provided by tenor\r\nurl=&quot;https://g.tenor.com/v1/search?q=$1&amp;key=$key&amp;limit=$2&quot; \r\n#search key and total results will be given by command arguments\r\n\r\nurl2=$(curl $url | jq -r &#39;.results[].media[].gif.url&#39;) # this have whole json result from tenor\r\ncurl &quot;$url2&quot;\r\n```\r\n```\r\ntestit cake 1\r\n  % Total    % Received % Xferd  Average Speed   Time    Time     Time  Current\r\n                                 Dload  Upload   Total   Spent    Left  Speed\r\n100  4301    0  4301    0     0  37504      0 --:--:-- --:--:-- --:--:-- 40196\r\n```",
                "title": "Unable to curl a variable that contains url of gif"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -2,
        "last_activity_date": 1647555528,
        "creation_date": 1647535309,
        "last_edit_date": 1647535521,
        "question_id": 71516052,
        "body_markdown": "```\r\n#! /bin/bash\r\n\r\nkey=LIVDSRZULELA #key provided by tenor\r\nurl=&quot;https://g.tenor.com/v1/search?q=$1&amp;key=$key&amp;limit=$2&quot; \r\n#search key and total results will be given by command arguments\r\n\r\njs=$(curl $url) # this have whole json result from tenor\r\n\r\nres=$(echo $js | jq &#39;.results[].media[].gif.url&#39;) # res contains the url of the gif that we searched\r\ncd $HOME/Desktop/Me/gifs\r\necho $res # outputs correct URL\r\ncurl -O $res # this is giving error\r\n```\r\nproblem is that I cant curl the res vaiable as its showing bad/illegal format kind of error",
        "link": "https://stackoverflow.com/questions/71516052/unable-to-curl-a-variable-that-contains-url-of-gif",
        "title": "Unable to curl a variable that contains url of gif"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1647542718,
                "creation_date": 1647542718,
                "answer_id": 71517534,
                "question_id": 71517326,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You could use the `--stream` option to read in the big input in smaller pieces\r\n~~~sh\r\njq --stream -n &#39;\r\n  {stats: (reduce (1 | truncate_stream(inputs)) as $i ({};\r\n    if ($i | has(1)) then .&quot;\\($i[0] | join(&quot;.&quot;))&quot;.&quot;\\($i[1])&quot; += 1 else . end\r\n  ))}\r\n&#39; input.json\r\n~~~\r\n~~~json\r\n{\r\n  &quot;stats&quot;: {\r\n    &quot;user.name&quot;: {\r\n      &quot;Bill&quot;: 2,\r\n      &quot;Alice&quot;: 1\r\n    },\r\n    &quot;user.items.0.name&quot;: {\r\n      &quot;shovel&quot;: 2,\r\n      &quot;hammer&quot;: 1\r\n    },\r\n    &quot;user.items.0.details.heavy&quot;: {\r\n      &quot;false&quot;: 2,\r\n      &quot;true&quot;: 1\r\n    },\r\n    &quot;user.items.1.name&quot;: {\r\n      &quot;hammer&quot;: 2,\r\n      &quot;shovel&quot;: 1\r\n    },\r\n    &quot;user.details.age&quot;: {\r\n      &quot;60&quot;: 1,\r\n      &quot;21&quot;: 1,\r\n      &quot;30&quot;: 1\r\n    }\r\n  }\r\n}\r\n~~~",
                "title": "Using JQ for statistical aggregation of key values in a large data set"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1664350057,
                "last_edit_date": 1664350057,
                "creation_date": 1647548569,
                "answer_id": 71518573,
                "question_id": 71517326,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Since the input is a JSON stream, you should be able to obtain a straightforward but performant solution using `inputs` and the -n command-line option.  Based on my understanding of the problem, here&#39;s what I get:\r\n\r\n```\r\ndef summary(stream):\r\n   reduce stream as [$p, $v] ({};\r\n      ($p|join(&quot;.&quot;)) as $q\r\n      | if .[$q] then .[$q][$v|tostring] += 1\r\n      else .[$q] = {($v|tostring): 1}\r\n      end);\r\n\r\n{stats: summary(inputs.content\r\n        | paths(scalars) as $p\r\n        | [$p, getpath($p)]) }\r\n```",
                "title": "Using JQ for statistical aggregation of key values in a large data set"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1666477032,
                "creation_date": 1666477032,
                "answer_id": 74167456,
                "question_id": 71517326,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "In case you are interested in checking out another tool, I am the author of a new query language and command-line tool for JSON queries and transformation, called Unquery:\r\n\r\nhttps://github.com/xcite-db/Unquery\r\n\r\nUsing Unquery, this is really stright-forward:\r\n\r\n    {\r\n       &quot;stats:**&quot;: {\r\n         &quot;$path&quot;: {\r\n            &quot;$(.)&quot; : &quot;$count&quot;\r\n         }\r\n       }\r\n    }\r\n\r\nThe result of the above query would be:\r\n\r\n    {\r\n        &quot;stats&quot;: {\r\n            &quot;content.user.details.age&quot;: {\r\n                &quot;21&quot;: 1,\r\n                &quot;30&quot;: 1,\r\n                &quot;60&quot;: 1\r\n            },\r\n            &quot;content.user.items[0].details.heavy&quot;: {\r\n                &quot;false&quot;: 2,\r\n                &quot;true&quot;: 1\r\n            },\r\n            &quot;content.user.items[0].name&quot;: {\r\n                &quot;hammer&quot;: 1,\r\n                &quot;shovel&quot;: 2\r\n            },\r\n            &quot;content.user.items[1].name&quot;: {\r\n                &quot;hammer&quot;: 2,\r\n                &quot;shovel&quot;: 1\r\n            },\r\n            &quot;content.user.name&quot;: {\r\n                &quot;Alice&quot;: 1,\r\n                &quot;Bill&quot;: 2\r\n            }\r\n        }\r\n    }\r\n\r\nIf you want to get `user.name` instead of `content.user.name` etc., simply replace `$path` by `$substr($path,8)` (assuming the top field is always &quot;content.&quot;, which is 8 characters).\r\n",
                "title": "Using JQ for statistical aggregation of key values in a large data set"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 1,
        "last_activity_date": 1666477032,
        "creation_date": 1647541579,
        "question_id": 71517326,
        "body_markdown": "I have a complex use case that I can currently mostly solve with JQ, but am wondering if JQ is no longer the right tool for the job, or if there is a way I can generalize my filter. The use case is to create a statistical aggregate of sorted key value counts in large data set of newline delimited JSON. The issue I am running into relates to the number of keys in my data set becoming too large of a filter for jq to actually compile.\r\n\r\nBelow is a sample input, note that it includes arrays.\r\n\r\n**Input: (input.json)**\r\n```\r\n{\r\n  &quot;content&quot;: {\r\n    &quot;user&quot;: {\r\n      &quot;name&quot;: &quot;Bill&quot;,\r\n      &quot;items&quot;: [\r\n        {\r\n          &quot;name&quot;: &quot;shovel&quot;,\r\n          &quot;details&quot;: {\r\n            &quot;heavy&quot;: false\r\n          }\r\n        },\r\n        {\r\n          &quot;name&quot;: &quot;hammer&quot;,\r\n        }\r\n      ],\r\n      &quot;details&quot;: {\r\n        &quot;age&quot;: 60\r\n      }\r\n    }\r\n  }\r\n}\r\n{\r\n  &quot;content&quot;: {\r\n    &quot;user&quot;: {\r\n      &quot;name&quot;: &quot;Bill&quot;,\r\n      &quot;items&quot;: [\r\n        {\r\n          &quot;name&quot;: &quot;shovel&quot;,\r\n          &quot;details&quot;: {\r\n            &quot;heavy&quot;: false\r\n          }\r\n        },\r\n        {\r\n          &quot;name&quot;: &quot;hammer&quot;,\r\n        }\r\n      ],\r\n      &quot;details&quot;: {\r\n        &quot;age&quot;: 21\r\n      }\r\n    }\r\n  }\r\n}\r\n{\r\n  &quot;content&quot;: {\r\n    &quot;user&quot;: {\r\n      &quot;name&quot;: &quot;Alice&quot;,\r\n      &quot;items&quot;: [\r\n        {\r\n          &quot;name&quot;: &quot;hammer&quot;,\r\n          &quot;details&quot;: {\r\n            &quot;heavy&quot;: true\r\n          }\r\n        },\r\n        {\r\n          &quot;name&quot;: &quot;shovel&quot;,\r\n        }\r\n      ],\r\n      &quot;details&quot;: {\r\n        &quot;age&quot;: 30\r\n      }\r\n    }\r\n  }\r\n}\r\n```\r\n\r\nMy desired output is below, essentially I get a listing of all keys in the structure, including array indices, with a sorted count by key value.\r\n\r\n**Output:**\r\n```\r\n{\r\n  &quot;stats&quot;: {\r\n    &quot;user.name&quot;: {\r\n      &quot;Bill&quot;: 2,\r\n      &quot;Alice&quot;: 1\r\n    },\r\n    &quot;user.items.0.name&quot;: {\r\n      &quot;shovel&quot;: 2,\r\n      &quot;hammer&quot;: 1\r\n    },\r\n    &quot;user.items.1.name&quot;: {\r\n      &quot;hammer&quot;: 2,\r\n      &quot;shovel&quot;: 1\r\n    },\r\n    &quot;user.items.0.details.heavy&quot;: {\r\n      &quot;true&quot;: 1,\r\n      &quot;&quot;: 2,\r\n    },\r\n    &quot;user.items.1.details.heavy&quot;: {\r\n      &quot;true&quot;: 1,\r\n      &quot;&quot;: 2\r\n    },\r\n    &quot;user.details.age&quot;: {\r\n      &quot;30&quot;: 1,\r\n      &quot;62&quot;: 1,\r\n      &quot;21&quot;: 1\r\n    }\r\n  }\r\n}\r\n\r\n```\r\n\r\n**Current Problematic Solution:**\r\n\r\nCurrently I initially get a list of all keys in the json input `[content.user.name, content.user.items.1.name, etc.]` and use that to construct a jq filter.\r\n\r\nFor context, here is the jq filter I use to get **keys**\r\n`select(objects)|=[.] | map( .content | paths(scalars)) | map(join(&quot;.&quot;)) | unique`\r\n\r\nThe current aggregation filter looks like this (for just a single content.user.name aggregate calculation):\r\n\r\n```\r\ncat input.json | jq -c -s &#39;{&quot;stats&quot;: {&quot;user.name&quot;: (map(.content.&quot;user&quot;?.&quot;name&quot;?) \r\n| del(..|nulls) | map(. | tostring) \r\n| reduce .[] as $i ( {}; setpath([$i]; getpath([$i]) + 1)) \r\n| to_entries | sort_by(.value) | reverse | from_entries)}}&#39;\r\n```\r\n\r\nSo to add more aggregate calculations, I use this template:\r\n\r\n```\r\n(newlines added for legibility)\r\n\r\n&quot;{KEY}&quot;: (map(.content.{KEY})\r\n| del(..|nulls) | map(. | tostring)\r\n| reduce .[] as $i ( {}; setpath([$i]; getpath([$i]) + 1))\r\n| to_entries | sort_by(.value) | reverse | from_entries)\r\n```\r\n\r\nFilter including content.user.details..age\r\n\r\n```\r\ncat input.json | jq -c -s &#39;{&quot;stats&quot;: {&quot;user.name&quot;: (map(.content.&quot;user&quot;?.&quot;name&quot;?) \r\n| del(..|nulls) | map(. | tostring) \r\n| reduce .[] as $i ( {}; setpath([$i]; getpath([$i]) + 1)) \r\n| to_entries | sort_by(.value) | reverse | from_entries),\r\n&quot;user.details.age&quot;: (map(.content.&quot;user&quot;?.&quot;details&quot;?.&quot;age&quot;?) \r\n| del(..|nulls) | map(. | tostring) \r\n| reduce .[] as $i ( {}; setpath([$i]; getpath([$i]) + 1)) \r\n| to_entries | sort_by(.value) | reverse | from_entries)}}&#39;\r\n```\r\n\r\nSo the size of my filter grows linearly with the number of keys in the data set. Which means for large data sets, my filter actually grows too large for jq to compile. I&#39;m not sure if I have been staring at this too long, but I am not sure if this is a problem best solved by jq. If I reduce the size of my key aggregation template, I am still capped by the max filter size at some number of keys, and I can&#39;t seem to find a way to map the original keys in order to reuse the template while iterating through keys. This would mean recalculating keys for each newline JSON which isn&#39;t optimal but not sure around that either\r\n\r\n**TLDR;**\r\n\r\nI want to aggregate key values by key from some newline delimited json.\r\n\r\nSome pseudocode of what would be the ideal solution is below, but I cannot get it to work.\r\n\r\n```\r\nget keys:\r\nselect(objects)|=[.] | map( .content | paths(scalars)) | map(join(&quot;.&quot;)) | unique\r\n\r\niterate through all keys and run:\r\n&quot;{KEY}&quot;: (map(.content.{KEY})\r\n| del(..|nulls) | map(. | tostring)\r\n| reduce .[] as $i ( {}; setpath([$i]; getpath([$i]) + 1))\r\n| to_entries | sort_by(.value) | reverse | from_entries)\r\n```\r\n\r\nAnyone have any ideas?\r\n",
        "link": "https://stackoverflow.com/questions/71517326/using-jq-for-statistical-aggregation-of-key-values-in-a-large-data-set",
        "title": "Using JQ for statistical aggregation of key values in a large data set"
    },
    {
        "tags": [
            "amazon-web-services",
            "jq",
            "aws-cli"
        ],
        "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": 1647544461,
                "post_id": 71517646,
                "comment_id": 126404305,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 5461038,
                    "reputation": 2481,
                    "user_id": 5373515,
                    "user_type": "registered",
                    "accept_rate": 60,
                    "profile_image": "https://www.gravatar.com/avatar/91555ff8667c510aff414efae9b9402e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "jayko03",
                    "link": "https://stackoverflow.com/users/5373515/jayko03"
                },
                "reply_to_user": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1647546696,
                "post_id": 71517646,
                "comment_id": 126405053,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1647547275,
                "creation_date": 1647547275,
                "answer_id": 71518358,
                "question_id": 71517646,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "My understanding of the problem description (as opposed to the example) leads me to this jq program:\r\n```\r\nmap(select( any(.Tags[]; .Key | ascii_downcase | IN( &quot;env&quot;, &quot;appname&quot;)) | not))\r\n```\r\n\r\nHopefully, the use of `any` and `IN` here will guide you to the formulation you want.",
                "title": "jq How to filter array object does not contains Key with case insensitively?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1647547275,
        "creation_date": 1647543342,
        "last_edit_date": 1647546653,
        "question_id": 71517646,
        "body_markdown": "I am trying to filter my aws ec2 instances by its Tag Key.\r\nI want to get the result that ec2 instance does not have specific Key(in my example, it is env or appname)\r\n```\r\naws ec2 describe-instances | jq -c &#39;.Reservations[].Instances[] | select(contains({Tags: [{Key:&quot;env&quot;}]}, {Tags:[{Key:&quot;AppName&quot;}]} | not) | {instanceId: .InstanceId, tags: .Tags}&#39;\r\n```\r\nwhich returns\r\nHowever I noticed that I mixed uppercase and lowercase in Key, for example\r\n```\r\n{\r\n {\r\n  &quot;InstanceId&quot;: &quot;t-1234&quot;,\r\n  &quot;Tags&quot;: [\r\n         {&quot;Key&quot;: &quot;Name&quot;,\r\n          &quot;Value&quot;: &quot;Foo&quot;},\r\n         {&quot;Key&quot;: &quot;env&quot;,\r\n          &quot;Value&quot;: &quot;prod&quot;}\r\n        ]\r\n },\r\n{\r\n  &quot;InstanceId&quot;: &quot;t-1235&quot;,\r\n  &quot;Tags&quot;: [\r\n         {&quot;Key&quot;: &quot;Name&quot;,\r\n          &quot;Value&quot;: &quot;Bar&quot;},\r\n         {&quot;Key&quot;: &quot;Env&quot;,\r\n          &quot;Value&quot;: &quot;prod&quot;},\r\n         {&quot;Key&quot;: &quot;AppName&quot;,\r\n          &quot;Value&quot;: &quot;BarApp&quot;}\r\n         ]\r\n },\r\n{\r\n  &quot;InstanceId&quot;: &quot;t-1236&quot;,\r\n  &quot;Tags&quot;: [\r\n         {&quot;Key&quot;: &quot;Name&quot;,\r\n          &quot;Value&quot;: &quot;Bar&quot;},\r\n         ]\r\n },\r\n}\r\n```\r\nWith this example, my desired output will be,\r\n```\r\n{\r\n {  // this instance does not have AppName\r\n  &quot;InstanceId&quot;: &quot;t-1234&quot;,\r\n  &quot;Tags&quot;: [\r\n         {&quot;Key&quot;: &quot;Name&quot;,\r\n          &quot;Value&quot;: &quot;Foo&quot;},\r\n         {&quot;Key&quot;: &quot;env&quot;,\r\n          &quot;Value&quot;: &quot;prod&quot;}\r\n        ]\r\n },\r\n{  // this instance does not have AppName and env\r\n  &quot;InstanceId&quot;: &quot;t-1236&quot;,\r\n   &quot;Tags&quot;: [\r\n         {&quot;Key&quot;: &quot;Name&quot;,\r\n          &quot;Value&quot;: &quot;Bar&quot;},\r\n         ]\r\n },\r\n}\r\n```\r\nI have been searching and reading that I need to use either `ascii_downcase` or `ascii_uppercase`, but keep failing applying. How can I improve my jq statement so that I can filter ec2 instances which do not have specific Key case-insenstiviely(like, `env` or `ENV` or `Env`)?\r\n\r\nThanks",
        "link": "https://stackoverflow.com/questions/71517646/jq-how-to-filter-array-object-does-not-contains-key-with-case-insensitively",
        "title": "jq How to filter array object does not contains Key with case insensitively?"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1647545736,
                "last_edit_date": 1647545736,
                "creation_date": 1647544971,
                "answer_id": 71517959,
                "question_id": 71517828,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Try updating `|=` the `data` field with a `map`:\r\n~~~sh\r\narray=&#39;{&quot;uid&quot;: &quot;foo123&quot; }, {&quot;uid&quot;: &quot;bar123&quot;}&#39;\r\nt=Test\r\n\r\njq --arg title &quot;$t&quot; --arg array &quot;[$array]&quot; \\\r\n  &#39;.data |= map(select(.title == $title).alert.notifications = ($array | fromjson))&#39;\r\n~~~\r\n\r\nAlternatively, wrap the LHS of the assigment into parentheses to retain the context:\r\n~~~sh\r\narray=&#39;{&quot;uid&quot;: &quot;foo123&quot; }, {&quot;uid&quot;: &quot;bar123&quot;}&#39;\r\nt=Test\r\n\r\njq --arg title &quot;$t&quot; --arg array &quot;[$array]&quot; \\\r\n  &#39;(.data[] | select(.title == $title).alert.notifications) = ($array | fromjson)&#39;\r\n~~~\r\n\r\nIn any case, there&#39;s no need for `.|`.",
                "title": "JQ How to update selected objects while also printing out the entire JSON document"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1647545736,
        "creation_date": 1647544303,
        "question_id": 71517828,
        "body_markdown": "I&#39;m trying to simply update an array, while also printing out the full JSON body. Whenever I update the array, I can only output the JSON object that Im updating rather than printing the entire JSON document, plus the updates.\r\n\r\nCommand:\r\n\r\n```\r\narray=&#39;{&quot;uid&quot;: &quot;foo123&quot; }, {&quot;uid&quot;: &quot;bar123&quot;}&#39;\r\nt=Test\r\n\r\njq --arg title &quot;$t&quot; --arg array &quot;[$array]&quot; \\\r\n  &#39;. | select(.data[].title == $title) | .alert.notifications = ($array | fromjson)&#39;\r\n```\r\n\r\nInput:\r\n\r\n```\r\n{\r\n  &quot;data&quot;: [\r\n    {\r\n      &quot;alert&quot;: {\r\n        &quot;notifications&quot;: [\r\n          {\r\n            &quot;uid&quot;: &quot;foo&quot;\r\n          },\r\n          {\r\n            &quot;uid&quot;: &quot;bar&quot;\r\n          }\r\n        ]\r\n      },\r\n      &quot;title&quot;: &quot;Test&quot;\r\n    },\r\n    {\r\n      &quot;alert&quot;: {\r\n        &quot;notifications&quot;: [\r\n          {\r\n            &quot;uid&quot;: &quot;foo1&quot;\r\n          },\r\n          {\r\n            &quot;uid&quot;: &quot;bar1&quot;\r\n          }\r\n        ]\r\n      },\r\n      &quot;title&quot;: &quot;Test2&quot;\r\n    }\r\n  ]\r\n}\r\n```\r\n\r\nUndesired Output:\r\n\r\n```\r\n{\r\n  &quot;data&quot;: [\r\n    {\r\n      &quot;alert&quot;: {\r\n        &quot;notifications&quot;: [\r\n          {\r\n            &quot;uid&quot;: &quot;foo&quot;\r\n          },\r\n          {\r\n            &quot;uid&quot;: &quot;bar&quot;\r\n          }\r\n        ]\r\n      },\r\n      &quot;title&quot;: &quot;Test&quot;\r\n    },\r\n    {\r\n      &quot;alert&quot;: {\r\n        &quot;notifications&quot;: [\r\n          {\r\n            &quot;uid&quot;: &quot;foo1&quot;\r\n          },\r\n          {\r\n            &quot;uid&quot;: &quot;bar1&quot;\r\n          }\r\n        ]\r\n      },\r\n      &quot;title&quot;: &quot;Test2&quot;\r\n    }\r\n  ],\r\n  &quot;alert&quot;: {\r\n    &quot;notifications&quot;: [\r\n      {\r\n        &quot;uid&quot;: &quot;foo123&quot;\r\n      },\r\n      {\r\n        &quot;uid&quot;: &quot;bar123&quot;\r\n      }\r\n    ]\r\n  }\r\n}\r\n```\r\n\r\nDesired Output:\r\n\r\n```\r\n{\r\n  &quot;data&quot;: [\r\n    {\r\n      &quot;alert&quot;: {\r\n        &quot;notifications&quot;: [\r\n          {\r\n            &quot;uid&quot;: &quot;foo123&quot;\r\n          },\r\n          {\r\n            &quot;uid&quot;: &quot;bar123&quot;\r\n          }\r\n        ]\r\n      },\r\n      &quot;title&quot;: &quot;Test&quot;\r\n    },\r\n    {\r\n      &quot;alert&quot;: {\r\n        &quot;notifications&quot;: [\r\n          {\r\n            &quot;uid&quot;: &quot;foo1&quot;\r\n          },\r\n          {\r\n            &quot;uid&quot;: &quot;bar1&quot;\r\n          }\r\n        ]\r\n      },\r\n      &quot;title&quot;: &quot;Test2&quot;\r\n    }\r\n  ]\r\n}\r\n```\r\n\r\n\r\nI have tried a few different scenarios and it the closest I have come is the undesired output. Any help would be greatly appreciated!\r\n\r\nThanks,",
        "link": "https://stackoverflow.com/questions/71517828/jq-how-to-update-selected-objects-while-also-printing-out-the-entire-json-docume",
        "title": "JQ How to update selected objects while also printing out the entire JSON document"
    },
    {
        "tags": [
            "json",
            "bash",
            "shell",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1647550858,
                "creation_date": 1647550858,
                "answer_id": 71518992,
                "question_id": 71518883,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "```\r\n$ jq -r &#39;.[].name&#39; world_cities.json\r\nNewport Beach\r\nNipomo\r\nNorco\r\nNorth Glendale\r\nNorth Highlands\r\n```\r\n\r\nThe data is surrounded by an array. You can access the elements with `.[]`: `.` is the array itself and `[]` gives its elements. Then `.name` gives you each element&#39;s name.\r\n\r\nFinally, use `-r` to have jq output raw strings without quotes.",
                "title": "Convert JSON to a newline-delimited list of all the things tagged &quot;name&quot; with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1647550858,
        "creation_date": 1647550210,
        "last_edit_date": 1647550617,
        "question_id": 71518883,
        "body_markdown": "I&#39;m trying to make a .txt list of cities from a dataset of cities with more than 15000 people. The JSON is structured like this:\r\n```\r\n[\r\n  {\r\n    &quot;country&quot;: &quot;United States&quot;,\r\n    &quot;geonameid&quot;: 5376890,\r\n    &quot;name&quot;: &quot;Newport Beach&quot;,\r\n    &quot;subcountry&quot;: &quot;California&quot;\r\n  },\r\n  {\r\n    &quot;country&quot;: &quot;United States&quot;,\r\n    &quot;geonameid&quot;: 5377100,\r\n    &quot;name&quot;: &quot;Nipomo&quot;,\r\n    &quot;subcountry&quot;: &quot;California&quot;\r\n  },\r\n  {\r\n    &quot;country&quot;: &quot;United States&quot;,\r\n    &quot;geonameid&quot;: 5377199,\r\n    &quot;name&quot;: &quot;Norco&quot;,\r\n    &quot;subcountry&quot;: &quot;California&quot;\r\n  },\r\n  {\r\n    &quot;country&quot;: &quot;United States&quot;,\r\n    &quot;geonameid&quot;: 5377613,\r\n    &quot;name&quot;: &quot;North Glendale&quot;,\r\n    &quot;subcountry&quot;: &quot;California&quot;\r\n  },\r\n  {\r\n    &quot;country&quot;: &quot;United States&quot;,\r\n    &quot;geonameid&quot;: 5377640,\r\n    &quot;name&quot;: &quot;North Highlands&quot;,\r\n    &quot;subcountry&quot;: &quot;California&quot;\r\n  }\r\n]\r\n```\r\nI want to take this and make it into a newline-delimited list of all the things tagged &quot;name&quot; like this:\r\n```\r\nNewport Beach\r\nNipomo\r\nNorco\r\nNorth Glendale\r\nNorth Highlands\r\n```\r\nI tried to do this on the command line using a tool I found called jq, which I though would work by writing something like\r\n```\r\ncat world_cities.json | jq &#39;.name&#39; &gt; cities_list.txt\r\n```\r\nbut I got an error that said &quot;jq: error (at &lt;stdin&gt;:0): Cannot index array with string &quot;name&quot;&quot;.\r\nOf course, I&#39;m sure I&#39;m not fully understanding how jq is supposed to work, and I don&#39;t have very much experience parsing JSON, but I&#39;m having trouble finding an answer to my specific problem online. Does anyone know what I can potentially do to achieve what I&#39;m trying to achieve from the command line?\r\n\r\nIf you want to see the whole dataset I&#39;m trying to parse, you can find it here: https://pkgstore.datahub.io/core/world-cities/world-cities_json/data/5b3dd46ad10990bca47b04b4739a02ba/world-cities_json.json",
        "link": "https://stackoverflow.com/questions/71518883/convert-json-to-a-newline-delimited-list-of-all-the-things-tagged-name-with-jq",
        "title": "Convert JSON to a newline-delimited list of all the things tagged &quot;name&quot; with jq"
    },
    {
        "tags": [
            "loops",
            "jq",
            "github-actions"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 336297,
                    "reputation": 350,
                    "user_id": 6350016,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/D9MuI.jpg?s=256",
                    "display_name": "ste-xx",
                    "link": "https://stackoverflow.com/users/6350016/ste-xx"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1647609048,
                "post_id": 71523580,
                "comment_id": 126419702,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1647622728,
                "creation_date": 1647622728,
                "answer_id": 71530633,
                "question_id": 71523580,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I suggest you to use the [JSON to variables][1] GitHub Actions. From the doc:\r\n\r\n&lt;kbd&gt; test.json&lt;/kbd&gt;\r\n\r\n```json\r\n{\r\n    &quot;value&quot;: &quot;value&quot;,\r\n    &quot;array&quot;: [\r\n        {\r\n            &quot;value&quot;: &quot;value 0&quot;\r\n        },\r\n        &quot;value 1&quot;\r\n    ],\r\n    &quot;obj&quot;: {\r\n        &quot;value1&quot;: &quot;value1&quot;,\r\n        &quot;value2&quot;: &quot;value2&quot;\r\n    }\r\n}\r\n\r\n```\r\n\r\n&lt;kbd&gt;workflow.main&lt;/kbd&gt;\r\n```yaml\r\n- name: JSON to variables\r\n  uses: antifree/json-to-variables@v1.0.1\r\n  with:\r\n    filename: &#39;test.json&#39;\r\n    prefix: test\r\n- name: Show output\r\n  run: echo &quot;The time was ${{ env.test_value }}, ${{ env.test_array_0_value }}, ${{ env.test_obj_value1 }}&quot;\r\n\r\n```\r\n\r\n  [1]: https://github.com/marketplace/actions/json-to-variables",
                "title": "Loop through JSON file and set each value as a variable within Github Actions workflow"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1647622728,
        "creation_date": 1647588011,
        "question_id": 71523580,
        "body_markdown": "**Goal**: set ~20 variables that are stored in a JSON file into the $GITHUBENV during GHA job.\r\n\r\nCurrently, I am hardcoding this with the parsing of the JSON file with jq:\r\n\r\n```\r\n- name: Set env variables from variables json\r\n      run: |\r\n          echo &quot;NAME=$(jq -r &#39;.name&#39; variables.json)&quot; &gt;&gt; $GITHUB_ENV\r\n          echo &quot;AGE=$(jq -r &#39;.age&#39; variables.json)&quot; &gt;&gt; $GITHUB_ENV\r\n          echo &quot;WEIGHT=$(jq -r &#39;.weight&#39; variables.json)&quot; &gt;&gt; $GITHUB_ENV\r\n          ...etc\r\n```\r\n**How can I &quot;for loop&quot; through this process?**\r\n\r\nAfterwards, I want to check if the variables entered manually through a workflow_dispatch run of the job match what are in the variables.json file. If they don&#39;t match, I want to update the json file with the new manually entered value:\r\n```\r\n- name: Set age if dispatching\r\n      shell: bash -l {0}\r\n      if: github.event.inputs.age != env.AGE\r\n      run: echo &quot;$( jq &#39;.name = ${{github.event.inputs.age}}&#39; variables.json )&quot; &gt; variables.json\r\n```\r\n**Similarly, how do I loop through this process?**\r\n",
        "link": "https://stackoverflow.com/questions/71523580/loop-through-json-file-and-set-each-value-as-a-variable-within-github-actions-wo",
        "title": "Loop through JSON file and set each value as a variable within Github Actions workflow"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": -1,
                "last_activity_date": 1731883868,
                "last_edit_date": 1731883868,
                "creation_date": 1647616848,
                "answer_id": 71529306,
                "question_id": 71528675,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "with the above content in the `input.json`\r\n\r\nquery:\r\n```shell\r\njq &#39;.[] | {id, keywords: .keywords[]} | select(.keywords == &quot;blue&quot;)&#39; input.json\r\n```\r\n\r\noutput:\r\n```\r\n{\r\n  &quot;id&quot;: 2345,\r\n  &quot;keywords&quot;: &quot;blue&quot;\r\n}\r\n{\r\n  &quot;id&quot;: 3456,\r\n  &quot;keywords&quot;: &quot;blue&quot;\r\n}\r\n```\r\n\r\nyou can get the first object from this.",
                "title": "JQ — Return first element that satisfies a predicate"
            },
            {
                "up_vote_count": 5,
                "is_accepted": false,
                "score": 5,
                "last_activity_date": 1647619038,
                "creation_date": 1647619038,
                "answer_id": 71529829,
                "question_id": 71528675,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Using [`first/1`][1] with a `select` expression is the right approach here\r\n\r\n```none\r\njq --arg v &quot;The sky is blue.&quot; &#39;first(.[] | select(.keywords as $k | $v | match($k[])))&#39;\r\n```\r\n\r\nproduces\r\n\r\n```json\r\n{\r\n  &quot;id&quot;: 2345,\r\n  &quot;name&quot;: &quot;Entry 2&quot;,\r\n  &quot;keywords&quot;: [\r\n    &quot;red&quot;,\r\n    &quot;blue&quot;,\r\n    &quot;pink&quot;\r\n  ]\r\n}\r\n```\r\n\r\n\r\n  [1]: https://stedolan.github.io/jq/manual/#first(expr),last(expr),nth(n;expr)",
                "title": "JQ — Return first element that satisfies a predicate"
            },
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1647629326,
                "creation_date": 1647629326,
                "answer_id": 71531862,
                "question_id": 71528675,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "A variation based on Inian&#39;s excellent answer:\r\n\r\n```none\r\nfirst(.[] | select(.keywords | any(inside(&quot;the sky is blue.&quot;))))\r\n```\r\n\r\nIf we have the data in `input.json` and the string `&quot;the sky is blue.&quot;` passed as a parameter we have:\r\n\r\n```none\r\njq --arg str &#39;the sky is blue&#39; &#39;first(.[] | select(.keywords | any(inside($str))))&#39; input.json\r\n```\r\n\r\nThis returns the first element which keywords is contained within `$str`:\r\n\r\n```json\r\n{\r\n  &quot;id&quot;: 2345,\r\n  &quot;name&quot;: &quot;Entry 2&quot;,\r\n  &quot;keywords&quot;: [\r\n    &quot;red&quot;,\r\n    &quot;blue&quot;,\r\n    &quot;pink&quot;\r\n  ]\r\n}\r\n```",
                "title": "JQ — Return first element that satisfies a predicate"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 5,
        "last_activity_date": 1731883868,
        "creation_date": 1647614182,
        "last_edit_date": 1647629828,
        "question_id": 71528675,
        "body_markdown": "I have a string like:\r\n\r\n```json\r\n&quot;The sky is blue.&quot;\r\n```\r\n\r\nand a JSON file like\r\n\r\n```json\r\n[\r\n  {\r\n  \t&quot;id&quot;: 1234,\r\n  \t&quot;name&quot;: &quot;Entry 1&quot;,\r\n  \t&quot;keywords&quot;: [\r\n      &quot;orange&quot;,\r\n      &quot;yellow&quot;\r\n    ]\r\n  }, \r\n  {\r\n  \t&quot;id&quot;: 2345,\r\n  \t&quot;name&quot;: &quot;Entry 2&quot;,\r\n  \t&quot;keywords&quot;: [\r\n      &quot;red&quot;,\r\n      &quot;blue&quot;,\r\n      &quot;pink&quot;\r\n    ]\r\n  }, \r\n  {\r\n  \t&quot;id&quot;: 3456,\r\n  \t&quot;name&quot;: &quot;Entry 3&quot;,\r\n  \t&quot;keywords&quot;: [\r\n  \t\t&quot;green&quot;,\r\n  \t\t&quot;blue&quot;,\r\n  \t\t&quot;black&quot;\r\n  \t]\r\n  }\r\n]\r\n```\r\n\r\nI want to return the first element which has a keyword that can be found in the string.\r\n\r\nIn this case I would like to have the element with the id `2345`, because the keyword `&quot;blue&quot;` occurs in the string, and it is the first match. \r\n\r\nIs there a one-line solution with JQ (e.g. with various pipes)? I&#39;m not looking for a solution with loops.",
        "link": "https://stackoverflow.com/questions/71528675/jq-return-first-element-that-satisfies-a-predicate",
        "title": "JQ — Return first element that satisfies a predicate"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1647758926,
                "creation_date": 1647758926,
                "answer_id": 71544665,
                "question_id": 71544639,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Let your script just produce a stream of objects by not printing the brackets and the commas.\r\n~~~sh\r\necho &quot;${JSON_STRING}&quot; &gt;&gt; state.json\r\n~~~\r\n`state.json` should then contain a stream of objects:\r\n~~~json\r\n{\r\n  &quot;cluster&quot;: &quot;eks-b&quot;,\r\n  &quot;asgname&quot;: &quot;eks-1234&quot;,\r\n  &quot;minSize&quot;: &quot;0&quot;,\r\n  &quot;DesiredCapacity&quot;: &quot;0&quot;,\r\n  &quot;MaxSize&quot;: &quot;0&quot;\r\n}\r\n{\r\n  &quot;cluster&quot;: &quot;eks-b&quot;,\r\n  &quot;asgname&quot;: &quot;eks-1234&quot;,\r\n  &quot;minSize&quot;: &quot;0&quot;,\r\n  &quot;DesiredCapacity&quot;: &quot;0&quot;,\r\n  &quot;MaxSize&quot;: &quot;0&quot;\r\n}\r\n{\r\n  &quot;cluster&quot;: &quot;dev&quot;,\r\n  &quot;asgname&quot;: &quot;eks-12345&quot;,\r\n  &quot;minSize&quot;: &quot;0&quot;,\r\n  &quot;DesiredCapacity&quot;: &quot;0&quot;,\r\n  &quot;MaxSize&quot;: &quot;0&quot;\r\n}\r\n{\r\n  &quot;cluster&quot;: &quot;dev&quot;,\r\n  &quot;asgname&quot;: &quot;eks-1234&quot;,\r\n  &quot;minSize&quot;: &quot;0&quot;,\r\n  &quot;DesiredCapacity&quot;: &quot;0&quot;,\r\n  &quot;MaxSize&quot;: &quot;0&quot;\r\n}\r\n{\r\n  &quot;cluster&quot;: &quot;eks-a&quot;,\r\n  &quot;asgname&quot;: &quot;eks-1234&quot;,\r\n  &quot;minSize&quot;: &quot;0&quot;,\r\n  &quot;DesiredCapacity&quot;: &quot;0&quot;,\r\n  &quot;MaxSize&quot;: &quot;0&quot;\r\n}\r\n{\r\n  &quot;cluster&quot;: &quot;eks-a&quot;,\r\n  &quot;asgname&quot;: &quot;eks-1323&quot;,\r\n  &quot;minSize&quot;: &quot;0&quot;,\r\n  &quot;DesiredCapacity&quot;: &quot;0&quot;,\r\n  &quot;MaxSize&quot;: &quot;0&quot;\r\n}\r\n~~~\r\nNow you can read in that stream with jq, using the `-s` option to convert it into a proper array.\r\n~~~sh\r\njq -s . state.json\r\n~~~\r\n~~~json\r\n[\r\n  {\r\n    &quot;cluster&quot;: &quot;eks-b&quot;,\r\n    &quot;asgname&quot;: &quot;eks-1234&quot;,\r\n    &quot;minSize&quot;: &quot;0&quot;,\r\n    &quot;DesiredCapacity&quot;: &quot;0&quot;,\r\n    &quot;MaxSize&quot;: &quot;0&quot;\r\n  },\r\n  {\r\n    &quot;cluster&quot;: &quot;eks-b&quot;,\r\n    &quot;asgname&quot;: &quot;eks-1234&quot;,\r\n    &quot;minSize&quot;: &quot;0&quot;,\r\n    &quot;DesiredCapacity&quot;: &quot;0&quot;,\r\n    &quot;MaxSize&quot;: &quot;0&quot;\r\n  },\r\n  {\r\n    &quot;cluster&quot;: &quot;dev&quot;,\r\n    &quot;asgname&quot;: &quot;eks-12345&quot;,\r\n    &quot;minSize&quot;: &quot;0&quot;,\r\n    &quot;DesiredCapacity&quot;: &quot;0&quot;,\r\n    &quot;MaxSize&quot;: &quot;0&quot;\r\n  },\r\n  {\r\n    &quot;cluster&quot;: &quot;dev&quot;,\r\n    &quot;asgname&quot;: &quot;eks-1234&quot;,\r\n    &quot;minSize&quot;: &quot;0&quot;,\r\n    &quot;DesiredCapacity&quot;: &quot;0&quot;,\r\n    &quot;MaxSize&quot;: &quot;0&quot;\r\n  },\r\n  {\r\n    &quot;cluster&quot;: &quot;eks-a&quot;,\r\n    &quot;asgname&quot;: &quot;eks-1234&quot;,\r\n    &quot;minSize&quot;: &quot;0&quot;,\r\n    &quot;DesiredCapacity&quot;: &quot;0&quot;,\r\n    &quot;MaxSize&quot;: &quot;0&quot;\r\n  },\r\n  {\r\n    &quot;cluster&quot;: &quot;eks-a&quot;,\r\n    &quot;asgname&quot;: &quot;eks-1323&quot;,\r\n    &quot;minSize&quot;: &quot;0&quot;,\r\n    &quot;DesiredCapacity&quot;: &quot;0&quot;,\r\n    &quot;MaxSize&quot;: &quot;0&quot;\r\n  }\r\n]\r\n~~~\r\n[Demo](https://jqplay.org/s/_k0HlYzNor) for the `jq -s` part",
                "title": "Remove last `},` in a dynamically generated JSON array using sed or jq"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1647767301,
                "creation_date": 1647767301,
                "answer_id": 71545432,
                "question_id": 71544639,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If you don&#39;t require the final result to be pretty-printed, you could save the expense of the call to `jq -s` by deleting the superfluous comma, e.g.\r\n\r\n    sed &#39;$s/,$//&#39;\r\n\r\nor if you like:\r\n\r\n    sed -i.bak &#39;$s/,$//&#39;\r\n\r\nEven better, you can avoid handling the terminating &#39;]&#39; in the same step, e.g. using &#39;$s/,$/]/&#39;\r\n\r\n",
                "title": "Remove last `},` in a dynamically generated JSON array using sed or jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1647767301,
        "creation_date": 1647758656,
        "last_edit_date": 1647763132,
        "question_id": 71544639,
        "body_markdown": "I am attempting to dynamically generate a JSON, however, the method I follow leaves a last `},` making the JSON invalid:\r\n```\r\n#Initializing Current State file\r\n    echo &quot;[&quot; &gt; state.json\r\n    # Getting list of all EKS clusters\r\n    for cluster in $(aws eks list-clusters --output text | awk &#39;{print $2}&#39;)\r\n    do\r\n      echo &quot;====== $cluster ======&quot;\r\n      # Get list of all ASG from cluster\r\n      for asg in $(aws autoscaling describe-auto-scaling-groups  --query &#39;AutoScalingGroups[?contains(Tags[?Key==`eks:cluster-name`].Value, `&#39;&quot;$cluster&quot;&#39;`)].[AutoScalingGroupName]&#39; --output text)\r\n      do\r\n        echo &quot;Getting capacity for ASG: $asg&quot;\r\n        MinSize=$(aws autoscaling describe-auto-scaling-groups --auto-scaling-group-name $asg --query &#39;AutoScalingGroups[*].MinSize&#39; --output text)\r\n        DesiredCapacity=$(aws autoscaling describe-auto-scaling-groups --auto-scaling-group-name $asg --query &#39;AutoScalingGroups[*].DesiredCapacity&#39; --output text)  \r\n        MaxSize=$(aws autoscaling describe-auto-scaling-groups --auto-scaling-group-name $asg --query &#39;AutoScalingGroups[*].MaxSize&#39; --output text)\r\n        JSON_STRING=$( jq -n \\\r\n                  --arg cn &quot;$cluster&quot; \\\r\n                  --arg asg &quot;$asg&quot; \\\r\n                  --arg MinSize &quot;$MinSize&quot; \\\r\n                  --arg DesiredCapacity &quot;$DesiredCapacity&quot; \\\r\n                  --arg MaxSize &quot;$MaxSize&quot; \\\r\n                  &#39;{cluster: $cn, asgname: $asg, minSize: $MinSize, DesiredCapacity: $DesiredCapacity, MaxSize: $MaxSize}&#39; )\r\n        echo &quot;${JSON_STRING},&quot; &gt;&gt; state.json\r\n      done\r\n    done\r\n    #Finalizing Current State file\r\n    echo &quot;]&quot; &gt;&gt; state.json\r\n```\r\n\r\n```\r\n$ cat state.json\r\n[\r\n{\r\n  &quot;cluster&quot;: &quot;eks-b&quot;,\r\n  &quot;asgname&quot;: &quot;eks-1234&quot;,\r\n  &quot;minSize&quot;: &quot;0&quot;,\r\n  &quot;DesiredCapacity&quot;: &quot;0&quot;,\r\n  &quot;MaxSize&quot;: &quot;0&quot;\r\n},\r\n{\r\n  &quot;cluster&quot;: &quot;eks-b&quot;,\r\n  &quot;asgname&quot;: &quot;eks-1234&quot;,\r\n  &quot;minSize&quot;: &quot;0&quot;,\r\n  &quot;DesiredCapacity&quot;: &quot;0&quot;,\r\n  &quot;MaxSize&quot;: &quot;0&quot;\r\n},\r\n{\r\n  &quot;cluster&quot;: &quot;dev&quot;,\r\n  &quot;asgname&quot;: &quot;eks-12345&quot;,\r\n  &quot;minSize&quot;: &quot;0&quot;,\r\n  &quot;DesiredCapacity&quot;: &quot;0&quot;,\r\n  &quot;MaxSize&quot;: &quot;0&quot;\r\n},\r\n{\r\n  &quot;cluster&quot;: &quot;dev&quot;,\r\n  &quot;asgname&quot;: &quot;eks-1234&quot;,\r\n  &quot;minSize&quot;: &quot;0&quot;,\r\n  &quot;DesiredCapacity&quot;: &quot;0&quot;,\r\n  &quot;MaxSize&quot;: &quot;0&quot;\r\n},\r\n{\r\n  &quot;cluster&quot;: &quot;eks-a&quot;,\r\n  &quot;asgname&quot;: &quot;eks-1234&quot;,\r\n  &quot;minSize&quot;: &quot;0&quot;,\r\n  &quot;DesiredCapacity&quot;: &quot;0&quot;,\r\n  &quot;MaxSize&quot;: &quot;0&quot;\r\n},\r\n{\r\n  &quot;cluster&quot;: &quot;eks-a&quot;,\r\n  &quot;asgname&quot;: &quot;eks-1323&quot;,\r\n  &quot;minSize&quot;: &quot;0&quot;,\r\n  &quot;DesiredCapacity&quot;: &quot;0&quot;,\r\n  &quot;MaxSize&quot;: &quot;0&quot;\r\n},\r\n]\r\n```\r\n`jq` validation:\r\n```\r\n$ cat state.json  | jq empty\r\nparse error: Expected another array element at line 44, column 1\r\n```\r\n\r\nI have attempted multiple options, mostly with `sed`, but have not met the specific requirement to only remove the last occurrence of `},`\r\nAny advice is appreciated.",
        "link": "https://stackoverflow.com/questions/71544639/remove-last-in-a-dynamically-generated-json-array-using-sed-or-jq",
        "title": "Remove last `},` in a dynamically generated JSON array using sed or jq"
    },
    {
        "tags": [
            "arrays",
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 6196394,
                    "reputation": 86601,
                    "user_id": 5291015,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/4tAvO.jpg?s=256",
                    "display_name": "Inian",
                    "link": "https://stackoverflow.com/users/5291015/inian"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1647839143,
                "post_id": 71552299,
                "comment_id": 126463164,
                "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": 1647839156,
                "post_id": 71552299,
                "comment_id": 126463165,
                "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": 1647892881,
                "post_id": 71552299,
                "comment_id": 126481364,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1647842424,
                "creation_date": 1647842424,
                "answer_id": 71553345,
                "question_id": 71552299,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Last: `last`\r\n\r\n5th: `.[4]`\r\n\r\n6th: `.[5]`\r\n\r\n5th and 6th (as array) `.[4:6]`\r\n\r\n5th and 6th (as array) `[ .[4], .[5] ]`\r\n\r\n5th and 6th (as stream) `.[4:6][]`\r\n\r\n5th and 6th (as stream) `.[4], .[5]`\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n",
                "title": "jq utility - extract certain json blocks"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1647892397,
                "last_edit_date": 1647892397,
                "creation_date": 1647884988,
                "answer_id": 71561951,
                "question_id": 71552299,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Last: .[-1]\r\n\r\nn-th, where $n is specified on the command line (0-based indexing): \r\n    jq --argjson n $n &#39;.[$n]&#39;\r\n\r\n$m-th and $n-th (with 0-based indexing): &#39;.[$m, $n]&#39;\r\n\r\nAn element chosen pseudo-randomly (assuming a bash or bash-like shell and that the array is not too long):\r\n\r\n```\r\njq --argjson prn $RANDOM &#39;\r\n  if length &gt; 32767 then &quot;Sorry - this algorithm is too simplistic.&quot; | error\r\n  else .[$prn % length]\r\n  end\r\n&#39;  \r\n```\r\n\r\nAn alternative way to make a pseudo-random choice without assuming a bash-like environment:\r\n```\r\njq &#39;\r\n  if length &gt; 1e6 then &quot;Sorry - this algorithm is too simplistic.&quot; | error\r\n  else \r\n   (now|tostring|sub(&quot;.*[.]&quot;;&quot;&quot;)|tonumber) as $n\r\n   | .[$n % length]\r\n  end&#39;\r\n```\r\n",
                "title": "jq utility - extract certain json blocks"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1647892816,
        "creation_date": 1647830723,
        "last_edit_date": 1647892816,
        "question_id": 71552299,
        "body_markdown": "I am formatting the json output from curl command using `jq` utility. I am not able to find a way to extract a json block by position.That is to say if I want to print just the last json block or a random json block like 5th or 6th or 5th &amp; 6th only, is there a `jq` option or a way to achieve this please?\r\n\r\nJSON array looks like this\r\n```json\r\n[\r\n  {\r\n    &quot;field1&quot;: &quot;value1&quot;,\r\n    &quot;field2&quot;: &quot;value2&quot;,\r\n    &quot;field3&quot;: &quot;value3&quot;\r\n  },\r\n  {\r\n    &quot;field1&quot;: &quot;value1&quot;,\r\n    &quot;field2&quot;: &quot;value2&quot;,\r\n    &quot;field3&quot;: &quot;value3&quot;\r\n  },\r\n  {\r\n    &quot;field1&quot;: &quot;value1&quot;,\r\n    &quot;field2&quot;: &quot;value2&quot;,\r\n    &quot;field3&quot;: &quot;value3&quot;\r\n  },\r\n  {\r\n    &quot;field1&quot;: &quot;value1&quot;,\r\n    &quot;field2&quot;: &quot;value2&quot;,\r\n    &quot;field3&quot;: &quot;value3&quot;\r\n  }\r\n]\r\n```",
        "link": "https://stackoverflow.com/questions/71552299/jq-utility-extract-certain-json-blocks",
        "title": "jq utility - extract certain json blocks"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1647861180,
                "last_edit_date": 1647861180,
                "creation_date": 1647860803,
                "answer_id": 71556575,
                "question_id": 71556455,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Update `|=` the `.Changes` array by adding to its `first` item&#39;s `ResourceRecordSet` field the second file&#39;s array items `input[]`:\r\n~~~sh\r\njq &#39;.Changes |= [first | .ResourceRecordSet += input[]]&#39; outer.json records.json\r\n~~~\r\n~~~json\r\n{\r\n  &quot;Comment&quot;: &quot;Delete record sets for $cluster_name&quot;,\r\n  &quot;Changes&quot;: [\r\n    {\r\n      &quot;Action&quot;: &quot;DELETE&quot;,\r\n      &quot;ResourceRecordSet&quot;: {\r\n        &quot;Name&quot;: &quot;abcde_svcx.$cluster_name.domain.com.&quot;,\r\n        &quot;Type&quot;: &quot;TXT&quot;,\r\n        &quot;TTL&quot;: 300,\r\n        &quot;ResourceRecords&quot;: [\r\n          {\r\n            &quot;Value&quot;: &quot;\\&quot;heritage=external-dns,external-dns/owner=$cluster_name,external-dns/resource=service/svcx/svcx-cluster\\&quot;&quot;\r\n          }\r\n        ]\r\n      }\r\n    },\r\n    {\r\n      &quot;Action&quot;: &quot;DELETE&quot;,\r\n      &quot;ResourceRecordSet&quot;: {\r\n        &quot;Name&quot;: &quot;svcx.$cluster_name.domain.com.&quot;,\r\n        &quot;Type&quot;: &quot;A&quot;,\r\n        &quot;AliasTarget&quot;: {\r\n          &quot;HostedZoneId&quot;: &quot;123456789&quot;,\r\n          &quot;DNSName&quot;: &quot;some-value.elb.us-east-2.amazonaws.com.&quot;,\r\n          &quot;EvaluateTargetHealth&quot;: true\r\n        }\r\n      }\r\n    }\r\n  ]\r\n}\r\n~~~\r\n[Demo](https://jqplay.org/s/0XLMizylKA)\r\n\r\nNote: If `outer.json`&#39;s `ResourceRecordSet` is always empty, you may as well just make an assignment `=` instead of an updating addition `+=`.",
                "title": "How do I add JSON array entries into a JSON object using jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1647861180,
        "creation_date": 1647860279,
        "last_edit_date": 1647860602,
        "question_id": 71556455,
        "body_markdown": "I am writing a script that is meant to clean up Route53 records, so I want to add entries in an array to a JSON object as below\r\n\r\nouter.json\r\n```json\r\n{\r\n  &quot;Comment&quot;: &quot;Delete record sets for $cluster_name&quot;,\r\n  &quot;Changes&quot;: [\r\n    {\r\n      &quot;Action&quot;: &quot;DELETE&quot;,\r\n      &quot;ResourceRecordSet&quot;: {}\r\n    }\r\n  ]\r\n}\r\n```\r\n\r\nrecords.json\r\n```json\r\n[\r\n  {\r\n    &quot;Name&quot;: &quot;abcde_svcx.$cluster_name.domain.com.&quot;,\r\n    &quot;Type&quot;: &quot;TXT&quot;,\r\n    &quot;TTL&quot;: 300,\r\n    &quot;ResourceRecords&quot;: [\r\n      {\r\n        &quot;Value&quot;: &quot;\\&quot;heritage=external-dns,external-dns/owner=$cluster_name,external-dns/resource=service/svcx/svcx-cluster\\&quot;&quot;\r\n      }\r\n    ]\r\n  },\r\n  {\r\n    &quot;Name&quot;: &quot;svcx.$cluster_name.domain.com.&quot;,\r\n    &quot;Type&quot;: &quot;A&quot;,\r\n    &quot;AliasTarget&quot;: {\r\n      &quot;HostedZoneId&quot;: &quot;123456789&quot;,\r\n      &quot;DNSName&quot;: &quot;some-value.elb.us-east-2.amazonaws.com.&quot;,\r\n      &quot;EvaluateTargetHealth&quot;: true\r\n    }\r\n  }\r\n]\r\n```\r\n\r\nI would like to have an output that looks like below:\r\n\r\noutput.json\r\n```json\r\n{\r\n  &quot;Comment&quot;: &quot;Delete record sets for $cluster_name&quot;,\r\n  &quot;Changes&quot;: [\r\n    {\r\n      &quot;Action&quot;: &quot;DELETE&quot;,\r\n      &quot;ResourceRecordSet&quot;: {\r\n        &quot;Name&quot;: &quot;abcde_svcx.$cluster_name.domain.com.&quot;,\r\n        &quot;Type&quot;: &quot;TXT&quot;,\r\n        &quot;TTL&quot;: 300,\r\n        &quot;ResourceRecords&quot;: [\r\n          {\r\n            &quot;Value&quot;: &quot;\\&quot;heritage=external-dns,external-dns/owner=$cluster_name,external-dns/resource=service/svcx/svcx-cluster\\&quot;&quot;\r\n          }\r\n        ]\r\n      }\r\n    },\r\n    {\r\n      &quot;Action&quot;: &quot;DELETE&quot;,\r\n      &quot;ResourceRecordSet&quot;: {\r\n        &quot;Name&quot;: &quot;svcx.$cluster_name.domain.com.&quot;,\r\n        &quot;Type&quot;: &quot;A&quot;,\r\n        &quot;AliasTarget&quot;: {\r\n          &quot;HostedZoneId&quot;: &quot;123456789&quot;,\r\n          &quot;DNSName&quot;: &quot;some-value.elb.us-east-2.amazonaws.com.&quot;,\r\n          &quot;EvaluateTargetHealth&quot;: true\r\n        }\r\n      }\r\n    }\r\n  ]\r\n}\r\n```\r\n\r\nIs this something that can be done in a shell script using jq?",
        "link": "https://stackoverflow.com/questions/71556455/how-do-i-add-json-array-entries-into-a-json-object-using-jq",
        "title": "How do I add JSON array entries into a JSON object using jq?"
    },
    {
        "tags": [
            "json",
            "linux",
            "shell",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1647872804,
                "last_edit_date": 1647872804,
                "creation_date": 1647870699,
                "answer_id": 71558774,
                "question_id": 71557998,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "One approach:\r\n\r\n```sh\r\njq -n \\\r\n   --argjson d1 file1.json \\\r\n   --argjson d2 file2.json \\\r\n&#39;\r\n   $d1 * $d2 |\r\n   with_entries(\r\n      .key as $user |\r\n      .value = (\r\n         with_entries(\r\n            .key as $server |\r\n            .value | ( $d1[ $user ][ $server ] + $d2[ $user ][ $server ] ) / 2\r\n         )\r\n      )\r\n   )\r\n&#39;\r\n```\r\n\r\n[Demo](https://jqplay.org/s/_h-AgRJlUR) on jqplay\r\n\r\n`$d1 * $d2` creates the right structure, but with the wrong values. We then fix up the values.\r\n\r\n---\r\n\r\nAnother approach:\r\n\r\n```sh\r\njq -s &#39;\r\n   length as $n |\r\n   reduce ( .[] | to_entries[] ) as $_ ( { };\r\n      $_.key as $user |\r\n      reduce ( $_.value | to_entries[] ) as $_ ( .;\r\n         $_.key as $server |\r\n         .[ $user ][ $server ] += $_.value / $n\r\n      )\r\n   )\r\n&#39; file1.json file2.json\r\n```\r\n\r\n[Demo](https://jqplay.org/s/doaxfjPmO3) on jqplay\r\n\r\nThis one works with more than two files!\r\n",
                "title": "How to merge multiple JSON files and average values"
            },
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1647872156,
                "creation_date": 1647872156,
                "answer_id": 71559093,
                "question_id": 71557998,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s a solution for an arbitrary number of input files. It first divides each value by the number of input files, and then adds them all up retaining the keys:\r\n~~~sh\r\njq -s &#39;\r\n  .[][][] /= length\r\n  | reduce (.[] | to_entries[]) as $u ({};\r\n      reduce ($u.value | to_entries[]) as $s (.;\r\n        .[$u.key][$s.key] += $s.value\r\n      )\r\n    )\r\n&#39; file*\r\n~~~\r\n~~~json\r\n{\r\n  &quot;user1&quot;: {\r\n    &quot;server1&quot;: 7.85,\r\n    &quot;server2&quot;: 5.15,\r\n    &quot;server3&quot;: 10.25\r\n  },\r\n  &quot;user2&quot;: {\r\n    &quot;server1&quot;: 7.5\r\n  },\r\n  &quot;user3&quot;: {\r\n    &quot;server1&quot;: 14\r\n  }\r\n}\r\n~~~\r\n[Demo](https://jqplay.org/s/-w5H6JtEB-)\r\n\r\n---\r\n\r\nThe division may also be shifted into the addition by using a variable at the beginning instead:\r\n~~~sh\r\njq -s &#39;\r\n  length as $c\r\n  | reduce (.[] | to_entries[]) as $u ({};\r\n      reduce ($u.value | to_entries[]) as $s (.;\r\n        .[$u.key][$s.key] += $s.value / $c\r\n      )\r\n    )\r\n&#39; file*\r\n~~~\r\n[Demo](https://jqplay.org/s/ErcOByZ_q2)",
                "title": "How to merge multiple JSON files and average values"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1647872804,
        "creation_date": 1647867428,
        "question_id": 71557998,
        "body_markdown": "I try to merge different JSON files, which contain this kind of data:\r\n```\r\n#file1:\r\n{\r\n  &quot;user1&quot;: {\r\n    &quot;server1&quot;: 7.2,\r\n    &quot;server2&quot;: 10.3\r\n  },\r\n  &quot;user2&quot;: {\r\n    &quot;server1&quot;: 15\r\n  }\r\n}\r\n```\r\n```\r\n#file2:\r\n{\r\n  &quot;user1&quot;: {\r\n    &quot;server1&quot;: 8.5,\r\n    &quot;server3&quot;: 20.5\r\n  },\r\n  &quot;user3&quot;: {\r\n    &quot;server1&quot;: 28\r\n  }\r\n}\r\n```\r\nAnd so on (12 per hour).\r\n\r\nThese data are a list of users with the servers usage in percentage, evolving every 5 min (user may dissapear and reappear depending of resources usage).\r\n\r\nI am under Linux and I generate these files with different Shell tools like `jq`.\r\n\r\nMy goal is to **obtain a merged file every hour with the average load on all available data**, like that (just considering the 2 files above):\r\n\r\n```\r\n#result:\r\n{\r\n  &quot;user1&quot;: {\r\n    &quot;server1&quot;: 7.85,\r\n    &quot;server2&quot;: 5.15,\r\n    &quot;server3&quot;: 10.25\r\n  },\r\n  &quot;user2&quot;: {\r\n    &quot;server1&quot;: 7.5\r\n  },\r\n  &quot;user3&quot;: {\r\n    &quot;server1&quot;: 14\r\n  }\r\n}\r\n```\r\n\r\nI try several queries with `reduce` command, but nothing works as expected.\r\n\r\nMaybe the best approach should to parse every files, extract data and store user in different file and after merge all data?\r\n\r\nThank for your analyse and example.",
        "link": "https://stackoverflow.com/questions/71557998/how-to-merge-multiple-json-files-and-average-values",
        "title": "How to merge multiple JSON files and average values"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1647905872,
                "last_edit_date": 1647905872,
                "creation_date": 1647889712,
                "answer_id": 71562896,
                "question_id": 71562848,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Use `select` to filter by condition\r\n~~~sh\r\njq &#39;select(.level == &quot;error&quot;)&#39;\r\n~~~\r\n~~~json\r\n{\r\n  &quot;level&quot;: &quot;error&quot;,\r\n  &quot;timestamp&quot;: &quot;2022-03-21T16:10:27.060Z&quot;,\r\n  &quot;msg&quot;: &quot;message 3&quot;\r\n}\r\n~~~\r\n[Demo](https://jqplay.org/s/H3u1pHqN4z)\r\n\r\nTo extract the message, use the `-r` option\r\n~~~sh\r\njq -r &#39;select(.level == &quot;error&quot;).msg&#39;\r\n~~~\r\n~~~\r\nmessage 3\r\n~~~\r\n[Demo](https://jqplay.org/s/Gzbq6QU-cI)\r\n\r\n---\r\n\r\nIf you want to access the nth object, you may want to use a structure whose items you can count. Using the `-s` option would turn the input stream into an array. Using the `--argjson` option enables you using an external (JSON) value for reference:\r\n~~~sh\r\njq -sr --argjson n 2 &#39;.[$n].msg&#39;\r\n~~~\r\n~~~\r\nmessage 3\r\n~~~\r\n[Demo](https://jqplay.org/s/uKiQCUK8jg)\r\n\r\nTo directly address the nth element of a stream, use the `nth` function, in combination with `inputs` and the `-n` option to address the entire stream at once:\r\n~~~sh\r\njq -nr --argjson n 2 &#39;nth($n;inputs).msg&#39;\r\n~~~\r\n~~~\r\nmessage 3\r\n~~~\r\n[Demo](https://jqplay.org/s/CEgQA7oeIJ)",
                "title": "How to use jq when the response is not a list"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1647905872,
        "creation_date": 1647889499,
        "question_id": 71562848,
        "body_markdown": "My json response is like this.\r\n\r\n```\r\n{\r\n  &quot;level&quot;: &quot;info&quot;,\r\n  &quot;timestamp&quot;: &quot;2022-03-21T16:10:27.060Z&quot;,\r\n  &quot;msg&quot;: &quot;starting test&quot;,\r\n}\r\n{\r\n  &quot;level&quot;: &quot;warn&quot;,\r\n  &quot;timestamp&quot;: &quot;2022-03-21T16:10:27.060Z&quot;,\r\n  &quot;msg&quot;: &quot;message 2&quot;\r\n}\r\n{\r\n  &quot;level&quot;: &quot;error&quot;,\r\n  &quot;timestamp&quot;: &quot;2022-03-21T16:10:27.060Z&quot;,\r\n  &quot;msg&quot;: &quot;message 3&quot;\r\n}\r\n\r\n\r\n```\r\n\r\nI want to extract.\r\n\r\nEither 3rd message (or nth message) or the message associated with error\r\n\r\nHow can I do this with jq?",
        "link": "https://stackoverflow.com/questions/71562848/how-to-use-jq-when-the-response-is-not-a-list",
        "title": "How to use jq when the response is not a list"
    },
    {
        "tags": [
            "json",
            "join",
            "key",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1647892003,
                "creation_date": 1647892003,
                "answer_id": 71563307,
                "question_id": 71563226,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Use the [SQL-Style Operators](https://stedolan.github.io/jq/manual/#SQL-StyleOperators) `JOIN` and `INDEX`\r\n~~~sh\r\njq &#39;JOIN(INDEX(inputs[];.Id);.[];.Id;add)&#39; json1 json2\r\n~~~\r\n~~~json\r\n[\r\n  {\r\n    &quot;Id&quot;: &quot;1&quot;,\r\n    &quot;FirstName&quot;: &quot;firstName1&quot;,\r\n    &quot;LastName&quot;: &quot;lastName1&quot;,\r\n    &quot;School&quot;: &quot;School1&quot;,\r\n    &quot;Degree&quot;: &quot;Degree1&quot;\r\n  },\r\n  {\r\n    &quot;Id&quot;: &quot;2&quot;,\r\n    &quot;FirstName&quot;: &quot;firstName2&quot;,\r\n    &quot;LastName&quot;: &quot;lastName2&quot;,\r\n    &quot;School&quot;: &quot;School2&quot;,\r\n    &quot;Degree&quot;: &quot;Degree2&quot;\r\n  },\r\n  {\r\n    &quot;Id&quot;: &quot;3&quot;,\r\n    &quot;FirstName&quot;: &quot;firstName2&quot;,\r\n    &quot;LastName&quot;: &quot;lastName3&quot;,\r\n    &quot;School&quot;: &quot;School3&quot;,\r\n    &quot;Degree&quot;: &quot;Degree3&quot;\r\n  }\r\n]\r\n~~~\r\n[Demo](https://jqplay.org/s/NfPvWJEYXY)",
                "title": "Combine two Json&#39;s by key using JQ"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1647902241,
        "creation_date": 1647891617,
        "last_edit_date": 1647902241,
        "question_id": 71563226,
        "body_markdown": "I have two json&#39;s that are a list of objects that share the same key and I am trying to combine them into one json using jq. The expected output is a single json that contains a list of the combined objects in list form. For example:\r\n\r\nJson 1:\r\n```\r\n[\r\n{&quot;Id&quot;:&quot;1&quot;, &quot;FirstName&quot;:&quot;firstName1&quot;, &quot;LastName&quot;:&quot;lastName1&quot;},\r\n{&quot;Id&quot;:&quot;2&quot;, &quot;FirstName&quot;:&quot;firstName2&quot;, &quot;LastName&quot;:&quot;lastName2&quot;},\r\n{&quot;Id&quot;:&quot;3&quot;, &quot;FirstName&quot;:&quot;firstName2&quot;, &quot;LastName&quot;:&quot;lastName3&quot;}\r\n]\r\n``` \r\n\r\nJson 2:\r\n```\r\n[\r\n{&quot;School&quot;:&quot;School1&quot;, &quot;Id&quot;:&quot;1&quot;, &quot;Degree&quot;:&quot;Degree1&quot;},\r\n{&quot;School&quot;:&quot;School2&quot;, &quot;Id&quot;:&quot;2&quot;, &quot;Degree&quot;:&quot;Degree2&quot;},\r\n{&quot;School&quot;:&quot;School3&quot;, &quot;Id&quot;:&quot;3&quot;, &quot;Degree&quot;:&quot;Degree3&quot;}\r\n]\r\n```\r\n\r\nCombined Json Based on Id\r\n```\r\n[\r\n{&quot;Id&quot;:&quot;1&quot;, &quot;FirstName&quot;:&quot;firstName1&quot;, &quot;LastName&quot;:&quot;lastName1&quot;,\r\n&quot;School&quot;:&quot;School1&quot;, &quot;Degree&quot;:&quot;Degree1&quot;},\r\n{&quot;Id&quot;:&quot;2&quot;, &quot;FirstName&quot;:&quot;firstName2&quot;, &quot;LastName&quot;:&quot;lastName2&quot;,\r\n&quot;School&quot;:&quot;School2&quot;, &quot;Degree&quot;:&quot;Degree2&quot;},\r\n{&quot;Id&quot;:&quot;3&quot;, &quot;FirstName&quot;:&quot;firstName2&quot;, &quot;LastName&quot;:&quot;lastName3&quot;,\r\n&quot;School&quot;:&quot;School3&quot;, &quot;Degree&quot;:&quot;Degree3&quot;}\r\n]\r\n```\r\nI have already tried a few ways to merge these jsons I [found in this thread](https://stackoverflow.com/questions/19529688/how-to-merge-2-json-objects-from-2-files-using-jq) such as:\r\n\r\n```\r\njq -s &#39;.[0] * .[1]&#39; file1 file2\r\n```\r\nI am still a novice in jq, so any help would be appreciated!",
        "link": "https://stackoverflow.com/questions/71563226/combine-two-jsons-by-key-using-jq",
        "title": "Combine two Json&#39;s by key using JQ"
    },
    {
        "tags": [
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1647936781,
                "post_id": 71565651,
                "comment_id": 126490123,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1693,
                    "reputation": 18059,
                    "user_id": 2283,
                    "user_type": "registered",
                    "accept_rate": 79,
                    "profile_image": "https://www.gravatar.com/avatar/3ac5db3768c09788ed9fe03c5f4ff171?s=256&d=identicon&r=PG",
                    "display_name": "Weeble",
                    "link": "https://stackoverflow.com/users/2283/weeble"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1647945135,
                "post_id": 71565651,
                "comment_id": 126493146,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1647911098,
                "last_edit_date": 1647911098,
                "creation_date": 1647909227,
                "answer_id": 71565668,
                "question_id": 71565651,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "One way would be to use the `-s` option and test for the empty array:\r\n~~~sh\r\njq -s &#39;if . == [] then &quot;empty&quot; else .[0].data end&#39; &lt;/dev/null\r\n~~~\r\n~~~json\r\nempty\r\n~~~\r\n\r\nBut what else should be considered an empty input? As JSON ignores newlines etc., there could be an actual input which is considered an empty JSON:\r\n~~~sh\r\necho | jq -s &#39;if . == [] then &quot;empty&quot; else .[0].data end&#39;\r\n~~~\r\n~~~json\r\nempty\r\n~~~\r\n\r\nWhile the expected case will pass...\r\n~~~sh\r\necho &#39;{&quot;data&quot;:1}&#39; | jq -s &#39;if . == [] then &quot;empty&quot; else .[0].data end&#39;\r\n~~~\r\n~~~json\r\n1\r\n~~~\r\n\r\n...other non-empty cases may not be caught as with the empty case\r\n~~~sh\r\necho &#39;{&quot;other&quot;:1}&#39; | jq -s &#39;if . == [] then &quot;empty&quot; else .[0].data end&#39;\r\n~~~\r\n~~~json\r\nnull\r\n~~~\r\n\r\nHowever, to elaborate more, you&#39;d need to specify what &quot;do something different&quot; means. If you wanted to fail, like with the `-e` option but with a custom error message, you could read in the whole input as raw text using the `-Rs` option, then try to convert it to JSON using the `fromjson` builtin, and react upon that if it failed using the `?` and `//` operators:\r\n\r\n~~~sh\r\njq -Rs &#39;fromjson? // error(&quot;Bad input&quot;) | .data&#39; &lt;/dev/null\r\n~~~\r\n~~~none\r\njq: error (at &lt;stdin&gt;:1): Bad input\r\n~~~\r\n\r\n~~~sh\r\necho | jq -Rs &#39;fromjson? // error(&quot;Bad input&quot;) | .data&#39;\r\n~~~\r\n~~~none\r\njq: error (at &lt;stdin&gt;:1): Bad input\r\n~~~\r\n\r\n~~~sh\r\necho &#39;{&quot;data&quot;:1}&#39; | jq -Rs &#39;fromjson? // error(&quot;Bad input&quot;) | .data&#39;\r\n~~~\r\n~~~json\r\n1\r\n~~~\r\n",
                "title": "How to test empty input?"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1647928027,
                "last_edit_date": 1647928027,
                "creation_date": 1647926513,
                "answer_id": 71567256,
                "question_id": 71565651,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can use\r\n\r\n```sh\r\njq -ne &#39;input? // null&#39;\r\n```\r\n\r\n```none\r\n$ echo {}  | jq -ne &#39;input? // null&#39; &gt;/dev/null; echo $?\r\n0\r\n\r\n$ echo &#39;&#39;  | jq -ne &#39;input? // null&#39; &gt;/dev/null; echo $?\r\n1\r\n\r\n$ &lt;/dev/null jq -ne &#39;input? // null&#39; &gt;/dev/null; echo $?\r\n1\r\n```\r\n\r\n---\r\n\r\nIf you also want to check that `.data` isn&#39;t missing and isn&#39;t `null` (or `false`), you can use\r\n\r\n```sh\r\njq -ne &#39;input? // null | .data&#39;\r\n```\r\n\r\n```none\r\n$ echo &#39;{&quot;data&quot;:123}&#39;  | jq -ne &#39;input? // null | .data&#39; &gt;/dev/null; echo $?\r\n0\r\n\r\n$ echo &#39;{&quot;data&quot;:null}&#39; | jq -ne &#39;input? // null | .data&#39; &gt;/dev/null; echo $?\r\n1\r\n\r\n$ echo {}              | jq -ne &#39;input? // null | .data&#39; &gt;/dev/null; echo $?\r\n1\r\n\r\n$ echo &#39;&#39;              | jq -ne &#39;input? // null | .data&#39; &gt;/dev/null; echo $?\r\n1\r\n\r\n$ &lt;/dev/null             jq -ne &#39;input? // null | .data&#39; &gt;/dev/null; echo $?\r\n1\r\n```\r\n",
                "title": "How to test empty input?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1647928027,
        "creation_date": 1647909030,
        "question_id": 71565651,
        "body_markdown": "The following command finishes silently when the input is empty. How to test for empty input and do something different depending on whether the input is empty or not?\r\n\r\n```\r\n$ jq -e -r .data &lt; /dev/null\r\n$ echo $?\r\n0\r\n```",
        "link": "https://stackoverflow.com/questions/71565651/how-to-test-empty-input",
        "title": "How to test empty input?"
    },
    {
        "tags": [
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 166270,
                    "reputation": 135171,
                    "user_id": 390278,
                    "user_type": "registered",
                    "accept_rate": 86,
                    "profile_image": "https://www.gravatar.com/avatar/84715fec547362389d02f5be0ed12814?s=256&d=identicon&r=PG",
                    "display_name": "Jeff Mercado",
                    "link": "https://stackoverflow.com/users/390278/jeff-mercado"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1647967176,
                "post_id": 71575557,
                "comment_id": 126502352,
                "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": 1647973226,
                "post_id": 71575557,
                "comment_id": 126504631,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1647970321,
                "last_edit_date": 1647970321,
                "creation_date": 1647970013,
                "answer_id": 71576448,
                "question_id": 71575557,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You&#39;re applying `scan` to the wrong thing.\r\n\r\n```jq\r\nif .spec.selector == &quot;all()&quot; then\r\n   &quot;{}&quot;\r\nelse\r\n   .spec.selector | \r\n   scan(&quot;([0-9A-Za-z_]+) == &#39;([0-9A-Za-z_]+)&quot;) |\r\n   { (.[0]): .[1] }\r\nend\r\n```\r\n\r\nThis simplifies to\r\n\r\n```jq\r\n.spec.selector |\r\nif . == &quot;all()&quot; then\r\n   &quot;{}&quot;\r\nelse\r\n   scan(&quot;([0-9A-Za-z_]+) == &#39;([0-9A-Za-z_]+)&quot;) |\r\n   { (.[0]): .[1] }\r\nend\r\n```\r\n\r\nIt seems weird that you output a string in one path and an object in the other. Is this correct?\r\n\r\nIn addition to not specifying what you want from the three alternatives (`all()`, `x == &#39;y&#39;`, other), you did not specify what output from the overall program, so it&#39;s not clear how this should be incorporated into your program.\r\n",
                "title": "jq error when using if then else with scan"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1647970321,
        "creation_date": 1647966334,
        "question_id": 71575557,
        "body_markdown": "I have json:\r\n```json\r\n{\r\n  &quot;apiVersion&quot;: &quot;projectcalico.org/v3&quot;,\r\n  &quot;kind&quot;: &quot;NetworkPolicy&quot;,\r\n  &quot;metadata&quot;: {\r\n    &quot;name&quot;: &quot;allow-tcp-6379&quot;,\r\n    &quot;namespace&quot;: &quot;production&quot;\r\n  },\r\n  &quot;spec&quot;: {\r\n    &quot;selector&quot;: &quot;all()&quot;,\r\n...\r\n}\r\n```\r\n\r\nI select the fields I need with the command ```jq &#39;if .spec.selector == &quot;all()&quot; then &quot;{}&quot; else (scan(&quot;([0-9A-Za-z_]+) == &#39;([0-9A-Za-z_]+)&quot;) | {(.[0]): .[1]}) end | {selector: .}&#39;```\r\n\r\nBut if I change the field to ```.spec.selector: &quot;app ==&#39;nginx&#39;&quot;``` then I get an error - ```jq: error (at &lt;stdin&gt;:39): object ({&quot;apiVersio...) cannot be matched, as it is not a string\r\nexit status 5```\r\n\r\nHow to fix this?\r\n\r\njqplay: https://jqplay.org/s/7zS1CTHM69",
        "link": "https://stackoverflow.com/questions/71575557/jq-error-when-using-if-then-else-with-scan",
        "title": "jq error when using if then else with scan"
    },
    {
        "tags": [
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 24555788,
                    "reputation": 613,
                    "user_id": 18464383,
                    "user_type": "registered",
                    "profile_image": "https://lh3.googleusercontent.com/a/AATXAJytHTqU0FvbgOgVBCGNQjo8_j1jY7yJASOT2530=k-s256",
                    "display_name": "Devesh",
                    "link": "https://stackoverflow.com/users/18464383/devesh"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1647970606,
                "post_id": 71576552,
                "comment_id": 126503737,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1647971305,
                "post_id": 71576552,
                "comment_id": 126503986,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1648410754,
                "last_edit_date": 1648410754,
                "creation_date": 1647992142,
                "answer_id": 71580179,
                "question_id": 71576552,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Ignoring potential complications having to do with arrays, looking at the &quot;symmetric difference&quot; of the sets of paths to scalars would make sense. As a starting point, you could thus consider: \r\n\r\n    jq -c &#39;\r\n     [paths(scalars)] as $f1\r\n     | [input | paths(scalars)] as $f2\r\n     | ($f1 - $f2) + ($f2 - $f1)&#39; file1.json file2.json \r\n\r\nYou might want to stringify the paths, but then again, it might be wise to avoid doing so if the mapping to the strings is not invertible.\r\n\r\n----\r\nIf arrays are present, you might want to compare the paths while ignoring the array indices:\r\n     \r\n\r\n    def p: [paths(scalars) | map(select(type==&quot;string&quot;))] | unique;\r\n    p as $f1\r\n    | (input | p) as $f2\r\n    | ($f1 - $f2) + ($f2 - $f1)\r\n    | .[]\r\n\r\nThe last line ensures that the result is a (possibly empty) stream, the point being that this makes it easy to check the return code to determine whether any difference was detected: simply use the -e command-line option.  If there are no differences, the return code will then be 4.\r\n\r\nOne way to check if the stream is empty would be to use the -4",
                "title": "Compare json files but ignore values"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 3,
        "last_activity_date": 1648410754,
        "creation_date": 1647970411,
        "last_edit_date": 1648125739,
        "question_id": 71576552,
        "body_markdown": "I would like to compare two json files and report differencies but I am interested in keys only and **not** values. So for example the &quot;json-diff&quot; between the following two files (of course they are much more complicated):\r\n```\r\n{\r\n    &quot;http&quot;: {\r\n        &quot;https&quot;: true,\r\n        &quot;swagger&quot;: {\r\n            &quot;enabled&quot;: false\r\n        },\r\n        &quot;scalingFactors&quot;: [0.1, 0.2]\r\n    }\r\n}\r\n```\r\n\r\n```\r\n{\r\n    &quot;http&quot;: {\r\n        &quot;https&quot;: true,\r\n        &quot;swagger&quot;: {\r\n            &quot;enabled&quot;: true\r\n        },\r\n        &quot;scalingFactors&quot;: [0.1, 0.1],\r\n        &quot;test&quot;: true\r\n    }\r\n}\r\n```\r\n\r\n**should report** that there is missing key:\r\n- `http.test`\r\n\r\nbut\r\n\r\n**should not report** that the following keys have different values:\r\n- `http.swagger.enabled`\r\n- `http.scalingFactors`\r\n\r\nI looked at the `jq` tool but I am not sure how to ignore values.\r\n",
        "link": "https://stackoverflow.com/questions/71576552/compare-json-files-but-ignore-values",
        "title": "Compare json files but ignore values"
    },
    {
        "tags": [
            "python",
            "json",
            "excel",
            "parsing",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 1020072,
                    "reputation": 243994,
                    "user_id": 1030675,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/957956ce51706d03f19a4dc85a767bb1?s=256&d=identicon&r=PG",
                    "display_name": "choroba",
                    "link": "https://stackoverflow.com/users/1030675/choroba"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1647986460,
                "post_id": 71579394,
                "comment_id": 126508813,
                "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": 1647986476,
                "post_id": 71579394,
                "comment_id": 126508814,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 21968090,
                    "reputation": 1,
                    "user_id": 16245010,
                    "user_type": "registered",
                    "profile_image": "https://lh3.googleusercontent.com/a/AATXAJx1i77uOOn6YVMPPk4pZJ0LEHKAoYWDAU6L6Ajt=k-s256",
                    "display_name": "Smith",
                    "link": "https://stackoverflow.com/users/16245010/smith"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1647987092,
                "post_id": 71579394,
                "comment_id": 126508948,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1020072,
                    "reputation": 243994,
                    "user_id": 1030675,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/957956ce51706d03f19a4dc85a767bb1?s=256&d=identicon&r=PG",
                    "display_name": "choroba",
                    "link": "https://stackoverflow.com/users/1030675/choroba"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1647987164,
                "post_id": 71579394,
                "comment_id": 126508972,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 21968090,
                    "reputation": 1,
                    "user_id": 16245010,
                    "user_type": "registered",
                    "profile_image": "https://lh3.googleusercontent.com/a/AATXAJx1i77uOOn6YVMPPk4pZJ0LEHKAoYWDAU6L6Ajt=k-s256",
                    "display_name": "Smith",
                    "link": "https://stackoverflow.com/users/16245010/smith"
                },
                "reply_to_user": {
                    "account_id": 1020072,
                    "reputation": 243994,
                    "user_id": 1030675,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/957956ce51706d03f19a4dc85a767bb1?s=256&d=identicon&r=PG",
                    "display_name": "choroba",
                    "link": "https://stackoverflow.com/users/1030675/choroba"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1647987485,
                "post_id": 71579394,
                "comment_id": 126509055,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1647987246,
                "last_edit_date": 1647987246,
                "creation_date": 1647986661,
                "answer_id": 71579474,
                "question_id": 71579394,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You were almost there:\r\n\r\n    jq -C &#39;select(.Plants[] | (.Name == &quot;corn-1&quot; and .Price == &quot;20&quot;)).Id&#39;\r\n\r\nThe problem was you used `.Price` in the context of the top object, so it never matched.\r\n\r\nIf there are several matches in one Plants, the Id will be printed multiple times. To get it only once, you can use\r\n\r\n    jq -C &#39;select(.Plants | any(.Name == &quot;corn-1&quot; and .Price == &quot;20&quot;)).Id&#39;",
                "title": "extract information from a json file with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1647987246,
        "creation_date": 1647986076,
        "last_edit_date": 1647986586,
        "question_id": 71579394,
        "body_markdown": "I tried to get the Id: if the name of the plant is corn-1 and the price is 20 then print the Id\r\n\r\n    {\r\n        &quot;Id&quot;:  &quot;Category-1&quot;,\r\n        &quot;Plants&quot;:\r\n        [\r\n            {\r\n                &quot;Name&quot;:  &quot;corn-1&quot;,\r\n                &quot;Price&quot;:  &quot;20&quot;\r\n            },\r\n            {\r\n                &quot;Name&quot;:  &quot;corn-2&quot;,\r\n                &quot;Price&quot;:  &quot;10&quot;\r\n            },\r\n            {\r\n                &quot;Name&quot;:  &quot;corn-3&quot;,\r\n                &quot;Price&quot;:  &quot;5&quot;\r\n            },\r\n        \r\n        ]\r\n    }\r\n\r\n    cat plants.json | jq -C &#39;select(.Plants[].Name==&quot;corn-1&quot; and .Price==&quot;20&quot;).Id\r\n\r\n\r\n but nothing is printed out. I should get Category-1.\r\nAny ideas please ?\r\n",
        "link": "https://stackoverflow.com/questions/71579394/extract-information-from-a-json-file-with-jq",
        "title": "extract information from a json file with jq"
    },
    {
        "tags": [
            "arrays",
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1647999565,
                "post_id": 71580794,
                "comment_id": 126511286,
                "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": 1647999628,
                "post_id": 71580794,
                "comment_id": 126511299,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1647999656,
                "creation_date": 1647999656,
                "answer_id": 71580876,
                "question_id": 71580794,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Your `select` receives a series of boolean values, one for each item in the `.cells` array. Using `not` inverts all of them, which means if you had a mixed set of boolean values, it would still be mixed, and in either case `select` would take those being evaluated to `true`.\r\n\r\nThe solution is to use `any` or `all` to [aggregate](https://stedolan.github.io/jq/manual/#any%2Cany%28condition%29%2Cany%28generator%3Bcondition%29) these boolean values. Without any sample data, I assume you are looking for\r\n~~~\r\n.rows[] | select(any(.cells[]; .value | IN($BL[])) | not)\r\n~~~",
                "title": "JQ using not with IN does not work or have any effect?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1647999656,
        "creation_date": 1647998787,
        "question_id": 71580794,
        "body_markdown": "This code works as expected:\r\n\r\n```\r\njq --argjson BL ${BL} &#39;.rows[] | select(.cells[] | .value | IN($BL[]))\r\n```\r\n\r\nIt returns a list of elements that contain a value in $BL\r\n\r\nI want to return all those that are not in $BL, so I use | not\r\n\r\nIt returns the exact same result as without the | not, it seems to make no difference.\r\n\r\n```\r\njq --argjson BL ${BL} &#39;.rows[] | select(.cells[] | .value | IN($BL[]) | not)\r\n```\r\n\r\nusing the following retuned nothing at all \r\n\r\n```\r\njq --argjson BL ${BL} &#39;.rows[] | select(.cells[] | .value | IN($BL[]|not))\r\n```\r\n \r\nis there a simple thing I&#39;m missing with using IN with NOT?\r\n\r\nfor reference $BL is and array on email address, trying to make an api call and return all elements that don&#39;t have an email listed in $BL",
        "link": "https://stackoverflow.com/questions/71580794/jq-using-not-with-in-does-not-work-or-have-any-effect",
        "title": "JQ using not with IN does not work or have any effect?"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1709688999,
                "last_edit_date": 1709688999,
                "creation_date": 1648039294,
                "answer_id": 71587417,
                "question_id": 71586980,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Following your scheme, there is no such solution because all of your filters address all items &quot;at once&quot;, meaning independently from their position in the array. That&#39;s why you can only set them to the same value or otherwise treat them in the same way, without using their index, which would be needed to address the specific new value to be used.\r\n\r\nTo achieve your goal, you will have to iterate over either array indices or the aligned elements.\r\n\r\nThe former could be implemented by using `reduce` to iterate over the new values in combination with `to_entries` to access their position (key), and successively update the input array&#39;s items using key and value.\r\n~~~\r\nreduce ([3,7] | to_entries[]) as $i (.; .[$i.key].a = $i.value)\r\n~~~\r\n~~~json\r\n[\r\n  {\r\n    &quot;a&quot;: 3,\r\n    &quot;b&quot;: &quot;john&quot;\r\n  },\r\n  {\r\n    &quot;a&quot;: 7,\r\n    &quot;b&quot;: &quot;mark&quot;\r\n  }\r\n]\r\n~~~\r\n[Demo](https://jqplay.org/s/eJhHDXzjszC)\r\n\r\nThe latter could be implemented using the `transpose` builtin, which aligns elements of two (or any number of) arrays by matching their indices, and outputs them as a combined array.\r\n~~~json\r\n[., [3,7]] | [transpose[] | first + {a:last}]\r\n~~~\r\n~~~json\r\n[\r\n  {\r\n    &quot;a&quot;: 3,\r\n    &quot;b&quot;: &quot;john&quot;\r\n  },\r\n  {\r\n    &quot;a&quot;: 7,\r\n    &quot;b&quot;: &quot;mark&quot;\r\n  }\r\n]\r\n~~~\r\n[Demo](https://jqplay.org/s/TcFt2tc985-)\r\n\r\n---\r\nNote: Your sample filters could be condensed to `.[].a = 5` ([Demo](https://jqplay.org/s/zxkmTDHZm6N)) and `.[].a += 2` ([Demo](https://jqplay.org/s/SF1ED9fWhkY)), respectively.",
                "title": "how to alter values in a field of a json array with jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1709688999,
        "creation_date": 1648037404,
        "last_edit_date": 1648208192,
        "question_id": 71586980,
        "body_markdown": "I would like to assign different values to a same field in a json array using jq command line utility,\r\n\r\nfor example let&#39;s take this:\r\n\r\n    myjson=&#39;[{&quot;a&quot;:1,&quot;b&quot;:&quot;john&quot;}, {&quot;a&quot;:2, &quot;b&quot;:&quot;mark&quot;}]&#39;\r\n\r\nwith the following I can assign all fields a same value\r\n\r\n    echo $myjson | jq &#39;[.[] | .a=5 ]&#39;\r\n\r\nI can also increment it:\r\n\r\n    echo $myjson | jq &#39;[.[] | .a+=2]&#39;\r\n\r\nbut how can I assign two new different values like 7  and 3  to the two a fields in the objects in the array?\r\n\r\nusing the following, or similar assigns a whole array to each variable\r\n\r\n    echo $myjson | jq &#39;[.[] | .a=[7,3]]&#39;",
        "link": "https://stackoverflow.com/questions/71586980/how-to-alter-values-in-a-field-of-a-json-array-with-jq",
        "title": "how to alter values in a field of a json array with jq?"
    },
    {
        "tags": [
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1648086263,
                "post_id": 71589807,
                "comment_id": 126537830,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1648102519,
                "last_edit_date": 1648102519,
                "creation_date": 1648054112,
                "answer_id": 71591016,
                "question_id": 71589807,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "One way using `reduce` operating on the whole list, forming only `n` entries (sub-arrays) at a time\r\n\r\n```none\r\njq -c --argjson g 4 &#39;. as $input | \r\n  reduce range(0; ( $input | length ) ; $g) as $r ( []; . + [ $input[ $r: ( $r + $g ) ] ] )&#39;\r\n```\r\n\r\nThe three argument form of `range(from: upto; by)` generates numbers from to upto with an increment of by\r\n\r\nE.g. `range(0; 9; 4)` from your original input produces a set of indices - `0, 4, 8` which is ranged over and the final list is formed by appending the slices, coming out of the array slice operation e.g. `[0:4]`, `[4:8]` and `[8:12]`\r\n\r\n",
                "title": "how to accomplish each_slice like ruby with jq"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1648071614,
                "creation_date": 1648071614,
                "answer_id": 71594367,
                "question_id": 71589807,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Use a `while` loop to chop off the first 4 elements `.[4:]` until the array is empty `[]`. Then, for each result array, consider only its first 4 items `[:4]`. Generalized to `$n`:\r\n~~~sh\r\njq -c --argjson n 4 &#39;[while(. != []; .[$n:])[:$n]]&#39;\r\n~~~\r\n~~~json\r\n[[1,2,3,4],[5,6,7,8],[9]]\r\n~~~\r\n[Demo](https://jqplay.org/s/WcP86BCN-G)\r\n",
                "title": "how to accomplish each_slice like ruby with jq"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1648075775,
                "creation_date": 1648075775,
                "answer_id": 71594997,
                "question_id": 71589807,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "There&#39;s an undocumented builtin function, `_nwise/1`, which you would use like this:\r\n```\r\njq -nc --argjson n 4 &#39;[1,2,3,4,5,6,7,8,9] | [_nwise($n)]&#39;\r\n\r\n[[1,2,3,4],[5,6,7,8],[9]]\r\n```\r\n\r\nNotice that using `--argjson` allows you to avoid the call to `tonumber`.",
                "title": "how to accomplish each_slice like ruby with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 2,
        "last_activity_date": 1648102519,
        "creation_date": 1648048998,
        "question_id": 71589807,
        "body_markdown": "Sample Input\r\n\r\n    [1,2,3,4,5,6,7,8,9]\r\n\r\nMy Solution\r\n\r\n    $ echo &#39;[1,2,3,4,5,6,7,8,9]&#39; | jq --arg g 4 &#39;. as $l|($g|tonumber) as $n |$l|length as $c|[range(0;$c;($g|tonumber))]|map($l[.:.+$n])&#39; -c\r\n\r\nOutput\r\n\r\n    [[1,2,3,4],[5,6,7,8],[9]]\r\n\r\n\r\nshorthand, handy method anything else?",
        "link": "https://stackoverflow.com/questions/71589807/how-to-accomplish-each-slice-like-ruby-with-jq",
        "title": "how to accomplish each_slice like ruby with jq"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1648056657,
                "creation_date": 1648056657,
                "answer_id": 71591580,
                "question_id": 71590931,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Your `jo` command produces an object with a &quot;locations&quot; field, whose value will be used to replace the one of the existing object (`.` refers to the outlying object rather than to its &quot;locations&quot; array).\r\n\r\nInstead you&#39;ll want the following :\r\n\r\n    jq --argjson element &quot;$element&quot; &#39;.locations += $element.locations&#39;",
                "title": "Trying to add array element to a maybe existing config file"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1648056657,
        "creation_date": 1648053740,
        "last_edit_date": 1648055359,
        "question_id": 71590931,
        "body_markdown": "I&#39;m testing the following:\r\n\r\n```sh\r\n#!/usr/bin/env bash\r\n\r\nelement=&quot;$(jo -p \\\r\n\tlocations=[&quot;$(jo \\\r\n\t\tname=&quot;$name&quot; \\\r\n\t\taddress=&quot;$address&quot; \\\r\n\t\tlatitude=$lat \\\r\n\t\tlongitude=$long \\\r\n\t\tgridId=$grid_id \\\r\n\t\tgridX=$grid_X \\\r\n\t\tgridY=$grid_Y \\\r\n\t\tcountyUGC=&quot;$countyUGC&quot; \\\r\n\t\tzoneUGC=&quot;$zoneUGC&quot; \\\r\n\t\tstationId=&quot;$stationId&quot;)&quot;])&quot;\r\n\r\nif [[ -e weather.locations ]]; then\r\n\tjq --argjson element &quot;$element&quot; &#39;. += $element&#39; \\\r\n\t\tweather.locations &gt;weather.locations.temp &amp;&amp; mv weather.locations.temp weather.locations\r\nelse\r\n\techo &quot;$entry&quot; &gt;weather.locations\r\nfi\r\n```\r\nThe 1st time I run this, the file will not exist (reason for my `[[ ]]`).  But subsequent times, it seems to always modify the initial element instead of adding.  My goal: Append location array with new element (I don&#39;t see any need for updating, but &quot;name&quot; would be the field to key off of)\r\n\r\noutput of the jo: (of course all the fields would be filled in)\r\n\r\n```json\r\n{\r\n  &quot;locations&quot;: [\r\n    {\r\n      &quot;name&quot;: &quot;home&quot;,\r\n      &quot;address&quot;: &quot;123 Main St, MyTown MyState&quot;,\r\n      &quot;latitude&quot;: null,\r\n      &quot;longitude&quot;: null,\r\n      &quot;gridId&quot;: null,\r\n      &quot;gridX&quot;: null,\r\n      &quot;gridY&quot;: null,\r\n      &quot;countyUGC&quot;: null,\r\n      &quot;zoneUGC&quot;: null,\r\n      &quot;stationId&quot;: null\r\n    }\r\n  ]\r\n}\r\n```\r\n\r\nThanks for any pointers",
        "link": "https://stackoverflow.com/questions/71590931/trying-to-add-array-element-to-a-maybe-existing-config-file",
        "title": "Trying to add array element to a maybe existing config file"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1648060465,
                "creation_date": 1648060465,
                "answer_id": 71592319,
                "question_id": 71592108,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "One way would be to use `walk`.\r\n\r\nAssuming $host holds the desired value, the jq filter would be:\r\n\r\n    walk(if type == &quot;object&quot; and has(&quot;JaegerAgentHost&quot;)\r\n         then .JaegerAgentHost = $host else . end)\r\n\r\nAn alternative would be to use `..` and `|=`:\r\n\r\n    (..|objects|select(.JaegerAgentHost).JaegerAgentHost) |= $host\r\n---\r\nYou could pass in the value using the `--arg` command-line option, e.g.\r\n\r\n       jq --arg host jaeger.app .....",
                "title": "Find a key-value anywhere in JSON file and replace key with a variable"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1695815752,
        "creation_date": 1648059285,
        "last_edit_date": 1695815752,
        "question_id": 71592108,
        "body_markdown": "I need to replace the value of &quot;JaegerAgentHost&quot; with a variable that I already have.\r\n\r\nI have multiple formats of JSON on each app.\r\n\r\nAPP1 JSON file:\r\n-\r\n\r\n    {\r\n    &quot;Settings&quot;: {\r\n    &quot;JaegerServiceSettings&quot;: {\r\n    &quot;JaegerAgentHost&quot;: &quot;jaeger.apps.internal&quot;,\r\n    &quot;JaegerAgentPort&quot;: &quot;6831&quot;\r\n    } } }\r\n\r\nAPP2 JSON file:\r\n-\r\n\r\n    {\r\n    &quot;JaegerServiceSettings&quot;: {\r\n    &quot;JaegerAgentHost&quot;: &quot;jaeger.apps.internal&quot;,\r\n    &quot;JaegerAgentPort&quot;: &quot;6831&quot;,\r\n    } }\r\n\r\nApp3 JSON file:\r\n-\r\n\r\n    {\r\n    &quot;JaegerAgentHost&quot;: &quot;jaeger.apps.internal&quot;,\r\n    &quot;JaegerAgentPort&quot;: &quot;6831&quot;\r\n    }\r\n\r\nirrespective of the path of key-value of JaegerAgentHost, I should be able to replace the value of it with my variable that ultimately should become as below\r\n\r\nexpected output::\r\n\r\nAPP1 JSON file:\r\n-\r\n\r\n    {\r\n    &quot;Settings&quot;: {\r\n    &quot;JaegerServiceSettings&quot;: {\r\n    &quot;JaegerAgentHost&quot;: &quot;jaeger.app&quot;,\r\n    &quot;JaegerAgentPort&quot;: &quot;6831&quot;\r\n    } } }\r\n\r\nAPP2 JSON file:\r\n-\r\n\r\n    {\r\n    &quot;JaegerServiceSettings&quot;: {\r\n    &quot;JaegerAgentHost&quot;: &quot;jaeger.app&quot;,\r\n    &quot;JaegerAgentPort&quot;: &quot;6831&quot;,\r\n    }}\r\n\r\nApp3 JSON file:\r\n-\r\n\r\n    {\r\n    &quot;JaegerAgentHost&quot;: &quot;jaeger.app&quot;,\r\n    &quot;JaegerAgentPort&quot;: &quot;6831&quot;\r\n    }\r\n\r\nPlease advice how we can do it, when I have multiple JSON files like to find and replace the perticular key-value with jq and bash\r\n\r\nAs of now I have multiple command for each json file to replace, which is not best practice.\r\n\r\nThis is blocking me from making a common script for all.\r\n\r\nI can use sed but worried about the structure changes that may happen to any of the JSON file as they were not uniform and would like to prefer jq.",
        "link": "https://stackoverflow.com/questions/71592108/find-a-key-value-anywhere-in-json-file-and-replace-key-with-a-variable",
        "title": "Find a key-value anywhere in JSON file and replace key with a variable"
    },
    {
        "tags": [
            "arrays",
            "json",
            "sorting",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1648069662,
                "creation_date": 1648069662,
                "answer_id": 71594048,
                "question_id": 71593996,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Update `|=` each field&#39;s array using `sort_by`, and convert to numbers using `tonumber`:\r\n~~~sh\r\njq &#39;.[].ddd |= sort_by(.fff.ggg.hhh.iii | tonumber)&#39;\r\n~~~\r\n~~~json\r\n{\r\n  &quot;aaa-1&quot;: {\r\n    &quot;ddd&quot;: [\r\n      {&quot;fff&quot;:{&quot;ggg&quot;:{&quot;hhh&quot;:{&quot;iii&quot;:&quot;1&quot;}}}},\r\n      {&quot;fff&quot;:{&quot;ggg&quot;:{&quot;hhh&quot;:{&quot;iii&quot;:&quot;10&quot;}}}},\r\n      {&quot;fff&quot;:{&quot;ggg&quot;:{&quot;hhh&quot;:{&quot;iii&quot;:&quot;100&quot;}}}}\r\n    ]\r\n  },\r\n  &quot;aaa-2&quot;: {\r\n    &quot;ddd&quot;: [\r\n      {&quot;fff&quot;:{&quot;ggg&quot;:{&quot;hhh&quot;:{&quot;iii&quot;:&quot;333&quot;}}}},\r\n      {&quot;fff&quot;:{&quot;ggg&quot;:{&quot;hhh&quot;:{&quot;iii&quot;:&quot;1000&quot;}}}}\r\n    ]\r\n  },\r\n  &quot;aaa-3&quot;: {\r\n    &quot;ddd&quot;: [\r\n      {&quot;fff&quot;:{&quot;ggg&quot;:{&quot;hhh&quot;:{&quot;iii&quot;:&quot;1&quot;}}}},\r\n      {&quot;fff&quot;:{&quot;ggg&quot;:{&quot;hhh&quot;:{&quot;iii&quot;:&quot;77&quot;}}}},\r\n      {&quot;fff&quot;:{&quot;ggg&quot;:{&quot;hhh&quot;:{&quot;iii&quot;:&quot;88&quot;}}}},\r\n      {&quot;fff&quot;:{&quot;ggg&quot;:{&quot;hhh&quot;:{&quot;iii&quot;:&quot;5555&quot;}}}}\r\n    ]\r\n  },\r\n  &quot;aaa-n&quot;: {\r\n    &quot;ddd&quot;: [\r\n      {&quot;fff&quot;:{&quot;ggg&quot;:{&quot;hhh&quot;:{&quot;iii&quot;:&quot;1&quot;}}}},\r\n      {&quot;fff&quot;:{&quot;ggg&quot;:{&quot;hhh&quot;:{&quot;iii&quot;:&quot;989898&quot;}}}}\r\n    ]\r\n  }\r\n}\r\n~~~\r\n[Demo](https://jqplay.org/s/xXV7ZsMQtg)",
                "title": "JQ sort-by different root with identical nested json object"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1648069662,
        "creation_date": 1648069316,
        "question_id": 71593996,
        "body_markdown": "I want to use JQ to sort each `ddd`-json-array by looking at its values in the `.fff.ggg.hhh.iii`-property.\r\n\r\nSo for example look at this json:\r\n\r\n```\r\n{\r\n  &quot;aaa-1&quot;: {\r\n    &quot;ddd&quot;: [\r\n      {&quot;fff&quot;: {&quot;ggg&quot;: {&quot;hhh&quot;: {&quot;iii&quot;: &quot;100&quot;}}}},\r\n      {&quot;fff&quot;: {&quot;ggg&quot;: {&quot;hhh&quot;: {&quot;iii&quot;: &quot;1&quot;}}}},\r\n      {&quot;fff&quot;: {&quot;ggg&quot;: {&quot;hhh&quot;: {&quot;iii&quot;: &quot;10&quot;}}}}\r\n    ]\r\n  },\r\n  &quot;aaa-2&quot;: {\r\n    &quot;ddd&quot;: [\r\n      {&quot;fff&quot;: {&quot;ggg&quot;: {&quot;hhh&quot;: {&quot;iii&quot;: &quot;1000&quot;}}}},\r\n      {&quot;fff&quot;: {&quot;ggg&quot;: {&quot;hhh&quot;: {&quot;iii&quot;: &quot;333&quot;}}}}\r\n    ]\r\n  },\r\n  &quot;aaa-3&quot;: {\r\n    &quot;ddd&quot;: [\r\n      {&quot;fff&quot;: {&quot;ggg&quot;: {&quot;hhh&quot;: {&quot;iii&quot;: &quot;77&quot;}}}},\r\n      {&quot;fff&quot;: {&quot;ggg&quot;: {&quot;hhh&quot;: {&quot;iii&quot;: &quot;88&quot;}}}},\r\n      {&quot;fff&quot;: {&quot;ggg&quot;: {&quot;hhh&quot;: {&quot;iii&quot;: &quot;5555&quot;}}}},\r\n      {&quot;fff&quot;: {&quot;ggg&quot;: {&quot;hhh&quot;: {&quot;iii&quot;: &quot;1&quot;}}}}\r\n    ]\r\n  }\r\n  ...\r\n  &quot;aaa-n&quot;: {\r\n    &quot;ddd&quot;: [\r\n      {&quot;fff&quot;: {&quot;ggg&quot;: {&quot;hhh&quot;: {&quot;iii&quot;: &quot;989898&quot;}}}},\r\n      ...\r\n      {&quot;fff&quot;: {&quot;ggg&quot;: {&quot;hhh&quot;: {&quot;iii&quot;: &quot;1&quot;}}}},\r\n    ]  \r\n  }\r\n}\r\n```\r\n\r\nWhat I want to end up with should look like this:\r\n\r\n```\r\n{\r\n  &quot;aaa-1&quot;: {\r\n    &quot;ddd&quot;: [\r\n      {&quot;fff&quot;: {&quot;ggg&quot;: {&quot;hhh&quot;: {&quot;iii&quot;: &quot;1&quot;}}}},\r\n      {&quot;fff&quot;: {&quot;ggg&quot;: {&quot;hhh&quot;: {&quot;iii&quot;: &quot;10&quot;}}}}\r\n      {&quot;fff&quot;: {&quot;ggg&quot;: {&quot;hhh&quot;: {&quot;iii&quot;: &quot;100&quot;}}}}\r\n    ]\r\n  },\r\n  &quot;aaa-2&quot;: {\r\n    &quot;ddd&quot;: [\r\n      {&quot;fff&quot;: {&quot;ggg&quot;: {&quot;hhh&quot;: {&quot;iii&quot;: &quot;333&quot;}}}},\r\n      {&quot;fff&quot;: {&quot;ggg&quot;: {&quot;hhh&quot;: {&quot;iii&quot;: &quot;1000&quot;}}}}\r\n    ]\r\n  },\r\n  &quot;aaa-3&quot;: {\r\n    &quot;ddd&quot;: [\r\n      {&quot;fff&quot;: {&quot;ggg&quot;: {&quot;hhh&quot;: {&quot;iii&quot;: &quot;1&quot;}}}},\r\n      {&quot;fff&quot;: {&quot;ggg&quot;: {&quot;hhh&quot;: {&quot;iii&quot;: &quot;77&quot;}}}},\r\n      {&quot;fff&quot;: {&quot;ggg&quot;: {&quot;hhh&quot;: {&quot;iii&quot;: &quot;88&quot;}}}},\r\n      {&quot;fff&quot;: {&quot;ggg&quot;: {&quot;hhh&quot;: {&quot;iii&quot;: &quot;5555&quot;}}}}\r\n    ]\r\n  }\r\n  ...\r\n  &quot;aaa-n&quot;: {\r\n    &quot;ddd&quot;: [\r\n      {&quot;fff&quot;: {&quot;ggg&quot;: {&quot;hhh&quot;: {&quot;iii&quot;: &quot;4&quot;}}}},\r\n      ...\r\n      {&quot;fff&quot;: {&quot;ggg&quot;: {&quot;hhh&quot;: {&quot;iii&quot;: &quot;989898&quot;}}}}\r\n    ]  \r\n  }\r\n}\r\n```\r\n\r\nI have tried various combinations and variants of these answers, but I could not come up with a solution:\r\n1. https://stackoverflow.com/a/58665725/504060\r\n2. https://stackoverflow.com/a/30332672/504060\r\n3. https://stackoverflow.com/a/51125483/504060\r\n\r\nI hope I could at least describe the problem in a meaningful fashion.\r\n\r\nCan someone help me?",
        "link": "https://stackoverflow.com/questions/71593996/jq-sort-by-different-root-with-identical-nested-json-object",
        "title": "JQ sort-by different root with identical nested json object"
    },
    {
        "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": 1,
                "creation_date": 1648137366,
                "post_id": 71605342,
                "comment_id": 126553543,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1693,
                    "reputation": 18059,
                    "user_id": 2283,
                    "user_type": "registered",
                    "accept_rate": 79,
                    "profile_image": "https://www.gravatar.com/avatar/3ac5db3768c09788ed9fe03c5f4ff171?s=256&d=identicon&r=PG",
                    "display_name": "Weeble",
                    "link": "https://stackoverflow.com/users/2283/weeble"
                },
                "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": 1648149273,
                "post_id": 71605342,
                "comment_id": 126558042,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 9853256,
                    "reputation": 490,
                    "user_id": 7298643,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/2D13T.png?s=256",
                    "display_name": "Jengels",
                    "link": "https://stackoverflow.com/users/7298643/jengels"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1648151417,
                "post_id": 71605342,
                "comment_id": 126558743,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1648173410,
                "last_edit_date": 1648173410,
                "creation_date": 1648160470,
                "answer_id": 71610131,
                "question_id": 71605342,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You could fix the input using jq or a text-processing tool such as [tag:sed]:\r\n```\r\n&lt; weird.json jq -R &#39;sub(&quot;^&quot;;&quot;\\&quot;&quot;) | sub(&quot;$&quot;;&quot;\\&quot;&quot;) | fromjson | fromjson&#39;\r\n```\r\nor\r\n```\r\n&lt; weird.json sed -e &#39;s/^/&quot;/&#39; -e &#39;s/$/&quot;/&#39; | jq -R &#39;fromjson|fromjson&#39;\r\n```\r\nWith your input, the result in both cases is:\r\n```\r\n{\r\n  &quot;id&quot;: 1,\r\n  &quot;firstName&quot;: &quot;firstName1&quot;,\r\n  &quot;lastName&quot;: &quot;lastName1&quot;\r\n}\r\n{\r\n  &quot;id&quot;: 2,\r\n  &quot;firstName&quot;: &quot;firstName2&quot;,\r\n  &quot;lastName&quot;: &quot;lastName2&quot;\r\n}\r\n\r\n```",
                "title": "Processing string representation of json within jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1648173410,
        "creation_date": 1648136176,
        "last_edit_date": 1648151288,
        "question_id": 71605342,
        "body_markdown": "I have a function in bash ```psql_json()``` that hits a postgres database and returns a json. I can not edit this bash function but it injects a postgres statement into this this query which is then sent to the db:\r\n```\r\n&quot;select row_to_json(t)::json from ($arg) t;&quot;\r\n```\r\nWhere arg is some statement ie:\r\n```\r\nselect * from table\r\n```\r\nHowever, this function returns a weirdly formatted json string as seen below:\r\n```\r\n{\\&quot;id\\&quot;:1,\\&quot;firstName\\&quot;:\\&quot;firstName1\\&quot;,\\&quot;lastName\\&quot;:\\&quot;lastName1\\&quot;}\\n\r\n{\\&quot;id\\&quot;:2,\\&quot;firstName\\&quot;:\\&quot;firstName2\\&quot;,\\&quot;lastName\\&quot;:\\&quot;lastName2\\&quot;}\r\n```\r\nThe above output is what happens after running these statements:\r\n```\r\nlocal_fn=&quot;$(mktemp)&quot;\r\npsql_json &#39;select * from table&#39; &gt; &quot;$local_fn&quot;\r\ncat &quot;$local_fn&quot;\r\n```\r\n\r\nNow when I try to put this json as is into jq, I get the following error:\r\n\r\n```\r\ncat json1.json | jq &#39;.&#39;\r\n\r\njq: error: syntax error, unexpected $end, expecting &#39;;&#39; or &#39;)&#39; (Unix shell quoting issues?)\r\n``` \r\n\r\n[I found this thread](https://stackoverflow.com/questions/34340549/convert-string-to-json-in-jq) which seems to indicate the issue is that I am passing a string into jq which it doesnt like and is unable to parse, so I tried both:\r\n\r\n```\r\ncat json1.json | jq &#39;fromjson]&#39;\r\ncat json1.json | jq &#39;[.[]|fromjson]&#39;\r\n```\r\n\r\nand they both return \r\n```\r\nparse error: Invalid numeric literal at line 1, column 3\r\n```\r\n\r\nIs there any way I can get string representation of the json above into jq in a clean way to process it or would I need to clean/edit the string in bash? ",
        "link": "https://stackoverflow.com/questions/71605342/processing-string-representation-of-json-within-jq",
        "title": "Processing string representation of json within jq"
    },
    {
        "tags": [
            "python",
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1648148251,
                "creation_date": 1648148251,
                "answer_id": 71608027,
                "question_id": 71606904,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "```jq\r\n[\r\n   path( .. | objects | select( .ssid ) ) as $path |\r\n   getpath($path) |\r\n   { app_name: $path[-2], ssid, bssid, wlan_profile_name, location }\r\n]\r\n```\r\n\r\n[Demo](https://jqplay.org/s/8xnHiOhkvQ) on jqplay\r\n",
                "title": "Is there an efficient way in jq_filter for parsing and filtering key, values"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1648148251,
        "creation_date": 1648142817,
        "last_edit_date": 1648143599,
        "question_id": 71606904,
        "body_markdown": "I have json like below:\r\n```json\r\n{\r\n  &quot;serge12&quot;: {\r\n    &quot;17&quot;: {\r\n      &quot;wlan_id&quot;: &quot;23&quot;,\r\n      &quot;interface&quot;: &quot;nwce&quot;,\r\n      &quot;bssid&quot;: &quot;00:b7:71:a5:de:60&quot;,\r\n      &quot;atf_override&quot;: &quot;n/a&quot;,\r\n      &quot;atf_policy_id&quot;: &quot;n/a&quot;,\r\n      &quot;atf_policy_name&quot;: &quot;n/a&quot;,\r\n      &quot;ssid&quot;: &quot;test&quot;,\r\n      &quot;wlan_profile_name&quot;: &quot;wlan&quot;,\r\n      &quot;location&quot;: &quot;default location&quot;\r\n    },\r\n    &quot;18&quot;: {\r\n      &quot;wlan_id&quot;: &quot;24&quot;,\r\n      &quot;interface&quot;: &quot;nwcg&quot;,\r\n      &quot;bssid&quot;: &quot;00:b7:71:a5:de:61&quot;,\r\n      &quot;atf_override&quot;: &quot;n/a&quot;,\r\n      &quot;atf_policy_id&quot;: &quot;n/a&quot;,\r\n      &quot;atf_policy_name&quot;: &quot;n/a&quot;,\r\n      &quot;ssid&quot;: &quot;tetra&quot;,\r\n      &quot;wlan_profile_name&quot;: &quot;wnet&quot;,\r\n      &quot;location&quot;: &quot;default location&quot;\r\n    },\r\n    &quot;serge13&quot;: {\r\n      &quot;27&quot;: {\r\n        &quot;wlan_id&quot;: &quot;23&quot;,\r\n        &quot;interface&quot;: &quot;nwce&quot;,\r\n        &quot;bssid&quot;: &quot;00:b7:71:a5:de:58&quot;,\r\n        &quot;atf_override&quot;: &quot;n/a&quot;,\r\n        &quot;atf_policy_id&quot;: &quot;n/a&quot;,\r\n        &quot;atf_policy_name&quot;: &quot;n/a&quot;,\r\n        &quot;ssid&quot;: &quot;test&quot;,\r\n        &quot;wlan_profile_name&quot;: &quot;wlan&quot;,\r\n        &quot;location&quot;: &quot;default location&quot;\r\n      },\r\n      &quot;29&quot;: {\r\n        &quot;wlan_id&quot;: &quot;24&quot;,\r\n        &quot;interface&quot;: &quot;nwcg&quot;,\r\n        &quot;bssid&quot;: &quot;00:b7:71:a5:de:69&quot;,\r\n        &quot;atf_override&quot;: &quot;n/a&quot;,\r\n        &quot;atf_policy_id&quot;: &quot;n/a&quot;,\r\n        &quot;atf_policy_name&quot;: &quot;n/a&quot;,\r\n        &quot;ssid&quot;: &quot;tetra_glance&quot;,\r\n        &quot;wlan_profile_name&quot;: &quot;wnet&quot;,\r\n        &quot;location&quot;: &quot;default location&quot;\r\n      }\r\n    }\r\n  }\r\n}\r\n```\r\nThis is a sample json file and will be big in actual output. From this json output,I need to filter &quot;ssid&quot;,&quot;bssid&quot;,&quot;wlan_profile_name&quot;,&quot;location&quot; and expected output is like below . \r\n\r\nI am using python3.9 with jq\r\n\r\n```json\r\n[\r\n  {\r\n    &quot;ap_name&quot;: &quot;serge12&quot;,\r\n    &quot;bssid&quot;: &quot;00:b7:71:a5:de:60&quot;,\r\n    &quot;location&quot;: &quot;default location&quot;,\r\n    &quot;ssid&quot;: &quot;test&quot;,\r\n    &quot;wlan_profile_name&quot;: &quot;wnet&quot;\r\n  },\r\n  {\r\n    &quot;ap_name&quot;: &quot;serge12&quot;,\r\n    &quot;bssid&quot;: &quot;00:b7:71:a5:de:61&quot;,\r\n    &quot;ssid&quot;: &quot;tetraglance&quot;,\r\n    &quot;wlan_profile_name&quot;: &quot;wnet&quot;,\r\n    &quot;location&quot;: &quot;default location&quot;\r\n  },\r\n  {\r\n    &quot;ap_name&quot;: &quot;serge13&quot;,\r\n    &quot;bssid&quot;: &quot;00:b7:71:a5:de:58&quot;,\r\n    &quot;location&quot;: &quot;default location&quot;,\r\n    &quot;ssid&quot;: &quot;test&quot;,\r\n    &quot;wlan_profile_name&quot;: &quot;wnet&quot;\r\n  },\r\n  {\r\n    &quot;ap_name&quot;: &quot;serge13&quot;,\r\n    &quot;bssid&quot;: &quot;00:b7:71:a5:de:69&quot;,\r\n    &quot;ssid&quot;: &quot;tetraglance&quot;,\r\n    &quot;wlan_profile_name&quot;: &quot;wlan&quot;,\r\n    &quot;location&quot;: &quot;default location&quot;\r\n  }\r\n]\r\n```\r\nI was trying to use jq_filter but not able to parse them in one shot\r\n```\r\njq_filter1 = . | to_entries | map({device:.key})\r\njq_filter2 = .[] | .| ( to_entries | map({ssid:.value.ssid, bssid:.value.bssid,location:.value.location}))\r\n```\r\nI dont know if we can join them or some efficient way to handle this.",
        "link": "https://stackoverflow.com/questions/71606904/is-there-an-efficient-way-in-jq-filter-for-parsing-and-filtering-key-values",
        "title": "Is there an efficient way in jq_filter for parsing and filtering key, values"
    },
    {
        "tags": [
            "java",
            "json",
            "jackson",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 7822670,
                    "reputation": 1786,
                    "user_id": 5915318,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/UoqcWhED.png?s=256",
                    "display_name": "David Kariuki",
                    "link": "https://stackoverflow.com/users/5915318/david-kariuki"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1648150547,
                "post_id": 71608432,
                "comment_id": 126558459,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 24281583,
                    "reputation": 160,
                    "user_id": 18228017,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/8D83k.png?s=256",
                    "display_name": "Cayman",
                    "link": "https://stackoverflow.com/users/18228017/cayman"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1648150640,
                "post_id": 71608432,
                "comment_id": 126558491,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 6611395,
                    "reputation": 1,
                    "user_id": 5106372,
                    "user_type": "registered",
                    "profile_image": "https://graph.facebook.com/131478630519869/picture?type=large",
                    "display_name": "Viveka Raja",
                    "link": "https://stackoverflow.com/users/5106372/viveka-raja"
                },
                "reply_to_user": {
                    "account_id": 24281583,
                    "reputation": 160,
                    "user_id": 18228017,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/8D83k.png?s=256",
                    "display_name": "Cayman",
                    "link": "https://stackoverflow.com/users/18228017/cayman"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1648153015,
                "post_id": 71608432,
                "comment_id": 126559221,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 6611395,
                    "reputation": 1,
                    "user_id": 5106372,
                    "user_type": "registered",
                    "profile_image": "https://graph.facebook.com/131478630519869/picture?type=large",
                    "display_name": "Viveka Raja",
                    "link": "https://stackoverflow.com/users/5106372/viveka-raja"
                },
                "reply_to_user": {
                    "account_id": 7822670,
                    "reputation": 1786,
                    "user_id": 5915318,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/UoqcWhED.png?s=256",
                    "display_name": "David Kariuki",
                    "link": "https://stackoverflow.com/users/5915318/david-kariuki"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1648153148,
                "post_id": 71608432,
                "comment_id": 126559265,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 12305345,
                    "reputation": 605,
                    "user_id": 8978587,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/Ln6Kz.png?s=256",
                    "display_name": "ShaharT",
                    "link": "https://stackoverflow.com/users/8978587/shahart"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1648160112,
                "post_id": 71608432,
                "comment_id": 126561291,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 6611395,
                    "reputation": 1,
                    "user_id": 5106372,
                    "user_type": "registered",
                    "profile_image": "https://graph.facebook.com/131478630519869/picture?type=large",
                    "display_name": "Viveka Raja",
                    "link": "https://stackoverflow.com/users/5106372/viveka-raja"
                },
                "reply_to_user": {
                    "account_id": 12305345,
                    "reputation": 605,
                    "user_id": 8978587,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/Ln6Kz.png?s=256",
                    "display_name": "ShaharT",
                    "link": "https://stackoverflow.com/users/8978587/shahart"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1648205924,
                "post_id": 71608432,
                "comment_id": 126571197,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 162724,
                    "reputation": 3105,
                    "user_id": 384366,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/Wiw4P.jpg?s=256",
                    "display_name": "qmacro",
                    "link": "https://stackoverflow.com/users/384366/qmacro"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1648207103,
                "post_id": 71608432,
                "comment_id": 126571613,
                "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": 1648217199,
                "post_id": 71608432,
                "comment_id": 126575359,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 6611395,
                    "reputation": 1,
                    "user_id": 5106372,
                    "user_type": "registered",
                    "profile_image": "https://graph.facebook.com/131478630519869/picture?type=large",
                    "display_name": "Viveka Raja",
                    "link": "https://stackoverflow.com/users/5106372/viveka-raja"
                },
                "reply_to_user": {
                    "account_id": 162724,
                    "reputation": 3105,
                    "user_id": 384366,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/Wiw4P.jpg?s=256",
                    "display_name": "qmacro",
                    "link": "https://stackoverflow.com/users/384366/qmacro"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1648325476,
                "post_id": 71608432,
                "comment_id": 126597380,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 6611395,
                    "reputation": 1,
                    "user_id": 5106372,
                    "user_type": "registered",
                    "profile_image": "https://graph.facebook.com/131478630519869/picture?type=large",
                    "display_name": "Viveka Raja",
                    "link": "https://stackoverflow.com/users/5106372/viveka-raja"
                },
                "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": 1648325689,
                "post_id": 71608432,
                "comment_id": 126597425,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1648216935,
                "creation_date": 1648216935,
                "answer_id": 71618197,
                "question_id": 71608432,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can sort the array located at `.data.type_fields` by its  object items&#39; field `.name` using `sort_by` and the update operator `|=`. \r\n~~~sh\r\njq &#39;.data.type_fields |= sort_by(.name)&#39; JsonFile1 &gt; JsonFile2\r\n~~~\r\n[Demo](https://jqplay.org/s/YNMTg4rgAr)\r\n\r\nHowever, when sorting your sample `JsonFile1` that way, the resulting JSON does not look like your sample `JsonFile2`.\r\n~~~json\r\n{\r\n  &quot;responseStatus&quot;: &quot;SUCCESS&quot;,\r\n  &quot;data&quot;: {\r\n    &quot;name&quot;: &quot;reusable_text__v&quot;,\r\n    &quot;object&quot;: &quot;annotation_keywords__sys&quot;,\r\n    &quot;label&quot;: &quot;Reusable Text&quot;,\r\n    &quot;label_plural&quot;: &quot;Reusable Text&quot;,\r\n    &quot;active&quot;: true,\r\n    &quot;additional_type_validations&quot;: [],\r\n    &quot;type_fields&quot;: [\r\n      {\r\n        &quot;required&quot;: false,\r\n        &quot;source&quot;: &quot;standard&quot;,\r\n        &quot;name&quot;: &quot;country__v&quot;\r\n      },\r\n      {\r\n        &quot;required&quot;: false,\r\n        &quot;source&quot;: &quot;standard&quot;,\r\n        &quot;name&quot;: &quot;create_from_annotation_id__sys&quot;\r\n      },\r\n      {\r\n        &quot;required&quot;: false,\r\n        &quot;source&quot;: &quot;standard&quot;,\r\n        &quot;name&quot;: &quot;create_from_annotation_source__sys&quot;\r\n      },\r\n      {\r\n        &quot;required&quot;: false,\r\n        &quot;source&quot;: &quot;custom&quot;,\r\n        &quot;name&quot;: &quot;create_from_annotation_source_unbound__sys&quot;\r\n      },\r\n      {\r\n        &quot;required&quot;: false,\r\n        &quot;source&quot;: &quot;standard&quot;,\r\n        &quot;name&quot;: &quot;created_by__v&quot;\r\n      },\r\n      {\r\n        &quot;required&quot;: false,\r\n        &quot;source&quot;: &quot;standard&quot;,\r\n        &quot;name&quot;: &quot;created_date__v&quot;\r\n      },\r\n      {\r\n        &quot;required&quot;: false,\r\n        &quot;source&quot;: &quot;system&quot;,\r\n        &quot;name&quot;: &quot;global_id__sys&quot;\r\n      },\r\n      {\r\n        &quot;required&quot;: false,\r\n        &quot;source&quot;: &quot;standard&quot;,\r\n        &quot;name&quot;: &quot;id&quot;\r\n      },\r\n      {\r\n        &quot;required&quot;: true,\r\n        &quot;source&quot;: &quot;custom&quot;,\r\n        &quot;name&quot;: &quot;lifecycle__v&quot;\r\n      },\r\n      {\r\n        &quot;required&quot;: false,\r\n        &quot;source&quot;: &quot;system&quot;,\r\n        &quot;name&quot;: &quot;link__sys&quot;\r\n      },\r\n      {\r\n        &quot;required&quot;: false,\r\n        &quot;source&quot;: &quot;standard&quot;,\r\n        &quot;name&quot;: &quot;modified_by__v&quot;\r\n      },\r\n      {\r\n        &quot;required&quot;: false,\r\n        &quot;source&quot;: &quot;standard&quot;,\r\n        &quot;name&quot;: &quot;modified_date__v&quot;\r\n      },\r\n      {\r\n        &quot;required&quot;: true,\r\n        &quot;source&quot;: &quot;standard&quot;,\r\n        &quot;name&quot;: &quot;name__v&quot;\r\n      },\r\n      {\r\n        &quot;required&quot;: false,\r\n        &quot;source&quot;: &quot;standard&quot;,\r\n        &quot;name&quot;: &quot;object_type__v&quot;\r\n      },\r\n      {\r\n        &quot;required&quot;: false,\r\n        &quot;source&quot;: &quot;standard&quot;,\r\n        &quot;name&quot;: &quot;product__v&quot;\r\n      },\r\n      {\r\n        &quot;required&quot;: true,\r\n        &quot;source&quot;: &quot;standard&quot;,\r\n        &quot;name&quot;: &quot;reusable_text_content__v&quot;\r\n      },\r\n      {\r\n        &quot;required&quot;: false,\r\n        &quot;source&quot;: &quot;standard&quot;,\r\n        &quot;name&quot;: &quot;reusable_text_type__v&quot;\r\n      },\r\n      {\r\n        &quot;required&quot;: false,\r\n        &quot;source&quot;: &quot;standard&quot;,\r\n        &quot;name&quot;: &quot;source_text_asset__v&quot;\r\n      },\r\n      {\r\n        &quot;required&quot;: false,\r\n        &quot;source&quot;: &quot;system&quot;,\r\n        &quot;name&quot;: &quot;stage__sys&quot;\r\n      },\r\n      {\r\n        &quot;required&quot;: true,\r\n        &quot;source&quot;: &quot;custom&quot;,\r\n        &quot;name&quot;: &quot;state__v&quot;\r\n      },\r\n      {\r\n        &quot;required&quot;: false,\r\n        &quot;source&quot;: &quot;system&quot;,\r\n        &quot;name&quot;: &quot;state_stage_id__sys&quot;\r\n      },\r\n      {\r\n        &quot;required&quot;: true,\r\n        &quot;source&quot;: &quot;standard&quot;,\r\n        &quot;name&quot;: &quot;status__v&quot;\r\n      }\r\n    ]\r\n  }\r\n}\r\n~~~\r\n",
                "title": "How can I sort a JSON file by an attribute in asec order?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1648216935,
        "creation_date": 1648150382,
        "last_edit_date": 1648206060,
        "question_id": 71608432,
        "body_markdown": "I have two JSON files to compare, and one of the outputs isn&#39;t in the right order. In order to compare a json file with another, \r\nI need to sort it by the name attribute. However, I encountered many difficulties. Can anyone help me solve this issue?\r\n\r\nOr Is there any way to sort the JsonFile 1 by attribute &quot;name&quot; is ascending order ( Expected output- JsonFile2)\r\n\r\n I tried with jq -s .Json.json &gt; out.json, No outputs. can I know how to pass thee jq to sort by attribute name ?\r\n\r\n**JsonFile1**:\r\n\r\n```json\r\n{\r\n  &quot;responseStatus&quot;: &quot;SUCCESS&quot;,\r\n  &quot;data&quot;: {\r\n    &quot;name&quot;: &quot;reusable_text__v&quot;,\r\n    &quot;object&quot;: &quot;annotation_keywords__sys&quot;,\r\n    &quot;label&quot;: &quot;Reusable Text&quot;,\r\n    &quot;label_plural&quot;: &quot;Reusable Text&quot;,\r\n    &quot;active&quot;: true,\r\n    &quot;additional_type_validations&quot;: [],\r\n    &quot;type_fields&quot;: [{\r\n        &quot;required&quot;: true,\r\n        &quot;source&quot;: &quot;standard&quot;,\r\n        &quot;name&quot;: &quot;reusable_text_content__v&quot;\r\n      },\r\n      {\r\n        &quot;required&quot;: false,\r\n        &quot;source&quot;: &quot;standard&quot;,\r\n        &quot;name&quot;: &quot;reusable_text_type__v&quot;\r\n      },\r\n      {\r\n        &quot;required&quot;: false,\r\n        &quot;source&quot;: &quot;standard&quot;,\r\n        &quot;name&quot;: &quot;source_text_asset__v&quot;\r\n      },\r\n      {\r\n        &quot;required&quot;: false,\r\n        &quot;source&quot;: &quot;standard&quot;,\r\n        &quot;name&quot;: &quot;country__v&quot;\r\n      },\r\n      {\r\n        &quot;required&quot;: false,\r\n        &quot;source&quot;: &quot;standard&quot;,\r\n        &quot;name&quot;: &quot;create_from_annotation_id__sys&quot;\r\n      },\r\n      {\r\n        &quot;required&quot;: false,\r\n        &quot;source&quot;: &quot;standard&quot;,\r\n        &quot;name&quot;: &quot;create_from_annotation_source__sys&quot;\r\n      },\r\n      {\r\n        &quot;required&quot;: false,\r\n        &quot;source&quot;: &quot;standard&quot;,\r\n        &quot;name&quot;: &quot;product__v&quot;\r\n      },\r\n      {\r\n        &quot;required&quot;: false,\r\n        &quot;source&quot;: &quot;standard&quot;,\r\n        &quot;name&quot;: &quot;id&quot;\r\n      },\r\n      {\r\n        &quot;required&quot;: true,\r\n        &quot;source&quot;: &quot;standard&quot;,\r\n        &quot;name&quot;: &quot;name__v&quot;\r\n      },\r\n      {\r\n        &quot;required&quot;: true,\r\n        &quot;source&quot;: &quot;standard&quot;,\r\n        &quot;name&quot;: &quot;status__v&quot;\r\n      },\r\n      {\r\n        &quot;required&quot;: false,\r\n        &quot;source&quot;: &quot;standard&quot;,\r\n        &quot;name&quot;: &quot;created_by__v&quot;\r\n      },\r\n      {\r\n        &quot;required&quot;: false,\r\n        &quot;source&quot;: &quot;standard&quot;,\r\n        &quot;name&quot;: &quot;created_date__v&quot;\r\n      },\r\n      {\r\n        &quot;required&quot;: false,\r\n        &quot;source&quot;: &quot;standard&quot;,\r\n        &quot;name&quot;: &quot;modified_by__v&quot;\r\n      },\r\n      {\r\n        &quot;required&quot;: false,\r\n        &quot;source&quot;: &quot;standard&quot;,\r\n        &quot;name&quot;: &quot;modified_date__v&quot;\r\n      },\r\n      {\r\n        &quot;required&quot;: false,\r\n        &quot;source&quot;: &quot;system&quot;,\r\n        &quot;name&quot;: &quot;global_id__sys&quot;\r\n      },\r\n      {\r\n        &quot;required&quot;: false,\r\n        &quot;source&quot;: &quot;system&quot;,\r\n        &quot;name&quot;: &quot;link__sys&quot;\r\n      },\r\n      {\r\n        &quot;required&quot;: false,\r\n        &quot;source&quot;: &quot;standard&quot;,\r\n        &quot;name&quot;: &quot;object_type__v&quot;\r\n      },\r\n      {\r\n        &quot;required&quot;: true,\r\n        &quot;source&quot;: &quot;custom&quot;,\r\n        &quot;name&quot;: &quot;lifecycle__v&quot;\r\n      },\r\n      {\r\n        &quot;required&quot;: true,\r\n        &quot;source&quot;: &quot;custom&quot;,\r\n        &quot;name&quot;: &quot;state__v&quot;\r\n      },\r\n      {\r\n        &quot;required&quot;: false,\r\n        &quot;source&quot;: &quot;custom&quot;,\r\n        &quot;name&quot;: &quot;create_from_annotation_source_unbound__sys&quot;\r\n      },\r\n      {\r\n        &quot;required&quot;: false,\r\n        &quot;source&quot;: &quot;system&quot;,\r\n        &quot;name&quot;: &quot;state_stage_id__sys&quot;\r\n      },\r\n      {\r\n        &quot;required&quot;: false,\r\n        &quot;source&quot;: &quot;system&quot;,\r\n        &quot;name&quot;: &quot;stage__sys&quot;\r\n      }\r\n    ]\r\n  }\r\n}\r\n```\r\n\r\n**JsonFile2**: (I need to sort previous json format by the name attribute in ascending order)\r\n\r\n```json\r\n{\r\n  &quot;responseStatus&quot;: &quot;SUCCESS&quot;,\r\n  &quot;data&quot;: {\r\n    &quot;name&quot;: &quot;reusable_text__c&quot;,\r\n    &quot;object&quot;: &quot;annotation_keywords__sys&quot;,\r\n    &quot;label&quot;: &quot;Reusable Text Asset&quot;,\r\n    &quot;label_plural&quot;: &quot;Reusable Text Assets&quot;,\r\n    &quot;active&quot;: true,\r\n    &quot;additional_type_validations&quot;: [],\r\n    &quot;type_fields&quot;: [{\r\n        &quot;required&quot;: false,\r\n        &quot;source&quot;: &quot;standard&quot;,\r\n        &quot;name&quot;: &quot;id&quot;\r\n      },\r\n      {\r\n        &quot;required&quot;: false,\r\n        &quot;source&quot;: &quot;standard&quot;,\r\n        &quot;name&quot;: &quot;object_type__v&quot;\r\n      },\r\n      {\r\n        &quot;required&quot;: true,\r\n        &quot;source&quot;: &quot;standard&quot;,\r\n        &quot;name&quot;: &quot;name__v&quot;\r\n      },\r\n      {\r\n        &quot;required&quot;: true,\r\n        &quot;source&quot;: &quot;standard&quot;,\r\n        &quot;name&quot;: &quot;status__v&quot;\r\n      },\r\n      {\r\n        &quot;required&quot;: false,\r\n        &quot;source&quot;: &quot;standard&quot;,\r\n        &quot;name&quot;: &quot;created_by__v&quot;\r\n      },\r\n      {\r\n        &quot;required&quot;: false,\r\n        &quot;source&quot;: &quot;standard&quot;,\r\n        &quot;name&quot;: &quot;created_date__v&quot;\r\n      },\r\n      {\r\n        &quot;required&quot;: false,\r\n        &quot;source&quot;: &quot;standard&quot;,\r\n        &quot;name&quot;: &quot;modified_by__v&quot;\r\n      },\r\n      {\r\n        &quot;required&quot;: false,\r\n        &quot;source&quot;: &quot;standard&quot;,\r\n        &quot;name&quot;: &quot;modified_date__v&quot;\r\n      },\r\n      {\r\n        &quot;required&quot;: false,\r\n        &quot;source&quot;: &quot;system&quot;,\r\n        &quot;name&quot;: &quot;global_id__sys&quot;\r\n      },\r\n      {\r\n        &quot;required&quot;: false,\r\n        &quot;source&quot;: &quot;system&quot;,\r\n        &quot;name&quot;: &quot;link__sys&quot;\r\n      },\r\n      {\r\n        &quot;required&quot;: true,\r\n        &quot;source&quot;: &quot;custom&quot;,\r\n        &quot;name&quot;: &quot;lifecycle__v&quot;\r\n      },\r\n      {\r\n        &quot;required&quot;: true,\r\n        &quot;source&quot;: &quot;custom&quot;,\r\n        &quot;name&quot;: &quot;state__v&quot;\r\n      },\r\n      {\r\n        &quot;required&quot;: true,\r\n        &quot;source&quot;: &quot;custom&quot;,\r\n        &quot;name&quot;: &quot;match_text__sys&quot;\r\n      },\r\n      {\r\n        &quot;required&quot;: false,\r\n        &quot;source&quot;: &quot;system&quot;,\r\n        &quot;name&quot;: &quot;state_stage_id__sys&quot;\r\n      },\r\n      {\r\n        &quot;required&quot;: false,\r\n        &quot;source&quot;: &quot;system&quot;,\r\n        &quot;name&quot;: &quot;stage__sys&quot;\r\n      },\r\n      {\r\n        &quot;required&quot;: true,\r\n        &quot;source&quot;: &quot;custom&quot;,\r\n        &quot;name&quot;: &quot;reusable_text_content__c&quot;\r\n      },\r\n      {\r\n        &quot;required&quot;: false,\r\n        &quot;source&quot;: &quot;custom&quot;,\r\n        &quot;name&quot;: &quot;create_from_annotation_source__sys&quot;\r\n      },\r\n      {\r\n        &quot;required&quot;: false,\r\n        &quot;source&quot;: &quot;custom&quot;,\r\n        &quot;name&quot;: &quot;create_from_annotation_id__sys&quot;\r\n      },\r\n      {\r\n        &quot;required&quot;: false,\r\n        &quot;source&quot;: &quot;custom&quot;,\r\n        &quot;name&quot;: &quot;reusable_text_type__c&quot;\r\n      },\r\n      {\r\n        &quot;required&quot;: false,\r\n        &quot;source&quot;: &quot;custom&quot;,\r\n        &quot;name&quot;: &quot;country__v&quot;\r\n      },\r\n      {\r\n        &quot;required&quot;: false,\r\n        &quot;source&quot;: &quot;custom&quot;,\r\n        &quot;name&quot;: &quot;product__v&quot;\r\n      },\r\n      {\r\n        &quot;required&quot;: false,\r\n        &quot;source&quot;: &quot;custom&quot;,\r\n        &quot;name&quot;: &quot;create_from_annotation_source_unbound__sys&quot;\r\n      },\r\n      {\r\n        &quot;required&quot;: false,\r\n        &quot;source&quot;: &quot;custom&quot;,\r\n        &quot;name&quot;: &quot;source_text_asset__c&quot;\r\n      }\r\n    ]\r\n  }\r\n}\r\n```\r\n\r\nI tried `JsonArray` and `JsonObject`, but did not succeed in finding the correct solution",
        "link": "https://stackoverflow.com/questions/71608432/how-can-i-sort-a-json-file-by-an-attribute-in-asec-order",
        "title": "How can I sort a JSON file by an attribute in asec order?"
    },
    {
        "tags": [
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1648168272,
                "post_id": 71610877,
                "comment_id": 126562849,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1526413,
                    "reputation": 13993,
                    "user_id": 1424739,
                    "user_type": "registered",
                    "accept_rate": 17,
                    "profile_image": "https://www.gravatar.com/avatar/19d3c927744b5ad3b94afbf88e1c3844?s=256&d=identicon&r=PG",
                    "display_name": "user1424739",
                    "link": "https://stackoverflow.com/users/1424739/user1424739"
                },
                "reply_to_user": {
                    "account_id": 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": 1648168291,
                "post_id": 71610877,
                "comment_id": 126562856,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 289134,
                    "reputation": 389369,
                    "user_id": 589924,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/b2cf53d5a3d25f95c0db4e025aed4153?s=256&d=identicon&r=PG",
                    "display_name": "ikegami",
                    "link": "https://stackoverflow.com/users/589924/ikegami"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1648189961,
                "post_id": 71610877,
                "comment_id": 126566222,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1648168422,
                "creation_date": 1648168422,
                "answer_id": 71610924,
                "question_id": 71610877,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You have lost the input context. Save it in a variable (eg. `. as $dot`) to reference it later (eg. `$dot.desc`):\r\n~~~sh\r\n$ jq -r --arg format &#39;|%s|&#39; &#39;. as $dot | $format | sub(&quot;%s&quot;; $dot.desc)&#39; &lt;&lt;&lt; &#39;{&quot;desc&quot;: &quot;my string&quot;}&#39;\r\n|my string|\r\n~~~",
                "title": "Why sub() can not perform a string substitution?"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1648168641,
                "creation_date": 1648168641,
                "answer_id": 71610942,
                "question_id": 71610877,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can use null input `-n` :\r\n\r\n```\r\njq -nr --arg format &#39;|%s|&#39; &#39;$format | sub(&quot;%s&quot;; input.desc)&#39; &lt;&lt;&lt; &#39;{&quot;desc&quot;: &quot;my string&quot;}&#39;\r\n```",
                "title": "Why sub() can not perform a string substitution?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1648168641,
        "creation_date": 1648167927,
        "question_id": 71610877,
        "body_markdown": "I don&#39;t understand why the `sub()` command does not replace &quot;%s&quot; with &quot;my string&quot; in the first jq command below. How to make it work?\r\n\r\n```\r\n$ jq -r --arg format &#39;|%s|&#39; &#39;$format | sub(&quot;%s&quot;; .desc)&#39; &lt;&lt;&lt; &#39;{&quot;desc&quot;: &quot;my string&quot;}&#39;\r\n||\r\n$ jq -r --arg format &#39;|%s|&#39; &#39;$format | sub(&quot;%s&quot;; &quot;my string&quot;)&#39; &lt;&lt;&lt; &#39;{&quot;x&quot;: &quot;y&quot;}&#39;\r\n|my string|\r\n$ jq -r .desc &lt;&lt;&lt; &#39;{&quot;desc&quot;: &quot;my string&quot;}&#39;\r\nmy string\r\n```",
        "link": "https://stackoverflow.com/questions/71610877/why-sub-can-not-perform-a-string-substitution",
        "title": "Why sub() can not perform a string substitution?"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1648208697,
                "creation_date": 1648208697,
                "answer_id": 71616450,
                "question_id": 71616386,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Your expected output needs to be wrapped in curly braces in order to be a valid JSON object. That said, use `from_entries` to create an object from an array of key-value pairs, which can be produced by accordingly `map`ping the input object&#39;s `Objects` array.\r\n~~~\r\n.Objects | map({key: .ElementName, value: .ElementArray}) | from_entries\r\n~~~\r\n~~~json\r\n{\r\n  &quot;Test1&quot;: [\r\n    &quot;abc&quot;,\r\n    &quot;bcd&quot;\r\n  ],\r\n  &quot;Test2&quot;: [\r\n    &quot;abc&quot;,\r\n    &quot;bcde&quot;\r\n  ]\r\n}\r\n~~~\r\n[Demo](https://jqplay.org/s/BKtNFKWEJs)",
                "title": "Parse an array of json object using jq"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1649046929,
                "creation_date": 1649046929,
                "answer_id": 71732080,
                "question_id": 71616386,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Demo\r\n\r\nhttps://jqplay.org/s/YbjICOd8EJ\r\n\r\nYou can also use `reduce`\r\n\r\n```\r\nreduce .Objects[] as $o ({}; .[$o.ElementName]=$o.ElementArray)\r\n```",
                "title": "Parse an array of json object using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1649046929,
        "creation_date": 1648208391,
        "last_edit_date": 1648208980,
        "question_id": 71616386,
        "body_markdown": "I am trying to parse the below json file and store the result into another json file. How do I achieve this ?\r\n\r\n```\r\n{\r\n  &quot;Objects&quot;: [\r\n    {\r\n      &quot;ElementName&quot;: &quot;Test1&quot;,\r\n      &quot;ElementArray&quot;: [&quot;abc&quot;,&quot;bcd&quot;],\r\n      &quot;ElementUnit&quot;: &quot;4&quot;\r\n    },\r\n    {\r\n      &quot;ElementName&quot;: &quot;Test2&quot;,\r\n      &quot;ElementArray&quot;: [&quot;abc&quot;,&quot;bcde&quot;],\r\n      &quot;ElementUnit&quot;: &quot;8&quot;\r\n    }\r\n  ]\r\n}\r\n```\r\nExpected result :\r\n```\r\n{\r\n&quot;Test1&quot; :[\r\n&quot;abc&quot;,&quot;bcd&quot;\r\n],\r\n&quot;Test2&quot; :[\r\n&quot;abc&quot;,&quot;bcde&quot;\r\n]\r\n}\r\n\r\n```\r\n\r\nI&#39;ve tried something on the lines of the below but I seem to be off - \r\n```\r\njq &#39;[.Objects[].ElementName ,(.Objects[]. ElementArray[])]&#39; user1.json\r\n\r\njq &quot;.Objects[].ElementName .Objects[].ElementArray&quot; ruser1.json\r\n```",
        "link": "https://stackoverflow.com/questions/71616386/parse-an-array-of-json-object-using-jq",
        "title": "Parse an array of json object using jq"
    },
    {
        "tags": [
            "json",
            "linux",
            "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": 1648221179,
                "post_id": 71619207,
                "comment_id": 126577026,
                "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": 1648221218,
                "post_id": 71619207,
                "comment_id": 126577038,
                "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": 1648221332,
                "post_id": 71619207,
                "comment_id": 126577086,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 10546687,
                    "reputation": 147,
                    "user_id": 7770708,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/427d562d017e1ec83ab81c297826e650?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Bombo",
                    "link": "https://stackoverflow.com/users/7770708/bombo"
                },
                "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": 1648221677,
                "post_id": 71619207,
                "comment_id": 126577218,
                "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": 1648231133,
                "post_id": 71619207,
                "comment_id": 126580489,
                "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": 1648231263,
                "post_id": 71619207,
                "comment_id": 126580533,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 10546687,
                    "reputation": 147,
                    "user_id": 7770708,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/427d562d017e1ec83ab81c297826e650?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Bombo",
                    "link": "https://stackoverflow.com/users/7770708/bombo"
                },
                "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": 1648463770,
                "post_id": 71619207,
                "comment_id": 126621977,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "is_answered": false,
        "answer_count": 0,
        "score": 0,
        "last_activity_date": 1648230429,
        "creation_date": 1648221080,
        "last_edit_date": 1648230429,
        "question_id": 71619207,
        "body_markdown": "Hy guys,\r\nGiven an array of JSON objects, I&#39;d like to output a CSV, but in this case i have a different keys and i need to take some values through JSONs&#39; multiple layers.\r\n\r\ni&#39;m not skill with a bash script.\r\ni have found that link https://stackoverflow.com/questions/68996590/convert-json-to-csv-using-jq-with-different-key\r\nbut I don&#39;t know how to adapt it to my case\r\n\r\nMy Json file:\r\n\r\n```json\r\n{\r\n  &quot;status&quot;: &quot;success&quot;,\r\n  &quot;data&quot;: {\r\n    &quot;n_per_page&quot;: 10,\r\n    &quot;transactions_by_dealer_code&quot;: {\r\n      &quot;06001&quot;: [\r\n        {\r\n          &quot;dealer_name&quot;: &quot;Pippo&quot;,\r\n          &quot;dealer_total_transaction_count&quot;: 0,\r\n          &quot;dealer_cancellation_count&quot;: 0,\r\n          &quot;dealer_reservation_count&quot;: 0,\r\n          &quot;transactons_detail&quot;: []\r\n        }\r\n      ],\r\n      &quot;06003&quot;: [\r\n        {\r\n          &quot;dealer_name&quot;: &quot;Pluto&quot;,\r\n          &quot;dealer_total_transaction_count&quot;: 1,\r\n          &quot;dealer_cancellation_count&quot;: 0,\r\n          &quot;dealer_reservation_count&quot;: 1,\r\n          &quot;transactons_detail&quot;: [\r\n            {\r\n              &quot;transaction_id&quot;: &quot;123456789&quot;,\r\n              &quot;deposite_amount&quot;: 0.01,\r\n              &quot;vehicle_make&quot;: &quot;ferrari&quot;\r\n            }\r\n          ]\r\n        }\r\n      ]\r\n    }\r\n  }\r\n}\r\n```\r\n\r\nthe correct output:\r\n```csv transactions_by_dealer_code,dealer_name,transaction_id,deposite_amount,vehicle_make\r\n06001,Pippo,,,,\r\n06002,Pluto,123456789,0.01,ferrari\r\n```\r\nThanks all.\r\n",
        "link": "https://stackoverflow.com/questions/71619207/bash-convert-json-to-csv-using-jq-with-different-key-multilayer",
        "title": "Bash Convert json to csv using jq with different key multilayer"
    },
    {
        "tags": [
            "json",
            "bash",
            "amazon-web-services",
            "jq",
            "amazon-cloudwatch"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 18240753,
                    "reputation": 1194,
                    "user_id": 13277819,
                    "user_type": "registered",
                    "profile_image": "https://lh3.googleusercontent.com/a-/AOh14GjlrFFvvJ-38PD8zUhsHEehcpgYlFxipFi4Sn2etw=k-s256",
                    "display_name": "Pankaj Saini",
                    "link": "https://stackoverflow.com/users/13277819/pankaj-saini"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1648355952,
                "post_id": 71621906,
                "comment_id": 126601146,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1044633,
                    "reputation": 6530,
                    "user_id": 1049905,
                    "user_type": "registered",
                    "accept_rate": 70,
                    "profile_image": "https://i.sstatic.net/24Yhk.jpg?s=256",
                    "display_name": "Bluz",
                    "link": "https://stackoverflow.com/users/1049905/bluz"
                },
                "reply_to_user": {
                    "account_id": 18240753,
                    "reputation": 1194,
                    "user_id": 13277819,
                    "user_type": "registered",
                    "profile_image": "https://lh3.googleusercontent.com/a-/AOh14GjlrFFvvJ-38PD8zUhsHEehcpgYlFxipFi4Sn2etw=k-s256",
                    "display_name": "Pankaj Saini",
                    "link": "https://stackoverflow.com/users/13277819/pankaj-saini"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1648457615,
                "post_id": 71621906,
                "comment_id": 126619747,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 18240753,
                    "reputation": 1194,
                    "user_id": 13277819,
                    "user_type": "registered",
                    "profile_image": "https://lh3.googleusercontent.com/a-/AOh14GjlrFFvvJ-38PD8zUhsHEehcpgYlFxipFi4Sn2etw=k-s256",
                    "display_name": "Pankaj Saini",
                    "link": "https://stackoverflow.com/users/13277819/pankaj-saini"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1648539971,
                "post_id": 71621906,
                "comment_id": 126643070,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1648242779,
                "last_edit_date": 1648242779,
                "creation_date": 1648242325,
                "answer_id": 71623093,
                "question_id": 71621906,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I can assist in inspecting/debuging all elements in the array with `printf` or `echo` command:\r\n\r\n\r\n     printf &quot;%s\\n&quot; ${sqsQueues[@]}\r\n\r\nThe array start from `0`.\r\n\r\n     echo &quot;qsQueues[0]=${sqsQueues[0]}&quot;\r\n\r\nIterating over the array:\r\n\r\n    for filteredQueueName in qsQueues; do\r\n       echo &quot;filteredQueueName=$filteredQueueName&quot;\r\n    done\r\n\r\nHope this is helpful.\r\n",
                "title": "aws cli cloudwatch describe-alarms where alarm name is like &quot;something&quot;"
            },
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1648541670,
                "creation_date": 1648541670,
                "answer_id": 71658612,
                "question_id": 71621906,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Consider this script which fetches alarm configuration when **AlarmName** contains **Bill**:\r\n````\r\npankaj@pankaj-mac TP % cat descalarm.sh \r\nfilteredQueueName=&quot;Bill&quot;\r\naws cloudwatch describe-alarms --query &quot;MetricAlarms[?contains(AlarmName, \\`${filteredQueueName}\\`) == \\`true\\`]&quot;\r\npankaj@pankaj-mac TP % ./descalarm.sh \r\n[\r\n    {\r\n        &quot;AlarmName&quot;: &quot;Billing Alarm&quot;,\r\n        &quot;AlarmArn&quot;: &quot;arn:aws:cloudwatch:us-xx-1:xxxx:alarm:Billing Alarm&quot;,\r\n        &quot;AlarmDescription&quot;: &quot;Send me an email if my bill goes above US$10&quot;,\r\n        &quot;AlarmConfigurationUpdatedTimestamp&quot;: &quot;2019-12-07T05:16:57.795000+00:00&quot;,\r\n        &quot;ActionsEnabled&quot;: true,\r\n        &quot;OKActions&quot;: [],\r\n        &quot;AlarmActions&quot;: [\r\n            &quot;arn:aws:sns:us-xx-1:xxxx:Billing_Alarm&quot;\r\n        ],\r\n        &quot;InsufficientDataActions&quot;: [],\r\n        &quot;StateValue&quot;: &quot;INSUFFICIENT_DATA&quot;,\r\n        &quot;StateReason&quot;: &quot;Unchecked: Initial alarm creation&quot;,\r\n        &quot;StateUpdatedTimestamp&quot;: &quot;2019-12-07T05:16:57.795000+00:00&quot;,\r\n        &quot;MetricName&quot;: &quot;EstimatedCharges&quot;,\r\n        &quot;Namespace&quot;: &quot;AWS/Billing&quot;,\r\n        &quot;Statistic&quot;: &quot;Maximum&quot;,\r\n        &quot;Dimensions&quot;: [\r\n            {\r\n                &quot;Name&quot;: &quot;Currency&quot;,\r\n                &quot;Value&quot;: &quot;USD&quot;\r\n            }\r\n        ],\r\n        &quot;Period&quot;: 21600,\r\n        &quot;EvaluationPeriods&quot;: 1,\r\n        &quot;DatapointsToAlarm&quot;: 1,\r\n        &quot;Threshold&quot;: 10.0,\r\n        &quot;ComparisonOperator&quot;: &quot;GreaterThanThreshold&quot;,\r\n        &quot;TreatMissingData&quot;: &quot;missing&quot;\r\n    }\r\n]\r\npankaj@pankaj-mac TP % \r\n\r\n````\r\n\r\nAnother example fetching alarms with **AlarmName** containing **xxx**. Rightly so, no alarms are found and empty array is returned.\r\n````\r\npankaj@pankaj-mac TP % cat descalarm.sh \r\nfilteredQueueName=&quot;xxx&quot;\r\naws cloudwatch describe-alarms --query &quot;MetricAlarms[?contains(AlarmName, \\`${filteredQueueName}\\`) == \\`true\\`]&quot;\r\npankaj@pankaj-mac TP % ./descalarm.sh \r\n[]\r\npankaj@pankaj-mac TP % \r\n\r\n````\r\n",
                "title": "aws cli cloudwatch describe-alarms where alarm name is like &quot;something&quot;"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 2,
        "last_activity_date": 1648541670,
        "creation_date": 1648234802,
        "last_edit_date": 1648242620,
        "question_id": 71621906,
        "body_markdown": "I have a bash array that contains a list of SQS queues:\r\n\r\n    sqsQueues=($(aws sqs list-queues | jq &#39;.[]&#39; --compact-output | sed &#39;s/\\[\\|\\]//g&#39; | sed -E &#39;s/&quot;|,/ /g&#39;))\r\n\r\nNow I want to check the values in that array and see if I have any cloudwatch alerts that have a name matching the names of the SQS queues.\r\n\r\nSo essentially, I would like something like this: \r\n\r\n    aws cloudwatch describe-alarms --query &quot;MetricAlarms[?AlarmName contains($filteredQueueName)]&quot;\r\n\r\n\r\n\r\nwhere `$filteredQueueName` is the name of the current queue I want to compare. \r\n\r\nI know that `jq` code above is not valid. But I am not sure how to ask &quot;Show me all cloudwatch alarms Where AlarmName *is LIKE* `$filteredQueueName`. I read about the command contains() on the `jq` manual page but I struggle to apply it in context.\r\n\r\nThanks\r\n\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/71621906/aws-cli-cloudwatch-describe-alarms-where-alarm-name-is-like-something",
        "title": "aws cli cloudwatch describe-alarms where alarm name is like &quot;something&quot;"
    },
    {
        "tags": [
            "json",
            "mongodb",
            "jq",
            "mongo-shell"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 3631143,
                    "reputation": 60146,
                    "user_id": 3027266,
                    "user_type": "registered",
                    "accept_rate": 75,
                    "profile_image": "https://i.sstatic.net/6OFEe.png?s=256",
                    "display_name": "Wernfried Domscheit",
                    "link": "https://stackoverflow.com/users/3027266/wernfried-domscheit"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1648240045,
                "post_id": 71622473,
                "comment_id": 126582996,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 3631143,
                    "reputation": 60146,
                    "user_id": 3027266,
                    "user_type": "registered",
                    "accept_rate": 75,
                    "profile_image": "https://i.sstatic.net/6OFEe.png?s=256",
                    "display_name": "Wernfried Domscheit",
                    "link": "https://stackoverflow.com/users/3027266/wernfried-domscheit"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1648240346,
                "post_id": 71622473,
                "comment_id": 126583073,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1648260409,
                "creation_date": 1648260409,
                "answer_id": 71624782,
                "question_id": 71622473,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "A MongoDB employee recommends using the `EJSON.stringify` wrapper, e.g.:\r\n \r\n```\r\n$ mongosh [...] --eval &quot;EJSON.stringify(db.adminCommand(&#39;listDatabases&#39;))&quot;\r\n```\r\n\r\nExcept for extensions such as `Long(_)` and `Date(_)`, it looks like `hjson` could also be used. ",
                "title": "Is there a way to standardize mongosh JSON output?"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1648294625,
                "last_edit_date": 1648294625,
                "creation_date": 1648294216,
                "answer_id": 71627659,
                "question_id": 71622473,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "In principle you can use `JSON.stringify()`. However it has some limitations, see this example:\r\n\r\n    x = {\r\n      a: 1,\r\n      b: ISODate(&quot;2022-03-26T11:15:53.750Z&quot;),\r\n      c: Int32(1),\r\n      d: Long(&quot;1&quot;),\r\n      e: Long(&quot;2&quot;),\r\n      f: Decimal128(&quot;-7.6E+11&quot;),\r\n      g: 1.345,\r\n      h: 2,\r\n      t: &#39;foo&#39;\r\n    }\r\n    \r\n    JSON.stringify(x, null, &quot; &quot;)\r\n    {\r\n     &quot;a&quot;: 1,\r\n     &quot;b&quot;: &quot;2022-03-26T11:15:53.750Z&quot;,\r\n     &quot;c&quot;: 1,\r\n     &quot;d&quot;: {\r\n      &quot;low&quot;: 1,\r\n      &quot;high&quot;: 0,\r\n      &quot;unsigned&quot;: false\r\n     },\r\n     &quot;e&quot;: {\r\n      &quot;low&quot;: 2,\r\n      &quot;high&quot;: 0,\r\n      &quot;unsigned&quot;: false\r\n     },\r\n     &quot;f&quot;: {\r\n      &quot;$numberDecimal&quot;: &quot;-7.6E+11&quot;\r\n     },\r\n     &quot;g&quot;: 1.345,\r\n     &quot;h&quot;: 2,\r\n     &quot;t&quot;: &quot;foo&quot;\r\n    }\r\n\r\n`Date` objects are converted into strings.\r\n\r\nAn alternative could be `EJSON.stringify()`, which recognizes data types like `Date`. It is also mentioned in [documentation][1]:\r\n\r\n&gt;`EJSON` has built in formatting options which may eliminate the need for a parser like `jq.` \r\n\r\n\r\nHowever, the values are printed as `{&quot;$date&quot;: &quot;2022-03-26T11:15:53.750Z&quot;}`\r\n\r\n    EJSON.stringify(x, null, &quot; &quot;)\r\n    {\r\n     &quot;a&quot;: 1,\r\n     &quot;b&quot;: {\r\n      &quot;$date&quot;: &quot;2022-03-26T11:15:53.750Z&quot;\r\n     },\r\n     &quot;c&quot;: 1,\r\n     &quot;d&quot;: 1,\r\n     &quot;e&quot;: 2,\r\n     &quot;f&quot;: {\r\n      &quot;$numberDecimal&quot;: &quot;-7.6E+11&quot;\r\n     },\r\n     &quot;g&quot;: 1.345,\r\n     &quot;h&quot;: 2,\r\n     &quot;t&quot;: &quot;foo&quot;\r\n    }\r\n\r\nMy solution is a customized function. `tojson` and `tojsononeline` do not exist anymore in `mongosh`, so I created my own:\r\n\r\n    if (typeof tojsononeline == &#39;undefined&#39;) {\r\n       function tojsononeline(x) {\r\n          return EJSON.stringify(x)\r\n             .replace(/\\{&quot;\\$date&quot;:&quot;(.{19,23}Z)&quot;\\}/g, &quot;ISODate(\\&quot;$1\\&quot;)&quot;)\r\n             .replace(/\\{&quot;\\$oid&quot;:&quot;(\\w{24})&quot;\\}/g, &quot;ObjectId(\\&quot;$1\\&quot;)&quot;)\r\n             .replace(/\\{&quot;\\$numberDecimal&quot;:&quot;(.+?)&quot;\\}/g, &quot;Decimal128(\\&quot;$1\\&quot;)&quot;);\r\n       }\r\n    }\r\n\r\n    tojsononeline(x)\r\n    {&quot;a&quot;:1,&quot;b&quot;:ISODate(&quot;2022-03-26T11:22:08.029Z&quot;),&quot;c&quot;:1,&quot;d&quot;:1,&quot;e&quot;:2,&quot;f&quot;:Decimal128(&quot;-7.6E+11&quot;),&quot;g&quot;:1.345,&quot;h&quot;:2,&quot;t&quot;:&quot;foo&quot;}\r\n\r\nThere are a few more data types used in MongoDB, however I think they are hardly relevant. Otherwise add a few more `replace()` operations.\r\n\r\nAnther solution is to install &quot;mongosh snippet&quot;, either with `snippet install mongocompat`, or download scripts from https://github.com/mongodb-labs/mongosh-snippets/tree/main/snippets/mongocompat and run\r\n\r\n    load(&#39;mongonative.js&#39;);\r\n    load(&#39;mongoassert.js&#39;);\r\n    load(&#39;mongotypes.js&#39;);\r\n\r\nPreferable put these 3 lines in your `.mongoshrc.js` file.\r\n\r\nThese 3 scripts define (almost?) all function from legacy `mongo` shell which are not (yet) available in new `mongosh`\r\n\r\n\r\nBe aware, when you move to new `mongosh`, then your application may face some more differences, see for example [mongosh Data Types][2]\r\n\r\n\r\n  [1]: https://www.mongodb.com/docs/mongodb-shell/reference/compatibility/#--eval-behavior\r\n  [2]: https://www.mongodb.com/docs/mongodb-shell/reference/data-types/",
                "title": "Is there a way to standardize mongosh JSON output?"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1677503018,
                "creation_date": 1677503018,
                "answer_id": 75580848,
                "question_id": 71622473,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can wrap your queries inside `EJSON.stringify` from inside `mongosh` console.\r\nEg: if you want to run the query `db.books.find({&quot;book-id&quot;:&quot;123456789&quot;})` execute the following.\r\n\r\n```\r\nEJSON.stringify(db.books.find({&quot;book-id&quot;:&quot;123456789&quot;}).toArray(), null, 2, { relaxed: false })\r\n```",
                "title": "Is there a way to standardize mongosh JSON output?"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 3,
        "last_activity_date": 1677503018,
        "creation_date": 1648238344,
        "question_id": 71622473,
        "body_markdown": "MongoDB upgraded their command-line interface (formerly *mongo*, now *mongosh*).  Before, the *mongo* command output was in proper JSON, the kind *jq* could ingest.  \r\n\r\nFor example: \r\n\r\n    { &quot;abc&quot; : &quot;hello&quot; }\r\n\r\nThe new *mongosh* command now outputs stuff like:\r\n\r\n    { abc: &#39;hello&#39; }\r\n\r\n...which can&#39;t be parsed by *jq*.\r\n\r\nIs there a way to standardize *mongosh* to output standard JSON?\r\n\r\nIf not, is there any shell command that filters &quot;incorrect but coherent&quot; JSON (from stdin) and normalizes it into a standard form (to stdout)?\r\n",
        "link": "https://stackoverflow.com/questions/71622473/is-there-a-way-to-standardize-mongosh-json-output",
        "title": "Is there a way to standardize mongosh JSON output?"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 17255430,
                    "reputation": 629,
                    "user_id": 12494637,
                    "user_type": "registered",
                    "profile_image": "https://lh3.googleusercontent.com/a-/AAuE7mD1xJCr_6xSt6jyXIe7x1r7D3ScdSnUPpNDMAYEPg=k-s256",
                    "display_name": "Nicholas Weston",
                    "link": "https://stackoverflow.com/users/12494637/nicholas-weston"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1648279738,
                "post_id": 71626063,
                "comment_id": 126588634,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 17234897,
                    "reputation": 57,
                    "user_id": 17127525,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/309f2046162366e0de8bda04b602f4a3?s=256&d=identicon&r=PG",
                    "display_name": "EricStolz",
                    "link": "https://stackoverflow.com/users/17127525/ericstolz"
                },
                "reply_to_user": {
                    "account_id": 17255430,
                    "reputation": 629,
                    "user_id": 12494637,
                    "user_type": "registered",
                    "profile_image": "https://lh3.googleusercontent.com/a-/AAuE7mD1xJCr_6xSt6jyXIe7x1r7D3ScdSnUPpNDMAYEPg=k-s256",
                    "display_name": "Nicholas Weston",
                    "link": "https://stackoverflow.com/users/12494637/nicholas-weston"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1648280947,
                "post_id": 71626063,
                "comment_id": 126588792,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1648284379,
                "creation_date": 1648284379,
                "answer_id": 71626558,
                "question_id": 71626063,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Ok, I managed it on my own. I thought it&#39;s more complex.\r\n\r\nHere is my query\r\n\r\n    .DATASERVER  | map((\\&quot;{\\&quot; + .NAME + \\&quot;,[\\&quot;  + .IP + \\&quot;,\\&quot;  + .ALIAS + \\&quot;]}\\&quot;) ) | {parameter: [.] }\r\n\r\nresult\r\n\r\n    {\r\n    \t&quot;parameter&quot;: [\r\n    \t\t[\r\n    \t\t\t&quot;{server02,[1.1.1.2,alias02]}&quot;,\r\n    \t\t\t&quot;{server03,[1.1.1.3,alias03]}&quot;\r\n    \t\t]\r\n    \t]\r\n    }",
                "title": "Reshape json values to value content"
            },
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1648289869,
                "creation_date": 1648289869,
                "answer_id": 71627142,
                "question_id": 71626063,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Producing the sample output from the question\r\n~~~sh\r\n{parameter: .DATASERVER | map(&quot;{\\(.IP),[\\(.NAME),\\(.ALIAS)],staticComment}&quot;)}\r\n~~~\r\n~~~json\r\n{\r\n  &quot;parameter&quot;: [\r\n    &quot;{1.1.1.2,[server02,alias02],staticComment}&quot;,\r\n    &quot;{1.1.1.3,[server03,alias03],staticComment}&quot;\r\n  ]\r\n}\r\n~~~\r\n[Demo](https://jqplay.org/s/YBEEMzva_0)\r\n\r\n---\r\nProducing the output from your own solution in a simpler way\r\n~~~\r\n{parameter: [.DATASERVER | map(&quot;{\\(.NAME),[\\(.IP),\\(.ALIAS)]}&quot;)]}\r\n~~~\r\n~~~json\r\n{\r\n  &quot;parameter&quot;: [\r\n    [\r\n      &quot;{server02,[1.1.1.2,alias02]}&quot;,\r\n      &quot;{server03,[1.1.1.3,alias03]}&quot;\r\n    ]\r\n  ]\r\n}\r\n\r\n~~~\r\n[Demo](https://jqplay.org/s/5x8WlHLb4o)",
                "title": "Reshape json values to value content"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1648322499,
                "creation_date": 1648322499,
                "answer_id": 71631117,
                "question_id": 71626063,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Starting with the given template, you could write:\r\n\r\n```\r\njq --arg parameter &quot;{&lt;IP&gt;,[&lt;NAME&gt;,&lt;ALIAS&gt;],&lt;COMMENT&gt;}&quot; &#39;\r\n [.DATASERVER[] as $l\r\n  | $parameter \r\n  | sub(&quot;&lt;IP&gt;&quot;; $l.IP)\r\n  | sub(&quot;&lt;NAME&gt;&quot;; $l.NAME) \r\n  | sub(&quot;&lt;ALIAS&gt;&quot;; $l.ALIAS)\r\n  | sub(&quot;&lt;COMMENT&gt;&quot;; $l.COMMENT // &quot;staticComment&quot;) ]\r\n | {parameter: .}\r\n&#39;\r\n```",
                "title": "Reshape json values to value content"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 0,
        "last_activity_date": 1648322499,
        "creation_date": 1648278991,
        "question_id": 71626063,
        "body_markdown": "I&#39;m not sure if this is even possible with jq but would be very happy if.\r\n\r\nThe data I receive must be transformed to build parameters for tools I use.\r\n\r\nOne tool requires the following string as parameter (*it&#39;s not a json or json object - simple string*):\r\n\r\n`-parameter=&quot;{&lt;IP&gt;,[&lt;NAME&gt;,&lt;ALIAS&gt;],&lt;COMMENT&gt;}&quot;`\r\n\r\nThe source data I recieve is json and looks like this\r\n\r\n```\r\n    {\r\n      &quot;MAINSERVER&quot;: {\r\n        &quot;COMMENT&quot;: &quot;Server&quot;,\r\n        &quot;IP&quot;: &quot;1.1.1.1&quot;,\r\n        &quot;NAME&quot;: &quot;Server1&quot;,\r\n        &quot;VERSION&quot;: &quot;19.4&quot;\r\n      },\r\n      &quot;DATASERVER&quot;: [\r\n        {\r\n          &quot;ALIAS&quot;: &quot;alias02&quot;,\r\n          &quot;IP&quot;: &quot;1.1.1.2&quot;,\r\n          &quot;NAME&quot;: &quot;server02&quot;\r\n        },\r\n        {\r\n          &quot;ALIAS&quot;: &quot;alias03&quot;,\r\n          &quot;IP&quot;: &quot;1.1.1.3&quot;,\r\n          &quot;NAME&quot;: &quot;server03&quot;\r\n        }\r\n      ]\r\n    }\r\n```\r\n\r\nI would like to transform each object array in DATASERVER to a string and push it to the key parameter.\r\n\r\n```\r\n{\r\n  &quot;parameter&quot;: [\r\n\t&quot;{1.1.1.2,[server02,alias02],staticComment}&quot;,\r\n\t&quot;{1.1.1.3,[server03,alias03],staticComment}&quot;\r\n  ]\r\n}   \r\n```\r\n\r\nAny support would be really appreciated. ",
        "link": "https://stackoverflow.com/questions/71626063/reshape-json-values-to-value-content",
        "title": "Reshape json values to value content"
    },
    {
        "tags": [
            "while-loop",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": false,
                "score": 4,
                "last_activity_date": 1648287055,
                "last_edit_date": 1648287055,
                "creation_date": 1648283028,
                "answer_id": 71626413,
                "question_id": 71626187,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You are using variables wrong. You cannot just assign a value to a variable like `$i = 1` or update it like `$i += 1`. \r\n\r\nVariables behave similar to other functions/filters, in the sense that they produce their value when evaluated, and that they have to be defined using the `as` construction (just like `def` for functions) before they can be used. The assignment operator `=` and its update variants like `+=`, on the other hand, only work for the context or a subset of the context. You can set `. = 1` (which can more simply be written as just `1`), or, if appropriate, a given subset like `.a[0].b += 1`.\r\n\r\nYou may want to have a look at the [variables](https://stedolan.github.io/jq/manual/#Variable%2FSymbolicBindingOperator%3A...as%24identifier%7C...) section, and the [assignment](https://stedolan.github.io/jq/manual/#Assignment) section of the manual; especially the part in the assignment section reading\r\n\r\n&gt; Note that the LHS of assignment operators refers to a value in `.`. Thus `$var.foo = 1` won&#39;t work as expected (`$var.foo` is not a valid or useful path expression in `.`); use `$var | .foo = 1` instead.\r\n\r\nYour example without variables works as expected. The context is being modified during the loop:\r\n~~~sh\r\n$ jq -n &#39;0 | while(.&lt;3; .+1)&#39;\r\n0\r\n1\r\n2\r\n~~~\r\n\r\nReferring to this part in the variable section reading\r\n&gt; The expression `exp as $x | ...` means: for each value of expression `exp`, run the rest of the pipeline with the entire original input, and with `$x` set to that value. Thus `as` functions as something of a foreach loop.\r\n\r\nyou can implement that loop using a variable like so:\r\n~~~sh\r\n$ jq -n &#39;(0,1,2) as $i | $i&#39;\r\n0\r\n1\r\n2\r\n~~~\r\nOr so:\r\n~~~sh\r\n$ jq -n &#39;range(3) as $i | $i&#39;\r\n0\r\n1\r\n2\r\n~~~\r\n\r\nNote that the variable definition only takes care of the looping through the values (by producing multiple contexts). The generation of the different values needs to be taken care of separately. And here, you can employ your while loop:\r\n~~~sh\r\n$ jq -n &#39;0 | while(.&lt;3; .+1) as $i | $i&#39;\r\n0\r\n1\r\n2\r\n~~~",
                "title": "jq while loop with variable produces error: Invalid path expression with result 0"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1648287055,
        "creation_date": 1648280520,
        "question_id": 71626187,
        "body_markdown": "Consider\r\n\r\n```\r\n$ jq -n &#39;0 as $i | while($i&lt;3; $i+=1)&#39;\r\nnull\r\njq: error (at &lt;unknown&gt;): Invalid path expression with result 0\r\n```\r\n\r\nI was expecting output of something like `0 1 2` but I get this error.\r\n\r\nWhat am I doing wrong?",
        "link": "https://stackoverflow.com/questions/71626187/jq-while-loop-with-variable-produces-error-invalid-path-expression-with-result",
        "title": "jq while loop with variable produces error: Invalid path expression with result 0"
    },
    {
        "tags": [
            "linux",
            "bash",
            "shell",
            "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": 1648321568,
                "post_id": 71627072,
                "comment_id": 126596579,
                "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": 1648322712,
                "post_id": 71627072,
                "comment_id": 126596804,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2435703,
                    "reputation": 27493,
                    "user_id": 2125671,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/13a492143ab4a2575b5a1f500691193c?s=256&d=identicon&r=PG",
                    "display_name": "Philippe",
                    "link": "https://stackoverflow.com/users/2125671/philippe"
                },
                "reply_to_user": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1648323007,
                "post_id": 71627072,
                "comment_id": 126596874,
                "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": 2435703,
                    "reputation": 27493,
                    "user_id": 2125671,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/13a492143ab4a2575b5a1f500691193c?s=256&d=identicon&r=PG",
                    "display_name": "Philippe",
                    "link": "https://stackoverflow.com/users/2125671/philippe"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1648331410,
                "post_id": 71627072,
                "comment_id": 126598455,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2435703,
                    "reputation": 27493,
                    "user_id": 2125671,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/13a492143ab4a2575b5a1f500691193c?s=256&d=identicon&r=PG",
                    "display_name": "Philippe",
                    "link": "https://stackoverflow.com/users/2125671/philippe"
                },
                "reply_to_user": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1648336127,
                "post_id": 71627072,
                "comment_id": 126599164,
                "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": 2435703,
                    "reputation": 27493,
                    "user_id": 2125671,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/13a492143ab4a2575b5a1f500691193c?s=256&d=identicon&r=PG",
                    "display_name": "Philippe",
                    "link": "https://stackoverflow.com/users/2125671/philippe"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1648345316,
                "post_id": 71627072,
                "comment_id": 126600127,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2435703,
                    "reputation": 27493,
                    "user_id": 2125671,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/13a492143ab4a2575b5a1f500691193c?s=256&d=identicon&r=PG",
                    "display_name": "Philippe",
                    "link": "https://stackoverflow.com/users/2125671/philippe"
                },
                "reply_to_user": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1648383449,
                "post_id": 71627072,
                "comment_id": 126605157,
                "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": 2435703,
                    "reputation": 27493,
                    "user_id": 2125671,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/13a492143ab4a2575b5a1f500691193c?s=256&d=identicon&r=PG",
                    "display_name": "Philippe",
                    "link": "https://stackoverflow.com/users/2125671/philippe"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1648431581,
                "post_id": 71627072,
                "comment_id": 126614607,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1648290833,
                "creation_date": 1648290833,
                "answer_id": 71627253,
                "question_id": 71627072,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "As you don&#39;t use the `--stream` option, I suppose your document is a *regular* JSON document.\r\n\r\nTo execute your command every second, you can implement a loop that `sleep`s for 1 second:\r\n~~~sh\r\nwhile true; do sleep 1; nc 127.0.0.1 30006 | jq &#39;.acList[] | select(…)&#39;; done\r\n~~~\r\n\r\nTo have the output on the screen **and** also save to a file (like you did with `A7.json`), you can add a call to `tee`:\r\n~~~sh\r\n# saves the document as returned by `nc` but outputs result of `jq`\r\nwhile true; do sleep 1; nc 127.0.0.1 30006 | tee A7.json | jq &#39;.acList[] | …&#39;; done\r\n\r\n# saves the result of `jq` and outputs it\r\nwhile true; do sleep 1; nc 127.0.0.1 30006 | jq &#39;.acList[] | …&#39; | tee A7.json; done\r\n~~~",
                "title": "Filtering Live json Stream on linux"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1648386484,
                "last_edit_date": 1648386484,
                "creation_date": 1648294429,
                "answer_id": 71627694,
                "question_id": 71627072,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Can you try this ?\r\n\r\n```\r\nnc localhost 30006 | tee -a A7.json |\r\n   while true; do\r\n      stdbuf -o 0 jq &#39;try (.acList[] | select(.Call | contains(&quot;QTR&quot;)))&#39; 2&gt;/dev/null\r\n   done\r\n```",
                "title": "Filtering Live json Stream on linux"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1648433257,
                "creation_date": 1648433257,
                "answer_id": 71641726,
                "question_id": 71627072,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Assuming that no other process is competing for the port,  I&#39;d suggest trying:\r\n\r\n    nc -k -l localhost 30006 | jq --unbuffered ....\r\n\r\nOr if you want to keep a copy of the output of the netcat command:\r\n\r\n    nc -k -l localhost 30006 | tee A7.json | jq --unbuffered ....\r\n\r\nYou might want to use `tee -a A7.json` instead.",
                "title": "Filtering Live json Stream on linux"
            },
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1648743525,
                "last_edit_date": 1648743525,
                "creation_date": 1648743185,
                "answer_id": 71695906,
                "question_id": 71627072,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "  # Break Down\r\n\r\n&lt;br&gt;\r\n\r\n#### Why I did what I did?\r\n---\r\n\r\n * I have live raw json stream data from the virtual radar server, which is running on my laptop along with Kali Linux WSL on the background.\r\n\r\n * For those who don&#39;t know virtual radar server is a Modes-s transmission decoder that is used to decode different ADS-B Formats. Also, it rebroadcast the data in a variety of formats.. one of them is the Json stream. And I want to save select aircraft data in json format on Kali Linux.\r\n\r\n * I used the following commands to save the data before \r\n\r\n\r\n```\r\n\r\n$ nc 127.0.0.1 30001 | jq &gt; A7.json - To save the stream.\r\n\r\n$ cat A7.json | jq &#39;.acList[] | select(.Call | contains(&quot;QTR&quot;))&#39; - To fetch Selected airline\r\n\r\n```\r\n\r\n * But I realized two things after using the above. One I&#39;m storing unwanted data which is consuming my storage. Two, when I used the second command it just goes through the json file once and produces the data which is saved at that moment and that moment alone. which caused me problems as I have to execute the command over and over again to extract the filter data which is causing me to generate duplicate data.\r\n\r\n&lt;br&gt;\r\n\r\n#### Command worked for me\r\n\r\n---\r\n\r\nThe following command worked flawlessly for my problem.\r\n```\r\n$ nc localhost 30001 | sudo jq --unbuffered &#39;.acList[] | select (.Icao | contains(&quot;800CB8&quot;))&#39; &gt; A7.json\r\n```\r\nThe following also caused me some trouble which i explain clearly down below.\r\n\r\n&lt;br&gt;\r\n\r\n\r\n#### Errors X Explanation\r\n\r\n----\r\n\r\nThis error was resulted in the missing the Field name &amp; key in the json object.\r\n```\r\n$ nc localhost 30001 | sudo jq --unbuffered &#39;.acList[] | select (.Call | contains(&quot;IAD&quot;))&#39; &gt; A7.json\r\n\r\n#OUTPUT\r\n\r\njq: error (at &lt;stdin&gt;:0): null (null) and string (&quot;IAD&quot;) cannot have their containment checked\r\n```\r\n\r\nIf you see the below JSON data you&#39;ll see the missing Field name &amp; key which caused the error message above. \r\n\r\n\r\n```\r\n{\r\n  &quot;Icao&quot;: &quot;800CB8&quot;,\r\n  &quot;Alt&quot;: 3950,\r\n  &quot;GAlt&quot;: 3794,\r\n  &quot;InHg&quot;: 29.7637787,\r\n  &quot;AltT&quot;: 0,\r\n  &quot;Call&quot;: &quot;IAD766&quot;,\r\n  &quot;Lat&quot;: 17.608658,\r\n  &quot;Long&quot;: 83.239166,\r\n  &quot;Mlat&quot;: false,\r\n  &quot;Tisb&quot;: false,\r\n  &quot;Spd&quot;: 209,\r\n  &quot;Trak&quot;: 88.9,\r\n  &quot;TrkH&quot;: false,\r\n  &quot;Sqk&quot;: &quot;&quot;,\r\n  &quot;Vsi&quot;: -1280,\r\n  &quot;VsiT&quot;: 0,\r\n  &quot;SpdTyp&quot;: 0,\r\n  &quot;CallSus&quot;: false,\r\n  &quot;Trt&quot;: 2\r\n}\r\n{\r\n  &quot;Icao&quot;: &quot;800CB8&quot;,\r\n  &quot;Alt&quot;: 3950,\r\n  &quot;GAlt&quot;: 3794,\r\n  &quot;AltT&quot;: 0,\r\n  &quot;Lat&quot;: 17.608658,\r\n  &quot;Long&quot;: 83.239166,\r\n  &quot;Mlat&quot;: false,\r\n  &quot;Spd&quot;: 209,\r\n  &quot;Trak&quot;: 88.9,\r\n  &quot;Vsi&quot;: -1280\r\n}\r\n{\r\n  &quot;Icao&quot;: &quot;800CB8&quot;,\r\n  &quot;Alt&quot;: 3800,\r\n  &quot;GAlt&quot;: 3644,\r\n  &quot;AltT&quot;: 0,\r\n  &quot;Lat&quot;: 17.608795,\r\n  &quot;Long&quot;: 83.246155,\r\n  &quot;Mlat&quot;: false,\r\n  &quot;Spd&quot;: 209,\r\n  &quot;Trak&quot;: 89.2,\r\n  &quot;Vsi&quot;: -1216\r\n}\r\n```\r\n\r\n&lt;br&gt;\r\n\r\n#### Commands that didn&#39;t work for me.\r\n----\r\n\r\n##### Command #1\r\n\r\nWhen i used jq with `--stream` with the filter it produced the below output. `--Stream` with output filter worked without any errors.\r\n\r\n```\r\n$ nc localhost 30001 | sudo jq --stream &#39;.acList[] | select (.Icao | contains(&quot;800&quot;))&#39; &gt; A7.json\r\n\r\n#OUTPUT\r\n\r\njq: error (at &lt;stdin&gt;:0): Cannot index array with string &quot;acList&quot;\r\njq: error (at &lt;stdin&gt;:0): Cannot index array with string &quot;acList&quot;\r\njq: error (at &lt;stdin&gt;:0): Cannot index array with string &quot;acList&quot;\r\njq: error (at &lt;stdin&gt;:0): Cannot index array with string &quot;acList&quot;\r\njq: error (at &lt;stdin&gt;:0): Cannot index array with string &quot;acList&quot;\r\njq: error (at &lt;stdin&gt;:0): Cannot index array with string &quot;acList&quot;\r\n```\r\n\r\n##### Command #2\r\n\r\nFor some reason `-k` `-l` didn&#39;t work to listen to the data. but the other command worked perfectly. i think it didn&#39;t work because of the existing port outside of the wsl. \r\n```\r\n$ nc -k -l localhost 30001\r\n\r\n$ nc localhost 30001\r\n```\r\n\r\n&lt;br&gt;\r\n\r\n`Thank you to everyone who helped me to solve my issue. I&#39;m very grateful to you guys `",
                "title": "Filtering Live json Stream on linux"
            }
        ],
        "is_answered": true,
        "answer_count": 4,
        "score": 0,
        "last_activity_date": 1648743525,
        "creation_date": 1648289240,
        "last_edit_date": 1648290874,
        "question_id": 71627072,
        "body_markdown": "I have live raw json stream data from the virtual radar server I&#39;m using.\r\n\r\nI use Netcat to fetch the data and jq to save it on my kali linux. using the following command.\r\n\r\n\r\n&gt;nc 127.0.0.1 30006 | jq &gt; A7.json\r\n\r\nBut i want to filter specific content from the data stream. \r\n\r\n\r\ni use the following command to extract the data.\r\n\r\n&gt; cat A7.json | jq &#39;.acList[] | select(.Call | contains(&quot;QTR&quot;))&#39; - To fetch Selected airline\r\n\r\nBut i realized later that the above command only works once. in other words, it does not refresh. as the data is updating every second. i have to execute the command over and over again to extract the filter data which is causing to generate duplicate data.\r\n\r\nCan someone help me how to filter the live data without executing the command over and over .\r\n\r\n",
        "link": "https://stackoverflow.com/questions/71627072/filtering-live-json-stream-on-linux",
        "title": "Filtering Live json Stream on linux"
    },
    {
        "tags": [
            "stream",
            "compare",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1648809267,
                "last_edit_date": 1648809267,
                "creation_date": 1648434582,
                "answer_id": 71641827,
                "question_id": 71641604,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "One way would be to read in the streams as arrays, use `transpose` to match their items, and `select` by one and output the other:\r\n~~~sh\r\njq -s &#39;[.,[(true,true,false,false,true)]] | transpose[] | select(.[1])[0]&#39; objects.json\r\n~~~\r\n[Demo](https://jqplay.org/s/JZLaMX_ys6)\r\n\r\nAnother approach would be to read in the streams as arrays, convert the booleans array into those `indices` where conditions match, and use them to reference into the objects array:\r\n~~~sh\r\njq -s &#39;.[[(true,true,false,false,true)] | indices(true)[]]&#39; objects.json\r\n~~~\r\n[Demo](https://jqplay.org/s/veYzppN4rA)\r\n\r\nThe same approach but using `nth` to reference into the `inputs` stream requires more precaution, as the successive consumption of stream inputs demands the provision of relative distances, not absolute positions to `nth`. A conversion can be implemented by successively checking the position of the next `true` value using `index` and a `while` loop:\r\n~~~sh\r\njq -n &#39;nth([true,true,false,false,true] | while(. != []; .[index(true) + 1:]) | index(true) | values; inputs)&#39; objects.json\r\n~~~\r\n[Demo](https://jqplay.org/s/pENuwzbX0T)\r\n\r\nOne could also use `reduce` to directly iterate over the boolean values, and just `select` any appropriate `input`:\r\n~~~sh\r\njq -n &#39;reduce (true,true,false,false,true) as $dict ([]; . + [input | select($dict)]) | .[]&#39; objects.json\r\n~~~\r\n[Demo](https://jqplay.org/s/-9w6ycdDJv)\r\n\r\nA solution using `foreach`, like you intended, also would need the `-n` option to not miss the first item:\r\n~~~sh\r\njq -n &#39;foreach (true,true,false,false,true) as $dict (null; input | select($dict))&#39; objects.json\r\n~~~\r\n[Demo](https://jqplay.org/s/bN8IjekfrZ)",
                "title": "Filtering by comparing two streams one-on-one in jq"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1648528849,
                "last_edit_date": 1648528849,
                "creation_date": 1648452575,
                "answer_id": 71643802,
                "question_id": 71641604,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Unfortunately, each invocation of jq can currently handle at most one external JSON stream. This is not usually an issue unless both streams are very large, so in this answer I&#39;ll focus on a solution that scales.  In fact, the amount of computer memory required is miniscule no matter how large the streams may be.  \r\n\r\nFor simplicity, let&#39;s assume that:\r\n* demon.json is a file consisting of a stream of JSON boolean values (i.e., not comma-separated);\r\n* object.json is your stream of JSON objects;\r\n* the streams have the same length;\r\n* we are working in a bash or bash-like environment. \r\n\r\nThen we could go with:\r\n```\r\npaste -d &#39;\\t&#39; demon.json &lt;(jq -c . objects.json) | jq -n &#39;\r\n  foreach inputs as $boolean (null; input; select($boolean))&#39;\r\n```\r\n\r\nSo apart from the startup costs of `paste` and `jq`, we basically only need enough memory to hold one of the objects in objects.json at a time. This solution is also very fast.\r\n\r\nOf course, if objects.json were already in JSONL (JSON-lines) format, then the first call to jq above would not be necessary.",
                "title": "Filtering by comparing two streams one-on-one in jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1648809267,
        "creation_date": 1648431654,
        "question_id": 71641604,
        "body_markdown": "I have streams\r\n```\r\n{\r\n    &quot;key&quot;: &quot;a&quot;,\r\n    &quot;value&quot;: 1\r\n}\r\n{\r\n    &quot;key&quot;: &quot;b&quot;,\r\n    &quot;value&quot;: 1\r\n}\r\n{\r\n    &quot;key&quot;: &quot;c&quot;,\r\n    &quot;value&quot;: 1\r\n}\r\n{\r\n    &quot;key&quot;: &quot;d&quot;,\r\n    &quot;value&quot;: 1\r\n}\r\n{\r\n    &quot;key&quot;: &quot;e&quot;,\r\n    &quot;value&quot;: 1\r\n}\r\n```\r\nAnd\r\n```\r\n (true,true,false,false,true)\r\n```\r\n\r\nI want to compare the two **one-on-one** and only print the object if the corresponding boolean is `true`.\r\n\r\nSo I want to output\r\n```\r\n{\r\n    &quot;key&quot;: &quot;a&quot;,\r\n    &quot;value&quot;: 1\r\n}\r\n{\r\n    &quot;key&quot;: &quot;b&quot;,\r\n    &quot;value&quot;: 1\r\n}\r\n{\r\n    &quot;key&quot;: &quot;e&quot;,\r\n    &quot;value&quot;: 1\r\n}\r\n```\r\n\r\nI tried (https://jqplay.org/s/GGTHEfQ9s3)\r\n```\r\nfilter:\r\n. as $input | foreach (true,true,false,false,true) as $dict ($input; select($dict))\r\n\r\ninput:\r\n{\r\n    &quot;key&quot;: &quot;a&quot;,\r\n    &quot;value&quot;: 1\r\n}\r\n{\r\n    &quot;key&quot;: &quot;b&quot;,\r\n    &quot;value&quot;: 1\r\n}\r\n{\r\n    &quot;key&quot;: &quot;c&quot;,\r\n    &quot;value&quot;: 1\r\n}\r\n{\r\n    &quot;key&quot;: &quot;d&quot;,\r\n    &quot;value&quot;: 1\r\n}\r\n{\r\n    &quot;key&quot;: &quot;e&quot;,\r\n    &quot;value&quot;: 1\r\n}\r\n```\r\nBut I get output:\r\n```\r\n{&quot;key&quot;:&quot;a&quot;,&quot;value&quot;:1}\r\n{&quot;key&quot;:&quot;a&quot;,&quot;value&quot;:1}\r\nnull\r\n{&quot;key&quot;:&quot;b&quot;,&quot;value&quot;:1}\r\n{&quot;key&quot;:&quot;b&quot;,&quot;value&quot;:1}\r\nnull\r\n{&quot;key&quot;:&quot;c&quot;,&quot;value&quot;:1}\r\n{&quot;key&quot;:&quot;c&quot;,&quot;value&quot;:1}\r\nnull\r\n{&quot;key&quot;:&quot;d&quot;,&quot;value&quot;:1}\r\n{&quot;key&quot;:&quot;d&quot;,&quot;value&quot;:1}\r\nnull\r\n{&quot;key&quot;:&quot;e&quot;,&quot;value&quot;:1}\r\n{&quot;key&quot;:&quot;e&quot;,&quot;value&quot;:1}\r\nnull\r\n```\r\n\r\nHelp will be appreciated.",
        "link": "https://stackoverflow.com/questions/71641604/filtering-by-comparing-two-streams-one-on-one-in-jq",
        "title": "Filtering by comparing two streams one-on-one in jq"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1648476813,
                "creation_date": 1648476813,
                "answer_id": 71648885,
                "question_id": 71648474,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Use `to_entries[0]` to reduce to the first item, `to_entries` to reconstruct the object, then update the `items` object using `|=`, and use `*` to merge with the second file accessed through `input`:\r\n~~~sh\r\njq &#39;(.items |= ([to_entries[0]] | from_entries)) * input&#39; 1.json 2.json\r\n~~~\r\n~~~json\r\n{\r\n  &quot;items&quot;: {\r\n    &quot;foo&quot;: {\r\n      &quot;key&quot;: &quot;value1&quot;\r\n    },\r\n    &quot;baz&quot;: {\r\n      &quot;key&quot;: &quot;value3&quot;\r\n    },\r\n    &quot;qux&quot;: {\r\n      &quot;key&quot;: &quot;value4&quot;\r\n    }\r\n  }\r\n}\r\n~~~\r\n[Demo](https://jqplay.org/s/RZ8tTERcHJ)",
                "title": "Merging one field from a JSON into another JSON using jq"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1648501381,
                "creation_date": 1648501381,
                "answer_id": 71653710,
                "question_id": 71648474,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "```sh\r\njq &#39;.items.foo = input.items.foo&#39; 2.json 1.json\r\n```\r\n",
                "title": "Merging one field from a JSON into another JSON using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1648501381,
        "creation_date": 1648474846,
        "last_edit_date": 1648475947,
        "question_id": 71648474,
        "body_markdown": "I have two JSON files with a similar structure. I want to take one of the item from the first JSON file and add it into the second JSON file using the `jq` command. I&#39;ve been trying to do it using `map` and `*` without any success.\r\n\r\nI have this file:\r\n\r\n```\r\n{\r\n  &quot;items&quot;: {\r\n    &quot;foo&quot;: {\r\n      &quot;key&quot;: &quot;value1&quot;\r\n    },\r\n    &quot;bar&quot;: {\r\n      &quot;key&quot;: &quot;value2&quot;\r\n    }\r\n  }\r\n}\r\n```\r\nAnd this file:\r\n\r\n```\r\n{\r\n  &quot;items&quot;: {\r\n    &quot;baz&quot;: {\r\n      &quot;key&quot;: &quot;value3&quot;\r\n    },\r\n    &quot;qux&quot;: {\r\n      &quot;key&quot;: &quot;value4&quot;\r\n    }\r\n  }\r\n}\r\n```\r\nAnd would like to take the first item on the first file and merge it into the second file, in order to get this output:\r\n```\r\n{\r\n  &quot;items&quot;: {\r\n    &quot;baz&quot;: {\r\n      &quot;key&quot;: &quot;value3&quot;\r\n    },\r\n    &quot;qux&quot;: {\r\n      &quot;key&quot;: &quot;value4&quot;\r\n    },\r\n    &quot;foo&quot;: {\r\n      &quot;key&quot;: &quot;value1&quot;\r\n    }\r\n  }\r\n}\r\n```",
        "link": "https://stackoverflow.com/questions/71648474/merging-one-field-from-a-json-into-another-json-using-jq",
        "title": "Merging one field from a JSON into another JSON using jq"
    },
    {
        "tags": [
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 2435703,
                    "reputation": 27493,
                    "user_id": 2125671,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/13a492143ab4a2575b5a1f500691193c?s=256&d=identicon&r=PG",
                    "display_name": "Philippe",
                    "link": "https://stackoverflow.com/users/2125671/philippe"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1648552335,
                "post_id": 71660127,
                "comment_id": 126647933,
                "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": 2435703,
                    "reputation": 27493,
                    "user_id": 2125671,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/13a492143ab4a2575b5a1f500691193c?s=256&d=identicon&r=PG",
                    "display_name": "Philippe",
                    "link": "https://stackoverflow.com/users/2125671/philippe"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1648555218,
                "post_id": 71660127,
                "comment_id": 126649007,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2435703,
                    "reputation": 27493,
                    "user_id": 2125671,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/13a492143ab4a2575b5a1f500691193c?s=256&d=identicon&r=PG",
                    "display_name": "Philippe",
                    "link": "https://stackoverflow.com/users/2125671/philippe"
                },
                "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": 1648564786,
                "post_id": 71660127,
                "comment_id": 126653341,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1648553171,
                "last_edit_date": 1648553171,
                "creation_date": 1648552540,
                "answer_id": 71661020,
                "question_id": 71660127,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "## 1a. What does it mean?\r\n\r\n&gt; syntax error, unexpected IDENT, expecting FORMAT or QQSTRING_START\r\n\r\nThis means the parser found an identifier where it was expecting a string. (FORMAT is the token for a formatter like `@csv` or `@text`, while QQSTRING_START is the token for a string, like `&quot;script&quot;`. In practice it&#39;s useless to use a formatter here since it won&#39;t let you use a non-constant string, but the parser doesn&#39;t know that.)\r\n\r\n## 1b. How to debug and fix this?\r\n\r\nProbably easiest to refer back to the [manual][manual]. It says that the form expect for &quot;import&quot; is\r\n\r\n```\r\nimport RelativePathString as NAME;\r\n```\r\n\r\nand the form expected for &quot;include&quot; is\r\n```\r\ninclude RelativePathString;\r\n```\r\nIt lacks examples to make this 100% clear, but &quot;RelativePathString&quot; is a placeholder - it needs to be a literal string. Try one of these:\r\n\r\n```\r\ncat test.json | jq -L jq &#39;include &quot;script&quot;; with_entries(.value |= esprop(.))&#39;\r\n```\r\n\r\n```\r\ncat test.json | jq -L jq &#39;import &quot;script&quot; as script; with_entries(.value |= script::esprop(.))&#39;\r\n```\r\n\r\nNote that the library path should be the directory containing your script, and the difference between include and import.\r\n\r\n## 2. Do .jq files used as a filter or a library have a different syntax?\r\n\r\nThey use the same syntax. The problem was with the import statement, not with the script file.\r\n\r\n[manual]: https://stedolan.github.io/jq/manual/#Modules",
                "title": "jq: file format as filter(-f) vs. library(-L)"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1648553171,
        "creation_date": 1648548555,
        "question_id": 71660127,
        "body_markdown": "```sh\r\n❯ jq --version\r\njq-1.6\r\n```\r\nI&#39;m using .jq file as a filter like following, it works:\r\n```sh\r\n❯ cat jq/script.jq\r\ndef fi(v):\r\n  v | tostring |\r\n  if test(&quot;\\\\.&quot;) then\r\n    &quot;float&quot;\r\n  else\r\n   &quot;integer&quot;\r\n  end;\r\n\r\ndef estype(v):\r\n  if type==&quot;number&quot; then\r\n    fi(v)\r\n  else\r\n    type\r\n  end;\r\n\r\ndef esprop(v):\r\n  if type==&quot;object&quot; then\r\n    {&quot;properties&quot;:  v | with_entries(.value |= esprop(.))}\r\n  else\r\n    {&quot;type&quot;: estype(v)}\r\n  end;\r\n\r\nwith_entries(.value |= esprop(.))\r\n\r\n❯ cat test.json | jq -f jq/script.jq\r\n...(omit results)\r\n```\r\n\r\nBut when I use it as library, it throw an error:\r\n```sh\r\n# comment the last filter, except the definitions of functions\r\n❯ cat jq/script.jq\r\ndef fi(v):\r\n  v | tostring |\r\n  if test(&quot;\\\\.&quot;) then\r\n    &quot;float&quot;\r\n  else\r\n   &quot;integer&quot;\r\n  end;\r\n\r\ndef estype(v):\r\n  if type==&quot;number&quot; then\r\n    fi(v)\r\n  else\r\n    type\r\n  end;\r\n\r\ndef esprop(v):\r\n  if type==&quot;object&quot; then\r\n    {&quot;properties&quot;:  v | with_entries(.value |= esprop(.))}\r\n  else\r\n    {&quot;type&quot;: estype(v)}\r\n  end;\r\n\r\n# with_entries(.value |= esprop(.))\r\n\r\n❯ cat test.json | jq -L jq/script.jq &#39;import script;&#39;\r\njq: error: syntax error, unexpected IDENT, expecting FORMAT or QQSTRING_START (Unix shell quoting issues?) at &lt;top-level&gt;, line 1:\r\nimport script;\r\njq: 1 compile error\r\n```\r\n\r\n\r\n1. What it means and how could I debug and fix this?\r\n\r\n2. Are .jq files as a filter or a library has different syntax([doesn&#39;t seems like that](https://github.com/stedolan/jq/blob/master/src/builtin.jq))?\r\n",
        "link": "https://stackoverflow.com/questions/71660127/jq-file-format-as-filter-f-vs-library-l",
        "title": "jq: file format as filter(-f) vs. library(-L)"
    },
    {
        "tags": [
            "json",
            "stream",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 3380335,
                    "reputation": 1371,
                    "user_id": 2837489,
                    "user_type": "registered",
                    "accept_rate": 88,
                    "profile_image": "https://www.gravatar.com/avatar/92eda62e2ada82246b8c72299e35c4a2?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Marcel Bochtler",
                    "link": "https://stackoverflow.com/users/2837489/marcel-bochtler"
                },
                "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": 1,
                "creation_date": 1648553694,
                "post_id": 71661117,
                "comment_id": 126648434,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1648557436,
                "last_edit_date": 1648557436,
                "creation_date": 1648553582,
                "answer_id": 71661258,
                "question_id": 71661117,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You didn&#39;t truncate the stream, therefore after filtering it to only include the parts below `.item`, `fromstream` is missing the final back-tracking item `[[&quot;item&quot;]]`. Either add it manually at the end (not recommended, this would also include the top-level object in the result), or, much simpler, use `1 | truncate_stream` to strip the first level altogether:\r\n~~~sh\r\njq --stream --null-input &#39;\r\n  fromstream(1 | truncate_stream(inputs | select(.[0][0] == &quot;item&quot;)))\r\n&#39; example.json\r\n~~~\r\n~~~json\r\n{\r\n  &quot;A&quot;: {\r\n    &quot;B&quot;: &quot;C&quot;\r\n  }\r\n}\r\n~~~\r\n\r\nAlternatively, you can use `reduce` and `setpath` to build up the result object yourself:\r\n~~~sh\r\njq --stream --null-input &#39;\r\n  reduce inputs as $in (null;\r\n    if $in | .[0][0] == &quot;item&quot; and has(1) then setpath($in[0];$in[1]) else . end\r\n  )\r\n&#39; example.json\r\n~~~\r\n~~~json\r\n{\r\n  &quot;item&quot;: {\r\n    &quot;A&quot;: {\r\n      &quot;B&quot;: &quot;C&quot;\r\n    }\r\n  }\r\n}\r\n~~~\r\n\r\nTo remove the top level object, either filter for `.item` at the end, or, similarly to `truncate_stream`, remove the path&#39;s first item using `[1:]` to strip the first level:\r\n~~~sh\r\njq --stream --null-input &#39;\r\n  reduce inputs as $in (null;\r\n    if $in | .[0][0] == &quot;item&quot; and has(1) then setpath($in[0][1:];$in[1]) else . end\r\n  )\r\n&#39; example.json\r\n~~~\r\n~~~json\r\n{\r\n  &quot;A&quot;: {\r\n    &quot;B&quot;: &quot;C&quot;\r\n  }\r\n}\r\n~~~",
                "title": "Get value of JSON object using jq --stream"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1648557436,
        "creation_date": 1648552928,
        "question_id": 71661117,
        "body_markdown": "I&#39;m trying to extract the value of an JSON object using `jq --stream`, because the real data can the size of multiple GigaBytes.\r\n\r\nThis is the JSON I&#39;m using for my tests, where I want to extract the value of `item`:\r\n```json\r\n{\r\n  &quot;other&quot;: &quot;content here&quot;,\r\n  &quot;item&quot;: {\r\n    &quot;A&quot;: {\r\n      &quot;B&quot;: &quot;C&quot;\r\n    }\r\n  },\r\n  &quot;test&quot;: &quot;test&quot;\r\n}\r\n\r\n```\r\n\r\nThe `jq` options I&#39;m using:\r\n```bash\r\njq --stream --null-input &#39;fromstream(inputs | select(.[0][0] == &quot;item&quot;))[]&#39; example.json\r\n```\r\n\r\nHowever, I don&#39;t get any output with this command.\r\n\r\nA strange thing I found is that when removing the object after the `item` the above command seems to work:\r\n```json\r\n{\r\n  &quot;other&quot;: &quot;content here&quot;,\r\n  &quot;item&quot;: {\r\n    &quot;A&quot;: {\r\n      &quot;B&quot;: &quot;C&quot;\r\n    }\r\n  }\r\n}\r\n\r\n```\r\n\r\nThe result looks as expected:\r\n```\r\n❯ jq --stream --null-input &#39;fromstream(inputs | select(.[0][0] == &quot;item&quot;))[]&#39; example.json\r\n{\r\n  &quot;A&quot;: {\r\n    &quot;B&quot;: &quot;C&quot;\r\n  }\r\n}\r\n```\r\nBut as I cannot control the input JSON this is not the solution.\r\n\r\n\r\nI&#39;m using jq version 1.6 on MacOS.",
        "link": "https://stackoverflow.com/questions/71661117/get-value-of-json-object-using-jq-stream",
        "title": "Get value of JSON object using jq --stream"
    },
    {
        "tags": [
            "json",
            "cygwin",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 6609824,
                    "reputation": 8547,
                    "user_id": 5105383,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/2YCB5.jpg?s=256",
                    "display_name": "matzeri",
                    "link": "https://stackoverflow.com/users/5105383/matzeri"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1648559454,
                "post_id": 71662276,
                "comment_id": 126650867,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1648585338,
                "creation_date": 1648585338,
                "answer_id": 71668364,
                "question_id": 71662276,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You were missing the array brackets around `.userId, .lastName` (which are also present in the solution you have linked to).\r\n~~~none\r\n[&quot;ID&quot;,&quot;NAME&quot;], [&quot;--&quot;,&quot;------&quot;], (.users[] | [.userId, .lastName]) | @tsv\r\n~~~\r\n~~~none\r\nID\tNAME\r\n--\t------\r\n1\tlastName_1\r\n2\tlastName_2\r\n3\tlastName_3\r\n4\tlastName_4\r\n5\tlastName_5\r\n~~~\r\n[Demo](https://jqplay.org/s/Oz_l9qKtus)",
                "title": "jq not processing a JSON file in Cygwin"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1648585338,
        "creation_date": 1648557921,
        "last_edit_date": 1648563316,
        "question_id": 71662276,
        "body_markdown": "When I try to use jq in cygwin to process a json file, I always get the message\r\n\r\n    assertion &quot;cb == jq_util_input_next_input_cb&quot; failed: file &quot;/usr/src/ports/jq/jq-1.6-1.x86_64/src/jq-1.6/src/util.c&quot;, line 371, function: jq_util_input_get_position\r\n\r\nI&#39;ve seen some other posts on this but I don&#39;t seem to find the solution. Is there any way to get it to work?\r\n\r\nI&#39;m using jq 1.6 in cygwin.\r\n\r\n**Update:**\r\n\r\nThis is my JSON file:\r\n\r\n    {\r\n      &quot;users&quot;: [\r\n        {\r\n          &quot;userId&quot;: 1,\r\n          &quot;firstName&quot;: &quot;firstName_1&quot;,\r\n          &quot;lastName&quot;: &quot;lastName_1&quot;,\r\n          &quot;phoneNumber&quot;: &quot;111111111&quot;,\r\n          &quot;emailAddress&quot;: &quot;emailAddress_1@email.com&quot;\r\n        },\r\n        {\r\n          &quot;userId&quot;: 2,\r\n          &quot;firstName&quot;: &quot;firstName_2&quot;,\r\n          &quot;lastName&quot;: &quot;lastName_2&quot;,\r\n          &quot;phoneNumber&quot;: &quot;222222222&quot;,\r\n          &quot;emailAddress&quot;: &quot;emailAddress_2@email.com&quot;\r\n        },\r\n        {\r\n          &quot;userId&quot;: 3,\r\n          &quot;firstName&quot;: &quot;firstName_3&quot;,\r\n          &quot;lastName&quot;: &quot;lastName_3&quot;,\r\n          &quot;phoneNumber&quot;: &quot;333333333&quot;,\r\n          &quot;emailAddress&quot;: &quot;emailAddress_3@email.com&quot;\r\n        },\r\n        {\r\n          &quot;userId&quot;: 4,\r\n          &quot;firstName&quot;: &quot;firstName_4&quot;,\r\n          &quot;lastName&quot;: &quot;lastName_4&quot;,\r\n          &quot;phoneNumber&quot;: &quot;444444444&quot;,\r\n          &quot;emailAddress&quot;: &quot;emailAddress_4@email.com&quot;\r\n        },\r\n        {\r\n          &quot;userId&quot;: 5,\r\n          &quot;firstName&quot;: &quot;firstName_5&quot;,\r\n          &quot;lastName&quot;: &quot;lastName_5&quot;,\r\n          &quot;phoneNumber&quot;: &quot;555555555&quot;,\r\n          &quot;emailAddress&quot;: &quot;emailAddress_5@email.com&quot;\r\n        }\r\n      ]\r\n    }\r\n\r\nIf I use this:\r\n\r\n    echo &quot;$(&lt;file_1.json)&quot; | jq -r &#39;[&quot;ID&quot;,&quot;NAME&quot;], [&quot;--&quot;,&quot;------&quot;], (.users[] | .userId, .lastName)&#39;\r\n\r\nI get this:\r\n\r\n    [\r\n      &quot;ID&quot;,\r\n      &quot;NAME&quot;\r\n    ]\r\n    [\r\n      &quot;--&quot;,\r\n      &quot;------&quot;\r\n    ]\r\n    1\r\n    lastName_1\r\n    2\r\n    lastName_2\r\n    3\r\n    lastName_3\r\n    4\r\n    lastName_4\r\n    5\r\n    lastName_5\r\n\r\nIf I try this:\r\n\r\n    echo &quot;$(&lt;file_1.json)&quot; | jq -r &#39;[&quot;ID&quot;,&quot;NAME&quot;], [&quot;--&quot;,&quot;------&quot;], (.users[] | .userId, .lastName) | @tsv&#39;\r\n\r\nI get this:\r\n\r\n    ID      NAME\r\n    --      ------\r\n    assertion &quot;cb == jq_util_input_next_input_cb&quot; failed: file &quot;/usr/src/ports/jq/jq-1.6-1.x86_64/src/jq-1.6/src/util.c&quot;, line 371, function: jq_util_input_get_position\r\n                        Aborted (core dumped)\r\n\r\nI was basing on this link:\r\nhttps://stackoverflow.com/questions/39139107/how-to-format-a-json-string-as-a-table-using-jq\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/71662276/jq-not-processing-a-json-file-in-cygwin",
        "title": "jq not processing a JSON file in Cygwin"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 43153,
                    "reputation": 34250,
                    "user_id": 125981,
                    "user_type": "registered",
                    "accept_rate": 80,
                    "profile_image": "https://www.gravatar.com/avatar/f2077dbed28ae040719cbe698800ec29?s=256&d=identicon&r=PG",
                    "display_name": "Mark Schultheiss",
                    "link": "https://stackoverflow.com/users/125981/mark-schultheiss"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1648566493,
                "post_id": 71664132,
                "comment_id": 126654214,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1648566818,
                "last_edit_date": 1648566818,
                "creation_date": 1648566354,
                "answer_id": 71664524,
                "question_id": 71664132,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You could do a range iteration over the array and form the desired k/v pair\r\n\r\n```none\r\njq &#39;[ range(0; length) as $r | \r\n  { ( .[$r] | split(&quot;-&quot;)[1] | ascii_downcase) : .[$r] } ] | add&#39;\r\n```\r\n\r\n[jqplay - demo(1)][1]\r\n\r\nor do a transposition of the array and form the k/v pair\r\n\r\n```none\r\njq --slurp &#39;transpose | \r\n  map( { ( .[] | split(&quot;-&quot;)[1] | ascii_downcase) : .[] } ) | add&#39;\r\n```\r\n\r\n[jqplay - demo(2)][2]\r\n\r\n\r\n  [1]: https://jqplay.org/s/5OPUWklsSl\r\n  [2]: https://jqplay.org/s/DoTOlNiuhf",
                "title": "JSON Array Literal to Object using JQ"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1648586058,
                "last_edit_date": 1648586058,
                "creation_date": 1648574772,
                "answer_id": 71666363,
                "question_id": 71664132,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Another approach could be to use `to_entries | map(…) | from_entries`, or its shortcut `with_entries(…)`.\r\n\r\nThen change the key based either on a static string and the numeric index:\r\n~~~sh\r\njq &#39;with_entries(.key |= &quot;lambda\\(.+1)&quot;)&#39;\r\n~~~\r\n[Demo](https://jqplay.org/s/S_EGkWtk4A)\r\n\r\nOr on the lower case version of the middle part of the value:\r\n~~~sh\r\njq &#39;with_entries(.key = ((.value / &quot;-&quot;)[1] | ascii_downcase))&#39;\r\n~~~\r\n[Demo](https://jqplay.org/s/7L5X7WPGQu)\r\n~~~json\r\n{\r\n  &quot;lambda1&quot;: &quot;DEV-Lambda1-xxxx&quot;,\r\n  &quot;lambda2&quot;: &quot;DEV-Lambda2-xxxx&quot;,\r\n  &quot;lambda3&quot;: &quot;DEV-Lambda3-xxxx&quot;,\r\n  &quot;lambda4&quot;: &quot;DEV-Lambda4-xxxx&quot;\r\n}\r\n~~~\r\n",
                "title": "JSON Array Literal to Object using JQ"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1648586058,
        "creation_date": 1648564861,
        "last_edit_date": 1648566472,
        "question_id": 71664132,
        "body_markdown": "I am using an AWS CLI command with json output and it creates an array:\r\n\r\n```\r\naws lambda list-functions --region us-east-2 --query &#39;Functions[?starts_with(FunctionName, `DEV`) == `true`].FunctionName&#39; --output json\r\n```\r\nWhich returns:\r\n```\r\n[\r\n    &quot;DEV-Lambda1-xxxx&quot;,\r\n    &quot;DEV-Lambda2-xxxx&quot;,\r\n    &quot;DEV-Lambda3-xxxx&quot;,\r\n    &quot;DEV-Lambda4-xxxx&quot;\r\n]\r\n```\r\n\r\nIn order to properly use the output in my Terraform, I need it to be a JSON *object*. Here is a simplified example:\r\n```\r\n{\r\n&quot;lambda1&quot;: &quot;DEV-Lambda1-xxxx&quot;,\r\n&quot;lambda2&quot;: &quot;DEV-Lambda2-xxxx&quot;,\r\n&quot;lambda3&quot;: &quot;DEV-Lambda3-xxxx&quot;,\r\n&quot;lambda4&quot;: &quot;DEV-Lambda4-xxxx&quot;\r\n}\r\n```\r\n\r\nI would like to use `jq` 1.5 or greater. How do I transpose an array into an object?\r\n\r\nI&#39;ve only been able to make it this far:\r\n\r\n```\r\nmap( { (&quot;lambda&quot;): . } ) | add \r\n```\r\n\r\nWhich outputs only the last lambda:\r\n\r\n```\r\n{\r\n  &quot;lambda&quot;: &quot;DEV-Lambda4-xxxx&quot;\r\n}\r\n```\r\n",
        "link": "https://stackoverflow.com/questions/71664132/json-array-literal-to-object-using-jq",
        "title": "JSON Array Literal to Object using JQ"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1648584383,
                "last_edit_date": 1648584383,
                "creation_date": 1648583256,
                "answer_id": 71667986,
                "question_id": 71667732,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "`join` the path array items using the dot as delimiter.\r\n\r\nFollowing your approach using `paths` and `getpath`:\r\n~~~\r\n[\r\n  paths as $path\r\n  | select(getpath($path) == &quot;Standard Generalized Markup Language&quot;)\r\n  | $path | join(&quot;.&quot;)\r\n]\r\n~~~\r\n[Demo](https://jqplay.org/s/pGy-GMI_K-)\r\n\r\nUsing `..`, `strings` and `path`:\r\n~~~\r\n[\r\n  path(.. | select(strings == &quot;Standard Generalized Markup Language&quot;)) \r\n  | join(&quot;.&quot;)\r\n]\r\n~~~\r\n[Demo](https://jqplay.org/s/ySH4-E0TzV)\r\n\r\nUsing `tostream`:\r\n~~~\r\n[\r\n  tostream | select(.[1] == &quot;Standard Generalized Markup Language&quot;)[0]\r\n  | join(&quot;.&quot;)\r\n]\r\n~~~\r\n[Demo](https://jqplay.org/s/wY8bTDbMJh)\r\n\r\n~~~json\r\n[\r\n  &quot;glossary.GlossDiv.GlossList.GlossEntry.GlossTerm&quot;\r\n]\r\n~~~\r\nIf you want a stream (instead of an array) of strings, omit the top-level brackets altogether.",
                "title": "when searching for text, get paths in dotted notation"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1648782936,
                "creation_date": 1648782936,
                "answer_id": 71701376,
                "question_id": 71667732,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I&#39;ve written a Bash script call [`jqg`](https://github.com/NorthboundTrain/jqg/) that will flatten JSON files and filter the results producing valid JSON output; it does pretty much what you want in a generic fashion.\r\n\r\nRunning the script with your JSON and with &quot;Standard Generalized Markup Language&quot; as the search string yields the following:\r\n\r\n```\r\n$ jqg &quot;Standard Generalized Markup Language&quot; /tmp/json.json\r\n{\r\n  &quot;glossary.GlossDiv.GlossList.GlossEntry.GlossTerm&quot;: &quot;Standard Generalized Markup Language&quot;\r\n}\r\n```\r\n\r\nYou can opt to only give the path elements and not the value:\r\n\r\n```\r\n$ jqg -K &quot;Standard Generalized Markup Language&quot; /tmp/json.json\r\n[\r\n  &quot;glossary.GlossDiv.GlossList.GlossEntry.GlossTerm&quot;\r\n]\r\n```\r\n\r\nand if you want the path as a string and not as full JSON, you can do that, too:\r\n\r\n```\r\n$ jqg -r -K &quot;Standard Generalized Markup Language&quot; /tmp/json.json\r\nglossary.GlossDiv.GlossList.GlossEntry.GlossTerm\r\n```\r\n\r\nNote: I am the author of `jqg`.",
                "title": "when searching for text, get paths in dotted notation"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1648782936,
        "creation_date": 1648581754,
        "question_id": 71667732,
        "body_markdown": "I&#39;m pretty new to jq.\r\n\r\nFor the JSON at the bottom of this post, I can do \r\n\r\n```shell\r\njq &#39;[paths as $path | select(getpath($path) == &quot;Standard Generalized Markup Language&quot;) | $path ]&#39; json.json\r\n```\r\n\r\nand get\r\n\r\n\r\n```\r\n[\r\n  [\r\n    &quot;glossary&quot;,\r\n    &quot;GlossDiv&quot;,\r\n    &quot;GlossList&quot;,\r\n    &quot;GlossEntry&quot;,\r\n    &quot;GlossTerm&quot;\r\n  ]\r\n]\r\n```\r\n\r\nHow can I modify that query so that I get the paths like this?\r\n\r\n`glossary.GlossDiv.GlossList.GlossEntry.GlossTerm`\r\n\r\n\r\n## `json.json`\r\n\r\n```\r\n{\r\n    &quot;glossary&quot;: {\r\n        &quot;title&quot;: &quot;example glossary&quot;,\r\n\t\t&quot;GlossDiv&quot;: {\r\n            &quot;title&quot;: &quot;S&quot;,\r\n\t\t\t&quot;GlossList&quot;: {\r\n                &quot;GlossEntry&quot;: {\r\n                    &quot;ID&quot;: &quot;SGML&quot;,\r\n\t\t\t\t\t&quot;SortAs&quot;: &quot;SGML&quot;,\r\n\t\t\t\t\t&quot;GlossTerm&quot;: &quot;Standard Generalized Markup Language&quot;,\r\n\t\t\t\t\t&quot;Acronym&quot;: &quot;SGML&quot;,\r\n\t\t\t\t\t&quot;Abbrev&quot;: &quot;ISO 8879:1986&quot;,\r\n\t\t\t\t\t&quot;GlossDef&quot;: {\r\n                        &quot;para&quot;: &quot;A meta-markup language, used to create markup languages such as DocBook.&quot;,\r\n\t\t\t\t\t\t&quot;GlossSeeAlso&quot;: [&quot;GML&quot;, &quot;XML&quot;]\r\n                    },\r\n\t\t\t\t\t&quot;GlossSee&quot;: &quot;markup&quot;\r\n                }\r\n            }\r\n        }\r\n    }\r\n}\r\n```",
        "link": "https://stackoverflow.com/questions/71667732/when-searching-for-text-get-paths-in-dotted-notation",
        "title": "when searching for text, get paths in dotted notation"
    },
    {
        "tags": [
            "arrays",
            "json",
            "object",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1648634599,
                "last_edit_date": 1648634599,
                "creation_date": 1648601972,
                "answer_id": 71670368,
                "question_id": 71670051,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You could build an `INDEX` on a matching `displayValue`, and then `JOIN` the arrays by updating `+=` the right object in `to.json` with the corresponding object in `from.json`:\r\n\r\nFIXED: Using `try` in the join update prevents from failing if the matching is not complete.\r\n\r\n~~~sh\r\njq &#39;\r\n  [\r\n    JOIN(\r\n      INDEX(.[].cells; .[] | select(.columnId == 7408953102493572).displayValue);\r\n      input[];\r\n      .cells[] | select(.columnId == 5460306864433028).displayValue;\r\n      (.[0].cells[] | select(.columnId == 5206337428711300)) += try\r\n        (.[1][] | select(.columnId == 5822630258337668) | del(.Column, .columnId))\r\n    )[0]\r\n  ]\r\n&#39; from.json to.json\r\n~~~\r\n~~~json\r\n[\r\n  {\r\n    &quot;id&quot;: 977325251291012,\r\n    &quot;cells&quot;: [\r\n      {\r\n        &quot;columnId&quot;: 2040705442965380,\r\n        &quot;value&quot;: true\r\n      },\r\n      {\r\n        &quot;columnId&quot;: 5206337428711300,\r\n        &quot;value&quot;: &quot;Dd Kk&quot;,\r\n        &quot;displayValue&quot;: &quot;Dd Kk link&quot;,\r\n        &quot;hyperlink&quot;: {\r\n          &quot;url&quot;: &quot;https://app.test.com/fvffvs/dfesfrfr&quot;\r\n        },\r\n        &quot;linkInFromCell&quot;: {\r\n          &quot;status&quot;: &quot;OK&quot;,\r\n          &quot;sheetId&quot;: 316850291664772,\r\n          &quot;rowId&quot;: 6836472364722052,\r\n          &quot;columnId&quot;: 6189414452881284,\r\n          &quot;sheetName&quot;: &quot;PROJECT INTAKE SHEET&quot;\r\n        }\r\n      },\r\n      {\r\n        &quot;columnId&quot;: 5460306864433028,\r\n        &quot;value&quot;: &quot;Dd Kk&quot;,\r\n        &quot;displayValue&quot;: &quot;Dd Kk&quot;\r\n      }\r\n    ]\r\n  },\r\n  {\r\n    &quot;id&quot;: 5480924878661508,\r\n    &quot;cells&quot;: [\r\n      {\r\n        &quot;columnId&quot;: 2040705442965380,\r\n        &quot;value&quot;: true\r\n      },\r\n      {\r\n        &quot;columnId&quot;: 5206337428711300,\r\n        &quot;displayValue&quot;: &quot;Macquarie Education Programs Building - J-10005&quot;,\r\n        &quot;hyperlink&quot;: {\r\n          &quot;url&quot;: &quot;https://app.test.com/jnjnnlkm/fvfbsfbfgvdsfe&quot;\r\n        },\r\n        &quot;linkInFromCell&quot;: {\r\n          &quot;status&quot;: &quot;OK&quot;,\r\n          &quot;sheetId&quot;: 316850291664772,\r\n          &quot;rowId&quot;: 4795289157298052,\r\n          &quot;columnId&quot;: 6189414452881284,\r\n          &quot;sheetName&quot;: &quot;PROJECT INTAKE SHEET&quot;\r\n        },\r\n        &quot;value&quot;: &quot;Macquarie Education Programs - J-10005&quot;\r\n      },\r\n      {\r\n        &quot;columnId&quot;: 5460306864433028,\r\n        &quot;value&quot;: &quot;Macquarie Education Programs&quot;,\r\n        &quot;displayValue&quot;: &quot;Macquarie Education Programs&quot;\r\n      }\r\n    ]\r\n  }\r\n]\r\n~~~\r\n[Demo](https://jqplay.org/s/wcl0MWlZL1)",
                "title": "JQ move(or copy) key value pairs to another object if a key/value pair meets condition in that object"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1648634599,
        "creation_date": 1648598240,
        "last_edit_date": 1648612823,
        "question_id": 71670051,
        "body_markdown": "I have two files, they are very large so I will give a snippet of relevant data:\r\n\r\nfrom_file:\r\n```\r\n  [\r\n    {\r\n      &quot;id&quot;: 7212486534162308,\r\n      &quot;rowNumber&quot;: 283,\r\n      &quot;cells&quot;: [\r\n        {\r\n          &quot;Column&quot;: &quot;SS name&quot;,\r\n          &quot;columnId&quot;: 7408953102493572,\r\n          &quot;displayValue&quot;: &quot;Dd Kk&quot;,\r\n          &quot;linkInFromCell&quot;: {\r\n            &quot;status&quot;: &quot;OK&quot;,\r\n            &quot;sheetId&quot;: 4409864198875012,\r\n            &quot;rowId&quot;: 5483738575202180,\r\n            &quot;columnId&quot;: 6482434207311748,\r\n            &quot;sheetName&quot;: &quot;INFORMATION - J-1000579&quot;\r\n          },\r\n          &quot;value&quot;: &quot;Dd Kk&quot;\r\n        },\r\n        {\r\n          &quot;Column&quot;: &quot;link&quot;,\r\n          &quot;columnId&quot;: 5822630258337668,\r\n          &quot;displayValue&quot;: &quot;Dd Kk link&quot;,\r\n          &quot;hyperlink&quot;: {\r\n            &quot;url&quot;: &quot;https://app.test.com/fvffvs/dfesfrfr&quot;\r\n          },\r\n          &quot;linkInFromCell&quot;: {\r\n            &quot;status&quot;: &quot;OK&quot;,\r\n            &quot;sheetId&quot;: 316850291664772,\r\n            &quot;rowId&quot;: 6836472364722052,\r\n            &quot;columnId&quot;: 6189414452881284,\r\n            &quot;sheetName&quot;: &quot;PROJECT INTAKE SHEET&quot;\r\n          },\r\n          &quot;value&quot;: &quot;Dd Kk&quot;\r\n        }\r\n      ]\r\n    },\r\n    {\r\n      &quot;id&quot;: 7046413570598788,\r\n      &quot;rowNumber&quot;: 284,\r\n      &quot;cells&quot;: [\r\n        {\r\n          &quot;Column&quot;: &quot;SS name&quot;,\r\n          &quot;columnId&quot;: 7408953102493572,\r\n          &quot;displayValue&quot;: &quot;Macquarie Education Programs&quot;,\r\n          &quot;linkInFromCell&quot;: {\r\n            &quot;status&quot;: &quot;OK&quot;,\r\n            &quot;sheetId&quot;: 8275059887368068,\r\n            &quot;rowId&quot;: 8307181892986756,\r\n            &quot;columnId&quot;: 687741640959876,\r\n            &quot;sheetName&quot;: &quot;INFORMATION - J-1000532.01&quot;\r\n          },\r\n          &quot;value&quot;: &quot;Macquarie Education Programs&quot;\r\n        },\r\n        {\r\n          &quot;Column&quot;: &quot;link&quot;,\r\n          &quot;columnId&quot;: 5822630258337668,\r\n          &quot;displayValue&quot;: &quot;Macquarie Education Programs Building - J-10005&quot;,\r\n          &quot;hyperlink&quot;: {\r\n            &quot;url&quot;: &quot;https://app.test.com/jnjnnlkm/fvfbsfbfgvdsfe&quot;\r\n          },\r\n          &quot;linkInFromCell&quot;: {\r\n            &quot;status&quot;: &quot;OK&quot;,\r\n            &quot;sheetId&quot;: 316850291664772,\r\n            &quot;rowId&quot;: 4795289157298052,\r\n            &quot;columnId&quot;: 6189414452881284,\r\n            &quot;sheetName&quot;: &quot;PROJECT INTAKE SHEET&quot;\r\n          },\r\n          &quot;value&quot;: &quot;Macquarie Education Programs - J-10005&quot;\r\n        }\r\n      ]\r\n    }\r\n  ]\r\n  ```\r\n\r\nto_file:\r\n```\r\n[\r\n  {\r\n    &quot;id&quot;: 977325251291012,\r\n    &quot;cells&quot;: [\r\n      {\r\n        &quot;columnId&quot;: 2040705442965380,\r\n        &quot;value&quot;: true\r\n      },\r\n      {\r\n        &quot;columnId&quot;: 5206337428711300,\r\n        &quot;value&quot;: &quot;&quot;\r\n      },\r\n      {\r\n        &quot;columnId&quot;: 5460306864433028,\r\n        &quot;value&quot;: &quot;Dd Kk&quot;,\r\n        &quot;displayValue&quot;: &quot;Dd Kk&quot;\r\n      }\r\n    ]\r\n  },\r\n  {\r\n    &quot;id&quot;: 5480924878661508,\r\n    &quot;cells&quot;: [\r\n      {\r\n        &quot;columnId&quot;: 2040705442965380,\r\n        &quot;value&quot;: true\r\n      },\r\n      {\r\n        &quot;columnId&quot;: 5206337428711300\r\n      },\r\n      {\r\n        &quot;columnId&quot;: 5460306864433028,\r\n        &quot;value&quot;: &quot;Macquarie Education Programs&quot;,\r\n        &quot;displayValue&quot;: &quot;Macquarie Education Programs&quot;\r\n      }\r\n    ]\r\n  }\r\n]\r\n```\r\n\r\nin the to_file, inside each object that contains &quot;columnId&quot;: 5206337428711300 I need to add all the key value pairs (except for &quot;Column&quot; and &quot;columnId&quot;) from the from_file &quot;columnId&quot;: 5822630258337668 containing object where that array of cell&#39;s &quot;columnId&quot;: 7408953102493572 containing object has the same &quot;displayValue&quot; value as the to_file&#39;s &quot;columnId&quot;: 5460306864433028 containing objects &quot;displayValue&quot; value.\r\n\r\ndesired outcome below:\r\n\r\n```\r\n[\r\n  {\r\n    &quot;id&quot;: 977325251291012,\r\n    &quot;cells&quot;: [\r\n      {\r\n        &quot;columnId&quot;: 2040705442965380,\r\n        &quot;value&quot;: true\r\n      },\r\n      {\r\n        &quot;columnId&quot;: 5206337428711300,\r\n        &quot;displayValue&quot;: &quot;Dd Kk link&quot;,\r\n        &quot;hyperlink&quot;: {\r\n          &quot;url&quot;: &quot;https://app.test.com/fvffvs/dfesfrfr&quot;\r\n        },\r\n        &quot;linkInFromCell&quot;: {\r\n          &quot;status&quot;: &quot;OK&quot;,\r\n          &quot;sheetId&quot;: 316850291664772,\r\n          &quot;rowId&quot;: 6836472364722052, \r\n          &quot;columnId&quot;: 6189414452881284,\r\n          &quot;sheetName&quot;: &quot;PROJECT INTAKE SHEET&quot;\r\n        },\r\n        &quot;value&quot;: &quot;Dd Kk&quot;\r\n\r\n      },\r\n      {\r\n        &quot;columnId&quot;: 5460306864433028,\r\n        &quot;value&quot;: &quot;Dd Kk&quot;,\r\n        &quot;displayValue&quot;: &quot;Dd Kk&quot;\r\n      }\r\n    ]\r\n  },\r\n  {\r\n    &quot;id&quot;: 5480924878661508,\r\n    &quot;cells&quot;: [\r\n      {\r\n        &quot;columnId&quot;: 2040705442965380,\r\n        &quot;value&quot;: true\r\n      },\r\n      {\r\n        &quot;columnId&quot;: 5206337428711300,\r\n        &quot;displayValue&quot;: &quot;Macquarie Education Programs Building - J-10005&quot;,\r\n        &quot;hyperlink&quot;: {\r\n          &quot;url&quot;: &quot;https://app.test.com/jnjnnlkm/fvfbsfbfgvdsfe&quot;\r\n        },\r\n        &quot;linkInFromCell&quot;: {\r\n          &quot;status&quot;: &quot;OK&quot;,\r\n          &quot;sheetId&quot;: 316850291664772,\r\n          &quot;rowId&quot;: 4795289157298052,\r\n          &quot;columnId&quot;: 6189414452881284,\r\n          &quot;sheetName&quot;: &quot;PROJECT INTAKE SHEET&quot;\r\n        },\r\n        &quot;value&quot;: &quot;Macquarie Education Programs - J-10005&quot;\r\n      },\r\n      {\r\n        &quot;columnId&quot;: 5460306864433028,\r\n        &quot;value&quot;: &quot;Macquarie Education Programs&quot;,\r\n        &quot;displayValue&quot;: &quot;Macquarie Education Programs&quot;\r\n      }\r\n    ]\r\n  }\r\n]\r\n```\r\n\r\nThanks\r\n\r\n@PMF answer below works but will fail if there is an item in the to_file that can&#39;t be found in the from file.\r\n\r\nthis works\r\n[Demo][1]\r\n```\r\n[\r\n    {\r\n    &quot;id&quot;: 7660296628791172,\r\n    &quot;rowNumber&quot;: 484,\r\n    &quot;cells&quot;: [\r\n      {\r\n        &quot;Column&quot;: &quot;SS name&quot;,\r\n        &quot;columnId&quot;: 7408953102493572,\r\n        &quot;displayValue&quot;: &quot;CSNSW&quot;,\r\n        &quot;linkInFromCell&quot;: {\r\n          &quot;status&quot;: &quot;OK&quot;,\r\n          &quot;sheetId&quot;: 3495076589528964,\r\n          &quot;rowId&quot;: 4453675823982468,\r\n          &quot;columnId&quot;: 6210919910926212,\r\n          &quot;sheetName&quot;: &quot;INFORMATION - J-1000739.01&quot;\r\n        },\r\n        &quot;value&quot;: &quot;CSNSW&quot;\r\n      },\r\n      {\r\n        &quot;Column&quot;: &quot;link&quot;,\r\n        &quot;columnId&quot;: 5822630258337668,\r\n        &quot;displayValue&quot;: &quot;CSNSW - J-1000739.01&quot;,\r\n        &quot;hyperlink&quot;: {\r\n          &quot;url&quot;: &quot;https://app.test.com/beffvfdcwe/ergrsvsrfv&quot;\r\n        },\r\n        &quot;linkInFromCell&quot;: {\r\n          &quot;status&quot;: &quot;OK&quot;,\r\n          &quot;sheetId&quot;: 3495076589528964,\r\n          &quot;rowId&quot;: 4655985963493252,\r\n          &quot;columnId&quot;: 6210919910926212,\r\n          &quot;sheetName&quot;: &quot;INFORMATION - J-1000739.01&quot;\r\n        },\r\n        &quot;value&quot;: &quot;CSNSW - J-1000739.01&quot;\r\n      }\r\n    ]\r\n  },\r\n  {\r\n    &quot;id&quot;: 7212486534162308,\r\n    &quot;rowNumber&quot;: 283,\r\n    &quot;cells&quot;: [\r\n      {\r\n        &quot;Column&quot;: &quot;SS name&quot;,\r\n        &quot;columnId&quot;: 7408953102493572,\r\n        &quot;displayValue&quot;: &quot;Dd Kk&quot;,\r\n        &quot;linkInFromCell&quot;: {\r\n          &quot;status&quot;: &quot;OK&quot;,\r\n          &quot;sheetId&quot;: 4409864198875012,\r\n          &quot;rowId&quot;: 5483738575202180,\r\n          &quot;columnId&quot;: 6482434207311748,\r\n          &quot;sheetName&quot;: &quot;INFORMATION - J-1000579&quot;\r\n        },\r\n        &quot;value&quot;: &quot;Dd Kk&quot;\r\n      },\r\n      {\r\n        &quot;Column&quot;: &quot;link&quot;,\r\n        &quot;columnId&quot;: 5822630258337668,\r\n        &quot;displayValue&quot;: &quot;Dd Kk link&quot;,\r\n        &quot;hyperlink&quot;: {\r\n          &quot;url&quot;: &quot;https://app.test.com/fvffvs/dfesfrfr&quot;\r\n        },\r\n        &quot;linkInFromCell&quot;: {\r\n          &quot;status&quot;: &quot;OK&quot;,\r\n          &quot;sheetId&quot;: 316850291664772,\r\n          &quot;rowId&quot;: 6836472364722052,\r\n          &quot;columnId&quot;: 6189414452881284,\r\n          &quot;sheetName&quot;: &quot;PROJECT INTAKE SHEET&quot;\r\n        },\r\n        &quot;value&quot;: &quot;Dd Kk&quot;\r\n      }\r\n    ]\r\n  },\r\n  {\r\n    &quot;id&quot;: 7046413570598788,\r\n    &quot;rowNumber&quot;: 284,\r\n    &quot;cells&quot;: [\r\n      {\r\n        &quot;Column&quot;: &quot;SS name&quot;,\r\n        &quot;columnId&quot;: 7408953102493572,\r\n        &quot;displayValue&quot;: &quot;Macquarie Education Programs&quot;,\r\n        &quot;linkInFromCell&quot;: {\r\n          &quot;status&quot;: &quot;OK&quot;,\r\n          &quot;sheetId&quot;: 8275059887368068,\r\n          &quot;rowId&quot;: 8307181892986756,\r\n          &quot;columnId&quot;: 687741640959876,\r\n          &quot;sheetName&quot;: &quot;INFORMATION - J-1000532.01&quot;\r\n        },\r\n        &quot;value&quot;: &quot;Macquarie Education Programs&quot;\r\n      },\r\n      {\r\n        &quot;Column&quot;: &quot;link&quot;,\r\n        &quot;columnId&quot;: 5822630258337668,\r\n        &quot;displayValue&quot;: &quot;Macquarie Education Programs Building - J-10005&quot;,\r\n        &quot;hyperlink&quot;: {\r\n          &quot;url&quot;: &quot;https://app.test.com/jnjnnlkm/fvfbsfbfgvdsfe&quot;\r\n        },\r\n        &quot;linkInFromCell&quot;: {\r\n          &quot;status&quot;: &quot;OK&quot;,\r\n          &quot;sheetId&quot;: 316850291664772,\r\n          &quot;rowId&quot;: 4795289157298052,\r\n          &quot;columnId&quot;: 6189414452881284,\r\n          &quot;sheetName&quot;: &quot;PROJECT INTAKE SHEET&quot;\r\n        },\r\n        &quot;value&quot;: &quot;Macquarie Education Programs - J-10005&quot;\r\n      }\r\n    ]\r\n  }\r\n]\r\n[\r\n  {\r\n    &quot;id&quot;: 977325251291012,\r\n    &quot;cells&quot;: [\r\n      {\r\n        &quot;columnId&quot;: 2040705442965380,\r\n        &quot;value&quot;: true\r\n      },\r\n      {\r\n        &quot;columnId&quot;: 5206337428711300,\r\n        &quot;value&quot;: &quot;&quot;\r\n      },\r\n      {\r\n        &quot;columnId&quot;: 5460306864433028,\r\n        &quot;value&quot;: &quot;Dd Kk&quot;,\r\n        &quot;displayValue&quot;: &quot;Dd Kk&quot;\r\n      }\r\n    ]\r\n  },\r\n  {\r\n    &quot;id&quot;: 5480924878661508,\r\n    &quot;cells&quot;: [\r\n      {\r\n        &quot;columnId&quot;: 2040705442965380,\r\n        &quot;value&quot;: true\r\n      },\r\n      {\r\n        &quot;columnId&quot;: 5206337428711300\r\n      },\r\n      {\r\n        &quot;columnId&quot;: 5460306864433028,\r\n        &quot;value&quot;: &quot;Macquarie Education Programs&quot;,\r\n        &quot;displayValue&quot;: &quot;Macquarie Education Programs&quot;\r\n      }\r\n    ]\r\n  }\r\n]\r\n```\r\n\r\nthis doesn&#39;t work\r\n[Demo][2]\r\n```\r\n[\r\n    {\r\n    &quot;id&quot;: 7660296628791172,\r\n    &quot;rowNumber&quot;: 484,\r\n    &quot;cells&quot;: [\r\n      {\r\n        &quot;Column&quot;: &quot;SS name&quot;,\r\n        &quot;columnId&quot;: 7408953102493572,\r\n        &quot;displayValue&quot;: &quot;CSNSW&quot;,\r\n        &quot;linkInFromCell&quot;: {\r\n          &quot;status&quot;: &quot;OK&quot;,\r\n          &quot;sheetId&quot;: 3495076589528964,\r\n          &quot;rowId&quot;: 4453675823982468,\r\n          &quot;columnId&quot;: 6210919910926212,\r\n          &quot;sheetName&quot;: &quot;INFORMATION - J-1000739.01&quot;\r\n        },\r\n        &quot;value&quot;: &quot;CSNSW&quot;\r\n      },\r\n      {\r\n        &quot;Column&quot;: &quot;link&quot;,\r\n        &quot;columnId&quot;: 5822630258337668,\r\n        &quot;displayValue&quot;: &quot;CSNSW - J-1000739.01&quot;,\r\n        &quot;hyperlink&quot;: {\r\n          &quot;url&quot;: &quot;https://app.test.com/beffvfdcwe/ergrsvsrfv&quot;\r\n        },\r\n        &quot;linkInFromCell&quot;: {\r\n          &quot;status&quot;: &quot;OK&quot;,\r\n          &quot;sheetId&quot;: 3495076589528964,\r\n          &quot;rowId&quot;: 4655985963493252,\r\n          &quot;columnId&quot;: 6210919910926212,\r\n          &quot;sheetName&quot;: &quot;INFORMATION - J-1000739.01&quot;\r\n        },\r\n        &quot;value&quot;: &quot;CSNSW - J-1000739.01&quot;\r\n      }\r\n    ]\r\n  },\r\n  {\r\n    &quot;id&quot;: 7212486534162308,\r\n    &quot;rowNumber&quot;: 283,\r\n    &quot;cells&quot;: [\r\n      {\r\n        &quot;Column&quot;: &quot;SS name&quot;,\r\n        &quot;columnId&quot;: 7408953102493572,\r\n        &quot;displayValue&quot;: &quot;Dd Kk&quot;,\r\n        &quot;linkInFromCell&quot;: {\r\n          &quot;status&quot;: &quot;OK&quot;,\r\n          &quot;sheetId&quot;: 4409864198875012,\r\n          &quot;rowId&quot;: 5483738575202180,\r\n          &quot;columnId&quot;: 6482434207311748,\r\n          &quot;sheetName&quot;: &quot;INFORMATION - J-1000579&quot;\r\n        },\r\n        &quot;value&quot;: &quot;Dd Kk&quot;\r\n      },\r\n      {\r\n        &quot;Column&quot;: &quot;link&quot;,\r\n        &quot;columnId&quot;: 5822630258337668,\r\n        &quot;displayValue&quot;: &quot;Dd Kk link&quot;,\r\n        &quot;hyperlink&quot;: {\r\n          &quot;url&quot;: &quot;https://app.test.com/fvffvs/dfesfrfr&quot;\r\n        },\r\n        &quot;linkInFromCell&quot;: {\r\n          &quot;status&quot;: &quot;OK&quot;,\r\n          &quot;sheetId&quot;: 316850291664772,\r\n          &quot;rowId&quot;: 6836472364722052,\r\n          &quot;columnId&quot;: 6189414452881284,\r\n          &quot;sheetName&quot;: &quot;PROJECT INTAKE SHEET&quot;\r\n        },\r\n        &quot;value&quot;: &quot;Dd Kk&quot;\r\n      }\r\n    ]\r\n  },\r\n  {\r\n    &quot;id&quot;: 7046413570598788,\r\n    &quot;rowNumber&quot;: 284,\r\n    &quot;cells&quot;: [\r\n      {\r\n        &quot;Column&quot;: &quot;SS name&quot;,\r\n        &quot;columnId&quot;: 7408953102493572,\r\n        &quot;displayValue&quot;: &quot;Macquarie Education Programs&quot;,\r\n        &quot;linkInFromCell&quot;: {\r\n          &quot;status&quot;: &quot;OK&quot;,\r\n          &quot;sheetId&quot;: 8275059887368068,\r\n          &quot;rowId&quot;: 8307181892986756,\r\n          &quot;columnId&quot;: 687741640959876,\r\n          &quot;sheetName&quot;: &quot;INFORMATION - J-1000532.01&quot;\r\n        },\r\n        &quot;value&quot;: &quot;Macquarie Education Programs&quot;\r\n      },\r\n      {\r\n        &quot;Column&quot;: &quot;link&quot;,\r\n        &quot;columnId&quot;: 5822630258337668,\r\n        &quot;displayValue&quot;: &quot;Macquarie Education Programs Building - J-10005&quot;,\r\n        &quot;hyperlink&quot;: {\r\n          &quot;url&quot;: &quot;https://app.test.com/jnjnnlkm/fvfbsfbfgvdsfe&quot;\r\n        },\r\n        &quot;linkInFromCell&quot;: {\r\n          &quot;status&quot;: &quot;OK&quot;,\r\n          &quot;sheetId&quot;: 316850291664772,\r\n          &quot;rowId&quot;: 4795289157298052,\r\n          &quot;columnId&quot;: 6189414452881284,\r\n          &quot;sheetName&quot;: &quot;PROJECT INTAKE SHEET&quot;\r\n        },\r\n        &quot;value&quot;: &quot;Macquarie Education Programs - J-10005&quot;\r\n      }\r\n    ]\r\n  }\r\n]\r\n[\r\n  {\r\n    &quot;id&quot;: 977325251291012,\r\n    &quot;cells&quot;: [\r\n      {\r\n        &quot;columnId&quot;: 2040705442965380,\r\n        &quot;value&quot;: true\r\n      },\r\n      {\r\n        &quot;columnId&quot;: 5206337428711300,\r\n        &quot;value&quot;: &quot;&quot;\r\n      },\r\n      {\r\n        &quot;columnId&quot;: 5460306864433028,\r\n        &quot;value&quot;: &quot;Dd Kk&quot;,\r\n        &quot;displayValue&quot;: &quot;Dd Kk&quot;\r\n      }\r\n    ]\r\n  },\r\n  {\r\n    &quot;id&quot;: 5480924878661508,\r\n    &quot;cells&quot;: [\r\n      {\r\n        &quot;columnId&quot;: 2040705442965380,\r\n        &quot;value&quot;: true\r\n      },\r\n      {\r\n        &quot;columnId&quot;: 5206337428711300\r\n      },\r\n      {\r\n        &quot;columnId&quot;: 5460306864433028,\r\n        &quot;value&quot;: &quot;Macquarie Education Programs&quot;,\r\n        &quot;displayValue&quot;: &quot;Macquarie Education Programs&quot;\r\n      }\r\n    ]\r\n  },\r\n  {\r\n    &quot;id&quot;: 7276986526263172,\r\n    &quot;cells&quot;: [\r\n      {\r\n        &quot;columnId&quot;: 2040705442965380,\r\n        &quot;value&quot;: true\r\n      },\r\n      {\r\n        &quot;columnId&quot;: 5206337428711300\r\n      },\r\n      {\r\n        &quot;columnId&quot;: 5460306864433028,\r\n        &quot;value&quot;: &quot;Dubbo&quot;,\r\n        &quot;displayValue&quot;: &quot;Dubbo&quot;\r\n      }      \r\n    ]\r\n  }\r\n]\r\n```\r\nThanks!!\r\n\r\n  [1]: https://jqplay.org/s/Z_Eb59BlxM\r\n  [2]: https://jqplay.org/s/KF165obu6f",
        "link": "https://stackoverflow.com/questions/71670051/jq-moveor-copy-key-value-pairs-to-another-object-if-a-key-value-pair-meets-con",
        "title": "JQ move(or copy) key value pairs to another object if a key/value pair meets condition in that object"
    },
    {
        "tags": [
            "switch-statement",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1648719183,
                "last_edit_date": 1648719183,
                "creation_date": 1648639490,
                "answer_id": 71676342,
                "question_id": 71676251,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Use the [alternate operator](https://stedolan.github.io/jq/manual/#Alternativeoperator://) `//`, which takes the second alternative if the first is `null` or `false`, and `empty` for the &quot;nothing&quot; result.\r\nIf accessing any field might fail, additionally use the [optional operator](https://stedolan.github.io/jq/manual/#ErrorSuppression/OptionalOperator:?) `?` on those fields.\r\n\r\n~~~json\r\n{\r\n  &quot;fieldA&quot;: &quot;A1 present&quot;,\r\n  &quot;fieldB&quot;: &quot;B1 present&quot;,\r\n  &quot;fieldC&quot;: &quot;irrelevant&quot;\r\n}\r\n{\r\n  &quot;fieldB&quot;: &quot;B2 present&quot;,\r\n  &quot;fieldC&quot;: &quot;irrelevant&quot;\r\n}\r\n{\r\n  &quot;fieldA&quot;: &quot;A3 present&quot;,\r\n  &quot;fieldC&quot;: &quot;irrelevant&quot;\r\n}\r\n{\r\n  &quot;fieldC&quot;: &quot;irrelevant&quot;\r\n}\r\n~~~\r\n~~~sh\r\njq &#39;.fieldA // .fieldB // empty&#39;\r\n~~~\r\n~~~json\r\n&quot;A1 present&quot;\r\n&quot;B2 present&quot;\r\n&quot;A3 present&quot;\r\n~~~\r\n[Demo](https://jqplay.org/s/CcoFjEgwIy)\r\n\r\n---\r\nAddressing @peak&#39;s &quot;warning&quot;: If you want to capture a filed that has the explicit boolean value `false`, while not capturing it if it is either missing or explicitly set to `null`, you can use `values` which selects non-null values only, and `first` to retrieve the first one that exists among a given stream of alternatives:\r\n\r\n~~~json\r\n{\r\n  &quot;fieldA&quot;: &quot;A1 present&quot;,\r\n  &quot;fieldB&quot;: &quot;B1 present&quot;,\r\n  &quot;fieldC&quot;: &quot;irrelevant&quot;\r\n}\r\n{\r\n  &quot;fieldA&quot;: false,\r\n  &quot;fieldB&quot;: &quot;B2 present&quot;,\r\n  &quot;fieldC&quot;: &quot;irrelevant&quot;\r\n}\r\n{\r\n  &quot;fieldA&quot;: null,\r\n  &quot;fieldB&quot;: &quot;B3 present&quot;,\r\n  &quot;fieldC&quot;: &quot;irrelevant&quot;\r\n}\r\n{\r\n  &quot;fieldB&quot;: &quot;B4 present&quot;,\r\n  &quot;fieldC&quot;: &quot;irrelevant&quot;\r\n}\r\n{\r\n  &quot;fieldC&quot;: &quot;irrelevant&quot;\r\n}\r\n~~~\r\n~~~sh\r\njq &#39;first(.fieldA, .fieldB | values)&#39;\r\n~~~\r\n~~~json\r\n&quot;A1 present&quot;\r\nfalse\r\n&quot;B3 present&quot;\r\n&quot;B4 present&quot;\r\n~~~\r\n[Demo](https://jqplay.org/s/7gWkk8GvuO)\r\n\r\nUsing this approach, there&#39;s no need to provide the explicit `empty` case. However, if you want to have a default fallback, add it as the last item in the stream, e.g. `first(.fieldA, .fieldB, &quot;&quot; | values)`.",
                "title": "How to use jq try with multiple conditions like a case?"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1648712406,
                "last_edit_date": 1648712406,
                "creation_date": 1648711752,
                "answer_id": 71688548,
                "question_id": 71676251,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "jq&#39;s `//` operator has quite complicated semantics (*)\r\nand in particular, when evaluating `E // F`, no distinction is made between E being `null`, `false`, or the empty stream.\r\n\r\nAlso, given an object as input, the expression `.x` will evaluate to the JSON value `null` if the key &quot;x&quot; is explicitly\r\nspecified as `null` **or** if the key &quot;x&quot; is not present at all.\r\n\r\nThus, *assuming an object has been given as input*,\r\nif we want .fieldA if .fieldA is non-null,\r\nand otherwise .fieldB if .fieldB is non-null,\r\nand otherwise the string &quot;missing&quot;, then we would have to write something along the lines of:\r\n```\r\n  if   .fieldA != null then .fieldA\r\n  elif .fieldB != null then .fieldB\r\n  else &quot;missing&quot;\r\n  end\r\n```\r\nSimply replace &quot;missing&quot; by `empty` to achieve the objective stated in the original question.\r\n\r\n---\r\n(*) See the [jq FAQ][1] \r\nfor complete details.\r\n\r\n\r\n  [1]: https://github.com/stedolan/jq/wiki/FAQ#or-versus-",
                "title": "How to use jq try with multiple conditions like a case?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 2,
        "last_activity_date": 1648719183,
        "creation_date": 1648639036,
        "last_edit_date": 1648689801,
        "question_id": 71676251,
        "body_markdown": "I need to output in a single column the value of a field A if it&#39;s not null or the value of field B if not null or nothing if both A and B are null.\r\n\r\nWhen I just had filed A to test I wrote this which worked ok\r\n\r\n    try .fieldA catch &quot;&quot;\r\n\r\nBut now as I need to take field B if A is null I tried those, and nothing worked\r\n\r\n    try .fieldA catch try .fieldB catch &quot;&quot; =&gt; this only returned empty values ever\r\n    try (.fieldA or .fieldB) catch &quot;&quot;  =&gt; this one outputs true or false, 2 resultst instead of 1\r\n    try (.fieldA,.fieldB) catch &quot;&quot;  =&gt; this one outputs both A and B if both are not nulll, so 2 resultst instead of 1\r\n\r\nI&#39;d like the try to stop evaluating whenever the first result is not null\r\n\r\nThanks",
        "link": "https://stackoverflow.com/questions/71676251/how-to-use-jq-try-with-multiple-conditions-like-a-case",
        "title": "How to use jq try with multiple conditions like a case?"
    },
    {
        "tags": [
            "json",
            "jq",
            "ksh"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 166270,
                    "reputation": 135171,
                    "user_id": 390278,
                    "user_type": "registered",
                    "accept_rate": 86,
                    "profile_image": "https://www.gravatar.com/avatar/84715fec547362389d02f5be0ed12814?s=256&d=identicon&r=PG",
                    "display_name": "Jeff Mercado",
                    "link": "https://stackoverflow.com/users/390278/jeff-mercado"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1648658556,
                "post_id": 71681011,
                "comment_id": 126682467,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 9041643,
                    "reputation": 425,
                    "user_id": 6735683,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/32a8de8fd0f0893a1512046459a8abce?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Timbuck",
                    "link": "https://stackoverflow.com/users/6735683/timbuck"
                },
                "reply_to_user": {
                    "account_id": 166270,
                    "reputation": 135171,
                    "user_id": 390278,
                    "user_type": "registered",
                    "accept_rate": 86,
                    "profile_image": "https://www.gravatar.com/avatar/84715fec547362389d02f5be0ed12814?s=256&d=identicon&r=PG",
                    "display_name": "Jeff Mercado",
                    "link": "https://stackoverflow.com/users/390278/jeff-mercado"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1648658641,
                "post_id": 71681011,
                "comment_id": 126682503,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 166270,
                    "reputation": 135171,
                    "user_id": 390278,
                    "user_type": "registered",
                    "accept_rate": 86,
                    "profile_image": "https://www.gravatar.com/avatar/84715fec547362389d02f5be0ed12814?s=256&d=identicon&r=PG",
                    "display_name": "Jeff Mercado",
                    "link": "https://stackoverflow.com/users/390278/jeff-mercado"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1648658709,
                "post_id": 71681011,
                "comment_id": 126682534,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 166270,
                    "reputation": 135171,
                    "user_id": 390278,
                    "user_type": "registered",
                    "accept_rate": 86,
                    "profile_image": "https://www.gravatar.com/avatar/84715fec547362389d02f5be0ed12814?s=256&d=identicon&r=PG",
                    "display_name": "Jeff Mercado",
                    "link": "https://stackoverflow.com/users/390278/jeff-mercado"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1648658813,
                "post_id": 71681011,
                "comment_id": 126682574,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 9041643,
                    "reputation": 425,
                    "user_id": 6735683,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/32a8de8fd0f0893a1512046459a8abce?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Timbuck",
                    "link": "https://stackoverflow.com/users/6735683/timbuck"
                },
                "reply_to_user": {
                    "account_id": 166270,
                    "reputation": 135171,
                    "user_id": 390278,
                    "user_type": "registered",
                    "accept_rate": 86,
                    "profile_image": "https://www.gravatar.com/avatar/84715fec547362389d02f5be0ed12814?s=256&d=identicon&r=PG",
                    "display_name": "Jeff Mercado",
                    "link": "https://stackoverflow.com/users/390278/jeff-mercado"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1648659120,
                "post_id": 71681011,
                "comment_id": 126682693,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1648659054,
                "creation_date": 1648659054,
                "answer_id": 71681168,
                "question_id": 71681011,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You are dynamically constructing a filter using the *value* of a variable. This is fragile, as the resulting expression is parsed, rather than using the value of the variable literally (similar to SQL injection attacks).\r\n\r\nYou can access the environment directly using `$ENV`.\r\n\r\n     % export entity_name=my_entity_name\r\n     % jq -r &#39;select(.components.schemas[$ENV.entity_name].properties != null)&#39; file.json\r\n\r\nor simply pass the key as an explicit argument\r\n\r\n    % jq -r --arg entity_name my_entity_name &#39;select(.components.schemas[$entity_name].properties != null)&#39; file.json",
                "title": "How to use environment variables within a command in jq script files?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 5,
        "last_activity_date": 1648659054,
        "creation_date": 1648658377,
        "last_edit_date": 1648658587,
        "question_id": 71681011,
        "body_markdown": "I am working with a large quantity of OpenAPI 3.0.0 files from which I need to create html pages. Each OpenAPI file represents an entity in a large object model. The Swagger Viewer, redoc-cli, and other tools do not produce the type of documentation I need. Here is an example file:\r\n\r\n```\r\n{\r\n    &quot;openapi&quot;: &quot;3.0.0&quot;,\r\n    &quot;paths&quot;: {},\r\n    &quot;info&quot;: {\r\n        &quot;title&quot;: &quot;My File&quot;,\r\n        &quot;version&quot;: &quot;1.0.0&quot;\r\n    },\r\n    &quot;components&quot;: {\r\n        &quot;schemas&quot;: {\r\n            &quot;my_entity_name&quot;: {\r\n                &quot;type&quot;: &quot;object&quot;,\r\n                &quot;description&quot;: &quot;....&quot;,\r\n                &quot;properties&quot;: {\r\n                    &quot;propertyOne&quot;: {\r\n                        &quot;type&quot;: &quot;string&quot;,\r\n                        &quot;description&quot;: &quot;...&quot;\r\n                    },\r\n                    &quot;propertyTwo&quot;: {\r\n                        &quot;type&quot;: &quot;string&quot;,\r\n                        &quot;format&quot;: &quot;date&quot;,\r\n                        &quot;description&quot;: &quot;...&quot;\r\n                    }\r\n                }\r\n            }\r\n        }\r\n    }\r\n}\r\n```\r\n\r\nWithin my solution I am using jq to parse the files (macOS, ksh). Since there are so many, I would like to pass an environment variable to jq. This is straightforward in the shell:\r\n\r\n     % entity_name=my_entity_name\r\n     % jq -r &#39;select(.components.schemas.&#39;$entity_name&#39;.properties != null)&#39; file.json\r\n\r\nIn a script file the approach is similar, and I get the results I expect. However, given the nature of what I am trying to do, I&#39;d like to use the jq -f option to put the jq commands in a file. \r\n\r\nI&#39;ve attempted putting the following in a file called `jqscript.jq`:\r\n\r\n     select(.components.schemas.&#39;$entity_name&#39;.properties != null)\r\n\r\nAnd I call make the call thus:\r\n\r\n      % jq -rf jqscript.jq --arg entity_name &quot;$entity_name&quot; file.json\r\n\r\nThis results in an error: \r\n\r\n```\r\njq: error: syntax error, unexpected INVALID_CHARACTER, expecting FORMAT or QQSTRING_START (Unix shell quoting issues?) at &lt;top-level&gt;, line 1:\r\nselect(.components.schemas.&#39;$entity_name&#39;.properties != null)                           \r\njq: 1 compile error\r\n```\r\n\r\nI&#39;ve tried to decipher how to use an environment variable in such a situation by modifying the ```&#39;$entity_name&#39;``` to ```$entity_name``` (removing the single quotes),```$[entity_name]```, ```${entity_name}```, et cetera but I had similar results. \r\n\r\nI was able to verify that variables can be passed to jq script files with the following example script:\r\n\r\n```{\r\nvalue: $entity_name\r\n} |\r\n.value\r\n```\r\n\r\nWhen I run with this file with `% jq -rf jqscript.jq --arg entity_name &quot;$entity_name&quot; file.json`, I get the expected value for entity_name returned. \r\n\r\nHow can I go about using an environment variable that is both within a jq command and that command is in a jq script file?\r\n",
        "link": "https://stackoverflow.com/questions/71681011/how-to-use-environment-variables-within-a-command-in-jq-script-files",
        "title": "How to use environment variables within a command in jq script files?"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 5351266,
                    "reputation": 73064,
                    "user_id": 4265352,
                    "user_type": "registered",
                    "profile_image": "https://lh4.googleusercontent.com/-lzAUc5pYb24/AAAAAAAAAAI/AAAAAAAAAGQ/q3h7bZUnqrs/s256-rj/photo.jpg",
                    "display_name": "axiac",
                    "link": "https://stackoverflow.com/users/4265352/axiac"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1648668448,
                "post_id": 71682906,
                "comment_id": 126685935,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1648669071,
                "creation_date": 1648669071,
                "answer_id": 71683193,
                "question_id": 71682906,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "`|` has a lower priority than the assignment (`=`). The expression `.id = .id | tostring` is interpreted as `(.id = .id) | tostring`.\r\n\r\nThe assignment does change anything and can be removed. The script becomes `[ .[] | tostring ]`, that explains the output (each object is serialized as JSON into a string).\r\n\r\nThe solution is to use parentheses to enforce the desired order of execution.&lt;br&gt;\r\nThe command is:\r\n\r\n```\r\njq &#39;[ .[] | .id = (.id | tostring) ]&#39; test.json\r\n```\r\n\r\n---\r\n\r\nDo not use process expansion (`$(...)`) to compose an `echo` command line. It is inefficient and not needed.\r\n\r\nRedirect the output of `jq` directly to a file. Use a different file than the input file (or it ends up destroying your data).\r\n\r\n```\r\njq &#39;[ .[] | .id = (.id | tostring) ]&#39; test.json &gt; output.json",
                "title": "Convert value of json from int to string using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1648669071,
        "creation_date": 1648667600,
        "last_edit_date": 1648668457,
        "question_id": 71682906,
        "body_markdown": "Given a json that looks something like:\r\n```\r\n[{&quot;id&quot;:1,&quot;firstName&quot;:&quot;firstName1&quot;,&quot;lastName&quot;:&quot;lastName1&quot;},\r\n{&quot;id&quot;:2,&quot;firstName&quot;:&quot;firstName2&quot;,&quot;lastName&quot;:&quot;lastName2&quot;},\r\n{&quot;id&quot;:3,&quot;firstName&quot;:&quot;firstName3&quot;,&quot;lastName&quot;:&quot;lastName3&quot;}]\r\n```\r\nWhat would be the best way to convert the id value from an int to a string and then saving the file?\r\n\r\nI have tried:\r\n\r\n```\r\necho &quot;$(jq -r &#39;[.[] | .id = .id|tostring]&#39; test.json)&quot; &gt; test.json\r\n``` \r\n\r\nBut that seems to put each entry into a string and adds the backslashes \r\n\r\n```\r\n[\r\n  &quot;{\\&quot;id\\&quot;:1,\\&quot;firstName\\&quot;:\\&quot;firstName1\\&quot;,\\&quot;lastName\\&quot;:\\&quot;lastName1\\&quot;}&quot;,\r\n  &quot;{\\&quot;id\\&quot;:2,\\&quot;firstName\\&quot;:\\&quot;firstName2\\&quot;,\\&quot;lastName\\&quot;:\\&quot;lastName2\\&quot;}&quot;,\r\n  &quot;{\\&quot;id\\&quot;:3,\\&quot;firstName\\&quot;:\\&quot;firstName3\\&quot;,\\&quot;lastName\\&quot;:\\&quot;lastName3\\&quot;}&quot;\r\n]\r\n```",
        "link": "https://stackoverflow.com/questions/71682906/convert-value-of-json-from-int-to-string-using-jq",
        "title": "Convert value of json from int to string using jq"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1648675630,
                "last_edit_date": 1648675630,
                "creation_date": 1648674723,
                "answer_id": 71684216,
                "question_id": 71684162,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Assuming your JSON looks more like this (curly braces around objects, and commas between array items):\r\n~~~json\r\n{&quot;result&quot;:\r\n[\r\n{&quot;id&quot;:&quot;799dbd172f409c65&quot;,&quot;status&quot;:&quot;active&quot;,&quot;plan&quot;:{&quot;planid&quot;:&quot;0feeeeeeeeeeeeeeee&quot;,&quot;name&quot;:&quot;Enterprise&quot;,&quot;externally_managed&quot;:true}},\r\n{&quot;id&quot;:&quot;a00eb4acb5905100&quot;,&quot;status&quot;:&quot;active&quot;,&quot;plan&quot;:{&quot;planid&quot;:&quot;0feeeeeeeeeeeeeeee&quot;,&quot;name&quot;:&quot;Enterprise&quot;,&quot;externally_managed&quot;:false}},\r\n{&quot;id&quot;:&quot;8e09545457675ed2&quot;,&quot;status&quot;:&quot;active&quot;,&quot;plan&quot;:{&quot;planid&quot;:&quot;0feeeeeeeeeeeeeeee&quot;,&quot;name&quot;:&quot;Enterprise&quot;,&quot;externally_managed&quot;:true}}\r\n]}\r\n~~~\r\n\r\nAll three of your attempts miss descending into the `.plan` object. Apart from that, all do work fine, only the first one would need a conversion to a string before applying `contains` (as you are already doing in the third one):\r\n~~~sh\r\n$ jq -r &#39;.result[] | select(.plan.externally_managed|tostring | contains(&quot;true&quot;)) | &quot;\\(.id)&quot;&#39;\r\n799dbd172f409c65\r\n8e09545457675ed2\r\n\r\n$ jq -r &#39;.result[] | select(.plan.externally_managed == true) | &quot;\\(.id)&quot;&#39;\r\n799dbd172f409c65\r\n8e09545457675ed2\r\n\r\n$ jq -r &#39;.result[] | select(.plan.externally_managed|tostring == &quot;true&quot;) | &quot;\\(.id)&quot;&#39;\r\n799dbd172f409c65\r\n8e09545457675ed2\r\n~~~\r\n\r\nHere&#39;s another, shorter one which directly uses the boolean value for `select`, and omits converting the value of `.id` into a string (which it is alrady, at least in your sample data):\r\n~~~sh\r\n$ jq -r &#39;.result[] | select(.plan.externally_managed).id&#39;\r\n799dbd172f409c65\r\n8e09545457675ed2\r\n~~~\r\n[Demo](https://jqplay.org/s/T7CJPTda4v)\r\n",
                "title": "Filtering json result for values using jq"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1648675630,
        "creation_date": 1648674329,
        "question_id": 71684162,
        "body_markdown": "I have a problem filtering JSON results with jq.\r\n\r\nI have the following JSON result:\r\n\r\n\r\n```\r\n{&quot;result&quot;:\r\n[\r\n&quot;id&quot;:&quot;799dbd172f409c65&quot;,&quot;status&quot;:&quot;active&quot;,&quot;plan&quot;:{&quot;planid&quot;:&quot;0feeeeeeeeeeeeeeee&quot;,&quot;name&quot;:&quot;Enterprise&quot;,&quot;externally_managed&quot;:true}}\r\n&quot;id&quot;:&quot;a00eb4acb5905100&quot;,&quot;status&quot;:&quot;active&quot;,&quot;plan&quot;:{&quot;planid&quot;:&quot;0feeeeeeeeeeeeeeee&quot;,&quot;name&quot;:&quot;Enterprise&quot;,&quot;externally_managed&quot;:false}}\r\n&quot;id&quot;:&quot;8e09545457675ed2&quot;,&quot;status&quot;:&quot;active&quot;,&quot;plan&quot;:{&quot;planid&quot;:&quot;0feeeeeeeeeeeeeeee&quot;,&quot;name&quot;:&quot;Enterprise&quot;,&quot;externally_managed&quot;:true}}\r\n]}\r\n```\r\n\r\nI&#39;d to get a list of IDs for accounts that have &quot;externally_managed&quot;:true.\r\n\r\nI tried using the following JR, but I failed again and again and again...\r\n\r\n\r\n```\r\njq -r &#39;.result[] | select( .externally_managed | contains(&quot;true&quot;)) | &quot;\\(.id)&quot;&#39;\r\njq -r &#39;.result[] | select( .externally_managed == true) | &quot;\\(.id)&quot;&#39;\r\njq -r &#39;.result[] | select( .externally_managed|tostring == &quot;true&quot;) | &quot;\\(.id)&quot;&#39;\r\n```\r\n\r\nThe expected result in this case is:\r\n```\r\n799dbd172f409c65\r\n8e09545457675ed2\r\n```\r\n\r\nany assistance will be much appreciated.\r\n\r\nThank you very much in advance!\r\n\r\nHave a good one\r\n",
        "link": "https://stackoverflow.com/questions/71684162/filtering-json-result-for-values-using-jq",
        "title": "Filtering json result for values using jq"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1648678317,
                "creation_date": 1648678317,
                "answer_id": 71684724,
                "question_id": 71684667,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Assuming your JSON looks more like this (strings in double quotes, no comma after the last array item):\r\n~~~json\r\n{ &quot;result&quot;: \r\n  [\r\n    { &quot;name&quot;: &quot;foo&quot;, &quot;text&quot;: &quot;my name is foo&quot; },\r\n    { &quot;name&quot;: &quot;bar&quot;, &quot;text&quot;: &quot;my name is baz&quot; }\r\n  ]\r\n}\r\n~~~\r\n\r\nWhen going into `.text`, you have lost the context from which you can access `.name`. You could save it (or directly the desired value) in a variable and reference it when needed:\r\n~~~sh\r\njq &#39;.result[] | select(.name as $name | .text | ascii_downcase | contains($name))&#39;\r\n~~~\r\n~~~json\r\n{\r\n  &quot;name&quot;: &quot;foo&quot;,\r\n  &quot;text&quot;: &quot;my name is foo&quot;\r\n}\r\n~~~\r\n[Demo](https://jqplay.org/s/60E0riPlQW)",
                "title": "jq select items where a property contains the value of another property"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1648678317,
        "creation_date": 1648677914,
        "question_id": 71684667,
        "body_markdown": "I&#39;m trying to filter for items from a list that contain the values of other properties in the same object.\r\n\r\nExample of the data.json:\r\n```\r\n{ result: \r\n  [\r\n    { name: &#39;foo&#39;, text: &#39;my name is foo&#39; },\r\n    { name: &#39;bar&#39;, text: &#39;my name is baz&#39; },\r\n  ]\r\n}\r\n```\r\n\r\nWhat I&#39;ve tried:\r\n\r\n```\r\ncat data.json | jq &#39;.result[] | select(.text | ascii_downcase | contains(.name))&#39;\r\n```\r\n\r\nHowever it throws the following error: \r\n`Cannot index string with string`\r\n\r\nIs there a way in jq to select based on a dynamic property rather than a string literal?\r\n",
        "link": "https://stackoverflow.com/questions/71684667/jq-select-items-where-a-property-contains-the-value-of-another-property",
        "title": "jq select items where a property contains the value of another property"
    },
    {
        "tags": [
            "json",
            "powershell",
            "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": 1648717557,
                "post_id": 71689656,
                "comment_id": 126697357,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 11854868,
                    "reputation": 821,
                    "user_id": 8675116,
                    "user_type": "registered",
                    "accept_rate": 72,
                    "profile_image": "https://lh6.googleusercontent.com/-ht09ft9gZLI/AAAAAAAAAAI/AAAAAAAAK4U/o46tohOPvc0/s256-rj/photo.jpg",
                    "display_name": "Beefcake",
                    "link": "https://stackoverflow.com/users/8675116/beefcake"
                },
                "reply_to_user": {
                    "account_id": 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": 1648717955,
                "post_id": 71689656,
                "comment_id": 126697510,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1648718050,
                "creation_date": 1648718050,
                "answer_id": 71689886,
                "question_id": 71689656,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "As `jq` is tagged, you can use `walk` to traverse the JSON document, and if it encounters an object, apply `del` to delete any `.metadata` field:\r\n~~~sh\r\njq &#39;walk(if type == &quot;object&quot; then del(.metadata) else . end)&#39; file.json\r\n~~~\r\n~~~json\r\n{\r\n  &quot;$schema&quot;: &quot;https://schema.management.azure.com/schemas/2018-05-01/subscriptionDeploymentTemplate.json#&quot;,\r\n  &quot;contentVersion&quot;: &quot;1.0.0.0&quot;,\r\n  &quot;parameters&quot;: {\r\n    &quot;p_vnetPeeringsCompute&quot;: {\r\n      &quot;type&quot;: &quot;array&quot;\r\n    },\r\n    &quot;p_vnetPeeringsStorage&quot;: {\r\n      &quot;type&quot;: &quot;array&quot;\r\n    },\r\n    &quot;p_vnetPeeringsLinkFile&quot;: {\r\n      &quot;type&quot;: &quot;array&quot;\r\n    },\r\n    &quot;p_tags&quot;: {\r\n      &quot;type&quot;: &quot;object&quot;,\r\n      &quot;defaultValue&quot;: {}\r\n    }\r\n  },\r\n  &quot;functions&quot;: [],\r\n  &quot;variables&quot;: {\r\n    &quot;v_longLocation&quot;: &quot;uksouth&quot;,\r\n    &quot;v_shortLocation&quot;: &quot;uks&quot;,\r\n    &quot;v_templateDescription&quot;: &quot;Azure Private DNS Template Spec&quot;,\r\n    &quot;v_templateDisplayName&quot;: &quot;privateDns&quot;,\r\n    &quot;v_templateName&quot;: &quot;privateDns&quot;,\r\n    &quot;v_templateVersion&quot;: &quot;2.0.0&quot;,\r\n    &quot;v_templateTags&quot;: {\r\n      &quot;tsName&quot;: &quot;[variables(&#39;v_templateName&#39;)]&quot;,\r\n      &quot;tsVersion&quot;: &quot;[variables(&#39;v_templateVersion&#39;)]&quot;\r\n    },\r\n    &quot;v_tags&quot;: &quot;[union(parameters(&#39;p_tags&#39;), variables(&#39;v_templateTags&#39;))]&quot;\r\n  },\r\n  &quot;resources&quot;: [\r\n    {\r\n      &quot;type&quot;: &quot;Microsoft.Resources/resourceGroups&quot;,\r\n      &quot;apiVersion&quot;: &quot;2021-01-01&quot;,\r\n      &quot;name&quot;: &quot;[format(&#39;{0}-{1}-compute-rsg&#39;, variables(&#39;v_shortLocation&#39;), subscription().displayName)]&quot;,\r\n      &quot;location&quot;: &quot;[variables(&#39;v_longLocation&#39;)]&quot;,\r\n      &quot;tags&quot;: &quot;[variables(&#39;v_tags&#39;)]&quot;\r\n    },\r\n    {\r\n      &quot;type&quot;: &quot;Microsoft.Resources/resourceGroups&quot;,\r\n      &quot;apiVersion&quot;: &quot;2021-01-01&quot;,\r\n      &quot;name&quot;: &quot;[format(&#39;{0}-{1}-link-rsg&#39;, variables(&#39;v_shortLocation&#39;), subscription().displayName)]&quot;,\r\n      &quot;location&quot;: &quot;[variables(&#39;v_longLocation&#39;)]&quot;,\r\n      &quot;tags&quot;: &quot;[variables(&#39;v_tags&#39;)]&quot;\r\n    },\r\n    {\r\n      &quot;type&quot;: &quot;Microsoft.Resources/resourceGroups&quot;,\r\n      &quot;apiVersion&quot;: &quot;2021-01-01&quot;,\r\n      &quot;name&quot;: &quot;[format(&#39;{0}-{1}-storage-rsg&#39;, variables(&#39;v_shortLocation&#39;), subscription().displayName)]&quot;,\r\n      &quot;location&quot;: &quot;[variables(&#39;v_longLocation&#39;)]&quot;,\r\n      &quot;tags&quot;: &quot;[variables(&#39;v_tags&#39;)]&quot;\r\n    },\r\n    {\r\n      &quot;type&quot;: &quot;Microsoft.Resources/deployments&quot;,\r\n      &quot;apiVersion&quot;: &quot;2020-06-01&quot;,\r\n      &quot;name&quot;: &quot;privateCompute&quot;,\r\n      &quot;resourceGroup&quot;: &quot;[format(&#39;{0}-{1}-compute-rsg&#39;, variables(&#39;v_shortLocation&#39;), subscription().displayName)]&quot;,\r\n      &quot;properties&quot;: {\r\n        &quot;expressionEvaluationOptions&quot;: {\r\n          &quot;scope&quot;: &quot;inner&quot;\r\n        },\r\n        &quot;mode&quot;: &quot;Incremental&quot;,\r\n        &quot;parameters&quot;: {\r\n          &quot;p_tags&quot;: {\r\n            &quot;value&quot;: &quot;[variables(&#39;v_tags&#39;)]&quot;\r\n          },\r\n          &quot;p_vnetPeeringsCompute&quot;: {\r\n            &quot;value&quot;: &quot;[parameters(&#39;p_vnetPeeringsCompute&#39;)]&quot;\r\n          }\r\n        },\r\n        &quot;template&quot;: {\r\n          &quot;$schema&quot;: &quot;https://schema.management.azure.com/schemas/2019-04-01/deploymentTemplate.json#&quot;,\r\n          &quot;contentVersion&quot;: &quot;1.0.0.0&quot;,\r\n          &quot;parameters&quot;: {\r\n            &quot;p_tags&quot;: {\r\n              &quot;type&quot;: &quot;object&quot;,\r\n              &quot;defaultValue&quot;: {}\r\n            },\r\n            &quot;p_vnetPeeringsCompute&quot;: {\r\n              &quot;type&quot;: &quot;array&quot;\r\n            }\r\n          },\r\n          &quot;functions&quot;: [],\r\n          &quot;resources&quot;: [\r\n            {\r\n              &quot;type&quot;: &quot;Microsoft.Network/privateDnsZones&quot;,\r\n              &quot;apiVersion&quot;: &quot;2020-06-01&quot;,\r\n              &quot;name&quot;: &quot;compute.bld.local&quot;,\r\n              &quot;tags&quot;: &quot;[parameters(&#39;p_tags&#39;)]&quot;,\r\n              &quot;location&quot;: &quot;Global&quot;\r\n            },\r\n            {\r\n              &quot;copy&quot;: {\r\n                &quot;name&quot;: &quot;vnl&quot;,\r\n                &quot;count&quot;: &quot;[length(parameters(&#39;p_vnetPeeringsCompute&#39;))]&quot;\r\n              },\r\n              &quot;type&quot;: &quot;Microsoft.Network/privateDnsZones/virtualNetworkLinks&quot;,\r\n              &quot;apiVersion&quot;: &quot;2020-06-01&quot;,\r\n              &quot;name&quot;: &quot;[format(&#39;{0}/{1}&#39;, &#39;compute.bld.local&#39;, last(split(parameters(&#39;p_vnetPeeringsCompute&#39;)[copyIndex()].id, &#39;/&#39;)))]&quot;,\r\n              &quot;tags&quot;: &quot;[parameters(&#39;p_tags&#39;)]&quot;,\r\n              &quot;location&quot;: &quot;Global&quot;,\r\n              &quot;properties&quot;: {\r\n                &quot;virtualNetwork&quot;: {\r\n                  &quot;id&quot;: &quot;[parameters(&#39;p_vnetPeeringsCompute&#39;)[copyIndex()].id]&quot;\r\n                },\r\n                &quot;registrationEnabled&quot;: false\r\n              },\r\n              &quot;dependsOn&quot;: [\r\n                &quot;[resourceId(&#39;Microsoft.Network/privateDnsZones&#39;, &#39;compute.bld.local&#39;)]&quot;\r\n              ]\r\n            }\r\n          ]\r\n        }\r\n      },\r\n      &quot;dependsOn&quot;: [\r\n        &quot;[subscriptionResourceId(&#39;Microsoft.Resources/resourceGroups&#39;, format(&#39;{0}-{1}-compute-rsg&#39;, variables(&#39;v_shortLocation&#39;), subscription().displayName))]&quot;\r\n      ]\r\n    },\r\n    {\r\n      &quot;type&quot;: &quot;Microsoft.Resources/deployments&quot;,\r\n      &quot;apiVersion&quot;: &quot;2020-06-01&quot;,\r\n      &quot;name&quot;: &quot;privateLink&quot;,\r\n      &quot;resourceGroup&quot;: &quot;[format(&#39;{0}-{1}-link-rsg&#39;, variables(&#39;v_shortLocation&#39;), subscription().displayName)]&quot;,\r\n      &quot;properties&quot;: {\r\n        &quot;expressionEvaluationOptions&quot;: {\r\n          &quot;scope&quot;: &quot;inner&quot;\r\n        },\r\n        &quot;mode&quot;: &quot;Incremental&quot;,\r\n        &quot;parameters&quot;: {\r\n          &quot;p_vnetPeeringsLinkFile&quot;: {\r\n            &quot;value&quot;: &quot;[parameters(&#39;p_vnetPeeringsLinkFile&#39;)]&quot;\r\n          },\r\n          &quot;p_tags&quot;: {\r\n            &quot;value&quot;: &quot;[variables(&#39;v_tags&#39;)]&quot;\r\n          }\r\n        },\r\n        &quot;template&quot;: {\r\n          &quot;$schema&quot;: &quot;https://schema.management.azure.com/schemas/2019-04-01/deploymentTemplate.json#&quot;,\r\n          &quot;contentVersion&quot;: &quot;1.0.0.0&quot;,\r\n          &quot;parameters&quot;: {\r\n            &quot;p_vnetPeeringsLinkFile&quot;: {\r\n              &quot;type&quot;: &quot;array&quot;\r\n            },\r\n            &quot;p_tags&quot;: {\r\n              &quot;type&quot;: &quot;object&quot;,\r\n              &quot;defaultValue&quot;: {}\r\n            }\r\n          },\r\n          &quot;functions&quot;: [],\r\n          &quot;resources&quot;: [\r\n            {\r\n              &quot;type&quot;: &quot;Microsoft.Network/privateDnsZones&quot;,\r\n              &quot;apiVersion&quot;: &quot;2020-06-01&quot;,\r\n              &quot;name&quot;: &quot;[format(&#39;privatelink.file.{0}&#39;, environment().suffixes.storage)]&quot;,\r\n              &quot;tags&quot;: &quot;[parameters(&#39;p_tags&#39;)]&quot;,\r\n              &quot;location&quot;: &quot;Global&quot;\r\n            },\r\n            {\r\n              &quot;copy&quot;: {\r\n                &quot;name&quot;: &quot;vnl&quot;,\r\n                &quot;count&quot;: &quot;[length(parameters(&#39;p_vnetPeeringsLinkFile&#39;))]&quot;\r\n              },\r\n              &quot;type&quot;: &quot;Microsoft.Network/privateDnsZones/virtualNetworkLinks&quot;,\r\n              &quot;apiVersion&quot;: &quot;2020-06-01&quot;,\r\n              &quot;name&quot;: &quot;[format(&#39;{0}/{1}&#39;, format(&#39;privatelink.file.{0}&#39;, environment().suffixes.storage), last(split(parameters(&#39;p_vnetPeeringsLinkFile&#39;)[copyIndex()].id, &#39;/&#39;)))]&quot;,\r\n              &quot;tags&quot;: &quot;[parameters(&#39;p_tags&#39;)]&quot;,\r\n              &quot;location&quot;: &quot;Global&quot;,\r\n              &quot;properties&quot;: {\r\n                &quot;virtualNetwork&quot;: {\r\n                  &quot;id&quot;: &quot;[parameters(&#39;p_vnetPeeringsLinkFile&#39;)[copyIndex()].id]&quot;\r\n                },\r\n                &quot;registrationEnabled&quot;: false\r\n              },\r\n              &quot;dependsOn&quot;: [\r\n                &quot;[resourceId(&#39;Microsoft.Network/privateDnsZones&#39;, format(&#39;privatelink.file.{0}&#39;, environment().suffixes.storage))]&quot;\r\n              ]\r\n            },\r\n            {\r\n              &quot;type&quot;: &quot;Microsoft.Network/privateDnsZones&quot;,\r\n              &quot;apiVersion&quot;: &quot;2020-06-01&quot;,\r\n              &quot;name&quot;: &quot;[format(&#39;privatelink{0}&#39;, environment().suffixes.sqlServerHostname)]&quot;,\r\n              &quot;tags&quot;: &quot;[parameters(&#39;p_tags&#39;)]&quot;,\r\n              &quot;location&quot;: &quot;Global&quot;\r\n            }\r\n          ]\r\n        }\r\n      },\r\n      &quot;dependsOn&quot;: [\r\n        &quot;[subscriptionResourceId(&#39;Microsoft.Resources/resourceGroups&#39;, format(&#39;{0}-{1}-link-rsg&#39;, variables(&#39;v_shortLocation&#39;), subscription().displayName))]&quot;\r\n      ]\r\n    },\r\n    {\r\n      &quot;type&quot;: &quot;Microsoft.Resources/deployments&quot;,\r\n      &quot;apiVersion&quot;: &quot;2020-06-01&quot;,\r\n      &quot;name&quot;: &quot;privateStorage&quot;,\r\n      &quot;resourceGroup&quot;: &quot;[format(&#39;{0}-{1}-storage-rsg&#39;, variables(&#39;v_shortLocation&#39;), subscription().displayName)]&quot;,\r\n      &quot;properties&quot;: {\r\n        &quot;expressionEvaluationOptions&quot;: {\r\n          &quot;scope&quot;: &quot;inner&quot;\r\n        },\r\n        &quot;mode&quot;: &quot;Incremental&quot;,\r\n        &quot;parameters&quot;: {\r\n          &quot;p_tags&quot;: {\r\n            &quot;value&quot;: &quot;[variables(&#39;v_tags&#39;)]&quot;\r\n          },\r\n          &quot;p_vnetPeeringsStorage&quot;: {\r\n            &quot;value&quot;: &quot;[parameters(&#39;p_vnetPeeringsStorage&#39;)]&quot;\r\n          }\r\n        },\r\n        &quot;template&quot;: {\r\n          &quot;$schema&quot;: &quot;https://schema.management.azure.com/schemas/2019-04-01/deploymentTemplate.json#&quot;,\r\n          &quot;contentVersion&quot;: &quot;1.0.0.0&quot;,\r\n          &quot;parameters&quot;: {\r\n            &quot;p_tags&quot;: {\r\n              &quot;type&quot;: &quot;object&quot;,\r\n              &quot;defaultValue&quot;: {}\r\n            },\r\n            &quot;p_vnetPeeringsStorage&quot;: {\r\n              &quot;type&quot;: &quot;array&quot;\r\n            }\r\n          },\r\n          &quot;functions&quot;: [],\r\n          &quot;resources&quot;: [\r\n            {\r\n              &quot;type&quot;: &quot;Microsoft.Network/privateDnsZones&quot;,\r\n              &quot;apiVersion&quot;: &quot;2020-06-01&quot;,\r\n              &quot;name&quot;: &quot;storage.bld.local&quot;,\r\n              &quot;tags&quot;: &quot;[parameters(&#39;p_tags&#39;)]&quot;,\r\n              &quot;location&quot;: &quot;Global&quot;\r\n            },\r\n            {\r\n              &quot;copy&quot;: {\r\n                &quot;name&quot;: &quot;vnl&quot;,\r\n                &quot;count&quot;: &quot;[length(parameters(&#39;p_vnetPeeringsStorage&#39;))]&quot;\r\n              },\r\n              &quot;type&quot;: &quot;Microsoft.Network/privateDnsZones/virtualNetworkLinks&quot;,\r\n              &quot;apiVersion&quot;: &quot;2020-06-01&quot;,\r\n              &quot;name&quot;: &quot;[format(&#39;{0}/{1}&#39;, &#39;storage.bld.local&#39;, last(split(parameters(&#39;p_vnetPeeringsStorage&#39;)[copyIndex()].id, &#39;/&#39;)))]&quot;,\r\n              &quot;tags&quot;: &quot;[parameters(&#39;p_tags&#39;)]&quot;,\r\n              &quot;location&quot;: &quot;Global&quot;,\r\n              &quot;properties&quot;: {\r\n                &quot;virtualNetwork&quot;: {\r\n                  &quot;id&quot;: &quot;[parameters(&#39;p_vnetPeeringsStorage&#39;)[copyIndex()].id]&quot;\r\n                },\r\n                &quot;registrationEnabled&quot;: false\r\n              },\r\n              &quot;dependsOn&quot;: [\r\n                &quot;[resourceId(&#39;Microsoft.Network/privateDnsZones&#39;, &#39;storage.bld.local&#39;)]&quot;\r\n              ]\r\n            }\r\n          ]\r\n        }\r\n      },\r\n      &quot;dependsOn&quot;: [\r\n        &quot;[subscriptionResourceId(&#39;Microsoft.Resources/resourceGroups&#39;, format(&#39;{0}-{1}-storage-rsg&#39;, variables(&#39;v_shortLocation&#39;), subscription().displayName))]&quot;\r\n      ]\r\n    }\r\n  ]\r\n}\r\n~~~\r\n[Demo](https://jqplay.org/s/kYei1U2IC4)",
                "title": "Programmatically find and remove object in JSON object"
            },
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1648719710,
                "creation_date": 1648719710,
                "answer_id": 71690300,
                "question_id": 71689656,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "In pure PowerShell you can use a recursive function to clean out any `&quot;metadata&quot;` property from objects at any nesting depth.\r\n\r\n    function StripMetadata {\r\n        param($node)\r\n    \r\n        if ($node -is [pscustomobject]) {\r\n            foreach ($prop in $node.PSObject.Properties) {\r\n                if ($prop.Name -eq &quot;metadata&quot;) {\r\n                    $node.PSObject.Properties.Remove($prop.Name)\r\n                } else {\r\n                    StripMetadata $prop.Value\r\n                }\r\n            }\r\n        } elseif ($node -is [array]) {\r\n            foreach ($item in $node) {\r\n                StripMetadata $item\r\n            }\r\n        }\r\n    }\r\n\r\nNote that this modifies the object in-place, there is no result value.\r\n\r\n    $data = $yourJson | ConvertFrom-Json \r\n    StripMetadata $data\r\n    $result = $data | ConvertTo-Json -Depth 100 -Compress\r\n\r\n`$result` is (formatted):\r\n\r\n    {\r\n    \t&quot;$schema&quot;: &quot;https://schema.management.azure.com/schemas/2018-05-01/subscriptionDeploymentTemplate.json#&quot;,\r\n    \t&quot;contentVersion&quot;: &quot;1.0.0.0&quot;,\r\n    \t&quot;parameters&quot;: {\r\n    \t\t&quot;p_vnetPeeringsCompute&quot;: {\r\n    \t\t\t&quot;type&quot;: &quot;array&quot;\r\n    \t\t},\r\n    \t\t&quot;p_vnetPeeringsStorage&quot;: {\r\n    \t\t\t&quot;type&quot;: &quot;array&quot;\r\n    \t\t},\r\n    \t\t&quot;p_vnetPeeringsLinkFile&quot;: {\r\n    \t\t\t&quot;type&quot;: &quot;array&quot;\r\n    \t\t},\r\n    \t\t&quot;p_tags&quot;: {\r\n    \t\t\t&quot;type&quot;: &quot;object&quot;,\r\n    \t\t\t&quot;defaultValue&quot;: {}\r\n    \t\t}\r\n    \t},\r\n    \t&quot;functions&quot;: [],\r\n    \t&quot;variables&quot;: {\r\n    \t\t&quot;v_longLocation&quot;: &quot;uksouth&quot;,\r\n    \t\t&quot;v_shortLocation&quot;: &quot;uks&quot;,\r\n    \t\t&quot;v_templateDescription&quot;: &quot;Azure Private DNS Template Spec&quot;,\r\n    \t\t&quot;v_templateDisplayName&quot;: &quot;privateDns&quot;,\r\n    \t\t&quot;v_templateName&quot;: &quot;privateDns&quot;,\r\n    \t\t&quot;v_templateVersion&quot;: &quot;2.0.0&quot;,\r\n    \t\t&quot;v_templateTags&quot;: {\r\n    \t\t\t&quot;tsName&quot;: &quot;[variables(\\u0027v_templateName\\u0027)]&quot;,\r\n    \t\t\t&quot;tsVersion&quot;: &quot;[variables(\\u0027v_templateVersion\\u0027)]&quot;\r\n    \t\t},\r\n    \t\t&quot;v_tags&quot;: &quot;[union(parameters(\\u0027p_tags\\u0027), variables(\\u0027v_templateTags\\u0027))]&quot;\r\n    \t},\r\n    \t&quot;resources&quot;: [{\r\n    \t\t&quot;type&quot;: &quot;Microsoft.Resources/resourceGroups&quot;,\r\n    \t\t&quot;apiVersion&quot;: &quot;2021-01-01&quot;,\r\n    \t\t&quot;name&quot;: &quot;[format(\\u0027{0}-{1}-compute-rsg\\u0027, variables(\\u0027v_shortLocation\\u0027), subscription().displayName)]&quot;,\r\n    \t\t&quot;location&quot;: &quot;[variables(\\u0027v_longLocation\\u0027)]&quot;,\r\n    \t\t&quot;tags&quot;: &quot;[variables(\\u0027v_tags\\u0027)]&quot;\r\n    \t}, {\r\n    \t\t&quot;type&quot;: &quot;Microsoft.Resources/resourceGroups&quot;,\r\n    \t\t&quot;apiVersion&quot;: &quot;2021-01-01&quot;,\r\n    \t\t&quot;name&quot;: &quot;[format(\\u0027{0}-{1}-link-rsg\\u0027, variables(\\u0027v_shortLocation\\u0027), subscription().displayName)]&quot;,\r\n    \t\t&quot;location&quot;: &quot;[variables(\\u0027v_longLocation\\u0027)]&quot;,\r\n    \t\t&quot;tags&quot;: &quot;[variables(\\u0027v_tags\\u0027)]&quot;\r\n    \t}, {\r\n    \t\t&quot;type&quot;: &quot;Microsoft.Resources/resourceGroups&quot;,\r\n    \t\t&quot;apiVersion&quot;: &quot;2021-01-01&quot;,\r\n    \t\t&quot;name&quot;: &quot;[format(\\u0027{0}-{1}-storage-rsg\\u0027, variables(\\u0027v_shortLocation\\u0027), subscription().displayName)]&quot;,\r\n    \t\t&quot;location&quot;: &quot;[variables(\\u0027v_longLocation\\u0027)]&quot;,\r\n    \t\t&quot;tags&quot;: &quot;[variables(\\u0027v_tags\\u0027)]&quot;\r\n    \t}, {\r\n    \t\t&quot;type&quot;: &quot;Microsoft.Resources/deployments&quot;,\r\n    \t\t&quot;apiVersion&quot;: &quot;2020-06-01&quot;,\r\n    \t\t&quot;name&quot;: &quot;privateCompute&quot;,\r\n    \t\t&quot;resourceGroup&quot;: &quot;[format(\\u0027{0}-{1}-compute-rsg\\u0027, variables(\\u0027v_shortLocation\\u0027), subscription().displayName)]&quot;,\r\n    \t\t&quot;properties&quot;: {\r\n    \t\t\t&quot;expressionEvaluationOptions&quot;: {\r\n    \t\t\t\t&quot;scope&quot;: &quot;inner&quot;\r\n    \t\t\t},\r\n    \t\t\t&quot;mode&quot;: &quot;Incremental&quot;,\r\n    \t\t\t&quot;parameters&quot;: {\r\n    \t\t\t\t&quot;p_tags&quot;: {\r\n    \t\t\t\t\t&quot;value&quot;: &quot;[variables(\\u0027v_tags\\u0027)]&quot;\r\n    \t\t\t\t},\r\n    \t\t\t\t&quot;p_vnetPeeringsCompute&quot;: {\r\n    \t\t\t\t\t&quot;value&quot;: &quot;[parameters(\\u0027p_vnetPeeringsCompute\\u0027)]&quot;\r\n    \t\t\t\t}\r\n    \t\t\t},\r\n    \t\t\t&quot;template&quot;: {\r\n    \t\t\t\t&quot;$schema&quot;: &quot;https://schema.management.azure.com/schemas/2019-04-01/deploymentTemplate.json#&quot;,\r\n    \t\t\t\t&quot;contentVersion&quot;: &quot;1.0.0.0&quot;,\r\n    \t\t\t\t&quot;parameters&quot;: {\r\n    \t\t\t\t\t&quot;p_tags&quot;: {\r\n    \t\t\t\t\t\t&quot;type&quot;: &quot;object&quot;,\r\n    \t\t\t\t\t\t&quot;defaultValue&quot;: {}\r\n    \t\t\t\t\t},\r\n    \t\t\t\t\t&quot;p_vnetPeeringsCompute&quot;: {\r\n    \t\t\t\t\t\t&quot;type&quot;: &quot;array&quot;\r\n    \t\t\t\t\t}\r\n    \t\t\t\t},\r\n    \t\t\t\t&quot;functions&quot;: [],\r\n    \t\t\t\t&quot;resources&quot;: [{\r\n    \t\t\t\t\t&quot;type&quot;: &quot;Microsoft.Network/privateDnsZones&quot;,\r\n    \t\t\t\t\t&quot;apiVersion&quot;: &quot;2020-06-01&quot;,\r\n    \t\t\t\t\t&quot;name&quot;: &quot;compute.bld.local&quot;,\r\n    \t\t\t\t\t&quot;tags&quot;: &quot;[parameters(\\u0027p_tags\\u0027)]&quot;,\r\n    \t\t\t\t\t&quot;location&quot;: &quot;Global&quot;\r\n    \t\t\t\t}, {\r\n    \t\t\t\t\t&quot;copy&quot;: {\r\n    \t\t\t\t\t\t&quot;name&quot;: &quot;vnl&quot;,\r\n    \t\t\t\t\t\t&quot;count&quot;: &quot;[length(parameters(\\u0027p_vnetPeeringsCompute\\u0027))]&quot;\r\n    \t\t\t\t\t},\r\n    \t\t\t\t\t&quot;type&quot;: &quot;Microsoft.Network/privateDnsZones/virtualNetworkLinks&quot;,\r\n    \t\t\t\t\t&quot;apiVersion&quot;: &quot;2020-06-01&quot;,\r\n    \t\t\t\t\t&quot;name&quot;: &quot;[format(\\u0027{0}/{1}\\u0027, \\u0027compute.bld.local\\u0027, last(split(parameters(\\u0027p_vnetPeeringsCompute\\u0027)[copyIndex()].id, \\u0027/\\u0027)))]&quot;,\r\n    \t\t\t\t\t&quot;tags&quot;: &quot;[parameters(\\u0027p_tags\\u0027)]&quot;,\r\n    \t\t\t\t\t&quot;location&quot;: &quot;Global&quot;,\r\n    \t\t\t\t\t&quot;properties&quot;: {\r\n    \t\t\t\t\t\t&quot;virtualNetwork&quot;: {\r\n    \t\t\t\t\t\t\t&quot;id&quot;: &quot;[parameters(\\u0027p_vnetPeeringsCompute\\u0027)[copyIndex()].id]&quot;\r\n    \t\t\t\t\t\t},\r\n    \t\t\t\t\t\t&quot;registrationEnabled&quot;: false\r\n    \t\t\t\t\t},\r\n    \t\t\t\t\t&quot;dependsOn&quot;: [&quot;[resourceId(\\u0027Microsoft.Network/privateDnsZones\\u0027, \\u0027compute.bld.local\\u0027)]&quot;]\r\n    \t\t\t\t}]\r\n    \t\t\t}\r\n    \t\t},\r\n    \t\t&quot;dependsOn&quot;: [&quot;[subscriptionResourceId(\\u0027Microsoft.Resources/resourceGroups\\u0027, format(\\u0027{0}-{1}-compute-rsg\\u0027, variables(\\u0027v_shortLocation\\u0027), subscription().displayName))]&quot;]\r\n    \t}, {\r\n    \t\t&quot;type&quot;: &quot;Microsoft.Resources/deployments&quot;,\r\n    \t\t&quot;apiVersion&quot;: &quot;2020-06-01&quot;,\r\n    \t\t&quot;name&quot;: &quot;privateLink&quot;,\r\n    \t\t&quot;resourceGroup&quot;: &quot;[format(\\u0027{0}-{1}-link-rsg\\u0027, variables(\\u0027v_shortLocation\\u0027), subscription().displayName)]&quot;,\r\n    \t\t&quot;properties&quot;: {\r\n    \t\t\t&quot;expressionEvaluationOptions&quot;: {\r\n    \t\t\t\t&quot;scope&quot;: &quot;inner&quot;\r\n    \t\t\t},\r\n    \t\t\t&quot;mode&quot;: &quot;Incremental&quot;,\r\n    \t\t\t&quot;parameters&quot;: {\r\n    \t\t\t\t&quot;p_vnetPeeringsLinkFile&quot;: {\r\n    \t\t\t\t\t&quot;value&quot;: &quot;[parameters(\\u0027p_vnetPeeringsLinkFile\\u0027)]&quot;\r\n    \t\t\t\t},\r\n    \t\t\t\t&quot;p_tags&quot;: {\r\n    \t\t\t\t\t&quot;value&quot;: &quot;[variables(\\u0027v_tags\\u0027)]&quot;\r\n    \t\t\t\t}\r\n    \t\t\t},\r\n    \t\t\t&quot;template&quot;: {\r\n    \t\t\t\t&quot;$schema&quot;: &quot;https://schema.management.azure.com/schemas/2019-04-01/deploymentTemplate.json#&quot;,\r\n    \t\t\t\t&quot;contentVersion&quot;: &quot;1.0.0.0&quot;,\r\n    \t\t\t\t&quot;parameters&quot;: {\r\n    \t\t\t\t\t&quot;p_vnetPeeringsLinkFile&quot;: {\r\n    \t\t\t\t\t\t&quot;type&quot;: &quot;array&quot;\r\n    \t\t\t\t\t},\r\n    \t\t\t\t\t&quot;p_tags&quot;: {\r\n    \t\t\t\t\t\t&quot;type&quot;: &quot;object&quot;,\r\n    \t\t\t\t\t\t&quot;defaultValue&quot;: {}\r\n    \t\t\t\t\t}\r\n    \t\t\t\t},\r\n    \t\t\t\t&quot;functions&quot;: [],\r\n    \t\t\t\t&quot;resources&quot;: [{\r\n    \t\t\t\t\t&quot;type&quot;: &quot;Microsoft.Network/privateDnsZones&quot;,\r\n    \t\t\t\t\t&quot;apiVersion&quot;: &quot;2020-06-01&quot;,\r\n    \t\t\t\t\t&quot;name&quot;: &quot;[format(\\u0027privatelink.file.{0}\\u0027, environment().suffixes.storage)]&quot;,\r\n    \t\t\t\t\t&quot;tags&quot;: &quot;[parameters(\\u0027p_tags\\u0027)]&quot;,\r\n    \t\t\t\t\t&quot;location&quot;: &quot;Global&quot;\r\n    \t\t\t\t}, {\r\n    \t\t\t\t\t&quot;copy&quot;: {\r\n    \t\t\t\t\t\t&quot;name&quot;: &quot;vnl&quot;,\r\n    \t\t\t\t\t\t&quot;count&quot;: &quot;[length(parameters(\\u0027p_vnetPeeringsLinkFile\\u0027))]&quot;\r\n    \t\t\t\t\t},\r\n    \t\t\t\t\t&quot;type&quot;: &quot;Microsoft.Network/privateDnsZones/virtualNetworkLinks&quot;,\r\n    \t\t\t\t\t&quot;apiVersion&quot;: &quot;2020-06-01&quot;,\r\n    \t\t\t\t\t&quot;name&quot;: &quot;[format(\\u0027{0}/{1}\\u0027, format(\\u0027privatelink.file.{0}\\u0027, environment().suffixes.storage), last(split(parameters(\\u0027p_vnetPeeringsLinkFile\\u0027)[copyIndex()].id, \\u0027/\\u0027)))]&quot;,\r\n    \t\t\t\t\t&quot;tags&quot;: &quot;[parameters(\\u0027p_tags\\u0027)]&quot;,\r\n    \t\t\t\t\t&quot;location&quot;: &quot;Global&quot;,\r\n    \t\t\t\t\t&quot;properties&quot;: {\r\n    \t\t\t\t\t\t&quot;virtualNetwork&quot;: {\r\n    \t\t\t\t\t\t\t&quot;id&quot;: &quot;[parameters(\\u0027p_vnetPeeringsLinkFile\\u0027)[copyIndex()].id]&quot;\r\n    \t\t\t\t\t\t},\r\n    \t\t\t\t\t\t&quot;registrationEnabled&quot;: false\r\n    \t\t\t\t\t},\r\n    \t\t\t\t\t&quot;dependsOn&quot;: [&quot;[resourceId(\\u0027Microsoft.Network/privateDnsZones\\u0027, format(\\u0027privatelink.file.{0}\\u0027, environment().suffixes.storage))]&quot;]\r\n    \t\t\t\t}, {\r\n    \t\t\t\t\t&quot;type&quot;: &quot;Microsoft.Network/privateDnsZones&quot;,\r\n    \t\t\t\t\t&quot;apiVersion&quot;: &quot;2020-06-01&quot;,\r\n    \t\t\t\t\t&quot;name&quot;: &quot;[format(\\u0027privatelink{0}\\u0027, environment().suffixes.sqlServerHostname)]&quot;,\r\n    \t\t\t\t\t&quot;tags&quot;: &quot;[parameters(\\u0027p_tags\\u0027)]&quot;,\r\n    \t\t\t\t\t&quot;location&quot;: &quot;Global&quot;\r\n    \t\t\t\t}]\r\n    \t\t\t}\r\n    \t\t},\r\n    \t\t&quot;dependsOn&quot;: [&quot;[subscriptionResourceId(\\u0027Microsoft.Resources/resourceGroups\\u0027, format(\\u0027{0}-{1}-link-rsg\\u0027, variables(\\u0027v_shortLocation\\u0027), subscription().displayName))]&quot;]\r\n    \t}, {\r\n    \t\t&quot;type&quot;: &quot;Microsoft.Resources/deployments&quot;,\r\n    \t\t&quot;apiVersion&quot;: &quot;2020-06-01&quot;,\r\n    \t\t&quot;name&quot;: &quot;privateStorage&quot;,\r\n    \t\t&quot;resourceGroup&quot;: &quot;[format(\\u0027{0}-{1}-storage-rsg\\u0027, variables(\\u0027v_shortLocation\\u0027), subscription().displayName)]&quot;,\r\n    \t\t&quot;properties&quot;: {\r\n    \t\t\t&quot;expressionEvaluationOptions&quot;: {\r\n    \t\t\t\t&quot;scope&quot;: &quot;inner&quot;\r\n    \t\t\t},\r\n    \t\t\t&quot;mode&quot;: &quot;Incremental&quot;,\r\n    \t\t\t&quot;parameters&quot;: {\r\n    \t\t\t\t&quot;p_tags&quot;: {\r\n    \t\t\t\t\t&quot;value&quot;: &quot;[variables(\\u0027v_tags\\u0027)]&quot;\r\n    \t\t\t\t},\r\n    \t\t\t\t&quot;p_vnetPeeringsStorage&quot;: {\r\n    \t\t\t\t\t&quot;value&quot;: &quot;[parameters(\\u0027p_vnetPeeringsStorage\\u0027)]&quot;\r\n    \t\t\t\t}\r\n    \t\t\t},\r\n    \t\t\t&quot;template&quot;: {\r\n    \t\t\t\t&quot;$schema&quot;: &quot;https://schema.management.azure.com/schemas/2019-04-01/deploymentTemplate.json#&quot;,\r\n    \t\t\t\t&quot;contentVersion&quot;: &quot;1.0.0.0&quot;,\r\n    \t\t\t\t&quot;parameters&quot;: {\r\n    \t\t\t\t\t&quot;p_tags&quot;: {\r\n    \t\t\t\t\t\t&quot;type&quot;: &quot;object&quot;,\r\n    \t\t\t\t\t\t&quot;defaultValue&quot;: {}\r\n    \t\t\t\t\t},\r\n    \t\t\t\t\t&quot;p_vnetPeeringsStorage&quot;: {\r\n    \t\t\t\t\t\t&quot;type&quot;: &quot;array&quot;\r\n    \t\t\t\t\t}\r\n    \t\t\t\t},\r\n    \t\t\t\t&quot;functions&quot;: [],\r\n    \t\t\t\t&quot;resources&quot;: [{\r\n    \t\t\t\t\t&quot;type&quot;: &quot;Microsoft.Network/privateDnsZones&quot;,\r\n    \t\t\t\t\t&quot;apiVersion&quot;: &quot;2020-06-01&quot;,\r\n    \t\t\t\t\t&quot;name&quot;: &quot;storage.bld.local&quot;,\r\n    \t\t\t\t\t&quot;tags&quot;: &quot;[parameters(\\u0027p_tags\\u0027)]&quot;,\r\n    \t\t\t\t\t&quot;location&quot;: &quot;Global&quot;\r\n    \t\t\t\t}, {\r\n    \t\t\t\t\t&quot;copy&quot;: {\r\n    \t\t\t\t\t\t&quot;name&quot;: &quot;vnl&quot;,\r\n    \t\t\t\t\t\t&quot;count&quot;: &quot;[length(parameters(\\u0027p_vnetPeeringsStorage\\u0027))]&quot;\r\n    \t\t\t\t\t},\r\n    \t\t\t\t\t&quot;type&quot;: &quot;Microsoft.Network/privateDnsZones/virtualNetworkLinks&quot;,\r\n    \t\t\t\t\t&quot;apiVersion&quot;: &quot;2020-06-01&quot;,\r\n    \t\t\t\t\t&quot;name&quot;: &quot;[format(\\u0027{0}/{1}\\u0027, \\u0027storage.bld.local\\u0027, last(split(parameters(\\u0027p_vnetPeeringsStorage\\u0027)[copyIndex()].id, \\u0027/\\u0027)))]&quot;,\r\n    \t\t\t\t\t&quot;tags&quot;: &quot;[parameters(\\u0027p_tags\\u0027)]&quot;,\r\n    \t\t\t\t\t&quot;location&quot;: &quot;Global&quot;,\r\n    \t\t\t\t\t&quot;properties&quot;: {\r\n    \t\t\t\t\t\t&quot;virtualNetwork&quot;: {\r\n    \t\t\t\t\t\t\t&quot;id&quot;: &quot;[parameters(\\u0027p_vnetPeeringsStorage\\u0027)[copyIndex()].id]&quot;\r\n    \t\t\t\t\t\t},\r\n    \t\t\t\t\t\t&quot;registrationEnabled&quot;: false\r\n    \t\t\t\t\t},\r\n    \t\t\t\t\t&quot;dependsOn&quot;: [&quot;[resourceId(\\u0027Microsoft.Network/privateDnsZones\\u0027, \\u0027storage.bld.local\\u0027)]&quot;]\r\n    \t\t\t\t}]\r\n    \t\t\t}\r\n    \t\t},\r\n    \t\t&quot;dependsOn&quot;: [&quot;[subscriptionResourceId(\\u0027Microsoft.Resources/resourceGroups\\u0027, format(\\u0027{0}-{1}-storage-rsg\\u0027, variables(\\u0027v_shortLocation\\u0027), subscription().displayName))]&quot;]\r\n    \t}]\r\n    }\r\n\r\n",
                "title": "Programmatically find and remove object in JSON object"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1648719710,
        "creation_date": 1648717050,
        "question_id": 71689656,
        "body_markdown": "TL;DR  How do I programatically search for an object which may not be in the same location for each file and remove it?\r\n\r\nIt&#39;s fine if I know exactly where the object will be inside the JSON, but if it changes locations it&#39;s difficult to script. At the moment we programtically build an ARM template and push it to Azure, but before we do we compare it to see the version in the cloud differs from the newly generated file, and if it does, either replace it or create a new one based on its version.\r\n\r\nThe problem is when the template spec is built with a new version Bicep, which then injects that information into the JSON file, which then adjusts the `version` and `templateHash` values. Sadly, I cannot prevent this from happening.\r\n\r\n```json\r\n          &quot;metadata&quot;: {\r\n            &quot;_generator&quot;: {\r\n              &quot;name&quot;: &quot;bicep&quot;,\r\n              &quot;version&quot;: &quot;0.4.1008.15138&quot;,\r\n              &quot;templateHash&quot;: &quot;17593852815978663805&quot;\r\n            }\r\n```\r\n\r\nI used to do a `Compare-Object` to compare the two files after turning them into PowerShell Objects, but when the binary change came in it threw that idea out. Then I started looking into a more complicated PowerShell comparison where it would ignore lines based on patterns, but this morning that failed with some random error that I can&#39;t diagnose cos it&#39;s in Azure DevOps pipeline.\r\n\r\n```powershell\r\nWrite-Host &quot;`n`n##[debug]&#128030;`tLooking for changes  &#128064;&quot;\r\n$bicepAlteredLines  = @()\r\n$templateSpecChange = $false\r\n$patterns           = @(\r\n    &#39;\\&quot;version\\&quot;&#39;\r\n    &#39;\\&quot;templateHash\\&quot;&#39;\r\n)\r\n\r\n\r\n# newFile (${currentDir}.json) goes into old oldFile (portal.json)\r\n$compare = Compare-Object `\r\n    -ReferenceObject  $(Get-Content -Path &quot;./portal.json&quot;) `\r\n    -DifferenceObject $(Get-Content -Path &quot;./${currentDir}.json&quot;)\r\n\r\n# find the values where new goes into old\r\nforeach($result in ($compare | Where-Object { $_.SideIndicator -eq &quot;=&gt;&quot; })) {\r\n\r\n    # loop over patterns that should be excluded because of bicep binary update\r\n    foreach($pattern in $patterns) {\r\n\r\n    # for each bicep binary metadata pattern, check to see if the difference line matches that pattern\r\n        if($result.InputObject -match $pattern) {\r\n\r\n            # create variable of old oldFile which is referenced on the same line\r\n            $comparedResult = $compare |\r\n                Where-Object {\r\n                    ($_.SideIndicator -eq &quot;&lt;=&quot;) -and\r\n                    ($_.InputObject.ReadCount -eq $result.InputObject.Readcount)\r\n                }\r\n\r\n            # check to see if the variable also contains the pattern that should be excluded\r\n            if($comparedResult.InputObject -match $pattern) {\r\n\r\n                $selectSearch = Select-String -Path &quot;./${currentDir}.json&quot; -Pattern $pattern -Context 2 |\r\n                    Where-Object {\r\n                        $_.LineNumber -eq $result.InputObject.Readcount\r\n                    }\r\n\r\n                # validate if the pattern relates to bicep and not just random string that looks like what we want\r\n                foreach($item in $selectSearch) {\r\n\r\n                    # we do this by checking the lines above the pattern, as this will contain the word &#39;bicep&#39;:\r\n                    # &quot;metadata&quot;: {\r\n                    #     &quot;_generator&quot;: {\r\n                    #       &quot;name&quot;: &quot;bicep&quot;,\r\n                    #       &quot;version&quot;: &quot;0.4.1008.15138&quot;,                &lt;- if this line was the pattern, 1 up contains &#39;bicep&#39;\r\n                    #       &quot;templateHash&quot;: &quot;9914162448113979868&quot;       &lt;- if this line was the pattern, 2 up contains &#39;bicep&#39;\r\n                    #     }\r\n                    foreach($bicepCheck in $item.Context.PreContext) {\r\n                        if($bicepCheck -match &quot;bicep&quot;) {\r\n\r\n                            # if &#39;bicep&#39; has been found, add array for readout later\r\n                            $bicepAlteredLines += $item.LineNumber\r\n                            Write-Host &quot;Bicep binary change found at line $($item.LineNumber) for pattern ${pattern}. Adding to ignore list.&quot;\r\n                        }\r\n                        else {\r\n                            # if the variable doesn&#39;t contain &#39;bicep&#39;, then obviously there&#39;s been a change in the JSON layout\r\n                            $templateSpecChange = $true\r\n                        }\r\n                    }\r\n                }\r\n            }\r\n            else {\r\n                # if the variable doesn&#39;t contain the pattern, then obviously there&#39;s been a change in the JSON layout\r\n                $templateSpecChange = $true\r\n            }\r\n        }\r\n        else {\r\n            # if the variable doesn&#39;t contain the pattern, then obviously there&#39;s been a change in the JSON layout\r\n            $templateSpecChange = $true\r\n        }\r\n    }\r\n}\r\n\r\n\r\nWrite-Host &quot;`nThe following lines are ignored due Bicep binary change:&quot;\r\n$bicepAlteredLines | Sort-Object -Unique\r\n\r\nWrite-Host &quot;`n`n##[debug]&#128030;`tDifference found in file comparison = ${templateSpecChange}&quot;\r\n\r\n```\r\n\r\nSo I would like to either;\r\n- ignore the metadata and only compare the surrounding information\r\n- remove the metadata object completely in all instances it has placed itself (ideal solution)\r\n\r\n```json\r\n{\r\n  &quot;$schema&quot;: &quot;https://schema.management.azure.com/schemas/2018-05-01/subscriptionDeploymentTemplate.json#&quot;,\r\n  &quot;contentVersion&quot;: &quot;1.0.0.0&quot;,\r\n  &quot;metadata&quot;: {\r\n    &quot;_generator&quot;: {\r\n      &quot;name&quot;: &quot;bicep&quot;,\r\n      &quot;version&quot;: &quot;0.4.1111.15138&quot;,\r\n      &quot;templateHash&quot;: &quot;asdfasdfasdf&quot;\r\n    }\r\n  },\r\n  &quot;parameters&quot;: {\r\n    &quot;p_vnetPeeringsCompute&quot;: {\r\n      &quot;type&quot;: &quot;array&quot;,\r\n      &quot;metadata&quot;: {\r\n        &quot;description&quot;: &quot;List of peerings to the virtual network.&quot;\r\n      }\r\n    },\r\n    &quot;p_vnetPeeringsStorage&quot;: {\r\n      &quot;type&quot;: &quot;array&quot;,\r\n      &quot;metadata&quot;: {\r\n        &quot;description&quot;: &quot;List of peerings to the virtual network.&quot;\r\n      }\r\n    },\r\n    &quot;p_vnetPeeringsLinkFile&quot;: {\r\n      &quot;type&quot;: &quot;array&quot;,\r\n      &quot;metadata&quot;: {\r\n        &quot;description&quot;: &quot;List of peerings to the virtual network.&quot;\r\n      }\r\n    },\r\n    &quot;p_tags&quot;: {\r\n      &quot;type&quot;: &quot;object&quot;,\r\n      &quot;defaultValue&quot;: {},\r\n      &quot;metadata&quot;: {\r\n        &quot;description&quot;: &quot;List of tags applied to resources.&quot;\r\n      }\r\n    }\r\n  },\r\n  &quot;functions&quot;: [],\r\n  &quot;variables&quot;: {\r\n    &quot;v_longLocation&quot;: &quot;uksouth&quot;,\r\n    &quot;v_shortLocation&quot;: &quot;uks&quot;,\r\n    &quot;v_templateDescription&quot;: &quot;Azure Private DNS Template Spec&quot;,\r\n    &quot;v_templateDisplayName&quot;: &quot;privateDns&quot;,\r\n    &quot;v_templateName&quot;: &quot;privateDns&quot;,\r\n    &quot;v_templateVersion&quot;: &quot;2.0.0&quot;,\r\n    &quot;v_templateTags&quot;: {\r\n      &quot;tsName&quot;: &quot;[variables(&#39;v_templateName&#39;)]&quot;,\r\n      &quot;tsVersion&quot;: &quot;[variables(&#39;v_templateVersion&#39;)]&quot;\r\n    },\r\n    &quot;v_tags&quot;: &quot;[union(parameters(&#39;p_tags&#39;), variables(&#39;v_templateTags&#39;))]&quot;\r\n  },\r\n  &quot;resources&quot;: [\r\n    {\r\n      &quot;type&quot;: &quot;Microsoft.Resources/resourceGroups&quot;,\r\n      &quot;apiVersion&quot;: &quot;2021-01-01&quot;,\r\n      &quot;name&quot;: &quot;[format(&#39;{0}-{1}-compute-rsg&#39;, variables(&#39;v_shortLocation&#39;), subscription().displayName)]&quot;,\r\n      &quot;location&quot;: &quot;[variables(&#39;v_longLocation&#39;)]&quot;,\r\n      &quot;tags&quot;: &quot;[variables(&#39;v_tags&#39;)]&quot;\r\n    },\r\n    {\r\n      &quot;type&quot;: &quot;Microsoft.Resources/resourceGroups&quot;,\r\n      &quot;apiVersion&quot;: &quot;2021-01-01&quot;,\r\n      &quot;name&quot;: &quot;[format(&#39;{0}-{1}-link-rsg&#39;, variables(&#39;v_shortLocation&#39;), subscription().displayName)]&quot;,\r\n      &quot;location&quot;: &quot;[variables(&#39;v_longLocation&#39;)]&quot;,\r\n      &quot;tags&quot;: &quot;[variables(&#39;v_tags&#39;)]&quot;\r\n    },\r\n    {\r\n      &quot;type&quot;: &quot;Microsoft.Resources/resourceGroups&quot;,\r\n      &quot;apiVersion&quot;: &quot;2021-01-01&quot;,\r\n      &quot;name&quot;: &quot;[format(&#39;{0}-{1}-storage-rsg&#39;, variables(&#39;v_shortLocation&#39;), subscription().displayName)]&quot;,\r\n      &quot;location&quot;: &quot;[variables(&#39;v_longLocation&#39;)]&quot;,\r\n      &quot;tags&quot;: &quot;[variables(&#39;v_tags&#39;)]&quot;\r\n    },\r\n    {\r\n      &quot;type&quot;: &quot;Microsoft.Resources/deployments&quot;,\r\n      &quot;apiVersion&quot;: &quot;2020-06-01&quot;,\r\n      &quot;name&quot;: &quot;privateCompute&quot;,\r\n      &quot;resourceGroup&quot;: &quot;[format(&#39;{0}-{1}-compute-rsg&#39;, variables(&#39;v_shortLocation&#39;), subscription().displayName)]&quot;,\r\n      &quot;properties&quot;: {\r\n        &quot;expressionEvaluationOptions&quot;: {\r\n          &quot;scope&quot;: &quot;inner&quot;\r\n        },\r\n        &quot;mode&quot;: &quot;Incremental&quot;,\r\n        &quot;parameters&quot;: {\r\n          &quot;p_tags&quot;: {\r\n            &quot;value&quot;: &quot;[variables(&#39;v_tags&#39;)]&quot;\r\n          },\r\n          &quot;p_vnetPeeringsCompute&quot;: {\r\n            &quot;value&quot;: &quot;[parameters(&#39;p_vnetPeeringsCompute&#39;)]&quot;\r\n          }\r\n        },\r\n        &quot;template&quot;: {\r\n          &quot;$schema&quot;: &quot;https://schema.management.azure.com/schemas/2019-04-01/deploymentTemplate.json#&quot;,\r\n          &quot;contentVersion&quot;: &quot;1.0.0.0&quot;,\r\n          &quot;metadata&quot;: {\r\n            &quot;_generator&quot;: {\r\n              &quot;name&quot;: &quot;bicep&quot;,\r\n              &quot;version&quot;: &quot;0.4.1008.15138&quot;,\r\n              &quot;templateHash&quot;: &quot;17593852815978663805&quot;\r\n            }\r\n          },\r\n          &quot;parameters&quot;: {\r\n            &quot;p_tags&quot;: {\r\n              &quot;type&quot;: &quot;object&quot;,\r\n              &quot;defaultValue&quot;: {},\r\n              &quot;metadata&quot;: {\r\n                &quot;description&quot;: &quot;List of tags applied to resources.&quot;\r\n              }\r\n            },\r\n            &quot;p_vnetPeeringsCompute&quot;: {\r\n              &quot;type&quot;: &quot;array&quot;,\r\n              &quot;metadata&quot;: {\r\n                &quot;description&quot;: &quot;List of peerings to the virtual network.&quot;\r\n              }\r\n            }\r\n          },\r\n          &quot;functions&quot;: [],\r\n          &quot;resources&quot;: [\r\n            {\r\n              &quot;type&quot;: &quot;Microsoft.Network/privateDnsZones&quot;,\r\n              &quot;apiVersion&quot;: &quot;2020-06-01&quot;,\r\n              &quot;name&quot;: &quot;compute.bld.local&quot;,\r\n              &quot;tags&quot;: &quot;[parameters(&#39;p_tags&#39;)]&quot;,\r\n              &quot;location&quot;: &quot;Global&quot;\r\n            },\r\n            {\r\n              &quot;copy&quot;: {\r\n                &quot;name&quot;: &quot;vnl&quot;,\r\n                &quot;count&quot;: &quot;[length(parameters(&#39;p_vnetPeeringsCompute&#39;))]&quot;\r\n              },\r\n              &quot;type&quot;: &quot;Microsoft.Network/privateDnsZones/virtualNetworkLinks&quot;,\r\n              &quot;apiVersion&quot;: &quot;2020-06-01&quot;,\r\n              &quot;name&quot;: &quot;[format(&#39;{0}/{1}&#39;, &#39;compute.bld.local&#39;, last(split(parameters(&#39;p_vnetPeeringsCompute&#39;)[copyIndex()].id, &#39;/&#39;)))]&quot;,\r\n              &quot;tags&quot;: &quot;[parameters(&#39;p_tags&#39;)]&quot;,\r\n              &quot;location&quot;: &quot;Global&quot;,\r\n              &quot;properties&quot;: {\r\n                &quot;virtualNetwork&quot;: {\r\n                  &quot;id&quot;: &quot;[parameters(&#39;p_vnetPeeringsCompute&#39;)[copyIndex()].id]&quot;\r\n                },\r\n                &quot;registrationEnabled&quot;: false\r\n              },\r\n              &quot;dependsOn&quot;: [\r\n                &quot;[resourceId(&#39;Microsoft.Network/privateDnsZones&#39;, &#39;compute.bld.local&#39;)]&quot;\r\n              ]\r\n            }\r\n          ]\r\n        }\r\n      },\r\n      &quot;dependsOn&quot;: [\r\n        &quot;[subscriptionResourceId(&#39;Microsoft.Resources/resourceGroups&#39;, format(&#39;{0}-{1}-compute-rsg&#39;, variables(&#39;v_shortLocation&#39;), subscription().displayName))]&quot;\r\n      ]\r\n    },\r\n    {\r\n      &quot;type&quot;: &quot;Microsoft.Resources/deployments&quot;,\r\n      &quot;apiVersion&quot;: &quot;2020-06-01&quot;,\r\n      &quot;name&quot;: &quot;privateLink&quot;,\r\n      &quot;resourceGroup&quot;: &quot;[format(&#39;{0}-{1}-link-rsg&#39;, variables(&#39;v_shortLocation&#39;), subscription().displayName)]&quot;,\r\n      &quot;properties&quot;: {\r\n        &quot;expressionEvaluationOptions&quot;: {\r\n          &quot;scope&quot;: &quot;inner&quot;\r\n        },\r\n        &quot;mode&quot;: &quot;Incremental&quot;,\r\n        &quot;parameters&quot;: {\r\n          &quot;p_vnetPeeringsLinkFile&quot;: {\r\n            &quot;value&quot;: &quot;[parameters(&#39;p_vnetPeeringsLinkFile&#39;)]&quot;\r\n          },\r\n          &quot;p_tags&quot;: {\r\n            &quot;value&quot;: &quot;[variables(&#39;v_tags&#39;)]&quot;\r\n          }\r\n        },\r\n        &quot;template&quot;: {\r\n          &quot;$schema&quot;: &quot;https://schema.management.azure.com/schemas/2019-04-01/deploymentTemplate.json#&quot;,\r\n          &quot;contentVersion&quot;: &quot;1.0.0.0&quot;,\r\n          &quot;metadata&quot;: {\r\n            &quot;_generator&quot;: {\r\n              &quot;name&quot;: &quot;bicep&quot;,\r\n              &quot;version&quot;: &quot;0.4.1008.15138&quot;,\r\n              &quot;templateHash&quot;: &quot;14603239311913824090&quot;\r\n            }\r\n          },\r\n          &quot;parameters&quot;: {\r\n            &quot;p_vnetPeeringsLinkFile&quot;: {\r\n              &quot;type&quot;: &quot;array&quot;,\r\n              &quot;metadata&quot;: {\r\n                &quot;description&quot;: &quot;List of peerings to the virtual network.&quot;\r\n              }\r\n            },\r\n            &quot;p_tags&quot;: {\r\n              &quot;type&quot;: &quot;object&quot;,\r\n              &quot;defaultValue&quot;: {},\r\n              &quot;metadata&quot;: {\r\n                &quot;description&quot;: &quot;List of tags applied to resources.&quot;\r\n              }\r\n            }\r\n          },\r\n          &quot;functions&quot;: [],\r\n          &quot;resources&quot;: [\r\n            {\r\n              &quot;type&quot;: &quot;Microsoft.Network/privateDnsZones&quot;,\r\n              &quot;apiVersion&quot;: &quot;2020-06-01&quot;,\r\n              &quot;name&quot;: &quot;[format(&#39;privatelink.file.{0}&#39;, environment().suffixes.storage)]&quot;,\r\n              &quot;tags&quot;: &quot;[parameters(&#39;p_tags&#39;)]&quot;,\r\n              &quot;location&quot;: &quot;Global&quot;\r\n            },\r\n            {\r\n              &quot;copy&quot;: {\r\n                &quot;name&quot;: &quot;vnl&quot;,\r\n                &quot;count&quot;: &quot;[length(parameters(&#39;p_vnetPeeringsLinkFile&#39;))]&quot;\r\n              },\r\n              &quot;type&quot;: &quot;Microsoft.Network/privateDnsZones/virtualNetworkLinks&quot;,\r\n              &quot;apiVersion&quot;: &quot;2020-06-01&quot;,\r\n              &quot;name&quot;: &quot;[format(&#39;{0}/{1}&#39;, format(&#39;privatelink.file.{0}&#39;, environment().suffixes.storage), last(split(parameters(&#39;p_vnetPeeringsLinkFile&#39;)[copyIndex()].id, &#39;/&#39;)))]&quot;,\r\n              &quot;tags&quot;: &quot;[parameters(&#39;p_tags&#39;)]&quot;,\r\n              &quot;location&quot;: &quot;Global&quot;,\r\n              &quot;properties&quot;: {\r\n                &quot;virtualNetwork&quot;: {\r\n                  &quot;id&quot;: &quot;[parameters(&#39;p_vnetPeeringsLinkFile&#39;)[copyIndex()].id]&quot;\r\n                },\r\n                &quot;registrationEnabled&quot;: false\r\n              },\r\n              &quot;dependsOn&quot;: [\r\n                &quot;[resourceId(&#39;Microsoft.Network/privateDnsZones&#39;, format(&#39;privatelink.file.{0}&#39;, environment().suffixes.storage))]&quot;\r\n              ]\r\n            },\r\n            {\r\n              &quot;type&quot;: &quot;Microsoft.Network/privateDnsZones&quot;,\r\n              &quot;apiVersion&quot;: &quot;2020-06-01&quot;,\r\n              &quot;name&quot;: &quot;[format(&#39;privatelink{0}&#39;, environment().suffixes.sqlServerHostname)]&quot;,\r\n              &quot;tags&quot;: &quot;[parameters(&#39;p_tags&#39;)]&quot;,\r\n              &quot;location&quot;: &quot;Global&quot;\r\n            }\r\n          ]\r\n        }\r\n      },\r\n      &quot;dependsOn&quot;: [\r\n        &quot;[subscriptionResourceId(&#39;Microsoft.Resources/resourceGroups&#39;, format(&#39;{0}-{1}-link-rsg&#39;, variables(&#39;v_shortLocation&#39;), subscription().displayName))]&quot;\r\n      ]\r\n    },\r\n    {\r\n      &quot;type&quot;: &quot;Microsoft.Resources/deployments&quot;,\r\n      &quot;apiVersion&quot;: &quot;2020-06-01&quot;,\r\n      &quot;name&quot;: &quot;privateStorage&quot;,\r\n      &quot;resourceGroup&quot;: &quot;[format(&#39;{0}-{1}-storage-rsg&#39;, variables(&#39;v_shortLocation&#39;), subscription().displayName)]&quot;,\r\n      &quot;properties&quot;: {\r\n        &quot;expressionEvaluationOptions&quot;: {\r\n          &quot;scope&quot;: &quot;inner&quot;\r\n        },\r\n        &quot;mode&quot;: &quot;Incremental&quot;,\r\n        &quot;parameters&quot;: {\r\n          &quot;p_tags&quot;: {\r\n            &quot;value&quot;: &quot;[variables(&#39;v_tags&#39;)]&quot;\r\n          },\r\n          &quot;p_vnetPeeringsStorage&quot;: {\r\n            &quot;value&quot;: &quot;[parameters(&#39;p_vnetPeeringsStorage&#39;)]&quot;\r\n          }\r\n        },\r\n        &quot;template&quot;: {\r\n          &quot;$schema&quot;: &quot;https://schema.management.azure.com/schemas/2019-04-01/deploymentTemplate.json#&quot;,\r\n          &quot;contentVersion&quot;: &quot;1.0.0.0&quot;,\r\n          &quot;metadata&quot;: {\r\n            &quot;_generator&quot;: {\r\n              &quot;name&quot;: &quot;bicep&quot;,\r\n              &quot;version&quot;: &quot;0.4.1008.15138&quot;,\r\n              &quot;templateHash&quot;: &quot;12131108274222647600&quot;\r\n            }\r\n          },\r\n          &quot;parameters&quot;: {\r\n            &quot;p_tags&quot;: {\r\n              &quot;type&quot;: &quot;object&quot;,\r\n              &quot;defaultValue&quot;: {},\r\n              &quot;metadata&quot;: {\r\n                &quot;description&quot;: &quot;List of tags applied to resources.&quot;\r\n              }\r\n            },\r\n            &quot;p_vnetPeeringsStorage&quot;: {\r\n              &quot;type&quot;: &quot;array&quot;,\r\n              &quot;metadata&quot;: {\r\n                &quot;description&quot;: &quot;List of peerings to the virtual network.&quot;\r\n              }\r\n            }\r\n          },\r\n          &quot;functions&quot;: [],\r\n          &quot;resources&quot;: [\r\n            {\r\n              &quot;type&quot;: &quot;Microsoft.Network/privateDnsZones&quot;,\r\n              &quot;apiVersion&quot;: &quot;2020-06-01&quot;,\r\n              &quot;name&quot;: &quot;storage.bld.local&quot;,\r\n              &quot;tags&quot;: &quot;[parameters(&#39;p_tags&#39;)]&quot;,\r\n              &quot;location&quot;: &quot;Global&quot;\r\n            },\r\n            {\r\n              &quot;copy&quot;: {\r\n                &quot;name&quot;: &quot;vnl&quot;,\r\n                &quot;count&quot;: &quot;[length(parameters(&#39;p_vnetPeeringsStorage&#39;))]&quot;\r\n              },\r\n              &quot;type&quot;: &quot;Microsoft.Network/privateDnsZones/virtualNetworkLinks&quot;,\r\n              &quot;apiVersion&quot;: &quot;2020-06-01&quot;,\r\n              &quot;name&quot;: &quot;[format(&#39;{0}/{1}&#39;, &#39;storage.bld.local&#39;, last(split(parameters(&#39;p_vnetPeeringsStorage&#39;)[copyIndex()].id, &#39;/&#39;)))]&quot;,\r\n              &quot;tags&quot;: &quot;[parameters(&#39;p_tags&#39;)]&quot;,\r\n              &quot;location&quot;: &quot;Global&quot;,\r\n              &quot;properties&quot;: {\r\n                &quot;virtualNetwork&quot;: {\r\n                  &quot;id&quot;: &quot;[parameters(&#39;p_vnetPeeringsStorage&#39;)[copyIndex()].id]&quot;\r\n                },\r\n                &quot;registrationEnabled&quot;: false\r\n              },\r\n              &quot;dependsOn&quot;: [\r\n                &quot;[resourceId(&#39;Microsoft.Network/privateDnsZones&#39;, &#39;storage.bld.local&#39;)]&quot;\r\n              ]\r\n            }\r\n          ]\r\n        }\r\n      },\r\n      &quot;dependsOn&quot;: [\r\n        &quot;[subscriptionResourceId(&#39;Microsoft.Resources/resourceGroups&#39;, format(&#39;{0}-{1}-storage-rsg&#39;, variables(&#39;v_shortLocation&#39;), subscription().displayName))]&quot;\r\n      ]\r\n    }\r\n  ]\r\n}\r\n```\r\n\r\nAt the moment I know it&#39;s in 2 standard locations, but I am not sure if it will appear in others.\r\n\r\n```\r\n➜ $asdf.resources.properties.template.metadata\r\n\r\n_generator\r\n----------\r\n@{name=bicep; version=0.4.1008.15138; templateHash=17593852815978663805}\r\n@{name=bicep; version=0.4.1008.15138; templateHash=14603239311913824090}\r\n@{name=bicep; version=0.4.1008.15138; templateHash=12131108274222647600}\r\n\r\ncompare\r\n➜ $asdf.metadata\r\n\r\n_generator\r\n----------\r\n@{name=bicep; version=0.4.1111.15138; templateHash=asdfasdfasdf}\r\n```\r\n\r\nIt would be more ideal if there was an option in PowerShell to find all instances of objects named `metadata` and remove them, but I cannot find an option like this in PowerShell. Any thoughts/ideas would be greatful.\r\n\r\nBefore anyone mentions that I should just remove all instances of `$asdf.resources.properties.template.metadata` and `$asdf.metadata`, I am wondering how to search for any instances of `*.metadata` that would/could be in other locations that may or may not come up. More of a &quot;look for all of `*.metadata` and remove from object, where ever it is&quot;.",
        "link": "https://stackoverflow.com/questions/71689656/programmatically-find-and-remove-object-in-json-object",
        "title": "Programmatically find and remove object in JSON object"
    },
    {
        "tags": [
            "json",
            "select",
            "key",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1648766745,
                "creation_date": 1648766745,
                "answer_id": 71699917,
                "question_id": 71699864,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Your desired output is not valid JSON.\r\n\r\nDo you want the words form an array under the value of the `.name` field?\r\n~~~sh\r\njq &#39;.parts[] | {(.name): (.items | split(&quot; &quot;))}&#39;\r\n~~~\r\n~~~json\r\n{\r\n  &quot;core&quot;: [\r\n    &quot;garbage&quot;,\r\n    &quot;with&quot;,\r\n    &quot;ITEM1&quot;,\r\n    &quot;ITEM2&quot;,\r\n    &quot;and&quot;,\r\n    &quot;more&quot;\r\n  ]\r\n}\r\n{\r\n  &quot;misc&quot;: [\r\n    &quot;ITEM3&quot;,\r\n    &quot;ITEM4&quot;,\r\n    &quot;ITEM5&quot;,\r\n    &quot;bla&quot;,\r\n    &quot;bla&quot;\r\n  ]\r\n}\r\n~~~\r\n[Demo](https://jqplay.org/s/TfgVhWyUrn)\r\n\r\nOr do you want each word to form a separate object?\r\n~~~sh\r\njq &#39;.parts[] | (.items | split(&quot; &quot;))[] as $word | {(.name): $word}&#39;\r\n~~~\r\n~~~json\r\n{&quot;core&quot;:&quot;garbage&quot;}\r\n{&quot;core&quot;:&quot;with&quot;}\r\n{&quot;core&quot;:&quot;ITEM1&quot;}\r\n{&quot;core&quot;:&quot;ITEM2&quot;}\r\n{&quot;core&quot;:&quot;and&quot;}\r\n{&quot;core&quot;:&quot;more&quot;}\r\n{&quot;misc&quot;:&quot;ITEM3&quot;}\r\n{&quot;misc&quot;:&quot;ITEM4&quot;}\r\n{&quot;misc&quot;:&quot;ITEM5&quot;}\r\n{&quot;misc&quot;:&quot;bla&quot;}\r\n{&quot;misc&quot;:&quot;bla&quot;}\r\n~~~\r\n[Demo](https://jqplay.org/s/2WQfbV5RSu)\r\n\r\nTo only capture words that match the regex `ITEM\\d+`, you could employ the `scan` function instead of splitting:\r\n~~~sh\r\njq &#39;.parts[] | {(.name): .items | scan(&quot;ITEM\\\\d+&quot;)}&#39;\r\n~~~\r\n~~~json\r\n{&quot;core&quot;:&quot;ITEM1&quot;}\r\n{&quot;core&quot;:&quot;ITEM2&quot;}\r\n{&quot;misc&quot;:&quot;ITEM3&quot;}\r\n{&quot;misc&quot;:&quot;ITEM4&quot;}\r\n{&quot;misc&quot;:&quot;ITEM5&quot;}\r\n~~~\r\n[Demo](https://jqplay.org/s/-aZmbO0BOC)",
                "title": "Extract certain array elements with its parent keys using jq"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1648767326,
                "creation_date": 1648767326,
                "answer_id": 71700002,
                "question_id": 71699864,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Building on your attempt, we could try:\r\n```\r\n.parts\r\n| .[]\r\n| .items |= (split(&quot; &quot;) | map(select(test(&quot;ITEM&quot;))))\r\n| {(.name): .items[]}\r\n```\r\n\r\nThis produces a stream of objects such as `{&quot;core&quot;:&quot;ITEM1&quot;}`. If you really want the non-JSON output shown in the Q, it&#39;s easy enough to add the additional step.\r\n",
                "title": "Extract certain array elements with its parent keys using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1648779166,
        "creation_date": 1648766213,
        "last_edit_date": 1648779166,
        "question_id": 71699864,
        "body_markdown": "I would like to know how to use jq to extract patterns from a .json file\r\n\r\n    echo &#39;{&quot;parts&quot;: [{&quot;name&quot;:&quot;core&quot;,&quot;items&quot;:&quot;garbage with ITEM1 ITEM2 and more&quot;},{&quot;name&quot;:&quot;misc&quot;,&quot;items&quot;:&quot;ITEM3 ITEM4 ITEM5 bla bla&quot;} ]}&#39; | jq &#39;.parts | .[] | .items |=split(&quot; &quot;)&#39;\r\n    {\r\n      &quot;name&quot;: &quot;core&quot;,\r\n      &quot;items&quot;: [\r\n        &quot;garbage&quot;,\r\n        &quot;with&quot;,\r\n        &quot;ITEM1&quot;,\r\n        &quot;ITEM2&quot;,\r\n        &quot;and&quot;,\r\n        &quot;more&quot;\r\n      ]\r\n    }\r\n    {\r\n      &quot;name&quot;: &quot;misc&quot;,\r\n      &quot;items&quot;: [\r\n        &quot;ITEM3&quot;,\r\n        &quot;ITEM4&quot;,\r\n        &quot;ITEM5&quot;,\r\n        &quot;bla&quot;,\r\n        &quot;bla&quot;\r\n      ]\r\n    }\r\n\r\nI think in splitting the items, but I don&#39;t know how to extract each ITEMx.\r\n\r\nI want to obtain this output:\r\n\r\n    { &quot;core&quot;,&quot;ITEM1&quot; }\r\n    { &quot;core&quot;,&quot;ITEM2&quot; }\r\n    { &quot;misc&quot;,&quot;ITEM3&quot; } \r\n    { &quot;misc&quot;,&quot;ITEM4&quot; }\r\n    { &quot;misc&quot;,&quot;ITEM5&quot; }  \r\n\r\n  \r\n\r\n",
        "link": "https://stackoverflow.com/questions/71699864/extract-certain-array-elements-with-its-parent-keys-using-jq",
        "title": "Extract certain array elements with its parent keys using jq"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1648823360,
                "last_edit_date": 1648823360,
                "creation_date": 1648822220,
                "answer_id": 71708275,
                "question_id": 71708143,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You could iterate over the items using [variable binding](https://stedolan.github.io/jq/manual/#Variable/SymbolicBindingOperator:...as$identifier|...) with `as`.\r\n\r\nThen either update `.b` to have the value of its items using the [update operator](https://stedolan.github.io/jq/manual/#Update-assignment:|=) `|=`:\r\n~~~sh\r\njq &#39;map([.b[] as $b | .b |= $b])&#39;\r\n~~~\r\n[Demo](https://jqplay.org/s/MeKpfPv_Z6)\r\n\r\nOr create completely new objects from data collected:\r\n~~~sh\r\njq &#39;map(.a as $a | [.b[] as $b | {$a,$b}])&#39;\r\n~~~\r\n[Demo](https://jqplay.org/s/EUt9SSFeV7)\r\n\r\n~~~json\r\n[\r\n  [\r\n    {\r\n      &quot;a&quot;: 1,\r\n      &quot;b&quot;: 2\r\n    },\r\n    {\r\n      &quot;a&quot;: 1,\r\n      &quot;b&quot;: 3\r\n    }\r\n  ],\r\n  [\r\n    {\r\n      &quot;a&quot;: 4,\r\n      &quot;b&quot;: 5\r\n    },\r\n    {\r\n      &quot;a&quot;: 4,\r\n      &quot;b&quot;: 6\r\n    }\r\n  ]\r\n]\r\n~~~\r\n",
                "title": "How to bring outer values inside an array iteration"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1648841265,
                "last_edit_date": 1648841265,
                "creation_date": 1648828061,
                "answer_id": 71709623,
                "question_id": 71708143,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Try this :\r\n\r\n```\r\njq &#39;map([{a,b:.b[]}])&#39;\r\n```\r\n\r\nAs @pmf pointed out, you can also update object :\r\n\r\n```\r\njq &#39;map([.b=.b[]])&#39;\r\n```",
                "title": "How to bring outer values inside an array iteration"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1648841265,
        "creation_date": 1648821696,
        "question_id": 71708143,
        "body_markdown": "I have a JSON in the shape\r\n\r\n    [\r\n      {\r\n        a:1,\r\n        b: [2,3]\r\n      },\r\n      {\r\n        a:4,\r\n        b: [5,6]\r\n      }\r\n    ]\r\n\r\nThat I want to transform in the shape\r\n\r\n    [\r\n      [\r\n        {\r\n          a: 1,\r\n          b: 2,\r\n        },\r\n        {\r\n          a: 1,\r\n          b: 3,\r\n        },\r\n      ],\r\n      [\r\n        {\r\n          a: 4,\r\n          b: 5,\r\n        },\r\n        {\r\n          a: 4,\r\n          b: 6,\r\n        },\r\n      ],\r\n    ]\r\n    \r\n\r\nThat is I want to bring the value of the field `a` inside the array.\r\n\r\nhow can I do this with jq?\r\n",
        "link": "https://stackoverflow.com/questions/71708143/how-to-bring-outer-values-inside-an-array-iteration",
        "title": "How to bring outer values inside an array iteration"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq",
            "export-to-csv"
        ],
        "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": 1648839337,
                "post_id": 71711506,
                "comment_id": 126734655,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 9538642,
                    "reputation": 67,
                    "user_id": 7087863,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f35573a15d288ef8fe7bf81015d87786?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "v3rd1ct",
                    "link": "https://stackoverflow.com/users/7087863/v3rd1ct"
                },
                "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": 1648839962,
                "post_id": 71711506,
                "comment_id": 126734802,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1660466742,
                "last_edit_date": 1660466742,
                "creation_date": 1660466006,
                "answer_id": 73350190,
                "question_id": 71711506,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "User [pmf](https://stackoverflow.com/users/2158479/pmf) has got it [in the comments](https://stackoverflow.com/questions/71711506/how-do-i-use-jq-to-convert-nested-json-output-to-csv#comment126734655_71711506):\r\n\r\n&gt; Use `?` to ignore an error, and `//` to provide an alternative if the first one is `null`, `false` or inexistent. Define every column at question along the lines of `(.clientConnInfo.clientName? // &quot;none&quot;)`",
                "title": "How do I use jq to convert nested JSON output to CSV?"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1660466742,
        "creation_date": 1648838698,
        "last_edit_date": 1648887876,
        "question_id": 71711506,
        "body_markdown": "I have a JSON output that I receive from cURL, I would like to pipe to jq to extract useful information and display the csv data in a terminal.\r\n\r\nSample JSON response:\r\n\r\n```\r\n{\r\n  &quot;operation&quot;: &quot;GET CLIENT SESSIONS&quot;,\r\n  &quot;outcome&quot;: &quot;SUCCESS&quot;,\r\n  &quot;result&quot;: {\r\n    &quot;Session&quot;: [\r\n      {\r\n        &quot;sessionID&quot;: &quot;E1B7190EF32AA9F6E63265ADBB88D1A9D6F4254457A0.production&quot;,\r\n        &quot;requestID&quot;: &quot;&quot;,\r\n        &quot;sessionPoolID&quot;: &quot;8LNIVzRTSo-jJV-CdPMP0Q&quot;,\r\n        &quot;agentID&quot;: &quot;&quot;,\r\n        &quot;ablSessionID&quot;: &quot;&quot;,\r\n        &quot;lastAccessStr&quot;: &quot;2022-04-01T10:36:14.745-0700&quot;,\r\n        &quot;elapsedTimeMs&quot;: 1675892,\r\n        &quot;sessionState&quot;: &quot;AVAILABLE&quot;,\r\n        &quot;requestState&quot;: &quot;READY&quot;,\r\n        &quot;sessionType&quot;: &quot;SESSION_FREE&quot;,\r\n        &quot;adapterType&quot;: &quot;APSV&quot;,\r\n        &quot;bound&quot;: false,\r\n        &quot;clientConnInfo&quot;: null,\r\n        &quot;agentConnInfo&quot;: null\r\n      },\r\n      {\r\n        &quot;sessionID&quot;: &quot;E1B7190EF32AA9F6E63265ADBB88D1A9D6F4254457A0.production&quot;,\r\n        &quot;requestID&quot;: &quot;&quot;,\r\n        &quot;sessionPoolID&quot;: &quot;8LNIVzRTSo-jJV-CdPMP0Q&quot;,\r\n        &quot;agentID&quot;: &quot;&quot;,\r\n        &quot;ablSessionID&quot;: &quot;&quot;,\r\n        &quot;lastAccessStr&quot;: &quot;2022-04-01T10:36:14.745-0700&quot;,\r\n        &quot;elapsedTimeMs&quot;: 1675892,\r\n        &quot;sessionState&quot;: &quot;AVAILABLE&quot;,\r\n        &quot;requestState&quot;: &quot;READY&quot;,\r\n        &quot;sessionType&quot;: &quot;SESSION_FREE&quot;,\r\n        &quot;adapterType&quot;: &quot;APSV&quot;,\r\n        &quot;bound&quot;: false,\r\n        &quot;clientConnInfo&quot;: null,\r\n        &quot;agentConnInfo&quot;: null\r\n      }\r\n    ]\r\n  },\r\n  &quot;errmsg&quot;: &quot;&quot;,\r\n  &quot;versionStr&quot;: &quot;v1.0.0 ( 2021-10-29 )&quot;,\r\n  &quot;versionNo&quot;: 1\r\n}\r\n```\r\n\r\nI am able to extract information using this query:\r\n\r\n```\r\njq &#39;.result.Session[] | ([.lastAccessStr, .elapsedTimeMs, .clientConnInfo]) | @csv&#39;\r\n```\r\n\r\nThe problem I am running into, sometimes the response can have additional nested data for clientConnInfo and agentConnInfo as seen in the example below.\r\n\r\n```\r\n{\r\n  &quot;operation&quot;: &quot;GET CLIENT SESSIONS&quot;,\r\n  &quot;outcome&quot;: &quot;SUCCESS&quot;,\r\n  &quot;result&quot;: {\r\n    &quot;Session&quot;: [\r\n      {\r\n        &quot;sessionID&quot;: &quot;E1B7190EF32AA9F6E63265ADBB88D1A9D6F4254457A0.production&quot;,\r\n        &quot;requestID&quot;: &quot;&quot;,\r\n        &quot;sessionPoolID&quot;: &quot;8LNIVzRTSo-jJV-CdPMP0Q&quot;,\r\n        &quot;agentID&quot;: &quot;&quot;,\r\n        &quot;ablSessionID&quot;: &quot;&quot;,\r\n        &quot;lastAccessStr&quot;: &quot;2022-04-01T10:36:14.745-0700&quot;,\r\n        &quot;elapsedTimeMs&quot;: 1675892,\r\n        &quot;sessionState&quot;: &quot;AVAILABLE&quot;,\r\n        &quot;requestState&quot;: &quot;READY&quot;,\r\n        &quot;sessionType&quot;: &quot;SESSION_FREE&quot;,\r\n        &quot;adapterType&quot;: &quot;APSV&quot;,\r\n        &quot;bound&quot;: false,\r\n        &quot;clientConnInfo&quot;: null,\r\n        &quot;agentConnInfo&quot;: null\r\n      },\r\n      {\r\n        &quot;sessionID&quot;: &quot;26691913A73E55175D233F86D219B4AEFA4AD14AE9E4.production&quot;,\r\n        &quot;requestID&quot;: &quot;ROOT:a:000002a6&quot;,\r\n        &quot;sessionPoolID&quot;: &quot;8LNIVzRTSo-jJV-CdPMP0Q&quot;,\r\n        &quot;agentID&quot;: &quot;qsrLXAxsRRanJio6dYOC2Q&quot;,\r\n        &quot;ablSessionID&quot;: &quot;&quot;,\r\n        &quot;lastAccessStr&quot;: &quot;2022-04-01T11:04:08.902-0700&quot;,\r\n        &quot;elapsedTimeMs&quot;: 1735,\r\n        &quot;sessionState&quot;: &quot;RESERVED&quot;,\r\n        &quot;requestState&quot;: &quot;RUNNING&quot;,\r\n        &quot;sessionType&quot;: &quot;SESSION_FREE&quot;,\r\n        &quot;adapterType&quot;: &quot;APSV&quot;,\r\n        &quot;bound&quot;: false,\r\n        &quot;clientConnInfo&quot;: {\r\n          &quot;clientName&quot;: &quot;xxxxx&quot;,\r\n          &quot;requestID&quot;: &quot;ROOT:a:000002a6&quot;,\r\n          &quot;sessionID&quot;: &quot;26691913A73E55175D233F86D219B4AEFA4AD14AE9E4.production&quot;,\r\n          &quot;adapterType&quot;: &quot;APSV&quot;,\r\n          &quot;reqStartTimeStr&quot;: &quot;2022-04-01T11:04:08.902-0700&quot;,\r\n          &quot;elapsedTimeMs&quot;: 1735,\r\n          &quot;executerThreadId&quot;: &quot;thd-8&quot;,\r\n          &quot;requestUrl&quot;: &quot;xxxxx&quot;,\r\n          &quot;requestProcedure&quot;: &quot;xxxxx.p&quot;,\r\n          &quot;httpSessionId&quot;: &quot;26691913A73E55175D233F86D219B4AEFA4AD14AE9E4.production&quot;\r\n        },\r\n        &quot;agentConnInfo&quot;: {\r\n          &quot;agentID&quot;: &quot;qsrLXAxsRRanJio6dYOC2Q&quot;,\r\n          &quot;connID&quot;: &quot;AR2k7gnYSiKPCk2DEHpaSg&quot;,\r\n          &quot;connPoolID&quot;: &quot;v0Lh7XcITsOSfoF_RjXXig&quot;,\r\n          &quot;state&quot;: &quot;RESERVED&quot;,\r\n          &quot;agentAddr&quot;: &quot;xxxxx&quot;,\r\n          &quot;localAddr&quot;: &quot;xxxxx&quot;\r\n        }\r\n      }\r\n    ]\r\n  },\r\n  &quot;errmsg&quot;: &quot;&quot;,\r\n  &quot;versionStr&quot;: &quot;v1.0.0 ( 2021-10-29 )&quot;,\r\n  &quot;versionNo&quot;: 1\r\n}\r\n```\r\n\r\nIf I try to use the same query, it dies with below error: \r\n\r\n```\r\njq: error (at &lt;stdin&gt;:0): object ({&quot;clientNam...) is not valid in a csv row\r\n```\r\n\r\nThe desired output is to capture this:\r\n\r\n.lastAccessStr\r\n.elapsedTimeMs\r\n.clientName (if available in output)\r\n.requestID (if available in output)\r\n.agentAddr (if available in output)\r\n.localAddr (if available in output)\r\n\r\nI have been trying to make this work using https://jqplay.org without any luck.\r\n\r\nCan anyone give me some examples on how I would go about making this work?",
        "link": "https://stackoverflow.com/questions/71711506/how-do-i-use-jq-to-convert-nested-json-output-to-csv",
        "title": "How do I use jq to convert nested JSON output to CSV?"
    },
    {
        "tags": [
            "json",
            "batch-file",
            "cmd",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 24885,
                    "reputation": 31572,
                    "user_id": 63550,
                    "user_type": "registered",
                    "accept_rate": 78,
                    "profile_image": "https://i.sstatic.net/RIZKi.png?s=256",
                    "display_name": "Peter Mortensen",
                    "link": "https://stackoverflow.com/users/63550/peter-mortensen"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1648923794,
                "post_id": 71716898,
                "comment_id": 126747818,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 24885,
                    "reputation": 31572,
                    "user_id": 63550,
                    "user_type": "registered",
                    "accept_rate": 78,
                    "profile_image": "https://i.sstatic.net/RIZKi.png?s=256",
                    "display_name": "Peter Mortensen",
                    "link": "https://stackoverflow.com/users/63550/peter-mortensen"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1651762251,
                "post_id": 71716898,
                "comment_id": 127444695,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 24885,
                    "reputation": 31572,
                    "user_id": 63550,
                    "user_type": "registered",
                    "accept_rate": 78,
                    "profile_image": "https://i.sstatic.net/RIZKi.png?s=256",
                    "display_name": "Peter Mortensen",
                    "link": "https://stackoverflow.com/users/63550/peter-mortensen"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1651941413,
                "post_id": 71716898,
                "comment_id": 127487664,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1650817612,
                "last_edit_date": 1650817612,
                "creation_date": 1648897143,
                "answer_id": 71716943,
                "question_id": 71716898,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "That would be\r\n\r\n```\r\nyour_json_file.media.track[0].Duration\r\n```\r\n\r\nWhere `.track[index]` denotes a certain element (track), in this case the first one.\r\n\r\n&lt;hr/&gt;\r\n\r\nYou should try an online JSON formatter like, *[JSON Formatter &amp;amp; Validator][1]*, to get automatic indentation.\r\n\r\nThis is your file content indented:\r\n\r\n```\r\n{\r\n   &quot;creatingLibrary&quot;:{\r\n      &quot;name&quot;:&quot;MediaInfoLib&quot;,\r\n      &quot;version&quot;:&quot;21.09&quot;,\r\n      &quot;url&quot;:&quot;https://mediaarea.net/MediaInfo&quot;\r\n   },\r\n   &quot;media&quot;:{\r\n      &quot;@ref&quot;:&quot;J:\\\\Austria\\\\Tag5\\\\EOS_ben\\\\100EOS5D\\\\TW_6248.MOV&quot;,\r\n      &quot;track&quot;:[\r\n         {\r\n            &quot;@type&quot;:&quot;General&quot;,\r\n            &quot;VideoCount&quot;:&quot;1&quot;,\r\n            &quot;AudioCount&quot;:&quot;1&quot;,\r\n            &quot;OtherCount&quot;:&quot;1&quot;,\r\n            &quot;FileExtension&quot;:&quot;MOV&quot;,\r\n            &quot;Format&quot;:&quot;MPEG-4&quot;,\r\n            &quot;Format_Profile&quot;:&quot;QuickTime&quot;,\r\n            &quot;CodecID&quot;:&quot;qt  &quot;,\r\n            &quot;CodecID_Version&quot;:&quot;2007.09&quot;,\r\n            &quot;CodecID_Compatible&quot;:&quot;qt  /CAEP&quot;,\r\n            &quot;FileSize&quot;:&quot;37229924&quot;,\r\n            &quot;Duration&quot;:&quot;9.520&quot;,\r\n            &quot;OverallBitRate_Mode&quot;:&quot;VBR&quot;,\r\n            &quot;OverallBitRate&quot;:&quot;31285650&quot;,\r\n            &quot;FrameRate&quot;:&quot;25.000&quot;,\r\n            &quot;FrameCount&quot;:&quot;238&quot;,\r\n            &quot;StreamSize&quot;:&quot;100484&quot;,\r\n            &quot;HeaderSize&quot;:&quot;98304&quot;,\r\n            &quot;DataSize&quot;:&quot;37130652&quot;,\r\n            &quot;FooterSize&quot;:&quot;968&quot;,\r\n            &quot;IsStreamable&quot;:&quot;Yes&quot;,\r\n            &quot;Encoded_Date&quot;:&quot;UTC 2014-03-13 22:31:17&quot;,\r\n            &quot;Tagged_Date&quot;:&quot;UTC 2014-03-13 22:31:17&quot;,\r\n            &quot;File_Created_Date&quot;:&quot;UTC 2014-03-13 21:31:26.000&quot;,\r\n            &quot;File_Created_Date_Local&quot;:&quot;2014-03-13 23:31:26.000&quot;,\r\n            &quot;File_Modified_Date&quot;:&quot;UTC 2014-03-13 21:31:26.000&quot;,\r\n            &quot;File_Modified_Date_Local&quot;:&quot;2014-03-13 23:31:26.000&quot;,\r\n            &quot;Copyright&quot;:&quot;BEN PAYA&quot;,\r\n            &quot;extra&quot;:{\r\n               &quot;com_apple_quicktime_make&quot;:&quot;Canon&quot;,\r\n               &quot;com_apple_quicktime_model&quot;:&quot;Canon EOS 5D Mark III&quot;,\r\n               &quot;com_apple_quicktime_rating_user&quot;:&quot;0.000&quot;,\r\n               &quot;com_apple_quicktime_author&quot;:&quot;PhilFried&quot;\r\n            }\r\n         }\r\n      ]\r\n   }\r\n}\r\n```\r\n\r\n  [1]: https://jsonformatter.curiousconcept.com/\r\n\r\n",
                "title": "Read a value out of a &quot;complicated&quot; JSON file"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": -1,
                "last_activity_date": 1648898289,
                "creation_date": 1648898289,
                "answer_id": 71717066,
                "question_id": 71716898,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "    @ECHO OFF\r\n    SETLOCAL\r\n    \r\n    rem The following settings for the source directory &amp; filename are names\r\n    rem that I use for testing and deliberately include names which include spaces to make sure\r\n    rem that the process works using such names. These will need to be changed to suit your situation.\r\n    \r\n    SET &quot;sourcedir=u:\\your files&quot;\r\n    SET &quot;filename1=%sourcedir%\\q71716898.txt&quot;\r\n    \r\n    REM (\r\n    FOR /f &quot;usebackqtokens=1,2delims=:, &quot; %%b IN (&quot;%filename1%&quot;) DO (\r\n     IF /i &quot;%%~b&quot;==&quot;duration&quot; SET &quot;duration=%%~c&quot;\r\n    )\r\n    SET duration\r\n    GOTO :EOF\r\n\r\nReasonably standard `for /f &quot;tokens` processing. \r\n\r\nThe `for/f` assigns tokens from each line in turn, token 1 to `%%b` and token 2 to `%%c`.\r\n\r\nChoosing delimiters of `:`, `,` and &lt;kbd&gt;space&lt;/kbd&gt;, the first token on the target line is `&quot;Duration&quot;` and the second `&quot;9.520&quot;`.\r\n\r\nSo, check that &quot;%%~b&quot; (the token, stripped of quotes, then re-enclosed in quotes is the same as the string `duration`, enclosed in quotes) and if so, assign the value of the second token to the variable `duration`.\r\n\r\nThe dequote/enquote ceremony is required in case the token contains separator characters which would interfere with  the `if` parsing, and the `/i` makes the comparison case-insensitive.\r\n\r\n",
                "title": "Read a value out of a &quot;complicated&quot; JSON file"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": -8,
                "last_activity_date": 1648916429,
                "last_edit_date": 1648916429,
                "creation_date": 1648911897,
                "answer_id": 71718686,
                "question_id": 71716898,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "It is best to use a tool that understands the JSON language. This will run in a `batch-file` from `cmd`.\r\n\r\nI note that `track` is an array. This code selects the first element of the array.\r\n\r\n    FOR /F &quot;delims=&quot; %%A IN (&#39;powershell.exe -NoLogo -NoProfile -Command ^\r\n        &quot;(ConvertFrom-Json -InputObject (Get-Content -Path &#39;.\\dura.json&#39; -Raw)).media.track[0].Duration&quot;&#39;) DO (SET &quot;DURATION=%%~A&quot;)\r\n    ECHO DURATION is %DURATION%\r\n\r\nIf you want to process the `Duration` for all tracks, please try some code and create a new question if needed.\r\n\r\n `{}` is used around a hash table. The use of `[]` indicates and array.",
                "title": "Read a value out of a &quot;complicated&quot; JSON file"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1651761729,
                "last_edit_date": 1651761729,
                "creation_date": 1648984727,
                "answer_id": 71725389,
                "question_id": 71716898,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "To get to **FrameCount** in the JSON content, the solution for me is:\r\n\r\n    jq.exe -r .media.track[0].FrameCount C:\\MP4convert\\test\\%filenam%.json &gt; test1.txt\r\n    for /f &quot;delims=&quot; %%x in (test1.txt) do set FrCountVar=%%x\r\n\r\nFor future use, I put the count in a new variable:\r\n\r\n    SET FrCount=%FrCountVar%\r\n\r\n&lt;sub&gt;Thanks [Finkle MacGraw&#39;s answer][1].&lt;/sub&gt;\r\n\r\n  [1]: https://stackoverflow.com/questions/71716898/read-a-value-out-of-a-complicated-json-file/71716943#71716943\r\n\r\n\r\n",
                "title": "Read a value out of a &quot;complicated&quot; JSON file"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1649012531,
                "creation_date": 1649012531,
                "answer_id": 71729029,
                "question_id": 71716898,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You may solve your problem in a very simple way via a pure Batch file:\r\n\r\n    @echo off\r\n    setlocal\r\n    \r\n    for /F &quot;tokens=2 delims=:, &quot; %%a in (&#39;findstr &quot;Duration&quot; test.txt&#39;) do set &quot;Duration=%%~a&quot;\r\n    \r\n    echo Duration = %Duration%\r\n\r\nFurthermore, you can get the values of _all fields_ in the same way:\r\n\r\n    @echo off\r\n    setlocal\r\n    \r\n    for /F &quot;tokens=1,2 delims=:, &quot; %%a in (&#39;findstr /V &quot;{ [ ] }&quot; test.txt&#39;) do set &quot;%%~a=%%~b&quot;\r\n    \r\n    rem Here you have the values of *all fields* in the json file. For example:\r\n    \r\n    echo Duration = %Duration%\r\n    echo FrameCount = %FrameCount%\r\n    echo CodecID_Version = %CodecID_Version%\r\n\r\nOutput:\r\n\r\n    Duration = 9.520\r\n    FrameCount = 238\r\n    CodecID_Version = 2007.09\r\n\r\n",
                "title": "Read a value out of a &quot;complicated&quot; JSON file"
            }
        ],
        "is_answered": true,
        "answer_count": 5,
        "score": -4,
        "last_activity_date": 1651761729,
        "creation_date": 1648896743,
        "last_edit_date": 1650817627,
        "question_id": 71716898,
        "body_markdown": "I&#39;m using [jq][1], but I didn&#39;t manage to get a value extracted from a .json-file (I got generated by mediainfo) in my batch-script.\r\n\r\nHow can I get the value of &quot;Duration&quot; in a variable for further use?\r\n\r\n    {\r\n    &quot;creatingLibrary&quot;: {\r\n    &quot;name&quot;: &quot;MediaInfoLib&quot;,\r\n    &quot;version&quot;: &quot;21.09&quot;,\r\n    &quot;url&quot;: &quot;https://mediaarea.net/MediaInfo&quot;\r\n    },\r\n    &quot;media&quot;: {\r\n    &quot;@ref&quot;: &quot;J:\\\\Austria\\\\Tag5\\\\EOS_ben\\\\100EOS5D\\\\TW_6248.MOV&quot;,\r\n    &quot;track&quot;: [\r\n    {\r\n    &quot;@type&quot;: &quot;General&quot;,\r\n    &quot;VideoCount&quot;: &quot;1&quot;,\r\n    &quot;AudioCount&quot;: &quot;1&quot;,\r\n    &quot;OtherCount&quot;: &quot;1&quot;,\r\n    &quot;FileExtension&quot;: &quot;MOV&quot;,\r\n    &quot;Format&quot;: &quot;MPEG-4&quot;,\r\n    &quot;Format_Profile&quot;: &quot;QuickTime&quot;,\r\n    &quot;CodecID&quot;: &quot;qt  &quot;,\r\n    &quot;CodecID_Version&quot;: &quot;2007.09&quot;,\r\n    &quot;CodecID_Compatible&quot;: &quot;qt  /CAEP&quot;,\r\n    &quot;FileSize&quot;: &quot;37229924&quot;,\r\n    &quot;Duration&quot;: &quot;9.520&quot;,\r\n    &quot;OverallBitRate_Mode&quot;: &quot;VBR&quot;,\r\n    &quot;OverallBitRate&quot;: &quot;31285650&quot;,\r\n    &quot;FrameRate&quot;: &quot;25.000&quot;,\r\n    &quot;FrameCount&quot;: &quot;238&quot;,\r\n    &quot;StreamSize&quot;: &quot;100484&quot;,\r\n    &quot;HeaderSize&quot;: &quot;98304&quot;,\r\n    &quot;DataSize&quot;: &quot;37130652&quot;,\r\n    &quot;FooterSize&quot;: &quot;968&quot;,\r\n    &quot;IsStreamable&quot;: &quot;Yes&quot;,\r\n    &quot;Encoded_Date&quot;: &quot;UTC 2014-03-13 22:31:17&quot;,\r\n    &quot;Tagged_Date&quot;: &quot;UTC 2014-03-13 22:31:17&quot;,\r\n    &quot;File_Created_Date&quot;: &quot;UTC 2014-03-13 21:31:26.000&quot;,\r\n    &quot;File_Created_Date_Local&quot;: &quot;2014-03-13 23:31:26.000&quot;,\r\n    &quot;File_Modified_Date&quot;: &quot;UTC 2014-03-13 21:31:26.000&quot;,\r\n    &quot;File_Modified_Date_Local&quot;: &quot;2014-03-13 23:31:26.000&quot;,\r\n    &quot;Copyright&quot;: &quot;BEN PAYA&quot;,\r\n    &quot;extra&quot;: {\r\n    &quot;com_apple_quicktime_make&quot;: &quot;Canon&quot;,\r\n    &quot;com_apple_quicktime_model&quot;: &quot;Canon EOS 5D Mark III&quot;,\r\n    &quot;com_apple_quicktime_rating_user&quot;: &quot;0.000&quot;,\r\n    &quot;com_apple_quicktime_author&quot;: &quot;PhilFried&quot;\r\n    }\r\n    },\r\n    {\r\n    &quot;@type&quot;: &quot;Video&quot;,\r\n    &quot;StreamOrder&quot;: &quot;0&quot;,\r\n    &quot;ID&quot;: &quot;1&quot;,\r\n    .\r\n    .\r\n    .\r\n\r\n\r\n  [1]: https://stedolan.github.io/jq/\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/71716898/read-a-value-out-of-a-complicated-json-file",
        "title": "Read a value out of a &quot;complicated&quot; JSON file"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1648949300,
                "last_edit_date": 1648949300,
                "creation_date": 1648947328,
                "answer_id": 71722214,
                "question_id": 71721556,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Using `to_entries`:\r\n\r\n```sh\r\njq -r &#39;.variables | to_entries[] | [ .key, .value.value ] | @csv&#39;\r\n```\r\n\r\nUsing `keys`:\r\n\r\n```sh\r\njq -r &#39;.variables | keys[] as $k | [ $k, .[$k].value ] | @csv&#39;\r\n```\r\n",
                "title": "How to access a json value within an object that has different named keys with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1648949300,
        "creation_date": 1648937628,
        "question_id": 71721556,
        "body_markdown": "I have data that looks like this:\r\n```\r\n{\r\n  &quot;Object0&quot; : {\r\n    &quot;data01&quot; : &quot;value01&quot;,\r\n    &quot;data02&quot; : &quot;value02&quot;,\r\n    &quot;data03&quot; : &quot;value03&quot;,\r\n    &quot;data04&quot; : &quot;value04&quot;\r\n  },\r\n  &quot;Object1&quot; : {\r\n    &quot;data11&quot; : &quot;value11&quot;,\r\n    &quot;data12&quot; : &quot;value12&quot;,\r\n    &quot;data13&quot; : &quot;value13&quot;,\r\n    &quot;data14&quot; : &quot;value14&quot;\r\n  },\r\n  &quot;variables&quot;: {\r\n    &quot;variable1&quot;: {\r\n      &quot;isSecret&quot;: null,\r\n      &quot;value&quot;: &quot;value1&quot;\r\n    },\r\n    &quot;variable2&quot;: {\r\n      &quot;isSecret&quot;: null,\r\n      &quot;value&quot;: &quot;value2&quot;\r\n    },\r\n    &quot;variable3&quot;: {\r\n      &quot;isSecret&quot;: null,\r\n      &quot;value&quot;: &quot;value3&quot;\r\n    },\r\n    &quot;variable4&quot;: {\r\n      &quot;isSecret&quot;: null,\r\n      &quot;value&quot;: &quot;value4&quot;\r\n    }\r\n  }\r\n}\r\n```\r\n\r\nI am trying to grab the variable names and the values, using jq. I want output that links the two together in any form of structured data. Something that would look/function similar to:\r\n```\r\nvarible1,value1\r\nvarible2,value2\r\nvarible3,value3\r\nvarible4,value4\r\n```\r\nIt could be json, csv or tsv. Whatever you have is great.\r\n\r\n\r\nRight now I am only able to get to the variable names with:\r\n\r\n```\r\n$ cat data.json | jq -r &#39;.variables | keys[]&#39;\r\nvariable1\r\nvariable2\r\nvariable3\r\nvariable4\r\n```\r\n\r\nI was also able to begin to create json key/value pairs with:\r\n```\r\n$ cat data.json | jq -r &#39;{(.variables | keys[]):&quot;42&quot;}&#39;\r\n{\r\n  &quot;variable1&quot;: &quot;42&quot;\r\n}\r\n{\r\n  &quot;variable2&quot;: &quot;42&quot;\r\n}\r\n{\r\n  &quot;variable3&quot;: &quot;42&quot;\r\n}\r\n{\r\n  &quot;variable4&quot;: &quot;42&quot;\r\n}\r\n```\r\nBut I&#39;m still not able to access those sweet values.\r\n\r\nI&#39;ve been reading through the man pages and I tried using recurse, walk, foreach, recursive descent, and a few others. I did not realize how robust jq is! It&#39;s now one of my favorite bash utilities. But I&#39;ve still got this problem. Can anyone shed some light on this?\r\n",
        "link": "https://stackoverflow.com/questions/71721556/how-to-access-a-json-value-within-an-object-that-has-different-named-keys-with-j",
        "title": "How to access a json value within an object that has different named keys with jq"
    },
    {
        "tags": [
            "json",
            "linux",
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1649007317,
                "post_id": 71728099,
                "comment_id": 126761532,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 22369000,
                    "reputation": 3,
                    "user_id": 16584342,
                    "user_type": "registered",
                    "profile_image": "https://graph.facebook.com/1749510921914707/picture?type=large",
                    "display_name": "Adhithya",
                    "link": "https://stackoverflow.com/users/16584342/adhithya"
                },
                "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": 1649064729,
                "post_id": 71728099,
                "comment_id": 126772875,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1649007107,
                "creation_date": 1649007107,
                "answer_id": 71728355,
                "question_id": 71728099,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The `--compact-output` (or `-c`) option qill print each object in a single line, and the `--join-output` (or `-j`) option will omit the newline character between the objects.\r\n~~~sh\r\njq -cj .\r\n~~~\r\n~~~json\r\n{&quot;Icao&quot;:&quot;800B0A&quot;,&quot;Alt&quot;:15375,&quot;GAlt&quot;:15278,&quot;AltT&quot;:0,&quot;Lat&quot;:10.579605,&quot;Long&quot;:76.506561,&quot;Mlat&quot;:false,&quot;Spd&quot;:334.5,&quot;Trak&quot;:26.3,&quot;Vsi&quot;:832}{&quot;Icao&quot;:&quot;800463&quot;,&quot;Alt&quot;:3575,&quot;GAlt&quot;:3445,&quot;AltT&quot;:0,&quot;Lat&quot;:40.626663,&quot;Long&quot;:-74.261963,&quot;Mlat&quot;:false,&quot;Spd&quot;:274.4,&quot;Trak&quot;:316.2,&quot;Vsi&quot;:1472}\r\n~~~\r\n\r\nNote that while this is valid JSON, your desired output is not. It has commas after the objects. If you really need them, you can print a literal string like a comma using the `--raw-output` (or `-r`) option:\r\n~~~sh\r\njq -cjr &#39;.,&quot;,&quot;&#39;\r\n~~~\r\n~~~json\r\n{&quot;Icao&quot;:&quot;800B0A&quot;,&quot;Alt&quot;:15375,&quot;GAlt&quot;:15278,&quot;AltT&quot;:0,&quot;Lat&quot;:10.579605,&quot;Long&quot;:76.506561,&quot;Mlat&quot;:false,&quot;Spd&quot;:334.5,&quot;Trak&quot;:26.3,&quot;Vsi&quot;:832},{&quot;Icao&quot;:&quot;800463&quot;,&quot;Alt&quot;:3575,&quot;GAlt&quot;:3445,&quot;AltT&quot;:0,&quot;Lat&quot;:40.626663,&quot;Long&quot;:-74.261963,&quot;Mlat&quot;:false,&quot;Spd&quot;:274.4,&quot;Trak&quot;:316.2,&quot;Vsi&quot;:1472},\r\n~~~\r\n",
                "title": "How to Stitch json data into single line with Jq linux"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -2,
        "last_activity_date": 1649007107,
        "creation_date": 1649005225,
        "question_id": 71728099,
        "body_markdown": "I have a json stream that I want to make the output into single line with jq ( Linux ) \r\n\r\n\r\n##### From this\r\n```\r\n{\r\n  &quot;Icao&quot;: &quot;800B0A&quot;,\r\n  &quot;Alt&quot;: 15375,\r\n  &quot;GAlt&quot;: 15278,\r\n  &quot;AltT&quot;: 0,\r\n  &quot;Lat&quot;: 10.579605,\r\n  &quot;Long&quot;: 76.506561,\r\n  &quot;Mlat&quot;: false,\r\n  &quot;Spd&quot;: 334.5,\r\n  &quot;Trak&quot;: 26.3,\r\n  &quot;Vsi&quot;: 832\r\n}\r\n{\r\n  &quot;Icao&quot;: &quot;800463&quot;,\r\n  &quot;Alt&quot;: 3575,\r\n  &quot;GAlt&quot;: 3445,\r\n  &quot;AltT&quot;: 0,\r\n  &quot;Lat&quot;: 40.626663,\r\n  &quot;Long&quot;: -74.261963,\r\n  &quot;Mlat&quot;: false,\r\n  &quot;Spd&quot;: 274.4,\r\n  &quot;Trak&quot;: 316.2,\r\n  &quot;Vsi&quot;: 1472\r\n}\r\n```\r\n\r\n\r\n##### To this\r\n```\r\n{&quot;Icao&quot;:&quot;A379CD&quot;,&quot;Alt&quot;:32025,&quot;GAlt&quot;:32114,&quot;InHg&quot;:30.0088577,&quot;AltT&quot;:0,&quot;Lat&quot;:38.335918,&quot;Long&quot;:-104.720284,&quot;Mlat&quot;:false,&quot;Spd&quot;:403.0,&quot;Trak&quot;:240.0,&quot;Vsi&quot;:64},{&quot;Icao&quot;:&quot;345042&quot;,&quot;Alt&quot;:22850,&quot;GAlt&quot;:22782,&quot;InHg&quot;:29.8523617,&quot;AltT&quot;:0,&quot;Lat&quot;:39.655243,&quot;Long&quot;:-8.845612,&quot;Mlat&quot;:false,&quot;Spd&quot;:308.5,&quot;Trak&quot;:212.6,&quot;Vsi&quot;:-1216},{&quot;Icao&quot;:&quot;40753D&quot;,&quot;Alt&quot;:37000,&quot;GAlt&quot;:37050,&quot;InHg&quot;:29.9704723,&quot;AltT&quot;:0,&quot;Lat&quot;:41.940674,&quot;Long&quot;:-8.029816,&quot;Mlat&quot;:false,&quot;Spd&quot;:468.4,&quot;Trak&quot;:190.2,&quot;Vsi&quot;:-64},\r\n```\r\n\r\nHope someone could hand a solution for the problem.",
        "link": "https://stackoverflow.com/questions/71728099/how-to-stitch-json-data-into-single-line-with-jq-linux",
        "title": "How to Stitch json data into single line with Jq linux"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1649046603,
                "creation_date": 1649046603,
                "answer_id": 71732050,
                "question_id": 71732014,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Pull out the iteration `[]` in front of `select` to apply the filter to each array item and keep its context. Also, to perform a partial match, `contains` is fine, for the the exact match you may use `==`.\r\n~~~sh\r\njq &#39;.aggregations.sites_monthly_top_10.buckets[] | select(.key == &quot;this.com&quot;).monthly.buckets&#39; response.json\r\n~~~\r\n~~~json\r\n[\r\n  {\r\n    &quot;key_as_string&quot;: &quot;2021-03 March&quot;,\r\n    &quot;key&quot;: 1614556800000,\r\n    &quot;doc_count&quot;: 16733\r\n  },\r\n  {\r\n    &quot;key_as_string&quot;: &quot;2021-04 April&quot;,\r\n    &quot;key&quot;: 1617235200000,\r\n    &quot;doc_count&quot;: 12744\r\n  }\r\n]\r\n~~~\r\n[Demo](https://jqplay.org/s/aLmqKz7i5k)",
                "title": "Get matching objects sub array"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1649046603,
        "creation_date": 1649046326,
        "question_id": 71732014,
        "body_markdown": "I have an elasticsearch aggregation response and want to use jq to filter a matching objects sub array do to further extraction (at the end create a csv file)\r\n\r\nI have a response like the following one:\r\n\r\n```\r\n{\r\n  &quot;took&quot;: 189,\r\n  &quot;timed_out&quot;: false,\r\n  &quot;_shards&quot;: {\r\n    &quot;total&quot;: 5,\r\n    &quot;successful&quot;: 5,\r\n    &quot;skipped&quot;: 0,\r\n    &quot;failed&quot;: 0\r\n  },\r\n  &quot;hits&quot;: {\r\n    &quot;total&quot;: 614388,\r\n    &quot;max_score&quot;: 0,\r\n    &quot;hits&quot;: []\r\n  },\r\n  &quot;aggregations&quot;: {\r\n    &quot;sites_monthly_top_10&quot;: {\r\n      &quot;doc_count_error_upper_bound&quot;: 4507,\r\n      &quot;sum_other_doc_count&quot;: 205762,\r\n      &quot;buckets&quot;: [\r\n        {\r\n          &quot;key&quot;: &quot;this.com&quot;,\r\n          &quot;doc_count&quot;: 120903,\r\n          &quot;monthly&quot;: {\r\n            &quot;buckets&quot;: [\r\n              {\r\n                &quot;key_as_string&quot;: &quot;2021-03 March&quot;,\r\n                &quot;key&quot;: 1614556800000,\r\n                &quot;doc_count&quot;: 16733\r\n              },\r\n              {\r\n                &quot;key_as_string&quot;: &quot;2021-04 April&quot;,\r\n                &quot;key&quot;: 1617235200000,\r\n                &quot;doc_count&quot;: 12744\r\n              }\r\n            ]\r\n          }\r\n        },\r\n        {\r\n          &quot;key&quot;: &quot;that.com&quot;,\r\n          &quot;doc_count&quot;: 81451,\r\n          &quot;monthly&quot;: {\r\n            &quot;buckets&quot;: [\r\n              {\r\n                &quot;key_as_string&quot;: &quot;2021-03 March&quot;,\r\n                &quot;key&quot;: 1614556800000,\r\n                &quot;doc_count&quot;: 4641\r\n              },\r\n              {\r\n                &quot;key_as_string&quot;: &quot;2021-04 April&quot;,\r\n                &quot;key&quot;: 1617235200000,\r\n                &quot;doc_count&quot;: 8687\r\n              }\r\n            ]\r\n          }\r\n        }\r\n      ]\r\n    }\r\n  }\r\n}\r\n```\r\nI want to work on the bucket element that has the key &quot;this.com&quot;. Matching works, but I still get both sub elements.\r\n```\r\ncat response.json | jq -r &#39; .aggregations.sites_monthly_top_10.buckets | select( .[].key | contains(&quot;this.com&quot;)) | .[].monthly.buckets&#39;\r\n```\r\ngives me \r\n```\r\n[\r\n  {\r\n    &quot;key_as_string&quot;: &quot;2021-03 March&quot;,\r\n    &quot;key&quot;: 1614556800000,\r\n    &quot;doc_count&quot;: 16733\r\n  },\r\n  {\r\n    &quot;key_as_string&quot;: &quot;2021-04 April&quot;,\r\n    &quot;key&quot;: 1617235200000,\r\n    &quot;doc_count&quot;: 12744\r\n  }\r\n]\r\n[\r\n  {\r\n    &quot;key_as_string&quot;: &quot;2021-03 March&quot;,\r\n    &quot;key&quot;: 1614556800000,\r\n    &quot;doc_count&quot;: 4641\r\n  },\r\n  {\r\n    &quot;key_as_string&quot;: &quot;2021-04 April&quot;,\r\n    &quot;key&quot;: 1617235200000,\r\n    &quot;doc_count&quot;: 8687\r\n  }\r\n]\r\n```\r\nbut I would like to access only monthly.buckets of the matching one.\r\n\r\nWhat am I missing here?",
        "link": "https://stackoverflow.com/questions/71732014/get-matching-objects-sub-array",
        "title": "Get matching objects sub array"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1649091708,
                "last_edit_date": 1649091708,
                "creation_date": 1649089399,
                "answer_id": 71740583,
                "question_id": 71740097,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Use a `select` expression with a boolean condition\r\n\r\n```none\r\n.Components | map(select(.ARTIFACTID or .ARTIFACT_ID))\r\n```\r\n\r\nDoing `{ARTIFACTID, ARTIFACT_ID}` requires either of the keys to be present in the resultant object. So if either of the keys are not present they are updated with `null`. Using `select` clause evaluates the expression and produces the result into the object only if it evaluates to true \r\n\r\n[jqplay - demo][1]\r\n\r\n\r\n  [1]: https://jqplay.org/s/DlnwgUyXNE",
                "title": "Select value field out of possible similar key names"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1649091708,
        "creation_date": 1649087260,
        "last_edit_date": 1649089444,
        "question_id": 71740097,
        "body_markdown": "I have a pom.json with a bug in it:\r\n\r\n    {\r\n            &quot;Components&quot;: [\r\n                    {\r\n                            &quot;ARTIFACTID&quot;: &quot;good artifact&quot;,\r\n                            &quot;BuildJobDate&quot;: &quot;2020-01-20T16:39:50&quot;\r\n                    },\r\n                    {\r\n                            &quot;ARTIFACT_ID&quot;: &quot;bad artifact&quot;,\r\n                            &quot;BuildJobDate&quot;: &quot;&#39;2021-11-29T17:23:39&#39;&quot;\r\n                    },\r\n                    {\r\n                            &quot;ARTIFACTID&quot;: &quot;another good artifact&quot;,\r\n                            &quot;BuildJobDate&quot;: &quot;2022-01-26T21:18:20&quot;\r\n                    }\r\n            ]\r\n    }\r\n\r\nin my install script I collect all `ARTIFACTID`:\r\n\r\n    local -ra artifacts=( $(jq -r &#39;.Components | .[].ARTIFACTID&#39; &quot;$manifest&quot;) )\r\n\r\ntried to fix it by `.[] | {ARTIFACTID, ARTIFACT_ID}` but can&#39;t understand how to leave only the valid values\r\n\r\nmy question is: is there is a way to select field out of possible fields in `jq` ?",
        "link": "https://stackoverflow.com/questions/71740097/select-value-field-out-of-possible-similar-key-names",
        "title": "Select value field out of possible similar key names"
    },
    {
        "tags": [
            "json",
            "linux",
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 1613587,
                    "reputation": 786618,
                    "user_id": 1491895,
                    "user_type": "registered",
                    "accept_rate": 69,
                    "profile_image": "https://www.gravatar.com/avatar/82f9e178a16364bf561d0ed4da09a35d?s=256&d=identicon&r=PG",
                    "display_name": "Barmar",
                    "link": "https://stackoverflow.com/users/1491895/barmar"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1649123666,
                "post_id": 71745498,
                "comment_id": 126790944,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 289134,
                    "reputation": 389369,
                    "user_id": 589924,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/b2cf53d5a3d25f95c0db4e025aed4153?s=256&d=identicon&r=PG",
                    "display_name": "ikegami",
                    "link": "https://stackoverflow.com/users/589924/ikegami"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1649125930,
                "post_id": 71745498,
                "comment_id": 126791255,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "is_answered": false,
        "answer_count": 0,
        "score": 0,
        "last_activity_date": 1649123558,
        "creation_date": 1649123153,
        "last_edit_date": 1649123558,
        "question_id": 71745498,
        "body_markdown": "Im using linux and i need to get the data using jq from the following json, but i cannot :(\r\n\r\n```\r\n{&quot;xJSON&quot;:&quot;{\\&quot;statusCode\\&quot;:\\&quot;200\\&quot;, \\&quot;status\\&quot;: \\&quot;OK\\&quot;,\\&quot;pJSON\\&quot;: \\&quot;{\\&quot;body\\&quot;: {\\&quot;assets\\&quot;: {\\&quot;loadingBackgroundImageBase64\\&quot;: \\&quot;iVBII=\\&quot;,\\&quot;loginBackgroundImageBase64\\&quot;: \\&quot;iVBORwTkSuQmCC\\&quot;,\\&quot;splashImageBase64\\&quot;: \\&quot;iVBORw0KGgAAAAElFTkSuQmCC\\&quot;,\\&quot;iconImageBase64\\&quot;: \\&quot;iVBORw0KGgoAAAA6ZH+gAAAABJRU5ErkJggg==\\&quot;},\\&quot;build-configuration\\&quot;: {\\&quot;token\\&quot;: \\&quot;dwqsdadsa\\&quot;,\\&quot;storePassword\\&quot;: \\&quot;3332sa\\&quot;,\\&quot;googleServicesAndroidBase64\\&quot;: \\&quot;ewogICIxIgp9\\&quot;,\\&quot;keystore\\&quot;: \\&quot;/u3+7Iy4IJYPYxbg==\\&quot;,\\&quot;keystore-password\\&quot;: \\&quot;33332d\\&quot;,\\&quot;keystore-alias\\&quot;: \\&quot;consist\\&quot;,\\&quot;googleServicesIOSBase64\\&quot;: \\&quot;PD94bWc3Q+\\&quot;},\\&quot;appConfiguration\\&quot;: {\\&quot;id\\&quot;: \\&quot;94c2c3063ee3fbc3847ce6\\&quot;,\\&quot;appVersion\\&quot;: \\&quot;7.9.0\\&quot;,\\&quot;buildVersion\\&quot;: \\&quot;1.0.0.0.0\\&quot;,\\&quot;responseContext\\&quot;: \\&quot;pruebareportes\\&quot;,\\&quot;soVersion\\&quot;: \\&quot;android\\&quot;,\\&quot;initialContext\\&quot;: {\\&quot;name\\&quot;: \\&quot;pruebareportes\\&quot;,\\&quot;url\\&quot;: \\&quot;pruebareportes.test.com\\&quot;},\\&quot;appName\\&quot;: \\&quot;test\\&quot;,\\&quot;appId\\&quot;: \\&quot;com.rrrr.test\\&quot;,\\&quot;tabs\\&quot;: [{\\&quot;iconName\\&quot;: \\&quot;icon_app-home\\&quot;,\\&quot;configuration\\&quot;: {\\&quot;item1\\&quot;: \\&quot;prueba\\&quot;},\\&quot;title\\&quot;: \\&quot;Inicio\\&quot;,\\&quot;type\\&quot;: \\&quot;home\\&quot;}]}}}\\&quot;}&quot;}\r\n```\r\nI cannot get any data from it using jq, i keep getting nulls or &quot;Cannot index string with string &quot;\r\n```\r\njq &#39;.xJSON.statusCode&#39; jsontest\r\njq: error (at jsontest:1): Cannot index string with string &quot;statusCode&quot;\r\n...\r\n\r\njq &#39;.appConfiguration.appId&#39; jsontest\r\nnull\r\n...\r\n```\r\nI Would really need some help, thanks!",
        "link": "https://stackoverflow.com/questions/71745498/jq-error-at-jsontest1-cannot-index-string-with-string",
        "title": "jq: error (at jsontest:1): Cannot index string with string"
    },
    {
        "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": 1649157146,
                "post_id": 71750689,
                "comment_id": 126799490,
                "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": 1649157200,
                "post_id": 71750689,
                "comment_id": 126799510,
                "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": 1649157358,
                "post_id": 71750689,
                "comment_id": 126799563,
                "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": 1649157412,
                "post_id": 71750689,
                "comment_id": 126799581,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 351076,
                    "reputation": 1985,
                    "user_id": 687331,
                    "user_type": "registered",
                    "accept_rate": 53,
                    "profile_image": "https://www.gravatar.com/avatar/567c5c0cc4cc8201125f2f829ace544d?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Anand",
                    "link": "https://stackoverflow.com/users/687331/anand"
                },
                "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": 1649158083,
                "post_id": 71750689,
                "comment_id": 126799812,
                "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": 1649158729,
                "post_id": 71750689,
                "comment_id": 126800037,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1649159665,
                "creation_date": 1649159665,
                "answer_id": 71751319,
                "question_id": 71750689,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "It&#39;s quite unclear what you are aiming at, but here&#39;s one way how you would read from a JSON file using just one call to `jq`, and most probably without the need to employ `sed` or `tr`. The selection as well as the formatting can easily be adjusted to your liking.\r\n~~~sh\r\njq -r &#39;.color | to_entries[] | &quot;\\(.key): \\(.value.value)&quot;&#39; &quot;$figma_json&quot;\r\n~~~\r\n~~~none\r\ngray1: #333333ff\r\ngray2: #4f4f4fff\r\ngray3: #828282ff\r\ngray4: #bdbdbdff\r\ngray5: #e0e0e0ff\r\ngray6: #f2f2f2ff\r\nred: #eb5757ff\r\norange: #f2994aff\r\nyellow: #f2c94cff\r\ngreen1: #219653ff\r\ngreen2: #27ae60ff\r\ngreen3: #6fcf97ff\r\nblue1: #2f80edff\r\nblue2: #2d9cdbff\r\nblue3: #56ccf2ff\r\npurple1: #9b51e0ff\r\npurple2: #bb6bd9ff\r\n~~~\r\n[Demo](https://jqplay.org/s/ONLXsDosA5)",
                "title": "Shell Script error: &quot;For loop&quot; is not throwing the expected output"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -1,
        "last_activity_date": 1649166144,
        "creation_date": 1649156811,
        "last_edit_date": 1649166144,
        "question_id": 71750689,
        "body_markdown": "I have json file which extract the color value from the file. For some reason, it only fetch only one block of code &amp; for the rest it throws error.\r\n\r\nsnippet\r\n\r\n```\r\n#!/bin/bash\r\n\r\nclear\r\n\r\necho &quot;Add the figma json file path&quot;\r\nread path\r\n\r\nfigma_json=&quot;$(echo -e &quot;${path}&quot; | tr -d &#39;[:space:]&#39;)&quot;\r\n\r\necho &quot;*****************************************&quot;\r\n\r\n\r\ncolor_values=$(cat $figma_json | jq -r &#39;.color&#39;)\r\ncolor_keys=$(cat $figma_json | jq -r &#39;.color | keys&#39; |sed &#39;s,^ *,,; s, *$,,&#39;| tr -s &#39; &#39; | tr &#39; &#39; &#39;_&#39;)\r\n\r\necho $color_keys\r\n\r\n\r\nfor c_key in $color_keys\r\ndo\r\n\r\n    echo &quot;key string: $c_key&quot;\r\n\r\n    echo $color_values | jq &quot;.$c_key.value&quot;\r\n    echo &quot;*********************************************&quot;\r\n\r\ndone\r\n```\r\n\r\nOutput\r\n\r\n```\r\ntrimmed string: &quot;gray1&quot;,\r\n{\r\n  &quot;description&quot;: &quot;&quot;,\r\n  &quot;type&quot;: &quot;color&quot;,\r\n  &quot;value&quot;: &quot;#333333ff&quot;,\r\n  &quot;extensions&quot;: {\r\n    &quot;org.lukasoppermann.figmaDesignTokens&quot;: {\r\n      &quot;styleId&quot;: &quot;S:0b49d19e868ec919fac01ec377bb989174094d7e,&quot;,\r\n      &quot;exportKey&quot;: &quot;color&quot;\r\n    }\r\n  }\r\n}\r\nnull\r\n*********************************************\r\ntrimmed string: &quot;gray2&quot; //Expected output\r\n&quot;#333333ff&quot;\r\n*********************************************\r\n```\r\n\r\nIf we look at the second output it prints the hex value of gray2 which is the expected output\r\nPlease use the follow link to get the json file\r\n[link][1]\r\n\r\n\r\n  [1]: https://drive.google.com/file/d/1kBMPvBkE-xmbNVUmvqw7Wrp2Em3K7j-P/view?usp=sharing",
        "link": "https://stackoverflow.com/questions/71750689/shell-script-error-for-loop-is-not-throwing-the-expected-output",
        "title": "Shell Script error: &quot;For loop&quot; is not throwing the expected output"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1649176535,
                "last_edit_date": 1649176535,
                "creation_date": 1649162023,
                "answer_id": 71751858,
                "question_id": 71751805,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You don&#39;t need a bash intervention with a `while` read loop, do it all with `jq` \r\n\r\n```none\r\njq -r &#39;.variables | keys_unsorted[] as $k | &quot;\\($k) \\(.[$k].value)&quot;&#39;\r\n```\r\n\r\nproduces a result as\r\n\r\n```none\r\nvariable1 value1\r\nvariable2 value2\r\n```\r\n\r\n[jqplay - demo][1]\r\n\r\n\r\n  [1]: https://jqplay.org/s/rmGBCKs_QT",
                "title": "JQ: access object by key variable"
            },
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1649162377,
                "creation_date": 1649162377,
                "answer_id": 71751957,
                "question_id": 71751805,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Using `to_entries` to split up the `.variables` object into an array of key-value pairs is also an option:\r\n~~~sh\r\njq -r &#39;.variables | to_entries[] | &quot;\\(.key): \\(.value.value)&quot;&#39;\r\n~~~\r\n~~~json\r\nvariable1: value1\r\nvariable2: value2\r\n~~~\r\n[Demo](https://jqplay.org/s/DVKwasnPSW)",
                "title": "JQ: access object by key variable"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1659015694,
                "creation_date": 1659015694,
                "answer_id": 73153879,
                "question_id": 71751805,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "```\r\njq &#39;.variables | with_entries(.value |= .value)&#39;\r\n```\r\n\r\n```json\r\n{\r\n  &quot;variable1&quot;: &quot;value1&quot;,\r\n  &quot;variable2&quot;: &quot;value2&quot;\r\n}\r\n```\r\n",
                "title": "JQ: access object by key variable"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 1,
        "last_activity_date": 1659015694,
        "creation_date": 1649161820,
        "last_edit_date": 1649169262,
        "question_id": 71751805,
        "body_markdown": "Assume I have an object &#39;variables&#39; containing a variable amount of unspecified other objects:\r\n\r\n    {\r\n       &quot;id&quot;:5,\r\n       &quot;variables&quot;:{\r\n          &quot;variable1&quot;:{\r\n             &quot;isSecret&quot;:null,\r\n             &quot;value&quot;:&quot;value1&quot;\r\n          },\r\n          &quot;variable2&quot;:{\r\n             &quot;isSecret&quot;:null,\r\n             &quot;value&quot;:&quot;value2&quot;\r\n          }\r\n       }\r\n    }\r\n\r\nWhat I need is a way to access both key name and the value of &#39;value&#39; in the same loop.\r\n\r\nI tried the following:\r\n\r\n    echo $service_connection | jq -r &#39;.variables | keys[]&#39; | while read variable; do\r\n        echo $variable\r\n        echo $service_connection | jq --arg var &quot;$variable&quot; -c &#39;.variables[$var].value&#39;\r\n    done\r\n\r\nThis gives me the following output:\r\n\r\n    variable1\r\n    null\r\n    variable2\r\n    null\r\n\r\nTo me, it seems like I would need something like \r\n\r\n    &#39;.variables.$var&#39;\r\n\r\nor\r\n\r\n    &#39;.variables.[$var]&#39;\r\n\r\nBut jq can&#39;t parse it.\r\n\r\nWhat am I doing wrong?",
        "link": "https://stackoverflow.com/questions/71751805/jq-access-object-by-key-variable",
        "title": "JQ: access object by key variable"
    },
    {
        "tags": [
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1649250745,
                "post_id": 71767039,
                "comment_id": 126828007,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 6196394,
                    "reputation": 86601,
                    "user_id": 5291015,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/4tAvO.jpg?s=256",
                    "display_name": "Inian",
                    "link": "https://stackoverflow.com/users/5291015/inian"
                },
                "reply_to_user": {
                    "account_id": 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": 1649250944,
                "post_id": 71767039,
                "comment_id": 126828094,
                "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": 1649251050,
                "post_id": 71767039,
                "comment_id": 126828146,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 11691407,
                    "reputation": 155,
                    "user_id": 8559593,
                    "user_type": "registered",
                    "profile_image": "https://graph.facebook.com/10213357189341225/picture?type=large",
                    "display_name": "Gal Yakir",
                    "link": "https://stackoverflow.com/users/8559593/gal-yakir"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1649270604,
                "post_id": 71767039,
                "comment_id": 126836200,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "is_answered": false,
        "answer_count": 0,
        "score": 0,
        "last_activity_date": 1649251023,
        "creation_date": 1649249288,
        "question_id": 71767039,
        "body_markdown": "I have JSON name values that look like this\r\n\r\n        {\r\n      &quot;key1&quot;: true,\r\n      &quot;key2&quot;: &quot;1.9.2&quot;,\r\n      &quot;key3&quot;: &quot;value3&quot;\r\n       }\r\nhow can I loop over it using bash  and jq so the output will look like this:\r\n\r\n    export key1=true\r\n    export key2=&quot;1.9.2&quot;\r\n    export key3=&quot;value3&quot;\r\n\r\n",
        "link": "https://stackoverflow.com/questions/71767039/get-value-and-keys-from-json-to-use-as-export",
        "title": "get value and keys from json to use as export"
    },
    {
        "tags": [
            "json",
            "group-by",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1649795574,
                "last_edit_date": 1649795574,
                "creation_date": 1649266243,
                "answer_id": 71771255,
                "question_id": 71770482,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can use the same technique with `group_by` to group by `.NexposeID` as you did with `.&quot;Host Name&quot;`:\r\n~~~sh\r\njq &#39;\r\n  group_by(.&quot;Host Name&quot;) | map(\r\n    (.[0] | {&quot;Host Name&quot;, &quot;IP Address&quot;}) + {Vuln: (\r\n      group_by(.NexposeID) | map(\r\n        .[0] | {(.NexposeID): {Proof, &quot;Vulnerability Description&quot;, &quot; Vulnerability Title&quot;}}\r\n      )\r\n      | add\r\n    )}\r\n  )\r\n&#39;\r\n~~~\r\n[Demo](https://jqplay.org/s/IiDDGr_1SE)\r\n\r\nYou may also employ `reduce` to avoid `add`ing the fields afterwards:\r\n~~~sh\r\njq &#39;\r\n  group_by(.&quot;Host Name&quot;) | map(\r\n    reduce group_by(.NexposeID)[][0] as $g (\r\n      .[0] | {&quot;Host Name&quot;, &quot;IP Address&quot;};\r\n      .Vuln[$g.NexposeID] = ($g | {Proof, &quot;Vulnerability Description&quot;, &quot; Vulnerability Title&quot;})\r\n    )\r\n  )\r\n&#39;\r\n~~~\r\n[Demo](https://jqplay.org/s/pMQsHSViYP)\r\n\r\nOutput:\r\n~~~json\r\n[\r\n  {\r\n    &quot;Host Name&quot;: &quot;host1&quot;,\r\n    &quot;IP Address&quot;: &quot;10.1.10.20&quot;,\r\n    &quot;Vuln&quot;: {\r\n      &quot;apache-log4j-core-cve-2021-44228&quot;: {\r\n        &quot;Proof&quot;: &quot;Vulnerable software installed: Apache Log4j Core 2.8.2 (/opt/IBM/WebSphere/AppServer/properties/patches/backup/9.0.5.3-WS-WASProd-IFPH42762/systemApps/isclite.ear/kc.war/WEB-INF/lib/log4j-core-2.8.2.jar)No mitigation applied. JndiLookup class discovered.&quot;,\r\n        &quot;Vulnerability Description&quot;: &quot;One vector that allowed exposure to this vulnerability was Log4j&amp;#8217;s allowance of Lookups to appear in log messages. This meant that when user input is logged, and that user input contained a JNDI Lookup pointing to a malicious server, then Log4j would resolve that JNDI Lookup, connect to that server, and potentially download serialized Java code from that remote server. This in turn could execute any code during deserialization. This is known as a RCE (Remote Code Execution) attack. In version 2.12.2 Log4j disables access to JNDI by default. Usage of JNDI in configuration now need to be enabled explicitly. Calls to the JndiLookup will now return a constant string. Also, Log4j now limits the protocols by default to only java. The message lookups feature has been completely removed. In version 2.16.0 the message lookups feature has been completely removed. Lookups in configuration still work. Furthermore, Log4j now disables access to JNDI by default. JNDI lookups in configuration now need to be enabled explicitly. Also, Log4j now limits the protocols by default to only java, ldap, and ldaps and limits the ldap protocols to only accessing Java primitive objects. Hosts other than the local host need to be explicitly allowed. This check requires the Security Console and Scan Engines to be on product version 6.6.118 or later.&quot;,\r\n        &quot; Vulnerability Title&quot;: &quot;Apache Log4j Core: CVE-2021-44228: JNDI support has not restricted what names could be resolved allowing remote code execution&quot;\r\n      },\r\n      &quot;apache-log4j-core-cve-2021-45046&quot;: {\r\n        &quot;Proof&quot;: &quot;Vulnerable software installed: Apache Log4j Core 2.8.2 (/opt/IBM/WebSphere/AppServer/properties/patches/backup/9.0.5.3-WS-WASProd-IFPH42762/systemApps/isclite.ear/kc.war/WEB-INF/lib/log4j-core-2.8.2.jar)No mitigation applied. JndiLookup class discovered.&quot;,\r\n        &quot;Vulnerability Description&quot;: &quot;It was found that the fix to address CVE-2021-44228 in Apache Log4j 2.15.0 was incomplete in certain non-default configurations. When the logging configuration uses a non-default Pattern Layout with a Context Lookup (for example, $${ctx:loginId}), attackers with control over Thread Context Map (MDC) input data can craft malicious input data using a JNDI Lookup pattern, resulting in an information leak and remote code execution in some environments and local code execution in all environments; remote code execution has been demonstrated on macOS but no other tested environments.&quot;,\r\n        &quot; Vulnerability Title&quot;: &quot;Apache Log4j Core: CVE-2021-45046: Apache Log4j2 Thread Context Lookup Pattern vulnerable to remote code execution in certain non-default configurations&quot;\r\n      },\r\n      &quot;apache-log4j-core-cve-2021-45105&quot;: {\r\n        &quot;Proof&quot;: &quot;Vulnerable software installed: Apache Log4j Core 2.8.2 (/opt/IBM/WebSphere/AppServer/properties/patches/backup/9.0.5.3-WS-WASProd-IFPH42762/systemApps/isclite.ear/kc.war/WEB-INF/lib/log4j-core-2.8.2.jar)&quot;,\r\n        &quot;Vulnerability Description&quot;: &quot;Apache Log4j2 versions 2.0-alpha1 through 2.16.0 did not protect from uncontrolled recursion from self-referential lookups. When the logging configuration uses a non-default Pattern Layout with a Context Lookup (for example, $${ctx:loginId}), attackers with control over Thread Context Map (MDC) input data can craft malicious input data that contains a recursive lookup, resulting in a StackOverflowError that will terminate the process. This is also known as a DOS (Denial of Service) attack.&quot;,\r\n        &quot; Vulnerability Title&quot;: &quot;Apache Log4j Core: CVE-2021-45105: Apache Log4j2 does not always protect from infinite recursion in lookup evaluation&quot;\r\n      }\r\n    }\r\n  },\r\n  {\r\n    &quot;Host Name&quot;: &quot;host2&quot;,\r\n    &quot;IP Address&quot;: &quot;10.1.10.10&quot;,\r\n    &quot;Vuln&quot;: {\r\n      &quot;apache-log4j-core-cve-2021-44228&quot;: {\r\n        &quot;Proof&quot;: &quot;Vulnerable software installed: Apache Log4j Core 2.8.2 (/opt/IBM/WebSphere/AppServer/properties/patches/backup/9.0.5.3-WS-WASProd-IFPH42762/systemApps/isclite.ear/kc.war/WEB-INF/lib/log4j-core-2.8.2.jar)No mitigation applied. JndiLookup class discovered.&quot;,\r\n        &quot;Vulnerability Description&quot;: &quot;One vector that allowed exposure to this vulnerability was Log4j&amp;#8217;s allowance of Lookups to appear in log messages. This meant that when user input is logged, and that user input contained a JNDI Lookup pointing to a malicious server, then Log4j would resolve that JNDI Lookup, connect to that server, and potentially download serialized Java code from that remote server. This in turn could execute any code during deserialization. This is known as a RCE (Remote Code Execution) attack. In version 2.12.2 Log4j disables access to JNDI by default. Usage of JNDI in configuration now need to be enabled explicitly. Calls to the JndiLookup will now return a constant string. Also, Log4j now limits the protocols by default to only java. The message lookups feature has been completely removed. In version 2.16.0 the message lookups feature has been completely removed. Lookups in configuration still work. Furthermore, Log4j now disables access to JNDI by default. JNDI lookups in configuration now need to be enabled explicitly. Also, Log4j now limits the protocols by default to only java, ldap, and ldaps and limits the ldap protocols to only accessing Java primitive objects. Hosts other than the local host need to be explicitly allowed. This check requires the Security Console and Scan Engines to be on product version 6.6.118 or later.&quot;,\r\n        &quot; Vulnerability Title&quot;: &quot;Apache Log4j Core: CVE-2021-44228: JNDI support has not restricted what names could be resolved allowing remote code execution&quot;\r\n      },\r\n      &quot;apache-log4j-core-cve-2021-45046&quot;: {\r\n        &quot;Proof&quot;: &quot;Vulnerable software installed: Apache Log4j Core 2.8.2 (/opt/IBM/WebSphere/AppServer/properties/patches/backup/9.0.5.3-WS-WASProd-IFPH42762/systemApps/isclite.ear/kc.war/WEB-INF/lib/log4j-core-2.8.2.jar)No mitigation applied. JndiLookup class discovered.&quot;,\r\n        &quot;Vulnerability Description&quot;: &quot;It was found that the fix to address CVE-2021-44228 in Apache Log4j 2.15.0 was incomplete in certain non-default configurations. When the logging configuration uses a non-default Pattern Layout with a Context Lookup (for example, $${ctx:loginId}), attackers with control over Thread Context Map (MDC) input data can craft malicious input data using a JNDI Lookup pattern, resulting in an information leak and remote code execution in some environments and local code execution in all environments; remote code execution has been demonstrated on macOS but no other tested environments.&quot;,\r\n        &quot; Vulnerability Title&quot;: &quot;Apache Log4j Core: CVE-2021-45046: Apache Log4j2 Thread Context Lookup Pattern vulnerable to remote code execution in certain non-default configurations&quot;\r\n      },\r\n      &quot;apache-log4j-core-cve-2021-45105&quot;: {\r\n        &quot;Proof&quot;: &quot;Vulnerable software installed: Apache Log4j Core 2.8.2 (/opt/IBM/WebSphere/AppServer/properties/patches/backup/9.0.5.3-WS-WASProd-IFPH42762/systemApps/isclite.ear/kc.war/WEB-INF/lib/log4j-core-2.8.2.jar)&quot;,\r\n        &quot;Vulnerability Description&quot;: &quot;Apache Log4j2 versions 2.0-alpha1 through 2.16.0 did not protect from uncontrolled recursion from self-referential lookups. When the logging configuration uses a non-default Pattern Layout with a Context Lookup (for example, $${ctx:loginId}), attackers with control over Thread Context Map (MDC) input data can craft malicious input data that contains a recursive lookup, resulting in a StackOverflowError that will terminate the process. This is also known as a DOS (Denial of Service) attack.&quot;,\r\n        &quot; Vulnerability Title&quot;: &quot;Apache Log4j Core: CVE-2021-45105: Apache Log4j2 does not always protect from infinite recursion in lookup evaluation&quot;\r\n      }\r\n    }\r\n  }\r\n]\r\n~~~\r\n\r\n---\r\nEdit: If you prefer the `.Vuln` field to be an array of objects, here&#39;s a solution using `unique_by`:\r\n~~~sh\r\njq &#39;\r\n  group_by(.&quot;Host Name&quot;) | map(\r\n    (.[0] | {&quot;Host Name&quot;, &quot;IP Address&quot;}) +\r\n    {Vuln: unique_by(.NexposeID) | map(\r\n      {Proof, &quot;Vulnerability Description&quot;, &quot; Vulnerability Title&quot;}\r\n    )}\r\n  )\r\n&#39;\r\n~~~\r\n~~~json\r\n[\r\n  {\r\n    &quot;Host Name&quot;: &quot;host1&quot;,\r\n    &quot;IP Address&quot;: &quot;10.1.10.20&quot;,\r\n    &quot;Vuln&quot;: [\r\n      {\r\n        &quot;Proof&quot;: &quot;Vulnerable software installed: Apache Log4j Core 2.8.2 (/opt/IBM/WebSphere/AppServer/properties/patches/backup/9.0.5.3-WS-WASProd-IFPH42762/systemApps/isclite.ear/kc.war/WEB-INF/lib/log4j-core-2.8.2.jar)No mitigation applied. JndiLookup class discovered.&quot;,\r\n        &quot;Vulnerability Description&quot;: &quot;One vector that allowed exposure to this vulnerability was Log4j&amp;#8217;s allowance of Lookups to appear in log messages. This meant that when user input is logged, and that user input contained a JNDI Lookup pointing to a malicious server, then Log4j would resolve that JNDI Lookup, connect to that server, and potentially download serialized Java code from that remote server. This in turn could execute any code during deserialization. This is known as a RCE (Remote Code Execution) attack. In version 2.12.2 Log4j disables access to JNDI by default. Usage of JNDI in configuration now need to be enabled explicitly. Calls to the JndiLookup will now return a constant string. Also, Log4j now limits the protocols by default to only java. The message lookups feature has been completely removed. In version 2.16.0 the message lookups feature has been completely removed. Lookups in configuration still work. Furthermore, Log4j now disables access to JNDI by default. JNDI lookups in configuration now need to be enabled explicitly. Also, Log4j now limits the protocols by default to only java, ldap, and ldaps and limits the ldap protocols to only accessing Java primitive objects. Hosts other than the local host need to be explicitly allowed. This check requires the Security Console and Scan Engines to be on product version 6.6.118 or later.&quot;,\r\n        &quot; Vulnerability Title&quot;: &quot;Apache Log4j Core: CVE-2021-44228: JNDI support has not restricted what names could be resolved allowing remote code execution&quot;\r\n      },\r\n      {\r\n        &quot;Proof&quot;: &quot;Vulnerable software installed: Apache Log4j Core 2.8.2 (/opt/IBM/WebSphere/AppServer/properties/patches/backup/9.0.5.3-WS-WASProd-IFPH42762/systemApps/isclite.ear/kc.war/WEB-INF/lib/log4j-core-2.8.2.jar)No mitigation applied. JndiLookup class discovered.&quot;,\r\n        &quot;Vulnerability Description&quot;: &quot;It was found that the fix to address CVE-2021-44228 in Apache Log4j 2.15.0 was incomplete in certain non-default configurations. When the logging configuration uses a non-default Pattern Layout with a Context Lookup (for example, $${ctx:loginId}), attackers with control over Thread Context Map (MDC) input data can craft malicious input data using a JNDI Lookup pattern, resulting in an information leak and remote code execution in some environments and local code execution in all environments; remote code execution has been demonstrated on macOS but no other tested environments.&quot;,\r\n        &quot; Vulnerability Title&quot;: &quot;Apache Log4j Core: CVE-2021-45046: Apache Log4j2 Thread Context Lookup Pattern vulnerable to remote code execution in certain non-default configurations&quot;\r\n      },\r\n      {\r\n        &quot;Proof&quot;: &quot;Vulnerable software installed: Apache Log4j Core 2.8.2 (/opt/IBM/WebSphere/AppServer/properties/patches/backup/9.0.5.3-WS-WASProd-IFPH42762/systemApps/isclite.ear/kc.war/WEB-INF/lib/log4j-core-2.8.2.jar)&quot;,\r\n        &quot;Vulnerability Description&quot;: &quot;Apache Log4j2 versions 2.0-alpha1 through 2.16.0 did not protect from uncontrolled recursion from self-referential lookups. When the logging configuration uses a non-default Pattern Layout with a Context Lookup (for example, $${ctx:loginId}), attackers with control over Thread Context Map (MDC) input data can craft malicious input data that contains a recursive lookup, resulting in a StackOverflowError that will terminate the process. This is also known as a DOS (Denial of Service) attack.&quot;,\r\n        &quot; Vulnerability Title&quot;: &quot;Apache Log4j Core: CVE-2021-45105: Apache Log4j2 does not always protect from infinite recursion in lookup evaluation&quot;\r\n      }\r\n    ]\r\n  },\r\n  {\r\n    &quot;Host Name&quot;: &quot;host2&quot;,\r\n    &quot;IP Address&quot;: &quot;10.1.10.10&quot;,\r\n    &quot;Vuln&quot;: [\r\n      {\r\n        &quot;Proof&quot;: &quot;Vulnerable software installed: Apache Log4j Core 2.8.2 (/opt/IBM/WebSphere/AppServer/properties/patches/backup/9.0.5.3-WS-WASProd-IFPH42762/systemApps/isclite.ear/kc.war/WEB-INF/lib/log4j-core-2.8.2.jar)No mitigation applied. JndiLookup class discovered.&quot;,\r\n        &quot;Vulnerability Description&quot;: &quot;One vector that allowed exposure to this vulnerability was Log4j&amp;#8217;s allowance of Lookups to appear in log messages. This meant that when user input is logged, and that user input contained a JNDI Lookup pointing to a malicious server, then Log4j would resolve that JNDI Lookup, connect to that server, and potentially download serialized Java code from that remote server. This in turn could execute any code during deserialization. This is known as a RCE (Remote Code Execution) attack. In version 2.12.2 Log4j disables access to JNDI by default. Usage of JNDI in configuration now need to be enabled explicitly. Calls to the JndiLookup will now return a constant string. Also, Log4j now limits the protocols by default to only java. The message lookups feature has been completely removed. In version 2.16.0 the message lookups feature has been completely removed. Lookups in configuration still work. Furthermore, Log4j now disables access to JNDI by default. JNDI lookups in configuration now need to be enabled explicitly. Also, Log4j now limits the protocols by default to only java, ldap, and ldaps and limits the ldap protocols to only accessing Java primitive objects. Hosts other than the local host need to be explicitly allowed. This check requires the Security Console and Scan Engines to be on product version 6.6.118 or later.&quot;,\r\n        &quot; Vulnerability Title&quot;: &quot;Apache Log4j Core: CVE-2021-44228: JNDI support has not restricted what names could be resolved allowing remote code execution&quot;\r\n      },\r\n      {\r\n        &quot;Proof&quot;: &quot;Vulnerable software installed: Apache Log4j Core 2.8.2 (/opt/IBM/WebSphere/AppServer/properties/patches/backup/9.0.5.3-WS-WASProd-IFPH42762/systemApps/isclite.ear/kc.war/WEB-INF/lib/log4j-core-2.8.2.jar)No mitigation applied. JndiLookup class discovered.&quot;,\r\n        &quot;Vulnerability Description&quot;: &quot;It was found that the fix to address CVE-2021-44228 in Apache Log4j 2.15.0 was incomplete in certain non-default configurations. When the logging configuration uses a non-default Pattern Layout with a Context Lookup (for example, $${ctx:loginId}), attackers with control over Thread Context Map (MDC) input data can craft malicious input data using a JNDI Lookup pattern, resulting in an information leak and remote code execution in some environments and local code execution in all environments; remote code execution has been demonstrated on macOS but no other tested environments.&quot;,\r\n        &quot; Vulnerability Title&quot;: &quot;Apache Log4j Core: CVE-2021-45046: Apache Log4j2 Thread Context Lookup Pattern vulnerable to remote code execution in certain non-default configurations&quot;\r\n      },\r\n      {\r\n        &quot;Proof&quot;: &quot;Vulnerable software installed: Apache Log4j Core 2.8.2 (/opt/IBM/WebSphere/AppServer/properties/patches/backup/9.0.5.3-WS-WASProd-IFPH42762/systemApps/isclite.ear/kc.war/WEB-INF/lib/log4j-core-2.8.2.jar)&quot;,\r\n        &quot;Vulnerability Description&quot;: &quot;Apache Log4j2 versions 2.0-alpha1 through 2.16.0 did not protect from uncontrolled recursion from self-referential lookups. When the logging configuration uses a non-default Pattern Layout with a Context Lookup (for example, $${ctx:loginId}), attackers with control over Thread Context Map (MDC) input data can craft malicious input data that contains a recursive lookup, resulting in a StackOverflowError that will terminate the process. This is also known as a DOS (Denial of Service) attack.&quot;,\r\n        &quot; Vulnerability Title&quot;: &quot;Apache Log4j Core: CVE-2021-45105: Apache Log4j2 does not always protect from infinite recursion in lookup evaluation&quot;\r\n      }\r\n    ]\r\n  }\r\n]\r\n~~~\r\n[Demo](https://jqplay.org/s/exbxo55Dtz)",
                "title": "Group objects by distinct value and while returning list of common values in jq"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1649795574,
        "creation_date": 1649262766,
        "last_edit_date": 1649277885,
        "question_id": 71770482,
        "body_markdown": "I have an array of vulnerabilities with duplicate hostnames and vulns. I would like to output an object by hostname and IP to include a list of vulnerabilities associated to that host.\r\n\r\nSo far I have been able to pull the object below with this query ```jq &#39;group_by(.&quot;Host Name&quot;) | map({&quot;HostName&quot;: .[0].&quot;Host Name&quot;, &quot;IP&quot;: .[0].&quot;IP Address&quot;, Vuln: map(.NexposeID) | unique})&#39;```\r\n\r\nWhat I&#39;m missing is an array of &quot;Vuln&quot; objects to include values like proof, description, and title for each nexposeid. \r\n\r\n```\r\n[\r\n  {\r\n    &quot;HostName&quot;: &quot;host1&quot;,\r\n    &quot;IP&quot;: &quot;10.1.10.20&quot;,\r\n    &quot;Vuln&quot;: [\r\n      &quot;apache-log4j-core-cve-2021-44228&quot;,\r\n      &quot;apache-log4j-core-cve-2021-45046&quot;,\r\n      &quot;apache-log4j-core-cve-2021-45105&quot;\r\n    ]\r\n  },\r\n  {\r\n    &quot;HostName&quot;: &quot;host2&quot;,\r\n    &quot;IP&quot;: &quot;10.1.10.10&quot;,\r\n    &quot;Vuln&quot;: [\r\n      &quot;apache-log4j-core-cve-2021-44228&quot;,\r\n      &quot;apache-log4j-core-cve-2021-45046&quot;,\r\n      &quot;apache-log4j-core-cve-2021-45105&quot;\r\n    ]\r\n  }\r\n]\r\n```\r\n\r\n**Sample JSON**\r\n\r\n```\r\n[\r\n  {\r\n    &quot; Vulnerability Title&quot;: &quot;Apache Log4j Core: CVE-2021-45046: Apache Log4j2 Thread Context Lookup Pattern vulnerable to remote code execution in certain non-default configurations&quot;,\r\n    &quot;Host Name&quot;: &quot;host1&quot;,\r\n    &quot;IP Address&quot;: &quot;10.1.10.20&quot;,\r\n    &quot;NexposeID&quot;: &quot;apache-log4j-core-cve-2021-45046&quot;,\r\n    &quot;Proof&quot;: &quot;Vulnerable software installed: Apache Log4j Core 2.8.2 (/opt/IBM/WebSphere/AppServer/properties/patches/backup/9.0.5.3-WS-WASProd-IFPH42762/systemApps/isclite.ear/kc.war/WEB-INF/lib/log4j-core-2.8.2.jar)No mitigation applied. JndiLookup class discovered.&quot;,\r\n    &quot;Proof Key&quot;: &quot;/opt/IBM/WebSphere/AppServer/properties/patches/backup/9.0.5.3-WS-WASProd-IFPH42762/systemApps/isclite.ear/kc.war/WEB-INF/lib/log4j-core-2.8.2.jar&quot;,\r\n    &quot;Solution Fix&quot;: &quot;Download and apply the patch from: https://logging.apache.org/log4j/2.x/download.html (https://logging.apache.org/log4j/2.x/download.html)&quot;,\r\n    &quot;Solution Summary&quot;: &quot;Upgrade Apache Log4j Core to the latest version&quot;,\r\n    &quot;Solution Type&quot;: &quot;PATCH&quot;,\r\n    &quot;Solution url&quot;: &quot;https://logging.apache.org/log4j/2.x/download.html&quot;,\r\n    &quot;Vulnerability Description&quot;: &quot;It was found that the fix to address CVE-2021-44228 in Apache Log4j 2.15.0 was incomplete in certain non-default configurations. When the logging configuration uses a non-default Pattern Layout with a Context Lookup (for example, $${ctx:loginId}), attackers with control over Thread Context Map (MDC) input data can craft malicious input data using a JNDI Lookup pattern, resulting in an information leak and remote code execution in some environments and local code execution in all environments; remote code execution has been demonstrated on macOS but no other tested environments.&quot;\r\n  },\r\n  {\r\n    &quot; Vulnerability Title&quot;: &quot;Apache Log4j Core: CVE-2021-45046: Apache Log4j2 Thread Context Lookup Pattern vulnerable to remote code execution in certain non-default configurations&quot;,\r\n    &quot;Host Name&quot;: &quot;host1&quot;,\r\n    &quot;IP Address&quot;: &quot;10.1.10.20&quot;,\r\n    &quot;NexposeID&quot;: &quot;apache-log4j-core-cve-2021-45046&quot;,\r\n    &quot;Proof&quot;: &quot;Vulnerable software installed: Apache Log4j Core 2.8.2 (/opt/IBM/WebSphere/AppServer/properties/patches/backup/9.0.5.3-WS-WASProd-IFPH42762/systemApps/isclite.ear/kc.war/WEB-INF/lib/log4j-core-2.8.2.jar)No mitigation applied. JndiLookup class discovered.&quot;,\r\n    &quot;Proof Key&quot;: &quot;/opt/IBM/WebSphere/AppServer/properties/patches/backup/9.0.5.3-WS-WASProd-IFPH42762/systemApps/isclite.ear/kc.war/WEB-INF/lib/log4j-core-2.8.2.jar&quot;,\r\n    &quot;Solution Fix&quot;: &quot;Download and apply the patch from: https://logging.apache.org/log4j/2.x/download.html (https://logging.apache.org/log4j/2.x/download.html)&quot;,\r\n    &quot;Solution Summary&quot;: &quot;Upgrade Apache Log4j Core to the latest version&quot;,\r\n    &quot;Solution Type&quot;: &quot;PATCH&quot;,\r\n    &quot;Solution url&quot;: &quot;https://logging.apache.org/log4j/2.x/download.html&quot;,\r\n    &quot;Vulnerability Description&quot;: &quot;It was found that the fix to address CVE-2021-44228 in Apache Log4j 2.15.0 was incomplete in certain non-default configurations. When the logging configuration uses a non-default Pattern Layout with a Context Lookup (for example, $${ctx:loginId}), attackers with control over Thread Context Map (MDC) input data can craft malicious input data using a JNDI Lookup pattern, resulting in an information leak and remote code execution in some environments and local code execution in all environments; remote code execution has been demonstrated on macOS but no other tested environments.&quot;\r\n  },\r\n  {\r\n    &quot; Vulnerability Title&quot;: &quot;Apache Log4j Core: CVE-2021-45046: Apache Log4j2 Thread Context Lookup Pattern vulnerable to remote code execution in certain non-default configurations&quot;,\r\n    &quot;Host Name&quot;: &quot;host2&quot;,\r\n    &quot;IP Address&quot;: &quot;10.1.10.10&quot;,\r\n    &quot;NexposeID&quot;: &quot;apache-log4j-core-cve-2021-45046&quot;,\r\n    &quot;Proof&quot;: &quot;Vulnerable software installed: Apache Log4j Core 2.8.2 (/opt/IBM/WebSphere/AppServer/properties/patches/backup/9.0.5.3-WS-WASProd-IFPH42762/systemApps/isclite.ear/kc.war/WEB-INF/lib/log4j-core-2.8.2.jar)No mitigation applied. JndiLookup class discovered.&quot;,\r\n    &quot;Proof Key&quot;: &quot;/opt/IBM/WebSphere/AppServer/properties/patches/backup/9.0.5.3-WS-WASProd-IFPH42762/systemApps/isclite.ear/kc.war/WEB-INF/lib/log4j-core-2.8.2.jar&quot;,\r\n    &quot;Solution Fix&quot;: &quot;Download and apply the patch from: https://logging.apache.org/log4j/2.x/download.html (https://logging.apache.org/log4j/2.x/download.html)&quot;,\r\n    &quot;Solution Summary&quot;: &quot;Upgrade Apache Log4j Core to the latest version&quot;,\r\n    &quot;Solution Type&quot;: &quot;PATCH&quot;,\r\n    &quot;Solution url&quot;: &quot;https://logging.apache.org/log4j/2.x/download.html&quot;,\r\n    &quot;Vulnerability Description&quot;: &quot;It was found that the fix to address CVE-2021-44228 in Apache Log4j 2.15.0 was incomplete in certain non-default configurations. When the logging configuration uses a non-default Pattern Layout with a Context Lookup (for example, $${ctx:loginId}), attackers with control over Thread Context Map (MDC) input data can craft malicious input data using a JNDI Lookup pattern, resulting in an information leak and remote code execution in some environments and local code execution in all environments; remote code execution has been demonstrated on macOS but no other tested environments.&quot;\r\n  },\r\n  {\r\n    &quot; Vulnerability Title&quot;: &quot;Apache Log4j Core: CVE-2021-45046: Apache Log4j2 Thread Context Lookup Pattern vulnerable to remote code execution in certain non-default configurations&quot;,\r\n    &quot;Host Name&quot;: &quot;host2&quot;,\r\n    &quot;IP Address&quot;: &quot;10.1.10.10&quot;,\r\n    &quot;NexposeID&quot;: &quot;apache-log4j-core-cve-2021-45046&quot;,\r\n    &quot;Proof&quot;: &quot;Vulnerable software installed: Apache Log4j Core 2.8.2 (/opt/IBM/WebSphere/AppServer/properties/patches/backup/9.0.5.3-WS-WASProd-IFPH42762/systemApps/isclite.ear/kc.war/WEB-INF/lib/log4j-core-2.8.2.jar)No mitigation applied. JndiLookup class discovered.&quot;,\r\n    &quot;Proof Key&quot;: &quot;/opt/IBM/WebSphere/AppServer/properties/patches/backup/9.0.5.3-WS-WASProd-IFPH42762/systemApps/isclite.ear/kc.war/WEB-INF/lib/log4j-core-2.8.2.jar&quot;,\r\n    &quot;Solution Fix&quot;: &quot;Download and apply the patch from: https://logging.apache.org/log4j/2.x/download.html (https://logging.apache.org/log4j/2.x/download.html)&quot;,\r\n    &quot;Solution Summary&quot;: &quot;Upgrade Apache Log4j Core to the latest version&quot;,\r\n    &quot;Solution Type&quot;: &quot;PATCH&quot;,\r\n    &quot;Solution url&quot;: &quot;https://logging.apache.org/log4j/2.x/download.html&quot;,\r\n    &quot;Vulnerability Description&quot;: &quot;It was found that the fix to address CVE-2021-44228 in Apache Log4j 2.15.0 was incomplete in certain non-default configurations. When the logging configuration uses a non-default Pattern Layout with a Context Lookup (for example, $${ctx:loginId}), attackers with control over Thread Context Map (MDC) input data can craft malicious input data using a JNDI Lookup pattern, resulting in an information leak and remote code execution in some environments and local code execution in all environments; remote code execution has been demonstrated on macOS but no other tested environments.&quot;\r\n  },\r\n  {\r\n    &quot; Vulnerability Title&quot;: &quot;Apache Log4j Core: CVE-2021-45105: Apache Log4j2 does not always protect from infinite recursion in lookup evaluation&quot;,\r\n    &quot;Host Name&quot;: &quot;host1&quot;,\r\n    &quot;IP Address&quot;: &quot;10.1.10.20&quot;,\r\n    &quot;NexposeID&quot;: &quot;apache-log4j-core-cve-2021-45105&quot;,\r\n    &quot;Proof&quot;: &quot;Vulnerable software installed: Apache Log4j Core 2.8.2 (/opt/IBM/WebSphere/AppServer/properties/patches/backup/9.0.5.3-WS-WASProd-IFPH42762/systemApps/isclite.ear/kc.war/WEB-INF/lib/log4j-core-2.8.2.jar)&quot;,\r\n    &quot;Proof Key&quot;: &quot;/opt/IBM/WebSphere/AppServer/properties/patches/backup/9.0.5.3-WS-WASProd-IFPH42762/systemApps/isclite.ear/kc.war/WEB-INF/lib/log4j-core-2.8.2.jar&quot;,\r\n    &quot;Solution Fix&quot;: &quot;Download and apply the patch from: https://logging.apache.org/log4j/2.x/download.html (https://logging.apache.org/log4j/2.x/download.html)&quot;,\r\n    &quot;Solution Summary&quot;: &quot;Upgrade Apache Log4j Core to 2.12.3&quot;,\r\n    &quot;Solution Type&quot;: &quot;PATCH&quot;,\r\n    &quot;Solution url&quot;: &quot;https://logging.apache.org/log4j/2.x/download.html&quot;,\r\n    &quot;Vulnerability Description&quot;: &quot;Apache Log4j2 versions 2.0-alpha1 through 2.16.0 did not protect from uncontrolled recursion from self-referential lookups. When the logging configuration uses a non-default Pattern Layout with a Context Lookup (for example, $${ctx:loginId}), attackers with control over Thread Context Map (MDC) input data can craft malicious input data that contains a recursive lookup, resulting in a StackOverflowError that will terminate the process. This is also known as a DOS (Denial of Service) attack.&quot;\r\n  },\r\n  {\r\n    &quot; Vulnerability Title&quot;: &quot;Apache Log4j Core: CVE-2021-45105: Apache Log4j2 does not always protect from infinite recursion in lookup evaluation&quot;,\r\n    &quot;Host Name&quot;: &quot;host1&quot;,\r\n    &quot;IP Address&quot;: &quot;10.1.10.20&quot;,\r\n    &quot;NexposeID&quot;: &quot;apache-log4j-core-cve-2021-45105&quot;,\r\n    &quot;Proof&quot;: &quot;Vulnerable software installed: Apache Log4j Core 2.8.2 (/opt/IBM/WebSphere/AppServer/properties/patches/backup/9.0.5.3-WS-WASProd-IFPH42762/systemApps/isclite.ear/kc.war/WEB-INF/lib/log4j-core-2.8.2.jar)&quot;,\r\n    &quot;Proof Key&quot;: &quot;/opt/IBM/WebSphere/AppServer/properties/patches/backup/9.0.5.3-WS-WASProd-IFPH42762/systemApps/isclite.ear/kc.war/WEB-INF/lib/log4j-core-2.8.2.jar&quot;,\r\n    &quot;Solution Fix&quot;: &quot;Download and apply the patch from: https://logging.apache.org/log4j/2.x/download.html (https://logging.apache.org/log4j/2.x/download.html)&quot;,\r\n    &quot;Solution Summary&quot;: &quot;Upgrade Apache Log4j Core to 2.12.3&quot;,\r\n    &quot;Solution Type&quot;: &quot;PATCH&quot;,\r\n    &quot;Solution url&quot;: &quot;https://logging.apache.org/log4j/2.x/download.html&quot;,\r\n    &quot;Vulnerability Description&quot;: &quot;Apache Log4j2 versions 2.0-alpha1 through 2.16.0 did not protect from uncontrolled recursion from self-referential lookups. When the logging configuration uses a non-default Pattern Layout with a Context Lookup (for example, $${ctx:loginId}), attackers with control over Thread Context Map (MDC) input data can craft malicious input data that contains a recursive lookup, resulting in a StackOverflowError that will terminate the process. This is also known as a DOS (Denial of Service) attack.&quot;\r\n  },\r\n  {\r\n    &quot; Vulnerability Title&quot;: &quot;Apache Log4j Core: CVE-2021-45105: Apache Log4j2 does not always protect from infinite recursion in lookup evaluation&quot;,\r\n    &quot;Host Name&quot;: &quot;host2&quot;,\r\n    &quot;IP Address&quot;: &quot;10.1.10.10&quot;,\r\n    &quot;NexposeID&quot;: &quot;apache-log4j-core-cve-2021-45105&quot;,\r\n    &quot;Proof&quot;: &quot;Vulnerable software installed: Apache Log4j Core 2.8.2 (/opt/IBM/WebSphere/AppServer/properties/patches/backup/9.0.5.3-WS-WASProd-IFPH42762/systemApps/isclite.ear/kc.war/WEB-INF/lib/log4j-core-2.8.2.jar)&quot;,\r\n    &quot;Proof Key&quot;: &quot;/opt/IBM/WebSphere/AppServer/properties/patches/backup/9.0.5.3-WS-WASProd-IFPH42762/systemApps/isclite.ear/kc.war/WEB-INF/lib/log4j-core-2.8.2.jar&quot;,\r\n    &quot;Solution Fix&quot;: &quot;Download and apply the patch from: https://logging.apache.org/log4j/2.x/download.html (https://logging.apache.org/log4j/2.x/download.html)&quot;,\r\n    &quot;Solution Summary&quot;: &quot;Upgrade Apache Log4j Core to 2.12.3&quot;,\r\n    &quot;Solution Type&quot;: &quot;PATCH&quot;,\r\n    &quot;Solution url&quot;: &quot;https://logging.apache.org/log4j/2.x/download.html&quot;,\r\n    &quot;Vulnerability Description&quot;: &quot;Apache Log4j2 versions 2.0-alpha1 through 2.16.0 did not protect from uncontrolled recursion from self-referential lookups. When the logging configuration uses a non-default Pattern Layout with a Context Lookup (for example, $${ctx:loginId}), attackers with control over Thread Context Map (MDC) input data can craft malicious input data that contains a recursive lookup, resulting in a StackOverflowError that will terminate the process. This is also known as a DOS (Denial of Service) attack.&quot;\r\n  },\r\n  {\r\n    &quot; Vulnerability Title&quot;: &quot;Apache Log4j Core: CVE-2021-45105: Apache Log4j2 does not always protect from infinite recursion in lookup evaluation&quot;,\r\n    &quot;Host Name&quot;: &quot;host2&quot;,\r\n    &quot;IP Address&quot;: &quot;10.1.10.10&quot;,\r\n    &quot;NexposeID&quot;: &quot;apache-log4j-core-cve-2021-45105&quot;,\r\n    &quot;Proof&quot;: &quot;Vulnerable software installed: Apache Log4j Core 2.8.2 (/opt/IBM/WebSphere/AppServer/properties/patches/backup/9.0.5.3-WS-WASProd-IFPH42762/systemApps/isclite.ear/kc.war/WEB-INF/lib/log4j-core-2.8.2.jar)&quot;,\r\n    &quot;Proof Key&quot;: &quot;/opt/IBM/WebSphere/AppServer/properties/patches/backup/9.0.5.3-WS-WASProd-IFPH42762/systemApps/isclite.ear/kc.war/WEB-INF/lib/log4j-core-2.8.2.jar&quot;,\r\n    &quot;Solution Fix&quot;: &quot;Download and apply the patch from: https://logging.apache.org/log4j/2.x/download.html (https://logging.apache.org/log4j/2.x/download.html)&quot;,\r\n    &quot;Solution Summary&quot;: &quot;Upgrade Apache Log4j Core to 2.12.3&quot;,\r\n    &quot;Solution Type&quot;: &quot;PATCH&quot;,\r\n    &quot;Solution url&quot;: &quot;https://logging.apache.org/log4j/2.x/download.html&quot;,\r\n    &quot;Vulnerability Description&quot;: &quot;Apache Log4j2 versions 2.0-alpha1 through 2.16.0 did not protect from uncontrolled recursion from self-referential lookups. When the logging configuration uses a non-default Pattern Layout with a Context Lookup (for example, $${ctx:loginId}), attackers with control over Thread Context Map (MDC) input data can craft malicious input data that contains a recursive lookup, resulting in a StackOverflowError that will terminate the process. This is also known as a DOS (Denial of Service) attack.&quot;\r\n  },\r\n  {\r\n    &quot; Vulnerability Title&quot;: &quot;Apache Log4j Core: CVE-2021-44228: JNDI support has not restricted what names could be resolved allowing remote code execution&quot;,\r\n    &quot;Host Name&quot;: &quot;host1&quot;,\r\n    &quot;IP Address&quot;: &quot;10.1.10.20&quot;,\r\n    &quot;NexposeID&quot;: &quot;apache-log4j-core-cve-2021-44228&quot;,\r\n    &quot;Proof&quot;: &quot;Vulnerable software installed: Apache Log4j Core 2.8.2 (/opt/IBM/WebSphere/AppServer/properties/patches/backup/9.0.5.3-WS-WASProd-IFPH42762/systemApps/isclite.ear/kc.war/WEB-INF/lib/log4j-core-2.8.2.jar)No mitigation applied. JndiLookup class discovered.&quot;,\r\n    &quot;Proof Key&quot;: &quot;/opt/IBM/WebSphere/AppServer/properties/patches/backup/9.0.5.3-WS-WASProd-IFPH42762/systemApps/isclite.ear/kc.war/WEB-INF/lib/log4j-core-2.8.2.jar&quot;,\r\n    &quot;Solution Fix&quot;: &quot;Download and apply the patch from: https://logging.apache.org/log4j/2.x/download.html (https://logging.apache.org/log4j/2.x/download.html)&quot;,\r\n    &quot;Solution Summary&quot;: &quot;Upgrade Apache Log4j Core to the latest version&quot;,\r\n    &quot;Solution Type&quot;: &quot;PATCH&quot;,\r\n    &quot;Solution url&quot;: &quot;https://logging.apache.org/log4j/2.x/download.html&quot;,\r\n    &quot;Vulnerability Description&quot;: &quot;One vector that allowed exposure to this vulnerability was Log4j&amp;#8217;s allowance of Lookups to appear in log messages. This meant that when user input is logged, and that user input contained a JNDI Lookup pointing to a malicious server, then Log4j would resolve that JNDI Lookup, connect to that server, and potentially download serialized Java code from that remote server. This in turn could execute any code during deserialization. This is known as a RCE (Remote Code Execution) attack. In version 2.12.2 Log4j disables access to JNDI by default. Usage of JNDI in configuration now need to be enabled explicitly. Calls to the JndiLookup will now return a constant string. Also, Log4j now limits the protocols by default to only java. The message lookups feature has been completely removed. In version 2.16.0 the message lookups feature has been completely removed. Lookups in configuration still work. Furthermore, Log4j now disables access to JNDI by default. JNDI lookups in configuration now need to be enabled explicitly. Also, Log4j now limits the protocols by default to only java, ldap, and ldaps and limits the ldap protocols to only accessing Java primitive objects. Hosts other than the local host need to be explicitly allowed. This check requires the Security Console and Scan Engines to be on product version 6.6.118 or later.&quot;\r\n  },\r\n  {\r\n    &quot; Vulnerability Title&quot;: &quot;Apache Log4j Core: CVE-2021-44228: JNDI support has not restricted what names could be resolved allowing remote code execution&quot;,\r\n    &quot;Host Name&quot;: &quot;host1&quot;,\r\n    &quot;IP Address&quot;: &quot;10.1.10.20&quot;,\r\n    &quot;NexposeID&quot;: &quot;apache-log4j-core-cve-2021-44228&quot;,\r\n    &quot;Proof&quot;: &quot;Vulnerable software installed: Apache Log4j Core 2.8.2 (/opt/IBM/WebSphere/AppServer/properties/patches/backup/9.0.5.3-WS-WASProd-IFPH42762/systemApps/isclite.ear/kc.war/WEB-INF/lib/log4j-core-2.8.2.jar)No mitigation applied. JndiLookup class discovered.&quot;,\r\n    &quot;Proof Key&quot;: &quot;/opt/IBM/WebSphere/AppServer/properties/patches/backup/9.0.5.3-WS-WASProd-IFPH42762/systemApps/isclite.ear/kc.war/WEB-INF/lib/log4j-core-2.8.2.jar&quot;,\r\n    &quot;Solution Fix&quot;: &quot;Download and apply the patch from: https://logging.apache.org/log4j/2.x/download.html (https://logging.apache.org/log4j/2.x/download.html)&quot;,\r\n    &quot;Solution Summary&quot;: &quot;Upgrade Apache Log4j Core to the latest version&quot;,\r\n    &quot;Solution Type&quot;: &quot;PATCH&quot;,\r\n    &quot;Solution url&quot;: &quot;https://logging.apache.org/log4j/2.x/download.html&quot;,\r\n    &quot;Vulnerability Description&quot;: &quot;One vector that allowed exposure to this vulnerability was Log4j&amp;#8217;s allowance of Lookups to appear in log messages. This meant that when user input is logged, and that user input contained a JNDI Lookup pointing to a malicious server, then Log4j would resolve that JNDI Lookup, connect to that server, and potentially download serialized Java code from that remote server. This in turn could execute any code during deserialization. This is known as a RCE (Remote Code Execution) attack. In version 2.12.2 Log4j disables access to JNDI by default. Usage of JNDI in configuration now need to be enabled explicitly. Calls to the JndiLookup will now return a constant string. Also, Log4j now limits the protocols by default to only java. The message lookups feature has been completely removed. In version 2.16.0 the message lookups feature has been completely removed. Lookups in configuration still work. Furthermore, Log4j now disables access to JNDI by default. JNDI lookups in configuration now need to be enabled explicitly. Also, Log4j now limits the protocols by default to only java, ldap, and ldaps and limits the ldap protocols to only accessing Java primitive objects. Hosts other than the local host need to be explicitly allowed. This check requires the Security Console and Scan Engines to be on product version 6.6.118 or later.&quot;\r\n  },\r\n  {\r\n    &quot; Vulnerability Title&quot;: &quot;Apache Log4j Core: CVE-2021-44228: JNDI support has not restricted what names could be resolved allowing remote code execution&quot;,\r\n    &quot;Host Name&quot;: &quot;host2&quot;,\r\n    &quot;IP Address&quot;: &quot;10.1.10.10&quot;,\r\n    &quot;NexposeID&quot;: &quot;apache-log4j-core-cve-2021-44228&quot;,\r\n    &quot;Proof&quot;: &quot;Vulnerable software installed: Apache Log4j Core 2.8.2 (/opt/IBM/WebSphere/AppServer/properties/patches/backup/9.0.5.3-WS-WASProd-IFPH42762/systemApps/isclite.ear/kc.war/WEB-INF/lib/log4j-core-2.8.2.jar)No mitigation applied. JndiLookup class discovered.&quot;,\r\n    &quot;Proof Key&quot;: &quot;/opt/IBM/WebSphere/AppServer/properties/patches/backup/9.0.5.3-WS-WASProd-IFPH42762/systemApps/isclite.ear/kc.war/WEB-INF/lib/log4j-core-2.8.2.jar&quot;,\r\n    &quot;Solution Fix&quot;: &quot;Download and apply the patch from: https://logging.apache.org/log4j/2.x/download.html (https://logging.apache.org/log4j/2.x/download.html)&quot;,\r\n    &quot;Solution Summary&quot;: &quot;Upgrade Apache Log4j Core to the latest version&quot;,\r\n    &quot;Solution Type&quot;: &quot;PATCH&quot;,\r\n    &quot;Solution url&quot;: &quot;https://logging.apache.org/log4j/2.x/download.html&quot;,\r\n    &quot;Vulnerability Description&quot;: &quot;One vector that allowed exposure to this vulnerability was Log4j&amp;#8217;s allowance of Lookups to appear in log messages. This meant that when user input is logged, and that user input contained a JNDI Lookup pointing to a malicious server, then Log4j would resolve that JNDI Lookup, connect to that server, and potentially download serialized Java code from that remote server. This in turn could execute any code during deserialization. This is known as a RCE (Remote Code Execution) attack. In version 2.12.2 Log4j disables access to JNDI by default. Usage of JNDI in configuration now need to be enabled explicitly. Calls to the JndiLookup will now return a constant string. Also, Log4j now limits the protocols by default to only java. The message lookups feature has been completely removed. In version 2.16.0 the message lookups feature has been completely removed. Lookups in configuration still work. Furthermore, Log4j now disables access to JNDI by default. JNDI lookups in configuration now need to be enabled explicitly. Also, Log4j now limits the protocols by default to only java, ldap, and ldaps and limits the ldap protocols to only accessing Java primitive objects. Hosts other than the local host need to be explicitly allowed. This check requires the Security Console and Scan Engines to be on product version 6.6.118 or later.&quot;\r\n  },\r\n  {\r\n    &quot; Vulnerability Title&quot;: &quot;Apache Log4j Core: CVE-2021-44228: JNDI support has not restricted what names could be resolved allowing remote code execution&quot;,\r\n    &quot;Host Name&quot;: &quot;host2&quot;,\r\n    &quot;IP Address&quot;: &quot;10.1.10.10&quot;,\r\n    &quot;NexposeID&quot;: &quot;apache-log4j-core-cve-2021-44228&quot;,\r\n    &quot;Proof&quot;: &quot;Vulnerable software installed: Apache Log4j Core 2.8.2 (/opt/IBM/WebSphere/AppServer/properties/patches/backup/9.0.5.3-WS-WASProd-IFPH42762/systemApps/isclite.ear/kc.war/WEB-INF/lib/log4j-core-2.8.2.jar)No mitigation applied. JndiLookup class discovered.&quot;,\r\n    &quot;Proof Key&quot;: &quot;/opt/IBM/WebSphere/AppServer/properties/patches/backup/9.0.5.3-WS-WASProd-IFPH42762/systemApps/isclite.ear/kc.war/WEB-INF/lib/log4j-core-2.8.2.jar&quot;,\r\n    &quot;Solution Fix&quot;: &quot;Download and apply the patch from: https://logging.apache.org/log4j/2.x/download.html (https://logging.apache.org/log4j/2.x/download.html)&quot;,\r\n    &quot;Solution Summary&quot;: &quot;Upgrade Apache Log4j Core to the latest version&quot;,\r\n    &quot;Solution Type&quot;: &quot;PATCH&quot;,\r\n    &quot;Solution url&quot;: &quot;https://logging.apache.org/log4j/2.x/download.html&quot;,\r\n    &quot;Vulnerability Description&quot;: &quot;One vector that allowed exposure to this vulnerability was Log4j&amp;#8217;s allowance of Lookups to appear in log messages. This meant that when user input is logged, and that user input contained a JNDI Lookup pointing to a malicious server, then Log4j would resolve that JNDI Lookup, connect to that server, and potentially download serialized Java code from that remote server. This in turn could execute any code during deserialization. This is known as a RCE (Remote Code Execution) attack. In version 2.12.2 Log4j disables access to JNDI by default. Usage of JNDI in configuration now need to be enabled explicitly. Calls to the JndiLookup will now return a constant string. Also, Log4j now limits the protocols by default to only java. The message lookups feature has been completely removed. In version 2.16.0 the message lookups feature has been completely removed. Lookups in configuration still work. Furthermore, Log4j now disables access to JNDI by default. JNDI lookups in configuration now need to be enabled explicitly. Also, Log4j now limits the protocols by default to only java, ldap, and ldaps and limits the ldap protocols to only accessing Java primitive objects. Hosts other than the local host need to be explicitly allowed. This check requires the Security Console and Scan Engines to be on product version 6.6.118 or later.&quot;\r\n  }\r\n]",
        "link": "https://stackoverflow.com/questions/71770482/group-objects-by-distinct-value-and-while-returning-list-of-common-values-in-jq",
        "title": "Group objects by distinct value and while returning list of common values in 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": 2,
                "creation_date": 1649273793,
                "post_id": 71772406,
                "comment_id": 126837135,
                "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": 1649273909,
                "post_id": 71772406,
                "comment_id": 126837163,
                "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": 1649273995,
                "post_id": 71772406,
                "comment_id": 126837189,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 351076,
                    "reputation": 1985,
                    "user_id": 687331,
                    "user_type": "registered",
                    "accept_rate": 53,
                    "profile_image": "https://www.gravatar.com/avatar/567c5c0cc4cc8201125f2f829ace544d?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Anand",
                    "link": "https://stackoverflow.com/users/687331/anand"
                },
                "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": 1649274230,
                "post_id": 71772406,
                "comment_id": 126837278,
                "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": 1649274243,
                "post_id": 71772406,
                "comment_id": 126837281,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 351076,
                    "reputation": 1985,
                    "user_id": 687331,
                    "user_type": "registered",
                    "accept_rate": 53,
                    "profile_image": "https://www.gravatar.com/avatar/567c5c0cc4cc8201125f2f829ace544d?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Anand",
                    "link": "https://stackoverflow.com/users/687331/anand"
                },
                "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": 1649274448,
                "post_id": 71772406,
                "comment_id": 126837340,
                "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": 1649275933,
                "post_id": 71772406,
                "comment_id": 126837835,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1649279090,
                "last_edit_date": 1649279090,
                "creation_date": 1649275455,
                "answer_id": 71772973,
                "question_id": 71772406,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s a solution using `tostream` instead of `to_entries` to facilitate simultaneous access to the full path and its value:\r\n~~~sh\r\njq -r &#39;\r\n  .color | tostream | select(.[0][-1] == &quot;value&quot; and has(1)) | .[0][:-1]+.[1:] | join(&quot;:&quot;)\r\n&#39; &quot;$figma_json&quot;\r\n~~~\r\n~~~none\r\nwhite:#ffffffff\r\ngray:50:#fafafaff\r\n~~~\r\n[Demo](https://jqplay.org/s/JcB3N3mWyb)\r\n",
                "title": "shell script: Returning wrong output"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1649275752,
                "creation_date": 1649275752,
                "answer_id": 71773028,
                "question_id": 71772406,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "An approach attempting to demonstrate bash best-practices:\r\n\r\n```\r\n#!/bin/bash\r\n\r\nfigma_json=$1                              # prefer command-line arguments to prompts\r\n[[ $figma_json ]] || {\r\n  read -r -p &#39;Figma JSON file path: &#39; path # read -r means backslashes not munged\r\n  figma_json=${path//[[:space:]]/}         # parameter expansion is more efficient than tr\r\n}\r\n\r\njq -r &#39;\r\n  def recurse_for_value($prefix):\r\n    to_entries[]\r\n    | .key as $current_key\r\n    | .value?.value? as $immediate_value\r\n    | if $immediate_value == null then\r\n        .value | recurse_for_value(\r\n                   if $prefix != &quot;&quot; then\r\n                     $prefix + &quot;:&quot; + $current_key\r\n                   else\r\n                     $current_key\r\n                   end\r\n                 )\r\n      else\r\n        if $prefix == &quot;&quot; then\r\n          &quot;\\($current_key):\\($immediate_value)&quot;\r\n        else\r\n          &quot;\\($prefix):\\($current_key):\\($immediate_value)&quot;\r\n        end\r\n      end\r\n    ;\r\n  .color |\r\n  recurse_for_value(&quot;&quot;)\r\n&#39; &quot;$figma_json&quot;\r\n```",
                "title": "shell script: Returning wrong output"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1666482044,
        "creation_date": 1649272360,
        "last_edit_date": 1666482044,
        "question_id": 71772406,
        "body_markdown": "In the given script, the nested key is not getting appended with the value. I could not figure out where the script is going wrong.\r\n\r\n```bash\r\n#!/bin/bash\r\n\r\necho &quot;Add the figma json file path&quot;\r\nread path\r\n\r\nfigma_json=&quot;$(echo -e &quot;${path}&quot; | tr -d &#39;[:space:]&#39;)&quot;\r\n\r\necho $(cat $figma_json | jq -r &#39;.color | to_entries[] | &quot;\\(.key):\\(.value| if .value == null then .[] | .value  else .value end)&quot;&#39;)\r\n``` \r\n\r\nSample input:\r\n\r\n```json\r\n{\r\n  &quot;color&quot;: {\r\n    &quot;white&quot;: {\r\n      &quot;description&quot;: &quot;this is just plain white color&quot;,\r\n      &quot;type&quot;: &quot;color&quot;,\r\n      &quot;value&quot;: &quot;#ffffffff&quot;,\r\n      &quot;extensions&quot;: {\r\n        &quot;org.lukasoppermann.figmaDesignTokens&quot;: {\r\n          &quot;styleId&quot;: &quot;S:40940df38088633aa746892469dd674de8b147eb,&quot;,\r\n          &quot;exportKey&quot;: &quot;color&quot;\r\n        }\r\n      }\r\n    },\r\n    &quot;gray&quot;: {\r\n      &quot;50&quot;: {\r\n        &quot;description&quot;: &quot;&quot;,\r\n        &quot;type&quot;: &quot;color&quot;,\r\n        &quot;value&quot;: &quot;#fafafaff&quot;,\r\n        &quot;extensions&quot;: {\r\n          &quot;org.lukasoppermann.figmaDesignTokens&quot;: {\r\n            &quot;styleId&quot;: &quot;S:748a0078c39ca645fbcb4b2a5585e5b0d84e5fd7,&quot;,\r\n            &quot;exportKey&quot;: &quot;color&quot;\r\n          }\r\n        }\r\n      }\r\n    }\r\n  }\r\n}\r\n```\r\n\r\nActual output:\r\n\r\n```none\r\nwhite:#ffffffff gray:#fafafaff \r\n```\r\n\r\nExcepted output:\r\n\r\n```none\r\nwhite:#ffffffff gray:50:#fafafaff\r\n```\r\n\r\n[Full input file][1]\r\n\r\n  [1]: https://drive.google.com/file/d/1j5Ola25ylaY1TWxe-OE7iSIYokF6fPz0/view?usp=sharing",
        "link": "https://stackoverflow.com/questions/71772406/shell-script-returning-wrong-output",
        "title": "shell script: Returning wrong output"
    }
]