[
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1651757133,
                "creation_date": 1651757133,
                "answer_id": 72127972,
                "question_id": 72127865,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You need [`getpath/1`][1] for this. The method takes an array of paths to a particular node and returns the value present at it\r\n\r\n```none\r\njq --arg nest &quot;$mypath&quot; &#39;getpath($nest|split(&quot;.&quot;))&#39;\r\n```\r\n\r\n\r\n  [1]: https://stedolan.github.io/jq/manual/#getpath(PATHS)",
                "title": "jq how to use split with nested keys in single --arg"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1651757923,
        "creation_date": 1651756741,
        "last_edit_date": 1651757923,
        "question_id": 72127865,
        "body_markdown": "I would like to pass a nested key to jq in an arg. Using a single `--arg key $mypath` fails.\r\n\r\nLooking at other questions it seems `split` is the correct method, but I cant find a basic example that works.\r\n\r\n    \r\n    mypath=&quot;level1.level2.level3&quot;\r\n    //working hardcode\r\n    jq &#39;.level1.level2.level3&#39; $myfile\r\n    \r\n    //variations tried\r\n    jq --arg nest &quot;${mypath}&quot; &#39;.[$nest]&#39; $myfile\r\n    jq --arg nest &quot;${mypath}&quot; &#39;.[$nest]|split(&quot;.&quot;)&#39; $myfile\r\n    jq --arg nest &quot;${mypath}&quot; &#39;.|split(&quot;.&quot;)|[$nest]&#39; $myfile\r\n\r\n  \r\n ",
        "link": "https://stackoverflow.com/questions/72127865/jq-how-to-use-split-with-nested-keys-in-single-arg",
        "title": "jq how to use split with nested keys in single --arg"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1651782238,
                "creation_date": 1651782238,
                "answer_id": 72133217,
                "question_id": 72128929,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The sample data provided is invalid as JSON, but assuming it has been adjusted as shown below, we would have:\r\n```\r\n&lt; sample.json  jq -r &#39;[.metric.name] + .values[] | @csv&#39;\r\n&quot;name1&quot;,16590879,&quot;0.043984349&quot;\r\n&quot;name1&quot;,16590876,&quot;0.043983444&quot;\r\n```\r\n\r\nIf you don&#39;t want the quotation marks, then use `join(&quot;,&quot;)` instead of `@csv`.\r\n\r\n----\r\n**sample.json**\r\n```\r\n{\r\n  &quot;metric&quot;: {\r\n    &quot;name&quot;: &quot;name1&quot;\r\n  },\r\n  &quot;values&quot;: [\r\n    [\r\n      16590879,\r\n      &quot;0.043984349&quot;\r\n    ],\r\n    [\r\n      16590876,\r\n      &quot;0.043983444&quot;\r\n    ]\r\n  ]\r\n}\r\n```",
                "title": "convert json to csv using jq bash"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1651782238,
        "creation_date": 1651760947,
        "last_edit_date": 1651767755,
        "question_id": 72128929,
        "body_markdown": " have a JSON data like below\r\n\r\n    &quot;metric&quot;: {\r\n       &quot;name&quot; : &quot;name1&quot;\r\n    },\r\n    &quot;values&quot;: [\r\n     [\r\n       16590879,\r\n       &quot;0.043984349&quot;\r\n    ],\r\n    &quot;values&quot;: [\r\n     [\r\n       16590876,\r\n       &quot;0.043983444&quot;\r\n    ]\r\n    ]\r\n}\r\n}\r\n\r\nwriting below jq , but not giving proper result\r\n\r\n    jq -r &#39;[.metric.name,(.values[] | map(.) | @csv)&#39;\r\n    \r\nActual result\r\n\r\n    [\r\n    &quot;name1&quot;,\r\n    &quot;16590879&quot;,\\&quot;0.043984349\\&quot;&quot;,\r\n    &quot;16590876&quot;,\\&quot;0.043983444\\&quot;&quot;,\r\n    &quot;16590874&quot;,\\&quot;0.043934345\\&quot;&quot;\r\n\r\nExpected result\r\n\r\n    name1,16590879,0.043984349\r\n    name1,16590876,0.043983444\r\n    name2,16590874,0.043934345\r\n\r\n",
        "link": "https://stackoverflow.com/questions/72128929/convert-json-to-csv-using-jq-bash",
        "title": "convert json to csv using jq bash"
    },
    {
        "tags": [
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1651771255,
                "post_id": 72129329,
                "comment_id": 127448254,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 25204817,
                    "reputation": 1,
                    "user_id": 19043319,
                    "user_type": "registered",
                    "profile_image": "https://lh3.googleusercontent.com/a-/AOh14Ghoo4oa9aRiVxdSwmeuwAJ8VWdaCML4jBwc2TSx=k-s256",
                    "display_name": "Peter Haberstroh",
                    "link": "https://stackoverflow.com/users/19043319/peter-haberstroh"
                },
                "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": 1651773169,
                "post_id": 72129329,
                "comment_id": 127448879,
                "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": 1651773979,
                "post_id": 72129329,
                "comment_id": 127449155,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 25204817,
                    "reputation": 1,
                    "user_id": 19043319,
                    "user_type": "registered",
                    "profile_image": "https://lh3.googleusercontent.com/a-/AOh14Ghoo4oa9aRiVxdSwmeuwAJ8VWdaCML4jBwc2TSx=k-s256",
                    "display_name": "Peter Haberstroh",
                    "link": "https://stackoverflow.com/users/19043319/peter-haberstroh"
                },
                "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": 1651774989,
                "post_id": 72129329,
                "comment_id": 127449532,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 25204817,
                    "reputation": 1,
                    "user_id": 19043319,
                    "user_type": "registered",
                    "profile_image": "https://lh3.googleusercontent.com/a-/AOh14Ghoo4oa9aRiVxdSwmeuwAJ8VWdaCML4jBwc2TSx=k-s256",
                    "display_name": "Peter Haberstroh",
                    "link": "https://stackoverflow.com/users/19043319/peter-haberstroh"
                },
                "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": 1651774994,
                "post_id": 72129329,
                "comment_id": 127449533,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1660468250,
                "creation_date": 1660468250,
                "answer_id": 73350397,
                "question_id": 72129329,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "`routes` has an array value and as such cannot be concatenated with a string. You can use [`join`](https://stedolan.github.io/jq/manual/v1.6/#join(str)) to turn that array into a single string:\r\n\r\n    jq -r &#39;.services[] | .host + &quot; &quot; + (.routes[].hosts | join(&quot;,&quot;))&#39;\r\n\r\nOutput:\r\n\r\n    host-name-test.com Google.com\r\n\r\n****\r\n\r\nAlternatively, using [string interpolation](https://stedolan.github.io/jq/manual/v1.6/#Stringinterpolation-\\(foo)) which will automatically serialize any values into their string representation:\r\n\r\n    jq -r &#39;.services[] | &quot;\\(.host) \\(.routes[].hosts)&quot;&#39;\r\n\r\nOutput:\r\n\r\n    host-name-test.com [&quot;Google.com&quot;]\r\n\r\n****\r\n\r\n`join` and string interpolation can be combined, giving you the identical output of the first command:\r\n\r\n    jq -r &#39;.services[] | &quot;\\(.host) \\(.routes[].hosts|join(&quot;,&quot;))&quot;&#39;",
                "title": "jq query to pull values from json file to create a listing"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1660468250,
        "creation_date": 1651762595,
        "last_edit_date": 1657674690,
        "question_id": 72129329,
        "body_markdown": "Given this input small sample:\r\n\r\n    {\r\n      &quot;_format_version&quot;: &quot;1.1&quot;,\r\n      &quot;_workspace&quot;: &quot;test&quot;,\r\n      &quot;services&quot;: [\r\n        {\r\n          &quot;connect_timeout&quot;: 60000,\r\n          &quot;host&quot;: &quot;host-name-test.com&quot;,\r\n          &quot;name&quot;: &quot;name-of-service&quot;,\r\n          &quot;path&quot;: &quot;/test/oauthpass&quot;,\r\n          &quot;port&quot;: 777,\r\n          &quot;protocol&quot;: &quot;http&quot;,\r\n          &quot;read_timeout&quot;: 1000,\r\n          &quot;retries&quot;: 1,\r\n          &quot;write_timeout&quot;: 1000,\r\n          &quot;routes&quot;: [\r\n            {\r\n              &quot;hosts&quot;: [\r\n                &quot;Google.com&quot;\r\n              ],\r\n              &quot;name&quot;: &quot;com.testing.active.oauth&quot;,\r\n              &quot;methods&quot;: [\r\n                &quot;POST&quot;\r\n              ],\r\n              &quot;paths&quot;: [\r\n                &quot;/vendors/otest/pass/?$&quot;\r\n              ],\r\n              &quot;path_handling&quot;: &quot;v8&quot;,\r\n              &quot;preserve_host&quot;: false,\r\n              &quot;protocols&quot;: [\r\n                &quot;https&quot;\r\n              ],\r\n              &quot;regex_priority&quot;: 0,\r\n              &quot;strip_path&quot;: true,\r\n              &quot;https_redirect_status_code&quot;: 426,\r\n              &quot;request_buffering&quot;: true,\r\n              &quot;response_buffering&quot;: true\r\n            }\r\n          ]\r\n        }\r\n    }\r\n\r\ntrying to get a listing from the data pulling certain values like the listing below:\r\n\r\n```\r\nhost-name-test.com, Google.com, POST, HTTPS\r\n```\r\n\r\nthe command that I have working so far is \r\n\r\n    cat /tmp/petecar.json | jq -r &#39; .services[] | .routes[] | ( .hosts[] + &quot;/&quot; + .paths[]) &#39; | more\r\n\r\nbut I can&#39;t access the values under services, please provide some sample on how to get the values \r\n\r\n",
        "link": "https://stackoverflow.com/questions/72129329/jq-query-to-pull-values-from-json-file-to-create-a-listing",
        "title": "jq query to pull values from json file to create a listing"
    },
    {
        "tags": [
            "shell",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1651803819,
                "creation_date": 1651803819,
                "answer_id": 72135505,
                "question_id": 72133488,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The following produces the valid JSON component of what is shown as the desired output:\r\n```\r\njq -n --arg op &quot;add&quot; \\\r\n   --arg path &quot;/support&quot; \\\r\n   --arg familyType EXAMPLE \\\r\n   --arg healthCheckUris http://example.com &#39;\r\n   {$op, $path, \r\n    apiSupports: [ {$familyType, $healthCheckUris }],\r\n    inboundurls: [ {$healthCheckUris }]\r\n }\r\n&#39;\r\n```\r\n",
                "title": "creating a nested json output file using jq variables using"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1666355896,
        "creation_date": 1651783730,
        "last_edit_date": 1666355896,
        "question_id": 72133488,
        "body_markdown": "I&#39;m trying to create a json file via shellscript, and someone has mentioned jq, but I&#39;m  struggling a little bit to make it work:\r\n**The desire output is:**\r\n```\r\ninboundurls{\r\n  &quot;op&quot;: &quot;add&quot;,\r\n  &quot;path&quot;: &quot;/support&quot;,\r\n  &quot;apiSupports&quot;: [\r\n    {\r\n      &quot;familyType&quot;: &quot;EXAMPLE&quot;,\r\n      &quot;healthCheckUris&quot;: &quot;http://example.com&quot;\r\n    }\r\n  ],\r\n  &quot;inboundurls&quot;: [\r\n    {\r\n      &quot;healthCheckUris&quot;: &quot;http://example.com&quot;\r\n    }\r\n  ]\r\n}\r\n```\r\nResearching about I found a start point, but it&#39;s not working properly, I need some help, here is what I have:\r\n\r\n**script:**\r\n```\r\n#!/bin/bash\r\napiSupports=$(jq -n --arg familyType EXAMPLE \\\r\n              --arg healthCheckUris http://example.com \\\r\n              &#39;$ARGS.named&#39;\r\n)\r\n\r\nfinal=$(jq -n --arg op &quot;add&quot; \\\r\n              --arg path &quot;/supportServices&quot; \\\r\n              --argjson apiSupports &quot;[$apiSupports]&quot; \\\r\n              &#39;$ARGS.named&#39;\r\n)\r\necho &quot;$final&quot;\r\n``` \r\n**the output of the script above:**\r\n\r\n```\r\n{\r\n  &quot;op&quot;: &quot;add&quot;,\r\n  &quot;path&quot;: &quot;/supportServices&quot;,\r\n  &quot;apiSupports&quot;: [\r\n    {\r\n      &quot;familyType&quot;: &quot;EXAMPLE&quot;,\r\n      &quot;healthCheckUris&quot;: &quot;http://example.com&quot;\r\n    }\r\n  ]\r\n}\r\n```\r\n\r\nIf anyone could help me I would be glad, or even suggesting Ideas, thank you in advance?\r\n\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/72133488/creating-a-nested-json-output-file-using-jq-variables-using",
        "title": "creating a nested json output file using jq variables using"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1651873904,
                "creation_date": 1651873904,
                "answer_id": 72147712,
                "question_id": 72147637,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "One way could be to reduce the items to those matching the criteria, and then output the key names:\r\n~~~sh\r\njq -r &#39;.books | .[] |= select(.availability) | keys_unsorted[]&#39;\r\n~~~\r\n[Demo](https://jqplay.org/s/CC9Brk4Lv7)\r\n\r\nAnother one could be using `to_entries` and work with `.key` and `.value`:\r\n~~~sh\r\njq -r &#39;.books | to_entries[] | select(.value.availability).key&#39;\r\n~~~\r\n[Demo](https://jqplay.org/s/cxnmYmvbXM)\r\n\r\nOutput in both cases:\r\n~~~json\r\nbook-name-1\r\nbook-name-4\r\n~~~\r\n\r\nTo also feature the commas, you could leave it as array, and use a `join(&quot;,\\n&quot;)` to combine:\r\n~~~json\r\nbook-name-1,\r\nbook-name-4\r\n~~~\r\n",
                "title": "Using JQ to filter the keys that have a boolean equal to true"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1651873904,
        "creation_date": 1651873251,
        "question_id": 72147637,
        "body_markdown": "I have this JSON file:\r\n```\r\n{\r\n   &quot;books&quot;:{\r\n      &quot;book-name-1&quot;:{\r\n         &quot;path&quot;:&quot;management/business&quot;,\r\n         &quot;availability&quot;: true,\r\n         &quot;vars&quot;:{\r\n            &quot;author&quot;:&quot;John&quot;,\r\n            &quot;year&quot;:&quot;2005&quot;\r\n         }\r\n      },\r\n      &quot;book-name-2&quot;:{\r\n         &quot;path&quot;:&quot;engineering/computing&quot;,\r\n         &quot;availability&quot;: false,\r\n         &quot;vars&quot;:{\r\n            &quot;author&quot;:&quot;Rick&quot;,\r\n            &quot;year&quot;:&quot;2010&quot;\r\n         }\r\n      },\r\n      &quot;book-name-3&quot;:{\r\n         &quot;path&quot;:&quot;finance/general&quot;,\r\n         &quot;vars&quot;:{\r\n            &quot;author&quot;:&quot;Joe&quot;,\r\n            &quot;year&quot;:&quot;2020&quot;\r\n         }\r\n      },\r\n      &quot;book-name-4&quot;:{\r\n         &quot;path&quot;:&quot;medicine/general&quot;,\r\n         &quot;availability&quot;: true,\r\n         &quot;vars&quot;:{\r\n            &quot;author&quot;:&quot;Stacy&quot;,\r\n            &quot;year&quot;:&quot;2018&quot;\r\n         }\r\n      }\r\n   }\r\n}\r\n```\r\nand I can&#39;t manage to filter it in such a way that I can get the names of the books that &quot;availability&quot; is equal to true.\r\n\r\nNote for example that book-name-3 does not have that variable and book-name-2 has it set to false.\r\n\r\nSo, the output I expect to get after filtering is:\r\n\r\n```\r\nbook-name-1,\r\nbook-name-4\r\n```\r\nHow could I make it possible using jq?",
        "link": "https://stackoverflow.com/questions/72147637/using-jq-to-filter-the-keys-that-have-a-boolean-equal-to-true",
        "title": "Using JQ to filter the keys that have a boolean equal to true"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": false,
                "score": 4,
                "last_activity_date": 1651886067,
                "creation_date": 1651886067,
                "answer_id": 72148735,
                "question_id": 72148717,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Add the [Error Suppression Operator](https://stedolan.github.io/jq/manual/#ErrorSuppression/OptionalOperator:?) `?` which defaults to `empty`\r\n~~~sh\r\njq &#39;.y | gsub(&quot;,&quot;; &quot;-&quot;)?&#39;\r\n~~~\r\n[Demo](https://jqplay.org/s/uc67iWWKFj)\r\n\r\nYou may additionally add a default alternative using the [Alternative Operator](https://stedolan.github.io/jq/manual/#Alternativeoperator://) `//`\r\n~~~sh\r\njq &#39;.y | gsub(&quot;,&quot;; &quot;-&quot;)? // &quot;&quot;&#39;\r\n~~~\r\n[Demo](https://jqplay.org/s/mTOV01-YLG)",
                "title": "jq: error (at &lt;stdin&gt;:1): null (null) cannot be matched, as it is not a string"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1651886067,
        "creation_date": 1651885791,
        "question_id": 72148717,
        "body_markdown": "```\r\n$ jq &#39;.y | gsub(&quot;,&quot;; &quot;-&quot;)&#39; &lt;&lt;&lt; &#39;{&quot;y&quot;: &quot;a,b&quot;}&#39;\r\n&quot;a-b&quot;\r\n$ jq &#39;.y | gsub(&quot;,&quot;; &quot;-&quot;)&#39; &lt;&lt;&lt; &#39;{&quot;x&quot;: &quot;a&quot;}&#39;\r\njq: error (at &lt;stdin&gt;:1): null (null) cannot be matched, as it is not a string\r\n```\r\n\r\nI got the above error. I can use if-else-end statement to solve the problem. But it is a little verbose.\r\n\r\nWhat is the most succinct way to fix the error so that .y is still accessed with &quot;,&quot; replaced by &quot;-&quot;, but when .y does not exist, an empty string will be printed?",
        "link": "https://stackoverflow.com/questions/72148717/jq-error-at-stdin1-null-null-cannot-be-matched-as-it-is-not-a-string",
        "title": "jq: error (at &lt;stdin&gt;:1): null (null) cannot be matched, as it is not a string"
    },
    {
        "tags": [
            "grep",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1652039381,
                "last_edit_date": 1652039381,
                "creation_date": 1652038638,
                "answer_id": 72164522,
                "question_id": 72164489,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "`grep` filters on the textual representation. Stay in `jq` to perform a logical filter, e.g. using `select` and `any` to forward only those inputs for which at least one (`any`) field value (`.[]`) matches (`==`) the given string.\r\n~~~sh\r\njq &#39;\r\n  {first_fruit: .record.key_A,second_fruit:.record.key_B}\r\n  | select(any(.[]; . == &quot;bananas&quot;))\r\n&#39;\r\n~~~\r\n~~~json\r\n{\r\n  &quot;first_fruit&quot;: &quot;apples&quot;,\r\n  &quot;second_fruit&quot;: &quot;bananas&quot;\r\n}\r\n~~~\r\n[Demo](https://jqplay.org/s/MPagvQI6GR)\r\n\r\nOr more efficiently, as @peak [pointed out](https://stackoverflow.com/questions/72164489/how-to-return-an-entire-json-object-when-greping-jq-output/72164522#comment127503635_72164522), you may want to select first and then shape the output:\r\n~~~sh\r\n.record | select(any(.[]; . == &quot;bananas&quot;))\r\n| {first_fruit: .key_A, second_fruit: .key_B}\r\n~~~\r\n\r\nInstead of finding exact matches with `==`, you can also use `contains` for partial matches, or `test` for a full regex test.\r\n~~~sh\r\nselect(any(.[]; contains(&quot;bananas&quot;)))\r\n~~~\r\n~~~sh\r\nselect(any(.[]; test(&quot;bananas&quot;)))\r\n~~~\r\n",
                "title": "How to return an entire json object when grep&#39;ing jq output?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1652039381,
        "creation_date": 1652038381,
        "question_id": 72164489,
        "body_markdown": "I have this json file - test.json\r\n\r\n    {&quot;type&quot;:&quot;RECORD&quot;,&quot;record&quot;:{&quot;key_A&quot;: &quot;apples&quot;,&quot;key_B&quot;:&quot;bananas&quot;}}\r\n\r\nThen I do \r\n\r\n    cat test.json | jq &#39;. | {first_fruit: .record.key_A,second_fruit:.record.key_B}&#39; | grep &quot;bananas&quot;\r\n      &quot;second_fruit&quot;: &quot;bananas&quot;\r\n\r\nSo it only shows me the &quot;second_fruit&quot;:&quot;bananas&quot; line. Is there a way to return the object that contains that grep match? So it should return \r\n\r\n    {\r\n      &quot;first_fruit&quot;: &quot;apples&quot;,\r\n      &quot;second_fruit&quot;: &quot;bananas&quot;\r\n    } \r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/72164489/how-to-return-an-entire-json-object-when-greping-jq-output",
        "title": "How to return an entire json object when grep&#39;ing jq output?"
    },
    {
        "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": 2,
                "creation_date": 1652040527,
                "post_id": 72164700,
                "comment_id": 127503909,
                "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": 1652040582,
                "post_id": 72164700,
                "comment_id": 127503919,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1652040667,
                "creation_date": 1652040667,
                "answer_id": 72164749,
                "question_id": 72164700,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "`=` is an assignment operator. `==` is an equality-comparison operator.\r\n\r\nYou want `select(.record.key_B == &quot;oranges&quot;)`.",
                "title": "select(.key=&quot;value&quot;) emits even non-matching items"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -1,
        "last_activity_date": 1652040667,
        "creation_date": 1652040213,
        "last_edit_date": 1652040629,
        "question_id": 72164700,
        "body_markdown": "I have the following test.json\r\n\r\n    {&quot;type&quot;:&quot;RECORD&quot;,&quot;record&quot;:{&quot;key_A&quot;: &quot;apples&quot;,&quot;key_B&quot;:&quot;bananas&quot;}}\r\n    {&quot;type&quot;:&quot;RECORD&quot;,&quot;record&quot;:{&quot;key_A&quot;: &quot;apples&quot;,&quot;key_B&quot;:&quot;oranges&quot;}}\r\n\r\nThen see the following command and output.\r\n\r\n    cat test.json | jq &#39;select(.record.key_B=&quot;oranges&quot;)&#39; \r\n    {\r\n      &quot;type&quot;: &quot;RECORD&quot;,\r\n      &quot;record&quot;: {\r\n        &quot;key_A&quot;: &quot;apples&quot;,\r\n        &quot;key_B&quot;: &quot;bananas&quot;\r\n      }\r\n    }\r\n    {\r\n      &quot;type&quot;: &quot;RECORD&quot;,\r\n      &quot;record&quot;: {\r\n        &quot;key_A&quot;: &quot;apples&quot;,\r\n        &quot;key_B&quot;: &quot;oranges&quot;\r\n      }\r\n    }\r\n\r\nI wish it would only output the record which match the select - the ones where .record.key_B = oranges so only the first record. How can I do this? \r\n\r\n",
        "link": "https://stackoverflow.com/questions/72164700/select-key-value-emits-even-non-matching-items",
        "title": "select(.key=&quot;value&quot;) emits even non-matching items"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1652070517,
                "creation_date": 1652070517,
                "answer_id": 72166997,
                "question_id": 72166959,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You are either missing a semi-colon (or equivalent), or misunderstanding shell variables.\r\n\r\n\r\n1) With the semicolon:\r\n```\r\nkeys=&#39;[[&quot;key1&quot;,&quot;a&quot;],[&quot;key2&quot;,&quot;b&quot;]]&#39; ; jq -c -n --argjson keys &quot;$keys&quot; &#39;$keys&#39;\r\n```\r\n2) Using shell variables:\r\n```\r\nkeys=&#39;[[&quot;key1&quot;,&quot;a&quot;],[&quot;key2&quot;,&quot;b&quot;]]&#39; jq -c -n &#39;env.keys | fromjson&#39;\r\n```\r\n",
                "title": "Error jq: invalid JSON text passed to --argjson"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 4,
        "last_activity_date": 1652070517,
        "creation_date": 1652069942,
        "question_id": 72166959,
        "body_markdown": "Consider\r\n```\r\n$ keys=&#39;[[&quot;key1&quot;,&quot;a&quot;],[&quot;key2&quot;,&quot;b&quot;]]&#39; jq -c --argjson keys &quot;$keys&quot; &#39;.[] | [getpath($keys[])]&#39; &lt;&lt;&lt;$&#39;[{&quot;key1&quot;:{&quot;a&quot;:1},&quot;key2&quot;:{&quot;b&quot;:2}}] [{&quot;key1&quot;:{&quot;a&quot;:3},&quot;key2&quot;:{&quot;b&quot;:4}}]&#39;\r\n```\r\n\r\nI expect output\r\n```\r\n[1,2]\r\n[3,4]\r\n```\r\n\r\nBut I seem to doing something wrong when defining `argjson`. I get error:\r\n\r\n```\r\njq: invalid JSON text passed to --argjson\r\n```\r\n\r\nWhat am I doing wrong? Thanks!",
        "link": "https://stackoverflow.com/questions/72166959/error-jq-invalid-json-text-passed-to-argjson",
        "title": "Error jq: invalid JSON text passed to --argjson"
    },
    {
        "tags": [
            "amazon-web-services",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 6196394,
                    "reputation": 86601,
                    "user_id": 5291015,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/4tAvO.jpg?s=256",
                    "display_name": "Inian",
                    "link": "https://stackoverflow.com/users/5291015/inian"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1652075990,
                "post_id": 72167446,
                "comment_id": 127508843,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1529894,
                    "reputation": 3703,
                    "user_id": 2780360,
                    "user_type": "registered",
                    "accept_rate": 81,
                    "profile_image": "https://i.sstatic.net/MIqzi.jpg?s=256",
                    "display_name": "d8aninja",
                    "link": "https://stackoverflow.com/users/2780360/d8aninja"
                },
                "reply_to_user": {
                    "account_id": 6196394,
                    "reputation": 86601,
                    "user_id": 5291015,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/4tAvO.jpg?s=256",
                    "display_name": "Inian",
                    "link": "https://stackoverflow.com/users/5291015/inian"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1652103220,
                "post_id": 72167446,
                "comment_id": 127517932,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1652076953,
                "last_edit_date": 1652076953,
                "creation_date": 1652076446,
                "answer_id": 72167593,
                "question_id": 72167446,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Its quite simple to extract, once you know the type of the top level objects. You can see `ResourceTagMappingList` is a list of records, so it should have a `[]` notation following it, which I think most beginners with `jq` tend to miss out. So\r\n\r\n```none\r\n.ResourceTagMappingList[].Tags | from_entries.&quot;tf-name&quot;\r\n```\r\n\r\nshould get you the desired value. See [jqplay demo][1]\r\n\r\nThe way it works is, the `from_entries` function takes an array of objects with key names `key` and `value` and transforms it to a value only pair. From there, we extract only the key name `tf-name`. The special double quotes are needed because the key name here contains a meta-character `-`, which should be quoted to treat the whole string as the key name.\r\n\r\nAnother way would be to use a `select` statement like below\r\n\r\n```none\r\n.ResourceTagMappingList[].Tags[] | select(.Key  == &quot;tf-name&quot;).Value \r\n```\r\n\r\n\r\n  [1]: https://jqplay.org/s/Num7Oz9uNK",
                "title": "How do I extract this field using JQ?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1652076953,
        "creation_date": 1652075238,
        "last_edit_date": 1652076450,
        "question_id": 72167446,
        "body_markdown": "JQ makes me irrationally angry and I despise its very existence. I have been trying to extract the value of the `tf-name` key for 30 minutes and I&#39;m going to become a hermit if I have to make another attempt at this. Please, how do I get `tmp` as a a result?\r\n```json  \r\n➜  aws resourcegroupstaggingapi get-resources --tag-filters Key=tf-name,Values=tmp --profile=test | jq   \r\n                               \r\n{\r\n  &quot;ResourceTagMappingList&quot;: [\r\n    {\r\n      &quot;ResourceARN&quot;: &quot;arn:aws:s3:::stack-hate-1234567890salt&quot;,\r\n      &quot;Tags&quot;: [\r\n        {\r\n          &quot;Key&quot;: &quot;aws:cloudformation:stack-name&quot;,\r\n          &quot;Value&quot;: &quot;hatestack&quot;\r\n        },\r\n        {\r\n          &quot;Key&quot;: &quot;aws:cloudformation:stack-id&quot;,\r\n          &quot;Value&quot;: &quot;arn:aws:cloudformation:us-west-2:6666666666666:stack/FSStack/hate-hate-hate-123456789&quot;\r\n        },\r\n        {\r\n          &quot;Key&quot;: &quot;tf-name&quot;,\r\n          &quot;Value&quot;: &quot;tmp&quot;\r\n        },\r\n        {\r\n          &quot;Key&quot;: &quot;aws:cloudformation:logical-id&quot;,\r\n          &quot;Value&quot;: &quot;hatebucket1234&quot;\r\n        },\r\n        {\r\n          &quot;Key&quot;: &quot;aws-cdk:auto-delete-objects&quot;,\r\n          &quot;Value&quot;: &quot;true&quot;\r\n        }\r\n      ]\r\n    }\r\n  ]\r\n\r\n```",
        "link": "https://stackoverflow.com/questions/72167446/how-do-i-extract-this-field-using-jq",
        "title": "How do I extract this field using JQ?"
    },
    {
        "tags": [
            "bash",
            "file",
            "filter",
            "jq"
        ],
        "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": 1652079051,
                "post_id": 72167883,
                "comment_id": 127509540,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 8919214,
                    "reputation": 1037,
                    "user_id": 6656508,
                    "user_type": "registered",
                    "accept_rate": 14,
                    "profile_image": "https://lh5.googleusercontent.com/-Cw00Euo9ls4/AAAAAAAAAAI/AAAAAAAAAD0/AxPxZMOm4qc/s256-rj/photo.jpg",
                    "display_name": "Logan Lee",
                    "link": "https://stackoverflow.com/users/6656508/logan-lee"
                },
                "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": 1652079327,
                "post_id": 72167883,
                "comment_id": 127509612,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 8919214,
                    "reputation": 1037,
                    "user_id": 6656508,
                    "user_type": "registered",
                    "accept_rate": 14,
                    "profile_image": "https://lh5.googleusercontent.com/-Cw00Euo9ls4/AAAAAAAAAAI/AAAAAAAAAD0/AxPxZMOm4qc/s256-rj/photo.jpg",
                    "display_name": "Logan Lee",
                    "link": "https://stackoverflow.com/users/6656508/logan-lee"
                },
                "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": 1652079591,
                "post_id": 72167883,
                "comment_id": 127509688,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 8919214,
                    "reputation": 1037,
                    "user_id": 6656508,
                    "user_type": "registered",
                    "accept_rate": 14,
                    "profile_image": "https://lh5.googleusercontent.com/-Cw00Euo9ls4/AAAAAAAAAAI/AAAAAAAAAD0/AxPxZMOm4qc/s256-rj/photo.jpg",
                    "display_name": "Logan Lee",
                    "link": "https://stackoverflow.com/users/6656508/logan-lee"
                },
                "reply_to_user": {
                    "account_id": 10015983,
                    "reputation": 144648,
                    "user_id": 9072753,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/EPmGy.jpg?s=256",
                    "display_name": "KamilCuk",
                    "link": "https://stackoverflow.com/users/9072753/kamilcuk"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1652079970,
                "post_id": 72167883,
                "comment_id": 127509809,
                "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": 1652082370,
                "post_id": 72167883,
                "comment_id": 127510586,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1652080044,
                "creation_date": 1652080044,
                "answer_id": 72168127,
                "question_id": 72167883,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can use `/dev/stdin` to represent standard input as a file:\r\n\r\n    jq -nf /dev/stdin &lt;&lt;&lt;$&#39;\\&quot;hello world\\&quot;&#39;\r\n    echo \\&quot;hello world\\&quot; | jq -nf /dev/stdin",
                "title": "Passing string rather than filename to -f option in jq under bash"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1652080044,
        "creation_date": 1652078678,
        "last_edit_date": 1652079511,
        "question_id": 72167883,
        "body_markdown": "I&#39;m curious whether I can replace *file name* with *a string* when using `-f` option of `jq`.\r\n\r\nWhen I do\r\n\r\n```\r\n$ jq -nf &lt;(echo \\&quot;hello world\\&quot;)\r\n```\r\nit correctly outputs\r\n```\r\n&quot;hello world&quot;\r\n```\r\n\r\nBut when I try\r\n```\r\n$ jq -nf &lt;&lt;&lt;$&#39;\\&quot;hello world\\&quot;&#39;\r\n```\r\n\r\nthis fails with error\r\n\r\n```\r\njq: Could not open .: It&#39;s a directory\r\n```\r\n\r\nAnyone knows how to make this work? I know this is more of a `bash` question than `jq`.\r\n\r\n`$ jq &#39;.&#39; &lt;&lt;&lt; &#39;&quot;hello world&quot;&#39;` works though.\r\n\r\nThanks.",
        "link": "https://stackoverflow.com/questions/72167883/passing-string-rather-than-filename-to-f-option-in-jq-under-bash",
        "title": "Passing string rather than filename to -f option in jq under bash"
    },
    {
        "tags": [
            "json",
            "bash",
            "kubernetes",
            "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": 1652112983,
                "post_id": 72174860,
                "comment_id": 127521957,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1652113703,
                "creation_date": 1652113703,
                "answer_id": 72175285,
                "question_id": 72174860,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s one rewrite with several duplicates factored out. Decide for yourself if this meets your requirement for elegance:\r\n~~~sh\r\n(\r\n  .metadata | {namespace, name}\r\n) + (\r\n  .spec.template.spec.containers[].env | {\r\n    databases: map(select(.name | contains (&quot;DB&quot;))),\r\n    redis: map(select(.name | contains (&quot;REDIS&quot;))),\r\n    elasticsearch: map(select(.name | test(&quot;^(ES_).&quot;) or contains (&quot;ELASTIC&quot;)))\r\n  }\r\n  | map_values(sort_by(.name))\r\n)\r\n~~~\r\n\r\nAdditionally, you could bring the sort up front to sort the unfiltered array just once:\r\n~~~sh\r\n(\r\n  .metadata | {namespace, name}\r\n) + (\r\n  .spec.template.spec.containers[].env | sort_by(.name) | {\r\n    databases: map(select(.name | contains (&quot;DB&quot;))),\r\n    redis: map(select(.name | contains (&quot;REDIS&quot;))),\r\n    elasticsearch: map(select(.name | test(&quot;^(ES_).&quot;) or contains (&quot;ELASTIC&quot;)))\r\n  }\r\n)\r\n~~~",
                "title": "Extract and group by type env variables from k8s deployments with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1652116551,
        "creation_date": 1652111714,
        "last_edit_date": 1652116551,
        "question_id": 72174860,
        "body_markdown": "I am trying to extract the list of k8s deployment environment variables and merge the environment variables into a group of categories using jq and regex.\r\n\r\n**Example**\r\n\r\nk8s deployment:\r\n```\r\napiVersion: apps/v1\r\nkind: Deployment\r\nmetadata:\r\n  labels:\r\n    app: test\r\n  name: test\r\nspec:\r\n  replicas: 1\r\n  selector:\r\n    matchLabels:\r\n      app: test\r\n  template:\r\n    metadata:\r\n      labels:\r\n        app: test\r\n    spec:\r\n      containers:\r\n      - name: server\r\n        env:\r\n        - name: DB_MAINDB_HOST\r\n          value: maindb.example.com\r\n        - name: DB_MAINDB_DATABASE\r\n          value: test\r\n        - name: DB_MAINDB_USERNAME\r\n          value: username\r\n        - name: DB_MAINDB_PASSWORD\r\n          value: password\r\n        - name: ES_HOST\r\n          value: es-client.example.com\r\n        - name: ES_INDEX\r\n          value: test\r\n        - name: REDIS_HOST\r\n          value: redis.example.com\r\n        image: bustbox\r\n```\r\n\r\n**Desired output**\r\n```\r\n{\r\n  &quot;namespace&quot;: &quot;default&quot;,\r\n  &quot;name&quot;: &quot;test&quot;,\r\n  &quot;databases&quot;: [\r\n    {\r\n      &quot;name&quot;: &quot;DB_MAINDB_DATABASE&quot;,\r\n      &quot;value&quot;: &quot;test&quot;\r\n    },\r\n    {\r\n      &quot;name&quot;: &quot;DB_MAINDB_HOST&quot;,\r\n      &quot;value&quot;: &quot;maindb.example.com&quot;\r\n    },\r\n    {\r\n      &quot;name&quot;: &quot;DB_MAINDB_PASSWORD&quot;,\r\n      &quot;value&quot;: &quot;password&quot;\r\n    },\r\n    {\r\n      &quot;name&quot;: &quot;DB_MAINDB_USERNAME&quot;,\r\n      &quot;value&quot;: &quot;username&quot;\r\n    }\r\n  ],\r\n  &quot;redis&quot;: [\r\n    {\r\n      &quot;name&quot;: &quot;REDIS_HOST&quot;,\r\n      &quot;value&quot;: &quot;redis.example.com&quot;\r\n    }\r\n  ],\r\n  &quot;elasticsearch&quot;: [\r\n    {\r\n      &quot;name&quot;: &quot;ES_HOST&quot;,\r\n      &quot;value&quot;: &quot;es-client.example.com&quot;\r\n    },\r\n    {\r\n      &quot;name&quot;: &quot;ES_INDEX&quot;,\r\n      &quot;value&quot;: &quot;test&quot;\r\n    }\r\n  ]\r\n}\r\n```\r\nI tried to do this with the following command:\r\n```\r\nkubectl get deployments test -o json | jq -r &#39;. |\r\n        {namespace: .metadata.namespace,\r\n        name: .metadata.name,\r\n        databases: (.spec.template.spec.containers[].env | [ map(.) | .[] | select(.name | contains (&quot;DB&quot;))] | sort_by(.name)),\r\n        redis: (.spec.template.spec.containers[].env | [ map(.) | .[] | select(.name | contains (&quot;REDIS&quot;))] | sort_by(.name)),\r\n        elasticsearch: (.spec.template.spec.containers[].env | [ map(.) | .[] | select(.name | test(&quot;^(ES_).&quot;) or contains (&quot;ELASTIC&quot;))] | sort_by(.name)),\r\n        }&#39;\r\n```\r\n\r\n\r\nI am looking for a slightly more elegant solution to my problem and, in addition, want to have the ability to manage a mapping of the categories with the relevant regex as additional input to the command.\r\n\r\nThanks!",
        "link": "https://stackoverflow.com/questions/72174860/extract-and-group-by-type-env-variables-from-k8s-deployments-with-jq",
        "title": "Extract and group by type env variables from k8s deployments with jq"
    },
    {
        "tags": [
            "json",
            "linux",
            "shell",
            "sed",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 6313442,
                    "reputation": 45115,
                    "user_id": 5625547,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/oqCND.jpg?s=256",
                    "display_name": "0stone0",
                    "link": "https://stackoverflow.com/users/5625547/0stone0"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1652192808,
                "post_id": 72187636,
                "comment_id": 127543985,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1652193277,
                "creation_date": 1652193277,
                "answer_id": 72188296,
                "question_id": 72187636,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Using `jq`\r\n```\r\n$ jq &#39;.data.name |= . + &quot;-test&quot;&#39; meta.json\r\n{\r\n  &quot;version&quot;: &quot;2.2.0&quot;,\r\n  &quot;vname&quot;: &quot;tf&quot;,\r\n  &quot;data&quot;: {\r\n    &quot;name&quot;: &quot;demo-test&quot;,\r\n    &quot;udn&quot;: {\r\n      &quot;description&quot;: &quot;The `main` tf in this template creates a resource`. &quot;\r\n    }\r\n  }\r\n}\r\n```\r\nUsing `sed`\r\n```\r\n$ sed &#39;/\\&lt;name\\&gt;/s/[[:punct:]]\\+$/-test&amp;/&#39; meta.json\r\n{\r\n  &quot;version&quot;: &quot;2.2.0&quot;,\r\n  &quot;vname&quot;: &quot;tf&quot;,\r\n  &quot;data&quot;: {\r\n    &quot;name&quot;: &quot;demo-test&quot;,\r\n    &quot;udn&quot;: {\r\n      &quot;description&quot;: &quot;The `main` tf in this template creates a resource`. &quot;\r\n    }\r\n  }\r\n}\r\n```",
                "title": "Find and append an string in json file using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1652193277,
        "creation_date": 1652190793,
        "question_id": 72187636,
        "body_markdown": "I&#39;ve a Json file `meta.json` with the below content and I want to do find and append operation in the below json file using *jq filter*. For example the below json value of `name` is `demo` so, append an string to it like `-test` so the final value will be `demo-test`\r\n\r\n```\r\n{\r\n  &quot;version&quot;: &quot;2.2.0&quot;,\r\n  &quot;vname&quot;: &quot;tf&quot;,\r\n  &quot;data&quot;: {\r\n    &quot;name&quot;: &quot;demo&quot;,\r\n    &quot;udn&quot;: {\r\n      &quot;description&quot;: &quot;The `main` tf in this template creates a resource`. &quot;\r\n    }\r\n  }\r\n}\r\n```\r\nThe updated json file should contain the data like below\r\n\r\n```\r\n{\r\n  &quot;version&quot;: &quot;2.2.0&quot;,\r\n  &quot;vname&quot;: &quot;tf&quot;,\r\n  &quot;data&quot;: {\r\n    &quot;name&quot;: &quot;demo-test&quot;,\r\n    &quot;udn&quot;: {\r\n      &quot;description&quot;: &quot;The `main` tf in this template creates a resource`. &quot;\r\n    }\r\n  }\r\n}\r\n```\r\n\r\nDoes JQ filter supports this? how we can do this?",
        "link": "https://stackoverflow.com/questions/72187636/find-and-append-an-string-in-json-file-using-jq",
        "title": "Find and append an string in json file using jq"
    },
    {
        "tags": [
            "r",
            "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": 1652192547,
                "post_id": 72187905,
                "comment_id": 127543849,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1181375,
                    "reputation": 23872,
                    "user_id": 1156245,
                    "user_type": "registered",
                    "accept_rate": 85,
                    "profile_image": "https://i.sstatic.net/Cug0U.jpg?s=256",
                    "display_name": "geotheory",
                    "link": "https://stackoverflow.com/users/1156245/geotheory"
                },
                "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": 1652195717,
                "post_id": 72187905,
                "comment_id": 127545319,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2435703,
                    "reputation": 27493,
                    "user_id": 2125671,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/13a492143ab4a2575b5a1f500691193c?s=256&d=identicon&r=PG",
                    "display_name": "Philippe",
                    "link": "https://stackoverflow.com/users/2125671/philippe"
                },
                "edited": false,
                "score": 3,
                "creation_date": 1652196692,
                "post_id": 72187905,
                "comment_id": 127545733,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1181375,
                    "reputation": 23872,
                    "user_id": 1156245,
                    "user_type": "registered",
                    "accept_rate": 85,
                    "profile_image": "https://i.sstatic.net/Cug0U.jpg?s=256",
                    "display_name": "geotheory",
                    "link": "https://stackoverflow.com/users/1156245/geotheory"
                },
                "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": 1652216710,
                "post_id": 72187905,
                "comment_id": 127552304,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1181375,
                    "reputation": 23872,
                    "user_id": 1156245,
                    "user_type": "registered",
                    "accept_rate": 85,
                    "profile_image": "https://i.sstatic.net/Cug0U.jpg?s=256",
                    "display_name": "geotheory",
                    "link": "https://stackoverflow.com/users/1156245/geotheory"
                },
                "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": 1,
                "creation_date": 1652217085,
                "post_id": 72187905,
                "comment_id": 127552403,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 7914169,
                    "reputation": 26288,
                    "user_id": 5977215,
                    "user_type": "registered",
                    "accept_rate": 79,
                    "profile_image": "https://i.sstatic.net/0nQX3.jpg?s=256",
                    "display_name": "SymbolixAU",
                    "link": "https://stackoverflow.com/users/5977215/symbolixau"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1652237535,
                "post_id": 72187905,
                "comment_id": 127555476,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1652237195,
                "last_edit_date": 1652237195,
                "creation_date": 1652216926,
                "answer_id": 72192967,
                "question_id": 72187905,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "&gt; Am I missing something about how jq works?\r\n\r\njq&#39;s processing of JSON is usually quite fast (*), but each invocation of jq does have a non-trivial start-up cost, so your `bash` &quot;for&quot; loop is suboptimal, in that a single jq invocation would be sufficient to produce the same result unless the glob expansion fails:\r\n\r\n    jq .sentence *.json\r\n\r\nIf you have difficulties with this, then since you&#39;ve indicated `ls *.json` works, the following should too:\r\n\r\n    cat *.json | jq .sentence\r\n\r\n---\r\n\r\n(*) At least if the whole JSON document must be read.  For comparison, here are some timings reading a well-known JSON file, jeopardy.json (**): \r\n```\r\n$ time jq length jeopardy.json\r\n216930\r\n\r\nuser 0m1.266s\r\nsys\t 0m0.271s\r\n\r\n$ time gojq length jeopardy.json\r\n216930\r\n\r\nuser 0m0.989s\r\nsys\t 0m0.162s\r\n\r\n$ time jaq length &lt; jeopardy.json\r\n216930\r\n\r\nuser 0m1.406s\r\nsys\t 0m0.221s\r\n\r\n$ time R -f &lt;(echo &#39;require(jsonlite);x=read_json(&quot;jeopardy.json&quot;)&#39; )\r\nuser 0m2.709s\r\nsys\t 0m0.463s\r\n\r\n$ time python3 &lt;&lt;&lt; &quot;import json; f = open(&#39;jeopardy.json&#39;); data=json.load(f); print(len(data))&quot;\r\n216930\r\n\r\nuser 0m0.693s\r\nsys\t 0m0.250s\r\n\r\ntime jj &#39;#&#39; &lt; jeopardy.json \r\n216930\r\n\r\nuser 0m0.242s\r\nsys\t 0m0.102s\r\n```\r\n\r\n\r\nFor certain types of queries, alternatives to jq&#39;s standard parser would be faster.  One potentially relevant alternative is jq&#39;s own &quot;streaming parser&quot;, though it is usually of interest for JSON texts that are too large to fit in memory. \r\n\r\n(**) Often named JEOPARDY_QUESTIONS1.json\r\ne.g. at https://github.com/ryanwholey/jeopardy_bot/blob/master/JEOPARDY_QUESTIONS1.json\r\n",
                "title": "jq slow performance for numerous files"
            },
            {
                "up_vote_count": 4,
                "is_accepted": false,
                "score": 4,
                "last_activity_date": 1652222059,
                "creation_date": 1652222059,
                "answer_id": 72193592,
                "question_id": 72187905,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Running jq (or any program) repetitively can take long time, so we need to reduce the number of calls as much as possible.\r\n\r\nFor `argument list too long errors`, try this :\r\n\r\n```\r\nfind . -maxdepth 1 -mindepth 1 -name &quot;*.json&quot; -exec jq .sentence {} +\r\n```\r\n\r\n`find` tries to append as many json files as possible in a single call to `jq`.",
                "title": "jq slow performance for numerous files"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 2,
        "last_activity_date": 1652237195,
        "creation_date": 1652191733,
        "last_edit_date": 1652192158,
        "question_id": 72187905,
        "body_markdown": "My understanding is that jq can greatly speed up json reads due to the way it actively parses the json stream.  But I&#39;m not seeing anything like this in practice.  Here is a comparison with an R workflow (using dummy data created with R).\r\n\r\n    require(dplyr)\r\n    # also requires purrr, stringr, tibble, jsonlite\r\n    \r\n    dir.create(&#39;jq-test&#39;)\r\n    setwd(&#39;jq-test&#39;)\r\n    \r\n    # dummy data ----------------\r\n    \r\n    dat = stringr::sentences[1:100] |&gt; tibble::enframe(name=&#39;id&#39;, value = &#39;sentence&#39;) |&gt; \r\n      mutate(text = purrr::map_chr(id, \\(x)c(letters,rep(&#39; &#39;,6))[sample(1:32, 1000, rep=TRUE)] |&gt; paste(collapse=&#39;&#39;)))\r\n    \r\n    for(i in 1:nrow(dat)) jsonlite::write_json(as.list(dat[i,]), paste0(i, &#39;.json&#39;), auto_unbox=TRUE)\r\n    \r\n    fl = list.files(pattern = &#39;.json&#39;)\r\n    \r\n    # test read\r\n    system.time({\r\n      x = purrr::map_chr(fl, ~ jsonlite::fromJSON(.x)[[&#39;sentence&#39;]])\r\n      data.frame(x=x) |&gt; write.table(file = &#39;sentences-r.txt&#39;, row.names=FALSE, col.names=FALSE)\r\n    })\r\n\r\n.. which reports following runtime for the test read stage:\r\n\r\n       user  system elapsed \r\n      0.042   0.030   0.557 \r\n\r\nNow testing with jq in bash:\r\n\r\n    cat /dev/null &gt; sentences-jq.txt\r\n    SECONDS=0\r\n    \r\n    for file in $(ls *.json)./; do\r\n        sentence=$(jq &quot;.sentence&quot; $file)\r\n        echo $sentence &gt;&gt; sentences-jq.txt\r\n    done\r\n    \r\n    echo runtime ${SECONDS}s\r\n\r\n.. which reports 5 seconds runtime.  So famously slow R is 10x quicker.  And to rule out the `&gt;&gt;` operation note I get the same runtime for `echo $sentence &gt; /dev/null`.\r\n\r\nAm I missing something about how jq works?\r\n",
        "link": "https://stackoverflow.com/questions/72187905/jq-slow-performance-for-numerous-files",
        "title": "jq slow performance for numerous files"
    },
    {
        "tags": [
            "json",
            "bash",
            "azure-devops",
            "jq",
            "azure-pipelines-yaml"
        ],
        "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": 1652198366,
                "post_id": 72189505,
                "comment_id": 127546474,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1652198445,
                "post_id": 72189505,
                "comment_id": 127546510,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 21397027,
                    "reputation": 23,
                    "user_id": 15759926,
                    "user_type": "registered",
                    "profile_image": "https://lh3.googleusercontent.com/-cCiNpCyi9ks/AAAAAAAAAAI/AAAAAAAAAAA/AMZuucnUbpTD4_iGYdaunShwQpyKAMcOVA/s96-c/s256-rj/photo.jpg",
                    "display_name": "James Lahiffe Baker",
                    "link": "https://stackoverflow.com/users/15759926/james-lahiffe-baker"
                },
                "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": 1652198639,
                "post_id": 72189505,
                "comment_id": 127546593,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2686715,
                    "reputation": 8666,
                    "user_id": 2320961,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/AdwXN.png?s=256",
                    "display_name": "Nic3500",
                    "link": "https://stackoverflow.com/users/2320961/nic3500"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1652198860,
                "post_id": 72189505,
                "comment_id": 127546666,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 21397027,
                    "reputation": 23,
                    "user_id": 15759926,
                    "user_type": "registered",
                    "profile_image": "https://lh3.googleusercontent.com/-cCiNpCyi9ks/AAAAAAAAAAI/AAAAAAAAAAA/AMZuucnUbpTD4_iGYdaunShwQpyKAMcOVA/s96-c/s256-rj/photo.jpg",
                    "display_name": "James Lahiffe Baker",
                    "link": "https://stackoverflow.com/users/15759926/james-lahiffe-baker"
                },
                "reply_to_user": {
                    "account_id": 2686715,
                    "reputation": 8666,
                    "user_id": 2320961,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/AdwXN.png?s=256",
                    "display_name": "Nic3500",
                    "link": "https://stackoverflow.com/users/2320961/nic3500"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1652199142,
                "post_id": 72189505,
                "comment_id": 127546749,
                "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": 1652199179,
                "post_id": 72189505,
                "comment_id": 127546771,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 21397027,
                    "reputation": 23,
                    "user_id": 15759926,
                    "user_type": "registered",
                    "profile_image": "https://lh3.googleusercontent.com/-cCiNpCyi9ks/AAAAAAAAAAI/AAAAAAAAAAA/AMZuucnUbpTD4_iGYdaunShwQpyKAMcOVA/s96-c/s256-rj/photo.jpg",
                    "display_name": "James Lahiffe Baker",
                    "link": "https://stackoverflow.com/users/15759926/james-lahiffe-baker"
                },
                "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": 1652202022,
                "post_id": 72189505,
                "comment_id": 127547772,
                "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": 1652202668,
                "post_id": 72189505,
                "comment_id": 127547977,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 21397027,
                    "reputation": 23,
                    "user_id": 15759926,
                    "user_type": "registered",
                    "profile_image": "https://lh3.googleusercontent.com/-cCiNpCyi9ks/AAAAAAAAAAI/AAAAAAAAAAA/AMZuucnUbpTD4_iGYdaunShwQpyKAMcOVA/s96-c/s256-rj/photo.jpg",
                    "display_name": "James Lahiffe Baker",
                    "link": "https://stackoverflow.com/users/15759926/james-lahiffe-baker"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1652204069,
                "post_id": 72189505,
                "comment_id": 127548531,
                "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": 1652206307,
                "post_id": 72189505,
                "comment_id": 127549303,
                "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": 1652206359,
                "post_id": 72189505,
                "comment_id": 127549316,
                "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": 1652206412,
                "post_id": 72189505,
                "comment_id": 127549335,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1652206680,
                "post_id": 72189505,
                "comment_id": 127549441,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 21397027,
                    "reputation": 23,
                    "user_id": 15759926,
                    "user_type": "registered",
                    "profile_image": "https://lh3.googleusercontent.com/-cCiNpCyi9ks/AAAAAAAAAAI/AAAAAAAAAAA/AMZuucnUbpTD4_iGYdaunShwQpyKAMcOVA/s96-c/s256-rj/photo.jpg",
                    "display_name": "James Lahiffe Baker",
                    "link": "https://stackoverflow.com/users/15759926/james-lahiffe-baker"
                },
                "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": 1652356024,
                "post_id": 72189505,
                "comment_id": 127589144,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1660468617,
                "creation_date": 1660468617,
                "answer_id": 73350439,
                "question_id": 72189505,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can get the extract the count and store it in a shell variable with the following statement:\r\n\r\n    modelCount=&quot;$(jq &#39;.variables.abc.models | length&#39; path/to/your/file&quot;\r\n\r\n[`length`](https://stedolan.github.io/jq/manual/v1.6/#length) in jq gives you the length of an array. [`$(…)` is command substution](https://pubs.opengroup.org/onlinepubs/9699919799/utilities/V3_chap02.html#tag_18_06_03) and substitutes the command with its output to be used by the parent command line.",
                "title": "Count The Number Of Json Key Pairs In A Bash Shell Script"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1660468617,
        "creation_date": 1652198104,
        "last_edit_date": 1660468351,
        "question_id": 72189505,
        "body_markdown": "Within a ADO yaml pipeline one of my jobs has a inline script bash shell running. I want to automate a counter being used for a loop later in the script. The counter represents the number of some json embedded key pairs (the value of these key pairs hold variables). Like in most ADO pipelines the variable sheet (it&#39;s actually a variable template sheet but that doesn&#39;t matter) is stored separately to the pipeline and called on at the start of the yaml pipeline. \r\n\r\n```json\r\n{\r\n  &quot;abc&quot;: {\r\n    &quot;models&quot;: {\r\n      &quot;model1&quot;: {\r\n        &quot;a&quot;: &quot;x&quot;,\r\n        &quot;b&quot;: &quot;z&quot;\r\n      },\r\n      &quot;model2&quot;: {\r\n        &quot;a&quot;: &quot;x&quot;,\r\n        &quot;b&quot;: &quot;z&quot;\r\n      },\r\n      &quot;model3&quot;: {\r\n        &quot;a&quot;: &quot;x&quot;,\r\n        &quot;b&quot;: &quot;z&quot;\r\n      }\r\n    }\r\n  }\r\n}\r\n```\r\n\r\nThe desired outcome of this example would be 3 but in the future more models will be added. For context the model names are subject to change - so it&#39;s not possible to do something odd like take the last key pair name and split off the number. It would be best if the solution is written in Bash as I would prefer to avoid any complexities. \r\n\r\nThe only related things I could find and test were:\r\n```\r\n            modelCount5=&quot;$(jq &#39;abc.models | length&#39; ${{ parameters.variableGroup }})&quot;\r\n            echo $modelCount5\r\n            modelCount6=&quot;$(jq &#39;.abc.models | length&#39; ${{ parameters.variableGroup }})&quot;\r\n            echo $modelCount6\r\n            modelCount7=&quot;$(jq &#39;$(abc.models) | length&#39; )&quot;\r\n            echo $modelCount7\r\n            modelCount9=&quot;$(jq &#39;$(abc.models) | length&#39; ${{ parameters.variableGroup }})&quot;\r\n            echo $modelCount9\r\n\r\n```\r\n\r\nThey all resulted in complie errors or directory not found errors.\r\nEg:\r\n```\r\njq: 1 compile error\r\nor\r\njq: error: Could not open file CTS: No such file or directory\r\n\r\n```\r\nI have checked the agent running the pipeline and `jq` has been preinstalled.\r\n\r\n\r\nAnswer\r\n\r\nThankyou all for your help. In the end I did this:\r\n```\r\n   modelCount=&quot;$(jq &#39;.variables.abc.models | length&#39; $(Build.SourcesDirectory)/variables/templates/variables-sheet.jsonc)&quot;   \r\n\r\n``` \r\n...and it worked great! It was a matter of configuring my path to the file properly.",
        "link": "https://stackoverflow.com/questions/72189505/count-the-number-of-json-key-pairs-in-a-bash-shell-script",
        "title": "Count The Number Of Json Key Pairs In A Bash Shell Script"
    },
    {
        "tags": [
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1652265111,
                "post_id": 72199423,
                "comment_id": 127562830,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 3150808,
                    "reputation": 45,
                    "user_id": 2664304,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/3c9c29624c0880a3c2535c1a75041eba?s=256&d=identicon&r=PG",
                    "display_name": "user2664304",
                    "link": "https://stackoverflow.com/users/2664304/user2664304"
                },
                "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": 1652267645,
                "post_id": 72199423,
                "comment_id": 127563735,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1662328331,
                "last_edit_date": 1662328331,
                "creation_date": 1662324276,
                "answer_id": 73602723,
                "question_id": 72199423,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "`#` starts a comment and your jq program degenerates to `.[]|.` which is identical to the program `.[]` (`|.` is a no-op/the identity filter). This program will simply select all values from the input.\r\n\r\nYou must quote certain characters, such as `#`, when they are part of propery names. The following will work with your JSON file:\r\n\r\n```\r\njq -r &#39;.[] | .&quot;#HpeiLOSnmpService&quot;.v2_3_0.HpeiLOSnmpService&#39;\r\n```",
                "title": "Parsing json file with jq from HPE iLO"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1669740825,
                "creation_date": 1669740825,
                "answer_id": 74617526,
                "question_id": 72199423,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Thanks.  Using the quotes around the key with a &#39;#&#39; works.  Ultimately, selecting the SecurityName that was unset was done with:\r\n\r\n```\r\njq -r &#39;.Users[] | select (.SecurityName == &quot;&quot;) | {&quot;AuthProtocol&quot;:.AuthProtocol,&quot;PrivacyProtocol&quot;:.PrivacyProtocol,&quot;SecurityName&quot;:.SecurityName,&quot;UserEngineID&quot;:.UserEngineID}&#39;\r\n```",
                "title": "Parsing json file with jq from HPE iLO"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1669740825,
        "creation_date": 1652264824,
        "question_id": 72199423,
        "body_markdown": "I have a json file pulled from an HPE iLO interface with the snmp configuration.  It looks like:\r\n\r\n    [\r\n       {\r\n         &quot;Comments&quot;: {\r\n           &quot;BIOSDate&quot;: &quot;01/23/2021&quot;,\r\n           &quot;BIOSFamily&quot;: &quot;U30&quot;,\r\n           &quot;Manufacturer&quot;: &quot;HPE&quot;,\r\n           &quot;Model&quot;: &quot;ProLiant DL380 Gen10&quot;,\r\n           &quot;SerialNumber&quot;: &quot;5UNESX378&quot;,\r\n           &quot;iLOVersion&quot;: &quot;iLO 5 v2.65&quot;\r\n         }\r\n       },\r\n       {\r\n         &quot;#HpeiLOSnmpService.v2_3_0.HpeiLOSnmpService&quot;: {\r\n           &quot;/redfish/v1/Managers/1/SnmpService/&quot;: {\r\n             &quot;@odata.context&quot;: &quot;/redfish/v1/$metadata#HpeiLOSnmpService.HpeIloSnmpService&quot;,\r\n             &quot;@odata.id&quot;: &quot;/redfish/v1/Managers/1/SnmpService&quot;,\r\n             &quot;Actions&quot;: {\r\n               &quot;#HpeIloSnmpService.SendSNMPTestAlert&quot;: {\r\n                 &quot;target&quot;: &quot;/redfish/v1/Managers/1/SnmpService/Actions/HpeILOSnmpService.SendSNMPTestAlert/&quot;\r\n               }\r\n             },\r\n             &quot;AlertDestinationAssociations&quot;: [\r\n               {\r\n                 &quot;SNMPAlertProtocol&quot;: &quot;SNMPv3Trap&quot;,\r\n                 &quot;SecurityName&quot;: null\r\n               }\r\n             ],\r\n             &quot;AlertDestinations&quot;: [\r\n               &quot;1.2.3.4&quot;,\r\n               &quot;5.6.7.8&quot;,\r\n               null,\r\n               null\r\n             ],\r\n             &quot;AlertsEnabled&quot;: true,\r\n             &quot;Name&quot;: &quot;SnmpService&quot;\r\n           },\r\n           &quot;PeriodicHSATrapConfig&quot;: &quot;Disabled&quot;,\r\n           &quot;ReadCommunities&quot;: [\r\n             &quot;&quot;,\r\n             &quot;&quot;,\r\n             &quot;&quot;\r\n           ],\r\n           &quot;Role&quot;: &quot;&quot;,\r\n           &quot;RoleDetail&quot;: &quot;&quot;,\r\n           &quot;SNMPAlertDestinations&quot;: {\r\n             &quot;@odata.id&quot;: &quot;/redfish/v1/Managers/1/SnmpService/SNMPAlertDestinations/&quot;\r\n            },\r\n            &quot;SNMPUsers&quot;: {\r\n              &quot;@odata.id&quot;: &quot;/redfish/v1/Managers/1/SnmpService/SNMPUsers/&quot;\r\n            },\r\n            &quot;SNMPv1Enabled&quot;: false,\r\n            &quot;SNMPv3EngineID&quot;: &quot;0x8920000000E3028329E002033&quot;,\r\n            &quot;SNMPv3InformRetryAttempt&quot;: 2,\r\n            &quot;SNMPv3InformRetryIntervalSeconds&quot;: 15,\r\n            &quot;Status&quot;: {\r\n              &quot;State&quot;: &quot;Enabled&quot;\r\n            },\r\n            &quot;TrapCommunities&quot;: [\r\n              &quot;&quot;,\r\n              &quot;&quot;,\r\n              &quot;&quot;,\r\n              &quot;&quot;,\r\n              &quot;&quot;,\r\n              &quot;&quot;,\r\n              &quot;&quot;\r\n            ],\r\n            &quot;TrapSourceHostname&quot;: &quot;Manager&quot;,\r\n            &quot;Users&quot;: [\r\n               {\r\n                &quot;AuthProtocol&quot;: &quot;MD5&quot;,\r\n                &quot;PrivacyProtocol&quot;: &quot;DES&quot;,\r\n                &quot;SecurityName&quot;: &quot;&quot;,\r\n                &quot;UserEngineID&quot;: null\r\n               },\r\n               {\r\n                 &quot;AuthProtocol&quot;: &quot;MD5&quot;,\r\n                 &quot;PrivacyProtocol&quot;: &quot;DES&quot;,\r\n                 &quot;SecurityName&quot;: &quot;&quot;,\r\n                 &quot;UserEngineID&quot;: null\r\n               },\r\n               {\r\n                 &quot;AuthProtocol&quot;: &quot;SHA&quot;,\r\n                 &quot;PrivacyProtocol&quot;: &quot;AES&quot;,\r\n                 &quot;SecurityName&quot;: &quot;oneview_4849283d97929392&quot;,\r\n                 &quot;UserEngineID&quot;: null\r\n               },\r\n               {\r\n                 &quot;AuthProtocol&quot;: &quot;MD5&quot;,\r\n                  &quot;PrivacyProtocol&quot;: &quot;DES&quot;,\r\n                  &quot;SecurityName&quot;: &quot;&quot;,\r\n                  &quot;UserEngineID&quot;: null\r\n               }\r\n          ]\r\n        }\r\n      }\r\n    ]\r\n\r\nI want to select an element in the Users array that has SecurityName set to &quot;&quot; and change that element.  I don&#39;t need the Comments portion.  So, I try to select the section starting with #HpeiLOSnmpService.v2_3_0.HpeiLOSnmpService with:\r\n\r\n    jq -r &#39;.[] | .#HpeiLOSnmpService.v2_3_0.HpeiLOSnmpService&#39; snmp.json\r\n\r\nbut it gives me everything without the enclosing array.  Anyone have a suggestion?\r\n\r\nThanks!\r\n\r\n",
        "link": "https://stackoverflow.com/questions/72199423/parsing-json-file-with-jq-from-hpe-ilo",
        "title": "Parsing json file with jq from HPE iLO"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1652268852,
                "last_edit_date": 1652268852,
                "creation_date": 1652268482,
                "answer_id": 72200246,
                "question_id": 72200061,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You could just use `select` to filter out that case\r\n~~~sh\r\njq &#39;[{values: (.foo + [.bar | select(. != &quot;&quot;)]) | map({key:.})}]&#39;\r\n~~~\r\n\r\nIf `.bar == &quot;key3&quot;`, it prints\r\n~~~json\r\n[\r\n  {\r\n    &quot;values&quot;: [\r\n      {\r\n        &quot;key&quot;: &quot;key1&quot;\r\n      },\r\n      {\r\n        &quot;key&quot;: &quot;key2&quot;\r\n      },\r\n      {\r\n        &quot;key&quot;: &quot;key3&quot;\r\n      }\r\n    ]\r\n  }\r\n]\r\n~~~\r\n\r\n\r\nIf `.bar == &quot;&quot;`, it prints\r\n~~~json\r\n[\r\n  {\r\n    &quot;values&quot;: [\r\n      {\r\n        &quot;key&quot;: &quot;key1&quot;\r\n      },\r\n      {\r\n        &quot;key&quot;: &quot;key2&quot;\r\n      }\r\n    ]\r\n  }\r\n]\r\n~~~\r\n\r\nIf `.bar` does not exist, it will print\r\n~~~json\r\n[\r\n  {\r\n    &quot;values&quot;: [\r\n      {\r\n        &quot;key&quot;: &quot;key1&quot;\r\n      },\r\n      {\r\n        &quot;key&quot;: &quot;key2&quot;\r\n      },\r\n      {\r\n        &quot;key&quot;: null\r\n      }\r\n    ]\r\n  }\r\n]\r\n~~~\r\nIf in this last case you want to have the same result as with `.bar == &quot;&quot;`, then change `. != &quot;&quot;` to `values != &quot;&quot;` in the filter to consider only values that are not `null` (or to `strings != &quot;&quot;` to only consider (non-empty) strings and disregard any other type).",
                "title": "Conditional append a element to an array"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1652268852,
        "creation_date": 1652267718,
        "question_id": 72200061,
        "body_markdown": "Here is the jq I have, it just wants to build a new element and then append it to an array,\r\n\r\n```\r\n[.[] | . as { foo: $foo1,  bar: $bar1} |\r\n    {\r\n        names: ([\r\n            $foo1 | range(0;length) as $i |\r\n            { key: ($foo1[$i]) }\r\n        ] + [{ key: $bar1 }])\r\n    } |\r\n    {\r\n    values: .names,\r\n    }\r\n]\r\n```\r\n\r\nAnd suppose I have a json like this, \r\n\r\n```\r\n{\r\n  &quot;foo&quot;:[\r\n     &quot;key1&quot;,\r\n     &quot;key2&quot;\r\n   ],\r\n  &quot;bar&quot;: &quot;key3&quot;\r\n\r\n}\r\n```\r\n\r\nThis will generate a json file like this, \r\n\r\n```\r\n[\r\n  {\r\n    &quot;values&quot;: [\r\n      {\r\n        &quot;key&quot;: &quot;key1&quot;\r\n      },\r\n      {\r\n        &quot;key&quot;: &quot;key2&quot;\r\n      },\r\n      {\r\n        &quot;key&quot;: &quot;key3&quot;\r\n      }\r\n    ]\r\n  }\r\n]\r\n```\r\n\r\nBut the element should be only appended when the $bar is not an empty string, can I do something like this?\r\n\r\n```\r\n[.[] | . as { foo1: $foo1,  bar1: $bar1 if $bar != &quot;&quot;}\r\n...\r\n```\r\n\r\nor do it when is appended, \r\n\r\n```\r\n        names: ([\r\n            $foo1 | range(0;length) as $i |\r\n            { key: ($foo1[$i]) }\r\n        ] + [{ key: $bar1 }] | if $bar != &quot;&quot;)\r\n\r\n```\r\n\r\nthanks in advance for any help!",
        "link": "https://stackoverflow.com/questions/72200061/conditional-append-a-element-to-an-array",
        "title": "Conditional append a element to an array"
    },
    {
        "tags": [
            "json",
            "key",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1652271690,
                "last_edit_date": 1652271690,
                "creation_date": 1652271650,
                "answer_id": 72200970,
                "question_id": 72200805,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s a solution using `to_entries`, which decomposes an object into an array of key-value pairs:\r\n~~~sh\r\njq -r &#39;.[] | .id as $id | to_entries[] | [$id,.key,.value] | join(&quot;|&quot;)&#39;\r\n~~~\r\n~~~json\r\n11|id|11\r\n11|b|100\r\n12|id|12\r\n12|d|fred\r\n12|e|300\r\n~~~",
                "title": "How to use jq to transform array of objects into separated list of key values - Outputing specific key value instead of array index"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1652273659,
        "creation_date": 1652270880,
        "last_edit_date": 1652273659,
        "question_id": 72200805,
        "body_markdown": "This is related to my previous question:\r\nhttps://stackoverflow.com/questions/71825711/how-to-use-jq-to-format-array-of-objects-to-separated-list-of-key-values\r\n\r\nHow can I (generically) transform the input file below to the output file below, using jq. The value at key &quot;id&quot; uniqely identifies the array element. The record format of the output file is: (value at key &quot;id&quot;) | key | value. \r\n\r\nI can do this if I add awk to solution of previous question, but I am having trouble getting my head around doing it all in jq.\r\n\r\n**Input file:**\r\n```\r\n[{&quot;id&quot;: 11, &quot;b&quot;: 100},\r\n {&quot;id&quot;: 12, &quot;d&quot;: &quot;fred&quot;, &quot;e&quot;: 300}]\r\n```\r\n**Output File:**\r\n```\r\n11|id|11\r\n11|b|100\r\n12|id|12\r\n12|d|fred\r\n12|e|300\r\n```\r\n",
        "link": "https://stackoverflow.com/questions/72200805/how-to-use-jq-to-transform-array-of-objects-into-separated-list-of-key-values",
        "title": "How to use jq to transform array of objects into separated list of key values - Outputing specific key value instead of array index"
    },
    {
        "tags": [
            "json",
            "bash",
            "shell",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 24263129,
                    "reputation": 105,
                    "user_id": 18212440,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/a4e35da713cd6cb2d523b97f214124f7?s=256&d=identicon&r=PG",
                    "display_name": "rabbit",
                    "link": "https://stackoverflow.com/users/18212440/rabbit"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1652282311,
                "post_id": 72203351,
                "comment_id": 127570149,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 4879,
                    "reputation": 248190,
                    "user_id": 7552,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/b60298053f87465641c1b1192338c8cd?s=256&d=identicon&r=PG",
                    "display_name": "glenn jackman",
                    "link": "https://stackoverflow.com/users/7552/glenn-jackman"
                },
                "edited": false,
                "score": 3,
                "creation_date": 1652283037,
                "post_id": 72203351,
                "comment_id": 127570471,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 21749867,
                    "reputation": 147,
                    "user_id": 16056004,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/z84Uf.jpg?s=256",
                    "display_name": "SystemCyprus",
                    "link": "https://stackoverflow.com/users/16056004/systemcyprus"
                },
                "reply_to_user": {
                    "account_id": 24263129,
                    "reputation": 105,
                    "user_id": 18212440,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/a4e35da713cd6cb2d523b97f214124f7?s=256&d=identicon&r=PG",
                    "display_name": "rabbit",
                    "link": "https://stackoverflow.com/users/18212440/rabbit"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1652283049,
                "post_id": 72203351,
                "comment_id": 127570475,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 4879,
                    "reputation": 248190,
                    "user_id": 7552,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/b60298053f87465641c1b1192338c8cd?s=256&d=identicon&r=PG",
                    "display_name": "glenn jackman",
                    "link": "https://stackoverflow.com/users/7552/glenn-jackman"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1652283190,
                "post_id": 72203351,
                "comment_id": 127570550,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 4879,
                    "reputation": 248190,
                    "user_id": 7552,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/b60298053f87465641c1b1192338c8cd?s=256&d=identicon&r=PG",
                    "display_name": "glenn jackman",
                    "link": "https://stackoverflow.com/users/7552/glenn-jackman"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1652283359,
                "post_id": 72203351,
                "comment_id": 127570629,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 21749867,
                    "reputation": 147,
                    "user_id": 16056004,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/z84Uf.jpg?s=256",
                    "display_name": "SystemCyprus",
                    "link": "https://stackoverflow.com/users/16056004/systemcyprus"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1652283449,
                "post_id": 72203351,
                "comment_id": 127570666,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1652298796,
                "last_edit_date": 1652298796,
                "creation_date": 1652285113,
                "answer_id": 72204246,
                "question_id": 72203351,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "It worked using the comment suggestions like this\r\n```\r\nelement=&#39;{&quot;x&quot;:&quot;zero&quot;}&#39;\r\nexample=&#39;{\r\n    &quot;a&quot;:&quot;one&quot;,\r\n    &quot;b&quot;:&quot;two&quot;,\r\n    &quot;c&quot;:&quot;three&quot;\r\n}&#39;\r\njq -n --argjson el &quot;$element&quot; --argjson ex &quot;$example&quot; &#39;$el + $ex&#39;\r\n```",
                "title": "How to append a json variable to another?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1652298904,
        "creation_date": 1652281380,
        "last_edit_date": 1652298904,
        "question_id": 72203351,
        "body_markdown": "I want to avoid using JSON files and use variables but it doesn&#39;t work\r\n```\r\nelement=&#39;{&quot;x&quot;: &quot;zero&quot;}&#39;\r\nexample=&#39;{\r\n    &quot;a&quot;: &quot;one&quot;,\r\n    &quot;b&quot;: &quot;two&quot;,\r\n    &quot;c&quot;: &quot;three&quot;,\r\n}&#39;\r\n\r\njq -s &#39;.[0] * .[1]&#39; element.json example.json\r\n```\r\nIf the contents of the JSON files are exactly as what&#39;s inside the single quotes of the vars it works as expected. But I also want the element to be the first one (with `*` it doesn&#39;t go first, with `+=`, it makes another object)\r\n\r\nIf I replace the filenames with `$element` and `$example`, it fails (expecting a file)\r\n\r\nI tried like this:\r\n```\r\njq --argjson el &quot;$element&quot; --argjson ex &quot;$example&quot; &#39;$el += $ex&#39;\r\n```\r\nbut it says `jq: invalid JSON text passed to --argjson`. I don&#39;t get it. The vars seem to be correct JSON.\r\n\r\nI just want this output, &quot;x&quot; first, using variables not files:\r\n\r\n```\r\n{\r\n    &quot;x&quot;: &quot;zero&quot;,\r\n    &quot;a&quot;: &quot;one&quot;,\r\n    &quot;b&quot;: &quot;two&quot;,\r\n    &quot;c&quot;: &quot;three&quot;,\r\n}\r\n```",
        "link": "https://stackoverflow.com/questions/72203351/how-to-append-a-json-variable-to-another",
        "title": "How to append a json variable to another?"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1652288018,
                "last_edit_date": 1652288018,
                "creation_date": 1652287485,
                "answer_id": 72204758,
                "question_id": 72204663,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "In order for the new field to appear at the top, the object that holds it must appear first in the addition statement. For example:\r\n```\r\n$ jq  --argjson el &quot;$element&quot;  &#39;map($el + .)&#39;  &lt;&lt;&lt; $example\r\n[\r\n  {\r\n    &quot;x&quot;: &quot;zero&quot;,\r\n    &quot;a&quot;: &quot;one&quot;,\r\n    &quot;b&quot;: &quot;two&quot;,\r\n    &quot;c&quot;: &quot;three&quot;\r\n  },\r\n  {\r\n    &quot;x&quot;: &quot;zero&quot;,\r\n    &quot;d&quot;: &quot;four&quot;,\r\n    &quot;e&quot;: &quot;five&quot;,\r\n    &quot;f&quot;: &quot;six&quot;\r\n  }\r\n]\r\n```\r\n",
                "title": "How to insert a field at the top of an object?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1652288018,
        "creation_date": 1652287031,
        "last_edit_date": 1652287509,
        "question_id": 72204663,
        "body_markdown": "This is my code\r\n```\r\nelement=&#39;{&quot;x&quot;:&quot;zero&quot;}&#39;\r\nexample=&#39;[\r\n{\r\n  &quot;a&quot;:&quot;one&quot;,\r\n  &quot;b&quot;:&quot;two&quot;,\r\n  &quot;c&quot;:&quot;three&quot;\r\n},\r\n{\r\n  &quot;d&quot;:&quot;four&quot;,\r\n  &quot;e&quot;:&quot;five&quot;,\r\n  &quot;f&quot;:&quot;six&quot;\r\n}]&#39;\r\n\r\njq --argjson el &quot;$element&quot; &#39;.[] += $el&#39; &lt;&lt;&lt; $example\r\n```\r\n\r\nIt currently outputs\r\n```\r\n[\r\n  {\r\n    &quot;a&quot;:&quot;one&quot;,\r\n    &quot;b&quot;:&quot;two&quot;,\r\n    &quot;c&quot;:&quot;three&quot;,\r\n    &quot;x&quot;:&quot;zero&quot;\r\n  },\r\n  {\r\n    &quot;d&quot;:&quot;four&quot;,\r\n    &quot;e&quot;:&quot;five&quot;,\r\n    &quot;f&quot;:&quot;six&quot;,\r\n    &quot;x&quot;:&quot;zero&quot;\r\n  }\r\n]\r\n```\r\n\r\nBut i would like to have the `&quot;x&quot;:&quot;zero&quot;` be the first element of all array elements, not the last.\r\n\r\nInverting the variable with the `.[]` iterator would make no sense. Any idea how this can be done?",
        "link": "https://stackoverflow.com/questions/72204663/how-to-insert-a-field-at-the-top-of-an-object",
        "title": "How to insert a field at the top of an object?"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1652293351,
                "creation_date": 1652293351,
                "answer_id": 72205900,
                "question_id": 72205843,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You need two nested iterations, one in each array. Save the value of `.id` in a variable to access it later.\r\n~~~sh\r\njq -r &#39;\r\n  .ticket_fields[] | select(.type==&quot;tagger&quot;) | .id as $id\r\n  | .custom_field_options[] | [$id, .name, .value]\r\n  | @tsv\r\n&#39;\r\n~~~\r\n",
                "title": "Group nested array objects to parent key in JQ"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1652293351,
        "creation_date": 1652293115,
        "question_id": 72205843,
        "body_markdown": "I have JSON coming from an external application, formatted like so:\r\n\r\n       {\r\n          &quot;ticket_fields&quot;: [\r\n          {\r\n            &quot;url&quot;: &quot;https://example.com/1122334455.json&quot;,\r\n            &quot;id&quot;: 1122334455,\r\n            &quot;type&quot;: &quot;tagger&quot;,\r\n            &quot;custom_field_options&quot;: [\r\n              {\r\n                &quot;id&quot;: 123456789,\r\n                &quot;name&quot;: &quot;I have a problem&quot;,\r\n                &quot;raw_name&quot;: &quot;I have a problem&quot;,\r\n                &quot;value&quot;: &quot;help_i_have_problem&quot;,\r\n                &quot;default&quot;: false\r\n              },\r\n              {\r\n                &quot;id&quot;: 456789123,\r\n                &quot;name&quot;: &quot;I have feedback&quot;,\r\n                &quot;raw_name&quot;: &quot;I have feedback&quot;,\r\n                &quot;value&quot;: &quot;help_i_have_feedback&quot;,\r\n                &quot;default&quot;: false\r\n              },\r\n            ]\r\n          }\r\n          {\r\n            &quot;url&quot;: &quot;https://example.com/6677889900.json&quot;,\r\n            &quot;id&quot;: 6677889900,\r\n            &quot;type&quot;: &quot;tagger&quot;,\r\n            &quot;custom_field_options&quot;: [\r\n              {\r\n                &quot;id&quot;: 321654987,\r\n                &quot;name&quot;: &quot;United States,\r\n                &quot;raw_name&quot;: &quot;United States&quot;,\r\n                &quot;value&quot;: &quot;location_123_united_states&quot;,\r\n                &quot;default&quot;: false\r\n              },\r\n              {\r\n                &quot;id&quot;: 987456321,\r\n                &quot;name&quot;: &quot;Germany&quot;,\r\n                &quot;raw_name&quot;: &quot;Germany&quot;,\r\n                &quot;value&quot;: &quot;location_456_germany&quot;,\r\n                &quot;default&quot;: false\r\n              }\r\n            ]\r\n          }\r\n        ]\r\n      }\r\n\r\nThe end goal is to be able to get the data into a TSV in the sense that each object in the custom_field_options array is grouped by the parent ID (`ticket_fields.id`), and then transposed such that each object would be represented on a single line, like so:\r\n\r\n| Ticket Field ID | Name | Value |\r\n| -------- | -------------- | ------- |\r\n| 1122334455| I have a problem | help_i_have_problem|\r\n| 1122334455| I have feedback | help_i_have_feedback|\r\n| 6677889900| United States | location_123_united_states|\r\n| 6677889900| Germany | location_456_germany|\r\n\r\nI have been able to export the data successfully to TSV already, but it reads per-line, and without preserving order, like so:\r\n\r\n*Using `jq -r &#39;.ticket_fields[] | select(.type==&quot;tagger&quot;) | [.id, .custom_field_options[].name, .custom_field_options[].value] | @tsv&#39;`*\r\n\r\n| Ticket Field ID | Name | Name | Value | Value |\r\n| -------- | -------------- | ------- | ------- |------- |\r\n| 1122334455| I have a problem | I have feedback | help_i_have_problem| help_i_have_feedback|\r\n| 6677889900| United States | Germany | location_123_united_states| location_456_germany|\r\n\r\nEach of the `custom_field_options` arrays in production may consist of any number of objects (not limited to 2 each). But I seem to be stuck on how to appropriately group or map these objects to their parent `ticket_fields.id` and to transpose the data in a clean manner. The `select(.type==&quot;tagger&quot;)` is mentioned in the query as there are multiple values for `ticket_fields.type` which need to be filtered out.\r\n\r\nBased on another answer on here, I did try variants of `jq -r &#39;.ticket_fields[] | select(.type==&quot;tagger&quot;) | map(.custom_field_options |= from_entries) | group_by(.custom_field_options.ticket_fields) | map(map( .custom_field_options |= to_entries))&#39;\r\n` without success. Any assistance would be greatly appreciated!",
        "link": "https://stackoverflow.com/questions/72205843/group-nested-array-objects-to-parent-key-in-jq",
        "title": "Group nested array objects to parent key in JQ"
    },
    {
        "tags": [
            "json",
            "bash",
            "shell",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1652301419,
                "post_id": 72207300,
                "comment_id": 127576596,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1652301473,
                "creation_date": 1652301473,
                "answer_id": 72207348,
                "question_id": 72207300,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Using `jq`:\r\n\r\n```bash\r\njq -r &#39;.tasks | .[] | select (.state == &quot;Passed&quot;) | .id&#39; file.json\r\n```",
                "title": "Prints id of all passed tasks in Json file using bash"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1652301648,
        "creation_date": 1652301162,
        "question_id": 72207300,
        "body_markdown": "I have a Json file like below,\r\n\r\n    {\r\n      &quot;tasks&quot;: [\r\n        {\r\n          &quot;id&quot;: &quot;nightly_1652299200&quot;,\r\n          &quot;repo&quot;: &quot;tx/tx5&quot;,\r\n          &quot;branch&quot;: &quot;dev&quot;,\r\n          &quot;type&quot;: &quot;HealthCheck&quot;,\r\n          &quot;started_on&quot;: &quot;2022-05-11 23:00:00 +0300 EEST&quot;,\r\n          &quot;state&quot;: &quot;Running&quot;,\r\n          &quot;top_sha&quot;: &quot;10143120c12cd506fca5a466a7c6b27e7cb35b18&quot;,\r\n          &quot;tested_shas&quot;: null,\r\n          &quot;self_url&quot;: &quot;tx/tx5/10143120c12cd506fca5a466a7c6b27e7cb35b18&quot;,\r\n          &quot;is_public&quot;: true\r\n        },\r\n        {\r\n          &quot;id&quot;: &quot;1652298808&quot;,\r\n          &quot;repo&quot;: &quot;tx/tx3d&quot;,\r\n          &quot;branch&quot;: &quot;6.3&quot;,\r\n          &quot;type&quot;: &quot;Integration&quot;,\r\n          &quot;started_on&quot;: &quot;2022-05-11 22:53:28 +0300 EEST&quot;,\r\n          &quot;state&quot;: &quot;Passed&quot;,\r\n          &quot;top_sha&quot;: &quot;40ca8db14a8ddd082270a81e895bf01048949ec4&quot;,\r\n          &quot;tested_shas&quot;: null,\r\n          &quot;self_url&quot;: &quot;tx/tx3d/40ca8db14a8ddd082270a81e895bf01048949ec4&quot;,\r\n          &quot;is_public&quot;: true\r\n        },\r\n        {\r\n          &quot;id&quot;: &quot;1652298252&quot;,\r\n          &quot;repo&quot;: &quot;tx/qtmultimedia&quot;,\r\n          &quot;branch&quot;: &quot;dev&quot;,\r\n          &quot;type&quot;: &quot;Integration&quot;,\r\n          &quot;started_on&quot;: &quot;2022-05-11 22:44:12 +0300 EEST&quot;,\r\n          &quot;state&quot;: &quot;Failed&quot;,\r\n          &quot;top_sha&quot;: &quot;d7dd593b6395a33862742a04a23d88b970f7b914&quot;,\r\n          &quot;tested_shas&quot;: null,\r\n          &quot;self_url&quot;: &quot;qt/qtmultimedia/d7dd593b6395a33862742a04a23d88b970f7b914&quot;,\r\n          &quot;is_public&quot;: true\r\n        }\r\n    }\r\n\r\nI need to find the ID of each and every Passed tasks (&quot;state&quot;: &quot;Passed&quot;) using a bash script. what will be the best approach for this.",
        "link": "https://stackoverflow.com/questions/72207300/prints-id-of-all-passed-tasks-in-json-file-using-bash",
        "title": "Prints id of all passed tasks in Json file using bash"
    },
    {
        "tags": [
            "bash",
            "command-line",
            "scripting",
            "command-line-interface",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1652306134,
                "creation_date": 1652306134,
                "answer_id": 72208019,
                "question_id": 72207971,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Use `transpose` to align the elements from both input arrays, then `add` to combine both sides:\r\n~~~sh\r\njq -n --argjson var1 &quot;$var1&quot; --argjson var2 &quot;$var2&quot; &#39;\r\n  [$var1, $var2] | [transpose[] | add]\r\n&#39;\r\n~~~\r\n~~~json\r\n[\r\n  {\r\n    &quot;a&quot;: &quot;1&quot;,\r\n    &quot;b&quot;: &quot;2&quot;,\r\n    &quot;c&quot;: &quot;3&quot;,\r\n    &quot;d&quot;: &quot;x&quot;,\r\n    &quot;e&quot;: &quot;y&quot;\r\n  },\r\n  {\r\n    &quot;a&quot;: &quot;4&quot;,\r\n    &quot;b&quot;: &quot;5&quot;,\r\n    &quot;c&quot;: &quot;6&quot;,\r\n    &quot;d&quot;: &quot;z&quot;,\r\n    &quot;e&quot;: &quot;q&quot;\r\n  },\r\n  {\r\n    &quot;a&quot;: &quot;7&quot;,\r\n    &quot;b&quot;: &quot;8&quot;,\r\n    &quot;c&quot;: &quot;9&quot;,\r\n    &quot;d&quot;: &quot;w&quot;,\r\n    &quot;e&quot;: &quot;v&quot;\r\n  }\r\n]\r\n~~~",
                "title": "How to merge two JSON array variables?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1652306134,
        "creation_date": 1652305771,
        "question_id": 72207971,
        "body_markdown": "Most of the googling shows it with files but I want to do it with variables. Tried a few things with the documentation but I can&#39;t find the right filter or function or not sure If my approach even makes sense.\r\n\r\n```\r\nvar1=&#39;[\r\n{&quot;a&quot;:&quot;1&quot;,&quot;b&quot;:&quot;2&quot;,&quot;c&quot;:&quot;3&quot;},\r\n{&quot;a&quot;:&quot;4&quot;,&quot;b&quot;:&quot;5&quot;,&quot;c&quot;:&quot;6&quot;},\r\n{&quot;a&quot;:&quot;7&quot;,&quot;b&quot;:&quot;8&quot;,&quot;c&quot;:&quot;9&quot;}\r\n]&#39;\r\n\r\nvar2=&#39;[\r\n{&quot;d&quot;:&quot;x&quot;,&quot;e&quot;:&quot;y&quot;},\r\n{&quot;d&quot;:&quot;z&quot;,&quot;e&quot;:&quot;q&quot;},\r\n{&quot;d&quot;:&quot;w&quot;,&quot;e&quot;:&quot;v&quot;}\r\n]&#39;\r\n```\r\n\r\nThe result I want is\r\n```\r\n&#39;[\r\n{&quot;a&quot;:&quot;1&quot;,&quot;b&quot;:&quot;2&quot;,&quot;c&quot;:&quot;3&quot;,&quot;d&quot;:&quot;x&quot;,&quot;e&quot;:&quot;y&quot;},\r\n{&quot;a&quot;:&quot;4&quot;,&quot;b&quot;:&quot;5&quot;,&quot;c&quot;:&quot;6&quot;,&quot;d&quot;:&quot;z&quot;,&quot;e&quot;:&quot;q&quot;},\r\n{&quot;a&quot;:&quot;7&quot;,&quot;b&quot;:&quot;8&quot;,&quot;c&quot;:&quot;9&quot;,&quot;d&quot;:&quot;w&quot;,&quot;e&quot;:&quot;v&quot;}\r\n]&#39;\r\n```\r\n\r\nIf i use\r\n```\r\njq -n --argjson var1 &quot;$var1&quot; --argjson var2 &quot;$var2&quot; &#39;$var1 + $var2&#39;\r\n```\r\nit just makes a bigger array with all 6 objects, not 3 longer ones\r\n\r\nIf I use `*` or `|=` it gives errors\r\n\r\nI&#39;m not even sure if it&#39;s a filter I need or a builtin function (map doesn&#39;t seem to be doing this)",
        "link": "https://stackoverflow.com/questions/72207971/how-to-merge-two-json-array-variables",
        "title": "How to merge two JSON array variables?"
    },
    {
        "tags": [
            "variables",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 6313442,
                    "reputation": 45115,
                    "user_id": 5625547,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/oqCND.jpg?s=256",
                    "display_name": "0stone0",
                    "link": "https://stackoverflow.com/users/5625547/0stone0"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1652346138,
                "post_id": 72212751,
                "comment_id": 127585595,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 6001080,
                    "reputation": 7652,
                    "user_id": 4742108,
                    "user_type": "registered",
                    "accept_rate": 49,
                    "profile_image": "https://i.sstatic.net/GvE0m.jpg?s=256",
                    "display_name": "Velkan",
                    "link": "https://stackoverflow.com/users/4742108/velkan"
                },
                "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": 1652346261,
                "post_id": 72212751,
                "comment_id": 127585640,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 476555,
                    "reputation": 47257,
                    "user_id": 887539,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/5baef9617bdee6db2f534c118bcbccee?s=256&d=identicon&r=PG",
                    "display_name": "Andreas Louv",
                    "link": "https://stackoverflow.com/users/887539/andreas-louv"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1652346779,
                "post_id": 72212751,
                "comment_id": 127585855,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 6001080,
                    "reputation": 7652,
                    "user_id": 4742108,
                    "user_type": "registered",
                    "accept_rate": 49,
                    "profile_image": "https://i.sstatic.net/GvE0m.jpg?s=256",
                    "display_name": "Velkan",
                    "link": "https://stackoverflow.com/users/4742108/velkan"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1652347193,
                "post_id": 72212751,
                "comment_id": 127586018,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1652348229,
                "creation_date": 1652348229,
                "answer_id": 72213253,
                "question_id": 72212751,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Named arguments are also available to the jq program as `$ARGS.named`.\r\n\r\nSo there is a dictionary to extract variables by a string name from:\r\n\r\n```\r\njq &#39;$ARGS.named[&quot;\\(.var)-file&quot;]&#39; --slurpfile alpha-file &lt;(echo 0) --slurpfile beta-file &lt;(echo 1) &lt;&lt;&lt;&#39;{&quot;var&quot;: &quot;alpha&quot;}&#39;\r\n```\r\n\r\noutputs\r\n\r\n```\r\n[\r\n  0\r\n]\r\n```",
                "title": "How to do double-indirection with jq variables?"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1652472872,
                "last_edit_date": 1652472872,
                "creation_date": 1652467265,
                "answer_id": 72234142,
                "question_id": 72212751,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You could use `getpath` like this:\r\n```\r\njq --slurpfile alphaFile &lt;(echo 0) --slurpfile betaFile &lt;(echo 1) &#39;\r\n   .var as $ab | {alpha: $alphaFile, beta: $betaFile} | getpath([$ab])&#39; &lt;&lt;&lt; &#39;{&quot;var&quot;: &quot;alpha&quot;}&#39;\r\n```\r\n\r\nBetter yet:\r\n\r\n```\r\njq --slurpfile alpha &lt;(echo 0) --slurpfile beta &lt;(echo 1) &#39;\r\n   .var as $ab | {$alpha, $beta} | getpath([$ab])&#39; &lt;&lt;&lt; &#39;{&quot;var&quot;: &quot;alpha&quot;}&#39;\r\n```\r\n\r\n",
                "title": "How to do double-indirection with jq variables?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1652472872,
        "creation_date": 1652346027,
        "last_edit_date": 1652466930,
        "question_id": 72212751,
        "body_markdown": "How to construct a name of a variable from data and access that variable?\r\n\r\nFor example it should somehow give the content of the alpha-file:\r\n\r\n```\r\njq &#39;$.var&quot;-file&quot;&#39; --slurpfile alpha-file &lt;(echo 0) --slurpfile beta-file &lt;(echo 1) &lt;&lt;&lt;&#39;{&quot;var&quot;: &quot;alpha&quot;}&#39;\r\n```\r\n\r\nIt should output:\r\n```\r\n[\r\n  0\r\n]\r\n```",
        "link": "https://stackoverflow.com/questions/72212751/how-to-do-double-indirection-with-jq-variables",
        "title": "How to do double-indirection with jq variables?"
    },
    {
        "tags": [
            "json",
            "shell",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1652358624,
                "creation_date": 1652358624,
                "answer_id": 72215645,
                "question_id": 72215572,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "`select` reproduces its input if the condition evaluates to `true`. Apply it therefore only to the part you want to test. Also, keep the overall context in parentheses to retain it on top-level for output:\r\n~~~sh\r\njq &#39;(.spec.templates[].dag.tasks[].templateRef.name | select(. == &quot;wft-sn&quot;)) += &quot;-test&quot;&#39;\r\n~~~\r\n~~~json\r\n{\r\n  &quot;apiVersion&quot;: &quot;argoproj.io/v1alpha1&quot;,\r\n  &quot;kind&quot;: &quot;Workflow&quot;,\r\n  &quot;metadata&quot;: {\r\n    &quot;generateName&quot;: &quot;kns-vm-&quot;\r\n  },\r\n  &quot;spec&quot;: {\r\n    &quot;templates&quot;: [\r\n      {\r\n        &quot;inputs&quot;: {\r\n          &quot;parameters&quot;: [\r\n            {\r\n              &quot;name&quot;: &quot;un&quot;,\r\n              &quot;value&quot;: &quot;org&quot;\r\n            }\r\n          ]\r\n        },\r\n        &quot;dag&quot;: {\r\n          &quot;tasks&quot;: [\r\n            {\r\n              &quot;name&quot;: &quot;create-ns&quot;,\r\n              &quot;templateRef&quot;: {\r\n                &quot;name&quot;: &quot;wft-kn&quot;\r\n              },\r\n              &quot;arguments&quot;: {\r\n                &quot;parameters&quot;: [\r\n                  {\r\n                    &quot;name&quot;: &quot;un&quot;,\r\n                    &quot;value&quot;: &quot;{{inputs.parameters.un}}&quot;\r\n                  }\r\n                ]\r\n              }\r\n            },\r\n            {\r\n              &quot;name&quot;: &quot;create-sm&quot;,\r\n              &quot;templateRef&quot;: {\r\n                &quot;name&quot;: &quot;wft-sn-test&quot;\r\n              },\r\n              &quot;arguments&quot;: {\r\n                &quot;parameters&quot;: [\r\n                  {\r\n                    &quot;name&quot;: &quot;un&quot;,\r\n                    &quot;value&quot;: &quot;{{inputs.parameters.un}}&quot;\r\n                  }\r\n                ]\r\n              }\r\n            }\r\n          ]\r\n        }\r\n      }\r\n    ]\r\n  }\r\n}\r\n~~~\r\nI have also removed the unnecessary `. |` and reduced `|= . +` to `+=`.\r\n",
                "title": "find a specific value in json file and append suffix to it using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1652360283,
        "creation_date": 1652358328,
        "last_edit_date": 1652360283,
        "question_id": 72215572,
        "body_markdown": "I want to match a specific value in json file and append an suffix to it in the same json file.\r\n\r\nHere is my json file\r\n```\r\n{\r\n  &quot;apiVersion&quot;: &quot;argoproj.io/v1alpha1&quot;,\r\n  &quot;kind&quot;: &quot;Workflow&quot;,\r\n  &quot;metadata&quot;: {\r\n    &quot;generateName&quot;: &quot;kns-vm-&quot;\r\n  },\r\n  &quot;spec&quot;: {\r\n    &quot;templates&quot;: [{\r\n      &quot;inputs&quot;: {\r\n        &quot;parameters&quot;: [{\r\n          &quot;name&quot;: &quot;un&quot;,\r\n          &quot;value&quot;: &quot;org&quot;\r\n        }]\r\n      },\r\n      &quot;dag&quot;: {\r\n        &quot;tasks&quot;: [{\r\n            &quot;name&quot;: &quot;create-ns&quot;,\r\n            &quot;templateRef&quot;: {\r\n              &quot;name&quot;: &quot;wft-kn&quot;\r\n            },\r\n            &quot;arguments&quot;: {\r\n              &quot;parameters&quot;: [{\r\n                &quot;name&quot;: &quot;un&quot;,\r\n                &quot;value&quot;: &quot;{{inputs.parameters.un}}&quot;\r\n              }]\r\n            }\r\n          },\r\n          {\r\n            &quot;name&quot;: &quot;create-sm&quot;,\r\n            &quot;templateRef&quot;: {\r\n              &quot;name&quot;: &quot;wft-sn&quot;\r\n            },\r\n            &quot;arguments&quot;: {\r\n              &quot;parameters&quot;: [{\r\n                &quot;name&quot;: &quot;un&quot;,\r\n                &quot;value&quot;: &quot;{{inputs.parameters.un}}&quot;\r\n              }]\r\n            }\r\n          }\r\n        ]\r\n      }\r\n    }]\r\n  }\r\n}\r\n```\r\n\r\nin this I want to find value `wft-sn` and append an suffix `-test` to it\r\n\r\nso the updated json file should look like this\r\n```\r\n{\r\n  &quot;apiVersion&quot;: &quot;argoproj.io/v1alpha1&quot;,\r\n  &quot;kind&quot;: &quot;Workflow&quot;,\r\n  &quot;metadata&quot;: {\r\n    &quot;generateName&quot;: &quot;kns-vm-&quot;\r\n  },\r\n  &quot;spec&quot;: {\r\n    &quot;templates&quot;: [{\r\n      &quot;inputs&quot;: {\r\n        &quot;parameters&quot;: [{\r\n          &quot;name&quot;: &quot;un&quot;,\r\n          &quot;value&quot;: &quot;org&quot;\r\n        }]\r\n      },\r\n      &quot;dag&quot;: {\r\n        &quot;tasks&quot;: [{\r\n            &quot;name&quot;: &quot;create-ns&quot;,\r\n            &quot;templateRef&quot;: {\r\n              &quot;name&quot;: &quot;wft-kn&quot;\r\n            },\r\n            &quot;arguments&quot;: {\r\n              &quot;parameters&quot;: [{\r\n                &quot;name&quot;: &quot;un&quot;,\r\n                &quot;value&quot;: &quot;{{inputs.parameters.un}}&quot;\r\n              }]\r\n            }\r\n          },\r\n          {\r\n            &quot;name&quot;: &quot;create-sm&quot;,\r\n            &quot;templateRef&quot;: {\r\n              &quot;name&quot;: &quot;wft-sn-test&quot;\r\n            },\r\n            &quot;arguments&quot;: {\r\n              &quot;parameters&quot;: [{\r\n                &quot;name&quot;: &quot;un&quot;,\r\n                &quot;value&quot;: &quot;{{inputs.parameters.un}}&quot;\r\n              }]\r\n            }\r\n          }\r\n        ]\r\n      }\r\n    }]\r\n  }\r\n}\r\n```\r\n\r\nI am using the `jq` command like below but it is not working\r\n\r\n`jq &#39;. | select(.spec.templates[].dag.tasks[].templateRef.name == &quot;wft-sn&quot;).name |= . + &quot;-test&quot;&#39; demo.json`\r\n\r\nwhat mistake I am doing here? how we can do this?",
        "link": "https://stackoverflow.com/questions/72215572/find-a-specific-value-in-json-file-and-append-suffix-to-it-using-jq",
        "title": "find a specific value in json file and append suffix to it using jq"
    },
    {
        "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": 0,
                "creation_date": 1652359945,
                "post_id": 72215851,
                "comment_id": 127590661,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1652407,
                    "reputation": 75,
                    "user_id": 1522716,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/a4da80301967133016eb49e8ee33ccf1?s=256&d=identicon&r=PG",
                    "display_name": "SAS",
                    "link": "https://stackoverflow.com/users/1522716/sas"
                },
                "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": 1652360290,
                "post_id": 72215851,
                "comment_id": 127590803,
                "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": 1652360984,
                "post_id": 72215851,
                "comment_id": 127591084,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1652812092,
                "last_edit_date": 1652812092,
                "creation_date": 1652360450,
                "answer_id": 72216063,
                "question_id": 72215851,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You could get rid of the shell loop and use one `jq` call:\r\n\r\n```bash\r\nnames=( alice bob )\r\njq -n --arg names &quot;${names[*]}&quot; &#39;{&quot;input&quot;: {&quot;names&quot;: ($names / &quot; &quot;) } }&#39;\r\n```\r\n\r\nor\r\n```bash\r\nnames=( alice bob )\r\nprintf &#39;%s\\0&#39; &quot;${names[@]}&quot; |\r\njq -sR &#39;(. / &quot;\\u0000&quot;) as $names | { &quot;input&quot;: { &quot;names&quot;: $names } }&#39;\r\n```",
                "title": "How to append json array using jq+shell in a loop?"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1652360633,
                "creation_date": 1652360633,
                "answer_id": 72216106,
                "question_id": 72215851,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You don&#39;t capture the output of an iteration step, so you lose the output from the `jq` call and start all over again in the next iteration step.\r\n\r\nHere&#39;s a `bash` solution which captures the output using `$(...)` and provides it for the next using `&lt;&lt;&lt;`. (Note that there are better ways to solve this problem, e.g. without looping but by proving `jq` all elements to be added at once.)\r\n~~~sh\r\njson=&#39;{&quot;input&quot;:{&quot;names&quot;:[]}}&#39;\r\n\r\nfor i in alice bob\r\ndo json=&quot;$(jq --arg val &quot;$i&quot; &#39;.input.names += [$val]&#39; &lt;&lt;&lt; &quot;$json&quot;)&quot;\r\ndone\r\n\r\necho &quot;$json&quot;\r\n~~~\r\n~~~json\r\n{\r\n  &quot;input&quot;: {\r\n    &quot;names&quot;: [\r\n      &quot;alice&quot;,\r\n      &quot;bob&quot;\r\n    ]\r\n  }\r\n}\r\n~~~",
                "title": "How to append json array using jq+shell in a loop?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1652812092,
        "creation_date": 1652359615,
        "question_id": 72215851,
        "body_markdown": "I can create a json object with an array using jq like this\r\n\r\n\r\n``` echo &#39;{&quot;input&quot;:{&quot;names&quot;:[]}}&#39; |  jq --arg val &quot;alice&quot; &#39;.input.names[0] += $val&#39;| jq --arg val &quot;bob&quot; &#39;.input.names[1] += $val&#39;```\r\n\r\nwhich gives\r\n```\r\n{\r\n  &quot;input&quot;: {\r\n    &quot;names&quot;: [\r\n      &quot;alice&quot;,\r\n      &quot;bob&quot;\r\n    ]\r\n  }\r\n}\r\n```\r\nNow I want to recreate this in a shell script where &quot;names&quot; come from a shell array\r\n```\r\n#!/bin/sh\r\n\r\nnames=( alice bob )\r\n                 \r\nITER=0\r\nfor i in &quot;${names[@]}&quot;\r\ndo                  \r\n    echo &#39;{&quot;input&quot;:{&quot;names&quot;:[]}}&#39; |  jq --arg val &quot;$i&quot; &#39;.input.names[$ITER] += $val&#39;\r\n    echo ${I} ${ITER}                                                               \r\n    ITER=$(expr $ITER + 1)                                                          \r\ndone  \r\n```\r\n\r\nbut I run into \r\n```\r\njq: error: $ITER is not defined at &lt;top-level&gt;, line 1:\r\n.input.names[$ITER] += $val             \r\njq: 1 compile error\r\n0\r\njq: error: $ITER is not defined at &lt;top-level&gt;, line 1:\r\n.input.names[$ITER] += $val             \r\njq: 1 compile error\r\n1\r\n```",
        "link": "https://stackoverflow.com/questions/72215851/how-to-append-json-array-using-jqshell-in-a-loop",
        "title": "How to append json array using jq+shell in a loop?"
    },
    {
        "tags": [
            "arrays",
            "json",
            "group-by",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1652365925,
                "last_edit_date": 1652365925,
                "creation_date": 1652365191,
                "answer_id": 72217328,
                "question_id": 72217255,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "With `group_by` you can group by any criteria given, then assemble all grouped items by taking their common `.src_ip` from any of them (eg. the first), and `.sessions` as a mapped array on `.session` from all of them. Add other parts as you see fit.\r\n~~~sh\r\njq &#39;group_by(.src_ip) | map({src_ip: .[0].src_ip, sessions: map(.session)})&#39;\r\n~~~\r\n",
                "title": "How do I group values to an array for the same field value in jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1652506409,
        "creation_date": 1652364932,
        "last_edit_date": 1652506409,
        "question_id": 72217255,
        "body_markdown": "I have json data that looks like\r\n\r\n```\r\n[\r\n  {\r\n    &quot;session&quot;: &quot;ffe887f3f150&quot;,\r\n    &quot;src_ip&quot;: &quot;81.71.87.156&quot;\r\n  },\r\n  {\r\n    &quot;session&quot;: &quot;fff42102e329&quot;,\r\n    &quot;src_ip&quot;: &quot;143.198.224.52&quot;\r\n  },\r\n  {\r\n    &quot;session&quot;: &quot;fff9c8ca82be&quot;,\r\n    &quot;src_ip&quot;: &quot;159.203.97.7&quot;\r\n  }\r\n]\r\n```\r\n\r\nI&#39;ve managed to filter out unique values of `session` but there can be more `sessions` linked to a same `src_ip`.\r\n\r\nNow I would like to merge the dataset in a way so that I have grouped `session` ID&#39;s to `src_ip` at one place such as\r\n\r\n\r\n```\r\n[\r\n...\r\n  {\r\n    &quot;src_ip&quot;: &quot;81.71.87.156&quot;\r\n    &quot;sessions&quot;: [&quot;ffe887f3f150&quot;,&quot;fff42102e329&quot;]\r\n  },\r\n...\r\n]\r\n\r\n```\r\nThis is somewhat similar to question asked here: https://stackoverflow.com/questions/26128753/how-do-i-collect-unique-elements-of-an-array-valued-field-across-multiple-object , however I struggle to transform that for my scenario.",
        "link": "https://stackoverflow.com/questions/72217255/how-do-i-group-values-to-an-array-for-the-same-field-value-in-jq",
        "title": "How do I group values to an array for the same field value in jq?"
    },
    {
        "tags": [
            "arrays",
            "json",
            "object",
            "filter",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1652373396,
                "last_edit_date": 1652373396,
                "creation_date": 1652373035,
                "answer_id": 72219186,
                "question_id": 72218950,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Using a `reduce` to iteratively build up the result object would be one way:\r\n~~~sh\r\necho &#39;[&quot;foo&quot;, &quot;baz&quot;]&#39; | jq --argjson index &#39;{&quot;foo&quot;:1,&quot;bar&quot;:2,&quot;baz&quot;:3}&#39; &#39;\r\n  reduce .[] as $x ({}; .[$x] = $index[$x])\r\n&#39;\r\n~~~\r\n\r\nUsing `JOIN`, creating key-value pairs, and employing `from_entries` for assembly would be another way:\r\n~~~sh\r\necho &#39;[&quot;baz&quot;, &quot;foo&quot;]&#39; | jq --argjson index &#39;{&quot;foo&quot;:1,&quot;bar&quot;:2,&quot;baz&quot;:3}&#39; &#39;\r\n  JOIN($index; .) | map({key:.[0], value:.[1]}) | from_entries\r\n&#39;\r\n~~~\r\n\r\nOutput:\r\n~~~json\r\n{\r\n  &quot;foo&quot;: 1,\r\n  &quot;baz&quot;: 3\r\n}\r\n~~~",
                "title": "How to limit properties of a JSON object given array of property names using JQ?"
            },
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1652377964,
                "creation_date": 1652377964,
                "answer_id": 72220142,
                "question_id": 72218950,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Provided that `.` is the object and `$arr` is the array, the following does the trick\r\n```\r\ndelpaths(keys - $arr | map([.]))\r\n```",
                "title": "How to limit properties of a JSON object given array of property names using JQ?"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1652406173,
                "last_edit_date": 1652406173,
                "creation_date": 1652391502,
                "answer_id": 72222332,
                "question_id": 72218950,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s a reduce-free solution that assumes $keys is the array of keys of interest and that is possibly more efficient than the one involving array subtraction:\r\n\r\n\r\n    . as $in | INDEX( $keys[]; $in[.] )\r\n\r\n",
                "title": "How to limit properties of a JSON object given array of property names using JQ?"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1652406048,
                "last_edit_date": 1652406048,
                "creation_date": 1652391948,
                "answer_id": 72222393,
                "question_id": 72218950,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "To achieve the desired result, one could write:\r\n\r\n     jq &#39;{foo, baz}&#39;\r\n\r\nThis can (with some considerable trepidation) be made into a solution for the given problem by text wrangling, e.g. along the lines of:\r\n\r\n    jq &quot;$(echo &#39;[&quot;foo&quot;, &quot;baz&quot;]&#39; | jq -Rr &#39;&quot;{&quot; + .[1:-1] + &quot;}&quot; &#39;)&quot;\r\n\r\nor\r\n\r\n    jq &quot;$(echo &#39;[&quot;foo&quot;, &quot;baz&quot;]&#39; | sed -e &#39;s/\\[/{/&#39; -e &#39;s/\\]/}/&#39;)&quot;\r\n\r\n\r\n\r\n",
                "title": "How to limit properties of a JSON object given array of property names using JQ?"
            }
        ],
        "is_answered": true,
        "answer_count": 4,
        "score": 1,
        "last_activity_date": 1652406173,
        "creation_date": 1652371982,
        "question_id": 72218950,
        "body_markdown": "Assuming I have the following JSON object _(which is just an example):_\r\n\r\n```\r\n{ \r\n  &quot;foo&quot;: 1, \r\n  &quot;bar&quot;: 2, \r\n  &quot;baz&quot;: 3 \r\n}\r\n```\r\n\r\nAnd the following JSON array _(another example):_\r\n\r\n```\r\n[&quot;foo&quot;, &quot;baz&quot;]\r\n```\r\n\r\nHow could I use [**jq**](https://stedolan.github.io/jq) to output the following object?\r\n\r\n```\r\n{ \r\n  &quot;foo&quot;: 1, \r\n  &quot;baz&quot;: 3 \r\n}\r\n```\r\n\r\nI hate asking this question because I feel certain it has been answered before, but google has failed me and my jq-fu is just not where it needs to be to figure this out.\r\n",
        "link": "https://stackoverflow.com/questions/72218950/how-to-limit-properties-of-a-json-object-given-array-of-property-names-using-jq",
        "title": "How to limit properties of a JSON object given array of property names using JQ?"
    },
    {
        "tags": [
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 6313442,
                    "reputation": 45115,
                    "user_id": 5625547,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/oqCND.jpg?s=256",
                    "display_name": "0stone0",
                    "link": "https://stackoverflow.com/users/5625547/0stone0"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1652441371,
                "post_id": 72228178,
                "comment_id": 127612845,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1652447414,
                "post_id": 72228178,
                "comment_id": 127615037,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1652459564,
                "last_edit_date": 1652459564,
                "creation_date": 1652441221,
                "answer_id": 72228824,
                "question_id": 72228178,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "&lt;sub&gt;Undeleting this due to @Peak&#39;s [comment](https://stackoverflow.com/questions/72228178/jq-wildcard-as-object-in-getpath-split/72228933?noredirect=1#comment127615037_72228178)&lt;/sub&gt;\r\n\r\n\r\n----------\r\n\r\n\r\n[`getpath`][1] expects an array with just the keys, so we&#39;ll need the following to find the value:\r\n```none\r\ngetpath([ &quot;notKnown&quot;, &quot;alpha&quot;, &quot;hello&quot;  ])\r\n```\r\n\r\n----------\r\n\r\nSo to get that using an arg, we can use your `split` command, but we&#39;ll need to remove the `.` and `[]` from the `myPath` var:\r\n```none\r\nmyPath=&quot;notKnown.alpha.hello&quot;\r\njq -r --arg str &quot;${myPath}&quot; &#39;getpath($str|split(&quot;.&quot;))&#39; json.json\r\n```\r\n\r\n\r\n----------\r\n\r\nLocal shell demo:\r\n\r\n```none\r\n$ jq . json.json\r\n{\r\n  &quot;notKnown&quot;: {\r\n    &quot;alpha&quot;: {\r\n      &quot;hello&quot;: &quot;world&quot;\r\n    }\r\n  }\r\n}\r\n$\r\n$ myPath=&quot;notKnown.alpha.hello&quot;\r\n$\r\n$ jq -r --arg str &quot;${myPath}&quot; &#39;getpath($str|split(&quot;.&quot;))&#39; json.json\r\nworld\r\n$\r\n```\r\n\r\n\r\n  [1]: https://stedolan.github.io/jq/manual/#getpath(PATHS)",
                "title": "jq wildcard as object in getpath split"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1652441775,
                "creation_date": 1652441775,
                "answer_id": 72228933,
                "question_id": 72228178,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "&gt; is there a way to have the format in myPath accept the wildcard as an object in the passed $str path?\r\n\r\nDon&#39;t think there is a way to let `getPath` deal with filters like\r\n`.[].alpha.hello`\r\n\r\n\r\n----------\r\n\r\nHowever, you can use the `myPath` variable as the *raw* filter itself to get the desired output:\r\n```\r\n$ myPath=&quot;.[].alpha.hello&quot;\r\n$ jq -r --arg str &quot;${myPath}&quot; &quot;$myPath&quot; json.json\r\nworld\r\n```",
                "title": "jq wildcard as object in getpath split"
            },
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1652471673,
                "creation_date": 1652471673,
                "answer_id": 72234807,
                "question_id": 72228178,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "`getpath` doesn&#39;t take some query, but a list of keys.\r\n\r\nYou are effectively calling\r\n\r\n```jq\r\ngetpath( [ &quot;notKnown[]&quot;, &quot;hello&quot; ] )\r\n```\r\n\r\nThis is equivalent to\r\n\r\n```jq\r\n.[ &quot;notKnown[]&quot; ][ &quot;hello&quot; ]\r\n```\r\n\r\nYou could use \r\n\r\n```jq\r\ndef _simple_query( $q ):\r\n   if $q | length == 0 then\r\n      .\r\n   else\r\n      $q[0] as $key |\r\n      $q[1:] as $r |\r\n      if $key == &quot;*&quot; then\r\n         .[] | _simple_query( $r )\r\n      else\r\n         select( has( $key ) ) | .[ $key ] | _simple_query( $r )\r\n      end\r\n   end;\r\n\r\ndef simple_query( $q ):\r\n   _simple_query( $q | split(&quot;.&quot;) );\r\n\r\nsimple_query( &quot;*.alpha.hello&quot; )\r\n```\r\n\r\n[Demo](https://jqplay.org/s/P2fFNlcGI_) on jqplay\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n",
                "title": "jq wildcard as object in getpath split"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 0,
        "last_activity_date": 1652471673,
        "creation_date": 1652438014,
        "last_edit_date": 1652441926,
        "question_id": 72228178,
        "body_markdown": "Given a basic json\r\n```json\r\n{ \r\n    &quot;notKnown&quot;: { \r\n        &quot;alpha&quot; : {\r\n            &quot;hello&quot;:&quot;world&quot;\r\n        }\r\n    } \r\n}\r\n```\r\n\r\nand then using `getpath` with a wildcard as an object does not seem to work \r\n```none\r\n//Eg 1 - complete string generates correct result\r\nmyPath=&quot;notKnown.alpha.hello&quot;\r\noutput=$(jq -r --arg str &quot;${myPath}&quot; &#39;getpath($str|split(&quot;.&quot;))&#39; &lt;&lt;&lt;$myJson) \r\n&gt;&gt; output=&quot;world&quot;   \r\n\r\n//Eg 2 - test the wildcard directly generates correct result\r\noutput=$(jq -r &#39;.notKnown[].hello&#39; &lt;&lt;&lt;$myJson) \r\n&gt;&gt; output=&quot;world&quot;\r\n\r\n//Eg 3 - merge the wildcard into the formatting from Eg1 - generates null\r\nmyPath=&quot;notKnown[].hello&quot;\r\noutput=$(jq -r --arg str &quot;${myPath}&quot; &#39;getpath($str|split(&quot;.&quot;))&#39; &lt;&lt;&lt;$myJson) \r\n&gt;&gt; output=null\r\n\r\n//Eg 4 - merge the wildcard into the formatting from Eg1 - generates null\r\ndifferent example strings that generate null (assuming the first dot should not be used)\r\n myPath=&quot;[].alpha.hello&quot;\r\n myPath=&quot;.[].alpha.hello&quot; //leading dot expect fail\r\n myPath=&quot;[]alpha.hello&quot;\r\n myPath=&quot;.[]alpha.hello&quot;   //leading dot expect fail \r\n\r\noutput=$(jq -r --arg str &quot;${myPath}&quot; &#39;getpath($str|split(&quot;.&quot;))&#39; &lt;&lt;&lt;$myJson)\r\n&gt;&gt; output=null\r\n```\r\n\r\nIs there a way to have the format in `myPath` accept the wildcard as an object in the passed `$str` path?\r\n",
        "link": "https://stackoverflow.com/questions/72228178/jq-wildcard-as-object-in-getpath-split",
        "title": "jq wildcard as object in getpath split"
    },
    {
        "tags": [
            "shell",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 6313442,
                    "reputation": 45115,
                    "user_id": 5625547,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/oqCND.jpg?s=256",
                    "display_name": "0stone0",
                    "link": "https://stackoverflow.com/users/5625547/0stone0"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1652442034,
                "post_id": 72228730,
                "comment_id": 127613044,
                "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": 1652442932,
                "post_id": 72228730,
                "comment_id": 127613345,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1652514503,
                "creation_date": 1652514503,
                "answer_id": 72238291,
                "question_id": 72228730,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Given this input:\r\n```\r\n{\r\n  &quot;ssh_keys&quot;: [\r\n    {\r\n      &quot;id&quot;: &quot;id1&quot;,\r\n      &quot;public_key&quot;: &quot;pk1&quot;,\r\n      &quot;name&quot;: &quot;terraform-02&quot;,\r\n      &quot;fingerprint&quot;: &quot;...&quot;\r\n    },\r\n    {\r\n      &quot;id&quot;: &quot;id2&quot;,\r\n      &quot;public_key&quot;: &quot;pk2&quot;,\r\n      &quot;name&quot;: &quot;terraform-02&quot;,\r\n      &quot;fingerprint&quot;: &quot;...&quot;\r\n    }\r\n  ],\r\n  &quot;meta&quot;: {\r\n    &quot;total&quot;: 2\r\n  }\r\n}\r\n```\r\n\r\nyou can select the `.id` like this:\r\n\r\n    jq &#39;.[][] | select(.name? == &quot;terraform-02&quot;).id&#39;\r\n\r\nThe output is:\r\n\r\n    &quot;id1&quot;\r\n    &quot;id2&quot;\r\n",
                "title": "Data extraction from array using jq"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1652514503,
        "creation_date": 1652440830,
        "last_edit_date": 1652443319,
        "question_id": 72228730,
        "body_markdown": "Please help me to figure that one out...\r\n\r\nI want to get the ID where the name is - terraform-02\r\n\r\n`jq &#39;.[] | map(select(.name == &quot;terraform-02&quot;))&#39;` - didn&#39;t work, to start filtering process\r\n\r\nThat is my array : \r\n\r\n`{&quot;ssh_keys&quot;: [\r\n{\r\n&quot;id&quot;: ...,\r\n&quot;public_key&quot;: &quot;...&quot;,\r\n&quot;name&quot;: &quot;terraform-02&quot;,\r\n&quot;fingerprint&quot;: &quot;.&quot;\r\n},\r\n{\r\n&quot;id&quot;: ...,\r\n&quot;public_key&quot;: &quot;...&quot;,\r\n&quot;name&quot;: &quot;terraform-02&quot;,\r\n&quot;fingerprint&quot;: &quot;...&quot;\r\n},\r\n],&quot;meta&quot;: {&quot;total&quot;: 2}}`",
        "link": "https://stackoverflow.com/questions/72228730/data-extraction-from-array-using-jq",
        "title": "Data extraction from array using jq"
    },
    {
        "tags": [
            "json",
            "linux",
            "sed",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1652697757,
                "last_edit_date": 1652697757,
                "creation_date": 1652693549,
                "answer_id": 72257022,
                "question_id": 72256635,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Your document format is json, so you should use jq for editing:\r\n\r\n    jq &#39;.files[0].aql.&quot;items.find&quot;.&quot;$or&quot;[0].&quot;$and&quot;[0].name.&quot;$nmatch&quot;=&quot;build1.1&quot;&#39; spec\r\n\r\nWith *sed*, you can&#39;t reliably access the correct name node. Your code doesn&#39;t work because you didn&#39;t include the quotes around `name` in your search pattern. Using sed would be ok if you have a unique identifier for *build*. Example:\r\n\r\n    sed -i &#39;s/BUILD_NUMBER/build1.1/g&#39; spec",
                "title": "sed command to change value in .spec file"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1652715362,
                "creation_date": 1652715362,
                "answer_id": 72261827,
                "question_id": 72256635,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "A more &quot;indirect&quot; way is to simply set everything with `$nmatch`:\r\n\r\n    jq &#39;(.. | select(has(&quot;$nmatch&quot;))? ) = &quot;build1.1&quot;&#39; input.json ",
                "title": "sed command to change value in .spec file"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1652715362,
        "creation_date": 1652691803,
        "last_edit_date": 1652698013,
        "question_id": 72256635,
        "body_markdown": "How to change a value in .spec file using sed? Want to change the `$nmatch` value of build to someother value say `&quot;build1.1&quot;`.\r\n\r\n```\r\n{\r\n&quot;files&quot;: [\r\n  {\r\n    &quot;aql&quot;: {\r\n    &quot;items.find&quot;: {\r\n    &quot;repo&quot;: {&quot;$eq&quot;:&quot;app-java-repo&quot;},\r\n    &quot;path&quot;: &quot;archives/test/app&quot;,\r\n    &quot;type&quot;: &quot;folder&quot;,\r\n    &quot;$or&quot;: [\r\n          {\r\n            &quot;$and&quot;: [\r\n              {\r\n                &quot;name&quot;: {&quot;$nmatch&quot; : &quot;*build*&quot;} //change value using sed\r\n              }\r\n            ]\r\n          }\r\n        ]\r\n      }\r\n    }\r\n  }\r\n]\r\n}\r\n```\r\nTried below command but not working \r\n```\r\nsed -i -e &#39;/name:/{s/\\($nmatch\\).*/\\1: &quot;&#39;&quot;build1.1&quot;&#39;&quot; /}&#39;\r\n```",
        "link": "https://stackoverflow.com/questions/72256635/sed-command-to-change-value-in-spec-file",
        "title": "sed command to change value in .spec file"
    },
    {
        "tags": [
            "bash",
            "terminal",
            "sh",
            "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": 1652735591,
                "post_id": 72265338,
                "comment_id": 127673798,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1652734621,
                "last_edit_date": 1652734621,
                "creation_date": 1652733944,
                "answer_id": 72265422,
                "question_id": 72265338,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "By using `--argjson` you need to provide valid JSON-encoded argument, thus if you want to receive `null` the value needs to be literally `null`. Your solution, however, adds quotes around it, so it can never be evaluated to `null`. (Also, it will only be a valid JSON string if it follows the JSON encoding for special characters such as the quote characters itself).\r\n\r\nIf you want to have a JSON string in the regular case, and `null` in the case where it is empty, import the content of `${like}` as string using `--arg` and without the extra quotes (just as you do with `${title}`), then use some `jq` logic to turn the empty string into `null`. An `if` statement would do, for example:\r\n\r\n~~~sh\r\nlike=\r\njq -n --arg like &quot;${like}&quot; &#39;{like: (if $like == &quot;&quot; then null else $like end)}&#39;\r\n~~~\r\n~~~json\r\n{\r\n  &quot;like&quot;: null\r\n}\r\n~~~",
                "title": "jq does not show null output"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -1,
        "last_activity_date": 1652734621,
        "creation_date": 1652733394,
        "question_id": 72265338,
        "body_markdown": "I have the following code in the command line script:\r\n```\r\noutput_json=$(jq -n \\\r\n                 --argjson ID &quot;${id}&quot; \\\r\n                 --arg Title &quot;${title}&quot; \\\r\n                 --argjson like &quot;\\&quot;${like}\\&quot;&quot; \\\r\n                &#39;$ARGS.named&#39;)\r\n```\r\n\r\nI put the `id`, `title` and `like` variables into the `jq`. I get the following output:\r\n```\r\n[\r\n  {\r\n    &quot;ID&quot;: 6,\r\n    &quot;Title&quot;: &quot;ABC&quot;,\r\n    &quot;like&quot;: &quot;&quot;\r\n  },\r\n  {\r\n    &quot;ID&quot;: 22,\r\n    &quot;Title&quot;: &quot;ABC&quot;,\r\n    &quot;like&quot;: &quot;Yes&quot;\r\n  }\r\n]\r\n```\r\nBut, I am trying to get the output in the following format, i.e. with null:\r\n```\r\n[\r\n  {\r\n    &quot;ID&quot;: 6,\r\n    &quot;Title&quot;: &quot;ABC&quot;,\r\n    &quot;like&quot;: null\r\n  },\r\n  {\r\n    &quot;ID&quot;: 22,\r\n    &quot;Title&quot;: &quot;ABC&quot;,\r\n    &quot;like&quot;: &quot;Yes&quot;\r\n  }\r\n]\r\n```\r\nI don&#39;t quite get it is it possible to do this in general, or is it a problem with my `jq` command?\r\n\r\nAnd as far as I understood `&quot;like&quot;: &quot;&quot;` is not the same as `&quot;like&quot;: null`. I am also a little confused now, and do not really understand what is the correct choice to use.",
        "link": "https://stackoverflow.com/questions/72265338/jq-does-not-show-null-output",
        "title": "jq does not show null output"
    },
    {
        "tags": [
            "csv",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 4,
                "creation_date": 1652809988,
                "post_id": 72266922,
                "comment_id": 127694800,
                "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": 1660468656,
                "post_id": 72266922,
                "comment_id": 129536274,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1663855630,
                "last_edit_date": 1663855630,
                "creation_date": 1662825890,
                "answer_id": 73673301,
                "question_id": 72266922,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I don&#39;t understand why the Stackoverflow community is often claimed to be &quot;unwelcoming to new users&quot;. Here is the community completing your question with an [MWE](https://stackoverflow.com/help/minimal-reproducible-example) (reversed from your given `jq` expression):\r\n\r\n```json\r\n{\r\n    &quot;games&quot;: [\r\n        {\r\n            &quot;teams&quot;: [\r\n                {\r\n                    &quot;tid&quot;: 111,\r\n                    &quot;ovr&quot;: 112,\r\n                    &quot;won&quot;: 114,\r\n                    &quot;lost&quot;: 118,\r\n                    &quot;players&quot;: [\r\n                        {\r\n                            &quot;pid&quot;: 11111,\r\n                            &quot;gs&quot;: 11112,\r\n                            &quot;min&quot;: 11114,\r\n                            &quot;fg&quot;: 11118,\r\n                            &quot;fga&quot;: 111116\r\n                        },\r\n                        {\r\n                            &quot;pid&quot;: 11121,\r\n                            &quot;gs&quot;: 11122,\r\n                            &quot;min&quot;: 11124,\r\n                            &quot;fg&quot;: 11128,\r\n                            &quot;fga&quot;: 111216\r\n                        }\r\n                    ]\r\n                },\r\n                {\r\n                    &quot;tid&quot;: 121,\r\n                    &quot;ovr&quot;: 122,\r\n                    &quot;won&quot;: 124,\r\n                    &quot;lost&quot;: 128,\r\n                    &quot;players&quot;: [\r\n                        {\r\n                            &quot;pid&quot;: 12111,\r\n                            &quot;gs&quot;: 12112,\r\n                            &quot;min&quot;: 12114,\r\n                            &quot;fg&quot;: 12118,\r\n                            &quot;fga&quot;: 121116\r\n                        },\r\n                        {\r\n                            &quot;pid&quot;: 12121,\r\n                            &quot;gs&quot;: 12122,\r\n                            &quot;min&quot;: 12124,\r\n                            &quot;fg&quot;: 12128,\r\n                            &quot;fga&quot;: 121216\r\n                        }\r\n                    ]\r\n                }\r\n            ]\r\n        },\r\n        {\r\n            &quot;teams&quot;: [\r\n                {\r\n                    &quot;tid&quot;: 211,\r\n                    &quot;ovr&quot;: 212,\r\n                    &quot;won&quot;: 214,\r\n                    &quot;lost&quot;: 218,\r\n                    &quot;players&quot;: [\r\n                        {\r\n                            &quot;pid&quot;: 21111,\r\n                            &quot;gs&quot;: 21112,\r\n                            &quot;min&quot;: 21114,\r\n                            &quot;fg&quot;: 21118,\r\n                            &quot;fga&quot;: 211116\r\n                        },\r\n                        {\r\n                            &quot;pid&quot;: 21121,\r\n                            &quot;gs&quot;: 21122,\r\n                            &quot;min&quot;: 21124,\r\n                            &quot;fg&quot;: 21128,\r\n                            &quot;fga&quot;: 211216\r\n                        }\r\n                    ]\r\n                },\r\n                {\r\n                    &quot;tid&quot;: 221,\r\n                    &quot;ovr&quot;: 222,\r\n                    &quot;won&quot;: 224,\r\n                    &quot;lost&quot;: 228,\r\n                    &quot;players&quot;: [\r\n                        {\r\n                            &quot;pid&quot;: 22111,\r\n                            &quot;gs&quot;: 22112,\r\n                            &quot;min&quot;: 22114,\r\n                            &quot;fg&quot;: 22118,\r\n                            &quot;fga&quot;: 221116\r\n                        },\r\n                        {\r\n                            &quot;pid&quot;: 22121,\r\n                            &quot;gs&quot;: 22122,\r\n                            &quot;min&quot;: 22124,\r\n                            &quot;fg&quot;: 22128,\r\n                            &quot;fga&quot;: 221216\r\n                        }\r\n                    ]\r\n                }\r\n            ]\r\n        }\r\n    ]\r\n}\r\n```\r\n\r\nTo generate one line of output per player, containing tid, ovr, won, lost, pid, gs, min, fg, and fga:\r\n\r\n```\r\n.games[].teams[]\r\n  | . as $team\r\n  | .players[]\r\n  | [$team[&quot;tid&quot;, &quot;ovr&quot;, &quot;won&quot;, &quot;lost&quot;], .pid, .gs, .min, .fg, .fga]\r\n  | join(&quot;, &quot;)\r\n```\r\n\r\nThe array construction can be simplified if you want all properties of a player in the output:\r\n\r\n```\r\n.games[].teams[]\r\n  | . as $team\r\n  | .players[]\r\n  | [$team[&quot;tid&quot;, &quot;ovr&quot;, &quot;won&quot;, &quot;lost&quot;], .[]]\r\n  | join(&quot;, &quot;)\r\n```\r\n\r\nOutput:\r\n\r\n```\r\n111, 112, 114, 118, 11111, 11112, 11114, 11118, 111116\r\n111, 112, 114, 118, 11121, 11122, 11124, 11128, 111216\r\n121, 122, 124, 128, 12111, 12112, 12114, 12118, 121116\r\n121, 122, 124, 128, 12121, 12122, 12124, 12128, 121216\r\n211, 212, 214, 218, 21111, 21112, 21114, 21118, 211116\r\n211, 212, 214, 218, 21121, 21122, 21124, 21128, 211216\r\n221, 222, 224, 228, 22111, 22112, 22114, 22118, 221116\r\n221, 222, 224, 228, 22121, 22122, 22124, 22128, 221216\r\n```\r\n\r\nAlthough the next question is why use `join(&quot;,&quot;)` when jq already as has perfectly-fine `@csv` filter (automatically handling escaping etc.)?\r\n\r\n```\r\n.games[].teams[]\r\n  | . as $team\r\n  | .players[]\r\n  | [$team[&quot;tid&quot;, &quot;ovr&quot;, &quot;won&quot;, &quot;lost&quot;], .[]]\r\n  | @csv\r\n```\r\n\r\n(`join(&quot;,&quot;)` will generate malformed CSV for string values containing a double quote).\r\n\r\nThe variable-assignment to `$team` can be changed to a destructuring assignment:\r\n\r\n```\r\n.games[].teams[]\r\n  | . as { $tid, $ovr, $won, $lost }\r\n  | .players[]\r\n  | [$tid, $ovr, $won, $lost, .[]]\r\n  | @csv\r\n```\r\n\r\n*****\r\n\r\nA solution without variables, first transforming the document into the correct structure:\r\n\r\n```\r\n.games[].teams[]\r\n  | { tid, ovr, won, lost } + .players[]\r\n  | map(.)\r\n  | @csv\r\n```",
                "title": "json to csv using jq on large json file"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -1,
        "last_activity_date": 1663855630,
        "creation_date": 1652746741,
        "last_edit_date": 1660468680,
        "question_id": 72266922,
        "body_markdown": "I have a very large JSON that contains sports data output from a sports simulation website.  I am working on a script that outputs player gamelog data into a csv file.  \r\n\r\nThe JSON is too large to post but there are over 700 games in the games[] array. 2 teams[] in each team array and 10 players in each player[] array.\r\n\r\n\r\nMy current code is:   \r\n```bash\r\njq -r &#39;.games[] | [.teams[] | .tid, .ovr, .won, .lost, (.players[] | .pid, .gs, .min, .fg, .fga)] | join(&quot;, &quot;)&#39; &gt; file.csv\r\n```\r\n    \r\nThis code puts all of the player data (both teams) for each game on one line of the csv. I would like one line per player in the csv.\r\n\r\nI have used **`map`** and **`join(&quot;\\n&quot;)`** in previous scripts but the nested arrays are giving me problems.\r\n\r\nThanks for the help.\r\n   \r\n",
        "link": "https://stackoverflow.com/questions/72266922/json-to-csv-using-jq-on-large-json-file",
        "title": "json to csv using jq on large json file"
    },
    {
        "tags": [
            "json",
            "jq",
            "export-to-csv"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 9899349,
                    "reputation": 22795,
                    "user_id": 7329832,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/eVENC.png?s=256",
                    "display_name": "jps",
                    "link": "https://stackoverflow.com/users/7329832/jps"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1652784544,
                "post_id": 72271344,
                "comment_id": 127684933,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1652779613,
                "creation_date": 1652779613,
                "answer_id": 72271454,
                "question_id": 72271344,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "```\r\n.zabbix_export.templates[] | .name as $tn | .items[] | [ $tn, .name, .triggers[]?.name? ] | join(&quot;; &quot;)\r\n```\r\n\r\n\r\n----------\r\n\r\n\r\n1. Loop over the templates\\\r\n`.zabbix_export.templates[]`\r\n1. Save the template name in a var\\\r\n`.name as $tn`\r\n2. Loop over the items\\\r\n`.items[]`\r\n3. Create an array with fields you like (including the name from step 1\\\r\n`[ $tn, .name, .triggers[]?.name? ]`\r\n4. Join the array to a string\\\r\n`join(&quot;; &quot;)`\r\n\r\n\r\n----------\r\n\r\n\r\nWill output:\r\n```json\r\n&quot;Template App Agent; Host name of zabbix_agentd running; Host name of zabbix_agentd was changed on {HOST.NAME}&quot;\r\n&quot;Template App Agent; Agent ping; Zabbix agent on {HOST.NAME} is unreachable for 5 minutes&quot;\r\n&quot;Template App Agent; Version of zabbix_agent(d) running&quot;\r\n```\r\n\r\n\r\n----------\r\n\r\n\r\n#### [Online demo](https://jqplay.org/s/KYdYRH5w0Du)",
                "title": "Extracting values from nested arrays"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1652779976,
                "creation_date": 1652779976,
                "answer_id": 72271522,
                "question_id": 72271344,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "This is a nested structure, you need to iterate level by level and add up the items you want to be in one output line. Store values from previous levels in variables.\r\n\r\nTo account for an inexistent `.triggers` array, you may use the Error Suppression Operator `?` in combination with Alternative Operator `//`.\r\n\r\nFinally, wrap the items in quotes (here using `map`), join them using `join`, and output them as raw text using the `-r` option\r\n\r\n~~~sh\r\njq -r &#39;\r\n  .[].templates[] | .name as $t\r\n  | .items[] | .name as $i\r\n  | [$t, $i, (.triggers[].name)? // &quot;&quot;]\r\n  | map(&quot;\\&quot;\\(.)\\&quot;&quot;) | join(&quot;; &quot;)\r\n&#39;\r\n~~~\r\n~~~json\r\n&quot;Template App Agent&quot;; &quot;Host name of zabbix_agentd running&quot;; &quot;Host name of zabbix_agentd was changed on {HOST.NAME}&quot;\r\n&quot;Template App Agent&quot;; &quot;Agent ping&quot;; &quot;Zabbix agent on {HOST.NAME} is unreachable for 5 minutes&quot;\r\n&quot;Template App Agent&quot;; &quot;Version of zabbix_agent(d) running&quot;; &quot;&quot;\r\n~~~\r\n[Demo](https://jqplay.org/s/00L7GY_yieG)\r\n\r\nAlso consider using the `@csv` builtin, which gives you valid CSV right away (properly encoded (not just quoted) items, but separated with commas, not semicolons):\r\n~~~sh\r\njq -r &#39;\r\n  .[].templates[] | .name as $t\r\n  | .items[] | .name as $i\r\n  | [$t, $i, (.triggers[].name)? // &quot;&quot;]\r\n  | @csv\r\n&#39;\r\n~~~\r\n~~~json\r\n&quot;Template App Agent&quot;,&quot;Host name of zabbix_agentd running&quot;,&quot;Host name of zabbix_agentd was changed on {HOST.NAME}&quot;\r\n&quot;Template App Agent&quot;,&quot;Agent ping&quot;,&quot;Zabbix agent on {HOST.NAME} is unreachable for 5 minutes&quot;\r\n&quot;Template App Agent&quot;,&quot;Version of zabbix_agent(d) running&quot;,&quot;&quot;\r\n~~~\r\n[Demo](https://jqplay.org/s/Kx7htHJX9hB)",
                "title": "Extracting values from nested arrays"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1652793039,
        "creation_date": 1652779053,
        "last_edit_date": 1652793039,
        "question_id": 72271344,
        "body_markdown": "I&#39;m trying to extract values from nested arrays in JSON below and output as CSV.\r\n\r\nFields to extract:  \r\n\r\n    templates.name  \r\n    items.name  \r\n    triggers.name\r\n\r\nOutput as:  \r\ntemplates.name; items.name; triggers.name\r\n\r\nAnticipated output something like:  \r\n\r\n    &quot;Template App Agent&quot;; &quot;Host name of zabbix_agentd running&quot;; &quot;Host name of zabbix_agentd was changed on {HOST.NAME}&quot;\r\n    &quot;Template App Agent&quot;; &quot;Agent ping&quot;; &quot;Zabbix agent on {HOST.NAME} is unreachable for 5 minutes&quot;\r\n    &quot;Template App Agent&quot;; &quot;Version of zabbix_agent(d) running&quot;; &quot;&quot;\r\n\r\nNote:  \r\nNot every item has a trigger.  \r\nSeveral triggers may exist for an item.\r\n\r\nI&#39;m new to JQ. So far only success is extracting the template name.\r\n\r\n    jq &#39;.[] | {templates: [.templates[].name]}&#39;\r\n\r\n\r\nData:\r\n\r\n    {\r\n        &quot;zabbix_export&quot;: {\r\n            &quot;version&quot;: &quot;5.4&quot;,\r\n            &quot;date&quot;: &quot;2022-05-17T06:25:59Z&quot;,\r\n            &quot;groups&quot;: [\r\n                {\r\n                    &quot;uuid&quot;: &quot;7df96b18c230490a9a0a9e2307226338&quot;,\r\n                    &quot;name&quot;: &quot;Templates&quot;\r\n                }\r\n            ],\r\n            &quot;templates&quot;: [\r\n                {\r\n                    &quot;uuid&quot;: &quot;e60e6598cf19448089a5f5a6c5d796a2&quot;,\r\n                    &quot;template&quot;: &quot;Template App Agent&quot;,\r\n                    &quot;name&quot;: &quot;Template App Agent&quot;,\r\n                    &quot;groups&quot;: [\r\n                        {\r\n                            &quot;name&quot;: &quot;Templates&quot;\r\n                        }\r\n                    ],\r\n                    &quot;items&quot;: [\r\n                        {\r\n                            &quot;uuid&quot;: &quot;24c03ed734d54dc8868a282a83a02200&quot;,\r\n                            &quot;name&quot;: &quot;Host name of zabbix_agentd running&quot;,\r\n                            &quot;key&quot;: &quot;agent.hostname&quot;,\r\n                            &quot;delay&quot;: &quot;1h&quot;,\r\n                            &quot;history&quot;: &quot;1w&quot;,\r\n                            &quot;trends&quot;: &quot;0&quot;,\r\n                            &quot;value_type&quot;: &quot;CHAR&quot;,\r\n                            &quot;request_method&quot;: &quot;POST&quot;,\r\n                            &quot;tags&quot;: [\r\n                                {\r\n                                    &quot;tag&quot;: &quot;Application&quot;,\r\n                                    &quot;value&quot;: &quot;Zabbix agent&quot;\r\n                                }\r\n                            ],\r\n                            &quot;triggers&quot;: [\r\n                                {\r\n                                    &quot;uuid&quot;: &quot;d2d12d9e7dfe4fedb252f19b85e5e6aa&quot;,\r\n                                    &quot;expression&quot;: &quot;(last(/Template App Agent/agent.hostname,#1)&lt;&gt;last(/Template App Agent/agent.hostname,#2))&gt;0&quot;,\r\n                                    &quot;name&quot;: &quot;Host name of zabbix_agentd was changed on {HOST.NAME}&quot;,\r\n                                    &quot;priority&quot;: &quot;INFO&quot;\r\n                                }\r\n                            ]\r\n                        },\r\n                        {\r\n                            &quot;uuid&quot;: &quot;abacad4ca5eb46d29864d8a4998f1cbb&quot;,\r\n                            &quot;name&quot;: &quot;Agent ping&quot;,\r\n                            &quot;key&quot;: &quot;agent.ping&quot;,\r\n                            &quot;history&quot;: &quot;1w&quot;,\r\n                            &quot;description&quot;: &quot;The agent always returns 1 for this item. It could be used in combination with nodata() for availability check.&quot;,\r\n                            &quot;valuemap&quot;: {\r\n                                &quot;name&quot;: &quot;Zabbix agent ping status&quot;\r\n                            },\r\n                            &quot;request_method&quot;: &quot;POST&quot;,\r\n                            &quot;tags&quot;: [\r\n                                {\r\n                                    &quot;tag&quot;: &quot;Application&quot;,\r\n                                    &quot;value&quot;: &quot;Zabbix agent&quot;\r\n                                }\r\n                            ],\r\n                            &quot;triggers&quot;: [\r\n                                {\r\n                                    &quot;uuid&quot;: &quot;6d2a73199f3b4288bf36331a142c1725&quot;,\r\n                                    &quot;expression&quot;: &quot;nodata(/Template App Agent/agent.ping,5m)=1&quot;,\r\n                                    &quot;name&quot;: &quot;Zabbix agent on {HOST.NAME} is unreachable for 5 minutes&quot;,\r\n                                    &quot;priority&quot;: &quot;AVERAGE&quot;\r\n                                }\r\n                            ]\r\n                        },\r\n                        {\r\n                            &quot;uuid&quot;: &quot;2cc337555efd43d181c28c792f8cbbdb&quot;,\r\n                            &quot;name&quot;: &quot;Version of zabbix_agent(d) running&quot;,\r\n                            &quot;key&quot;: &quot;agent.version&quot;,\r\n                            &quot;delay&quot;: &quot;1h&quot;,\r\n                            &quot;history&quot;: &quot;1w&quot;,\r\n                            &quot;trends&quot;: &quot;0&quot;,\r\n                            &quot;value_type&quot;: &quot;CHAR&quot;,\r\n                            &quot;request_method&quot;: &quot;POST&quot;,\r\n                            &quot;tags&quot;: [\r\n                                {\r\n                                    &quot;tag&quot;: &quot;Application&quot;,\r\n                                    &quot;value&quot;: &quot;Zabbix agent&quot;\r\n                                }\r\n                            ]\r\n                        }\r\n                    ],\r\n                    &quot;valuemaps&quot;: [\r\n                        {\r\n                            &quot;uuid&quot;: &quot;3d66c59a28c04b0ca8227c87902ddb4d&quot;,\r\n                            &quot;name&quot;: &quot;Zabbix agent ping status&quot;,\r\n                            &quot;mappings&quot;: [\r\n                                {\r\n                                    &quot;value&quot;: &quot;1&quot;,\r\n                                    &quot;newvalue&quot;: &quot;Up&quot;\r\n                                }\r\n                            ]\r\n                        }\r\n                    ]\r\n                }\r\n            ]\r\n        }\r\n    }\r\n\r\n",
        "link": "https://stackoverflow.com/questions/72271344/extracting-values-from-nested-arrays",
        "title": "Extracting values from nested arrays"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 911998,
                    "reputation": 66613,
                    "user_id": 947357,
                    "user_type": "registered",
                    "accept_rate": 75,
                    "profile_image": "https://i.sstatic.net/wW1C6.png?s=256",
                    "display_name": "A.H.",
                    "link": "https://stackoverflow.com/users/947357/a-h"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1652813713,
                "post_id": 72277613,
                "comment_id": 127696003,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 25026533,
                    "reputation": 145,
                    "user_id": 18884688,
                    "user_type": "registered",
                    "profile_image": "https://lh3.googleusercontent.com/a/AATXAJymEyOdaMV5_qZK6T4e1fgBYaZE41Vo07DwACtX=k-s256",
                    "display_name": "Nicholas Rinaldi",
                    "link": "https://stackoverflow.com/users/18884688/nicholas-rinaldi"
                },
                "reply_to_user": {
                    "account_id": 911998,
                    "reputation": 66613,
                    "user_id": 947357,
                    "user_type": "registered",
                    "accept_rate": 75,
                    "profile_image": "https://i.sstatic.net/wW1C6.png?s=256",
                    "display_name": "A.H.",
                    "link": "https://stackoverflow.com/users/947357/a-h"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1652814816,
                "post_id": 72277613,
                "comment_id": 127696335,
                "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": 1652829645,
                "post_id": 72277613,
                "comment_id": 127700042,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 25026533,
                    "reputation": 145,
                    "user_id": 18884688,
                    "user_type": "registered",
                    "profile_image": "https://lh3.googleusercontent.com/a/AATXAJymEyOdaMV5_qZK6T4e1fgBYaZE41Vo07DwACtX=k-s256",
                    "display_name": "Nicholas Rinaldi",
                    "link": "https://stackoverflow.com/users/18884688/nicholas-rinaldi"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1652879883,
                "post_id": 72277613,
                "comment_id": 127713483,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1652806151,
                "creation_date": 1652806151,
                "answer_id": 72277873,
                "question_id": 72277613,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can do the comparison within `jq`, return the boolean result as its exit status using the `-e` option, and react upon that in `bash`, e.g. using an `if` statement.\r\n\r\n~~~sh\r\nif jq -e &#39;\r\n  .config | map(select(.main != null) | .main[].mainAccount) | .[0] == .[1]\r\n&#39; file.json &gt;/dev/null\r\nthen echo &quot;equal&quot;\r\nelse echo &quot;not equal&quot;\r\nfi\r\n~~~\r\n~~~\r\nnot equal\r\n~~~",
                "title": "How to perform a check on multiple sub-trees"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1652813613,
                "last_edit_date": 1652813613,
                "creation_date": 1652811558,
                "answer_id": 72278916,
                "question_id": 72277613,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Since all information is within this one JSON file it is better to do the processing in `jq` as much as possible and to keep the shell out.\r\n\r\nGiven your input you can try this `jq`:\r\n\r\n```\r\njq &#39;\r\n    .config[]\r\n    | {\r\n        environment,\r\n        condition: (.main[0].mainAccount == .second[0].secondAccount)\r\n    }&#39; input.json\r\n```\r\n\r\nThe result is:\r\n```json\r\n{\r\n  &quot;environment&quot;: &quot;testing&quot;,\r\n  &quot;condition&quot;: false\r\n}\r\n{\r\n  &quot;environment&quot;: &quot;production&quot;,\r\n  &quot;condition&quot;: true\r\n}\r\n```\r\n\r\nSome questions though:\r\n\r\n- Why are the values of `first` and `second` arrays objects and not object?\r\n- Is it really intended to match the first one of both?\r\n- Can there be more items in the arrays?\r\n\r\nAlso: If you want to process the results in a shell, I propose this expression because the output can be used (`source` or `eval`) in a shell:\r\n\r\n```\r\njq -r &#39;\r\n    .config[]\r\n    | &quot;\\(.environment)=\\(.main[0].mainAccount == .second[0].secondAccount)&quot;&#39; input.json\r\n```\r\n\r\nThe output is:\r\n\r\n    testing=false\r\n    production=true\r\n",
                "title": "How to perform a check on multiple sub-trees"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1652879995,
        "creation_date": 1652804838,
        "last_edit_date": 1652879995,
        "question_id": 72277613,
        "body_markdown": "What I&#39;m trying to do currently, is, within each environment, compare mainAccount and secondAccount values.\r\n\r\nIf they do match, then I will trigger some downstream code to check the file version. If they do not, then I will pass. That is not really relevant, however I am struggling to compare the values across each environment. Since each .json file will have different amounts of environments.\r\n\r\nMeaning, in testing environment, I want to check if mainAccount = secondAccount, and same in production environment.\r\n\r\nI&#39;m running into issues parsing this JSON with jq:\r\n\r\n**json1**\r\n\r\n```\r\n{\r\n    &quot;file_version&quot;: 1.0,\r\n    &quot;config&quot;: [\r\n        {\r\n            &quot;environment&quot;: &quot;testing&quot;,\r\n            &quot;main&quot;: [\r\n                {\r\n                    &quot;mainAccount&quot;: &quot;123&quot;\r\n                }\r\n            ],\r\n            &quot;second&quot;: [\r\n                {\r\n                    &quot;secondAccount&quot;: &quot;456&quot;\r\n                }\r\n            ]\r\n        },\r\n        {\r\n            &quot;environment&quot;: &quot;production&quot;,\r\n            &quot;main&quot;: [\r\n                {\r\n                    &quot;mainAccount&quot;: &quot;789&quot;\r\n                }\r\n            ],\r\n            &quot;second&quot;: [\r\n                {\r\n                    &quot;secondAccount&quot;: &quot;789&quot;\r\n                }\r\n            ]\r\n        }\r\n    ]\r\n}\r\n```\r\n\r\nHere&#39;s another sample .json file for comparsion:\r\n\r\n**json2**\r\n\r\n        {\r\n        &quot;file_version&quot;: 1.3,\r\n        &quot;config&quot;: [\r\n            {\r\n                &quot;environment&quot;: &quot;testing&quot;,\r\n                &quot;main&quot;: [\r\n                    {\r\n                        &quot;mainAccount&quot;: &quot;123&quot;\r\n                    }\r\n                ],\r\n                &quot;second&quot;: [\r\n                    {\r\n                        &quot;secondAccount&quot;: &quot;456&quot;\r\n                    }\r\n                ]\r\n            },\r\n            {\r\n                &quot;environment&quot;: &quot;production&quot;,\r\n                &quot;main&quot;: [\r\n                    {\r\n                        &quot;mainAccount&quot;: &quot;789&quot;\r\n                    }\r\n                ],\r\n                &quot;second&quot;: [\r\n                    {\r\n                        &quot;secondAccount&quot;: &quot;789&quot;\r\n                    }\r\n                ]\r\n            },\r\n            {\r\n                &quot;environment&quot;: &quot;pre-production&quot;,\r\n                &quot;main&quot;: [\r\n                    {\r\n                        &quot;mainAccount&quot;: &quot;456&quot;\r\n                    }\r\n                ],\r\n                &quot;second&quot;: [\r\n                    {\r\n                        &quot;secondAccount&quot;: &quot;789&quot;\r\n                    }\r\n                ]\r\n            },\r\n            {\r\n                &quot;environment&quot;: &quot;staging&quot;,\r\n                &quot;main&quot;: [\r\n                    {\r\n                        &quot;mainAccount&quot;: &quot;234&quot;\r\n                    }\r\n                ],\r\n                &quot;second&quot;: [\r\n                    {\r\n                        &quot;secondAccount&quot;: &quot;456&quot;\r\n                    }\r\n                ]\r\n            }\r\n        ]\r\n    }\r\n\r\nIf I run this command:\r\n\r\n    jq -r &#39;.config[] | select(.main != null) | .main[].mainAccount\r\n\r\nMy output is:\r\n\r\n    123\r\n    789\r\n\r\nIf i store this output in a variable, it&#39;ll be `123 789` so comparing this to the &quot;secondAccount&quot; value is troublesome.\r\n\r\nI think what I&#39;m looking for is iteration here, however, I&#39;m not sure how to implement this. I wanted to take a pythonic approach to check the length of the `config` array, create a for loop in that length range, then collect the value based on an index like\r\n\r\n    .config[0] | select(.main != null) | .main[].mainAccount\r\n    .config[1] | select(.main != null) | .main[].mainAccount\r\n\r\netc. The issue however, is that when I read in the `.config[]` value as a variable, bash doesn&#39;t interpret it like that. The length will be the length of characters, not, the amount of objects in the array.\r\n\r\n**EXPECTED OUTPUT**\r\nNothing. I simply want to, for each .json file above, compare the mainAccount and secondAccount values with eachother, within each environment.\r\n\r\nIn **json1**, I want to compare mainAccount == secondAccount in environment: testing. Then mainAccount == secondAccount in environment: production. \r\n\r\nThen move onto json 2 and compare mainAccount == secondAccount in environment: testing. Then environment production, pre-production, staging, so on and so forth. ",
        "link": "https://stackoverflow.com/questions/72277613/how-to-perform-a-check-on-multiple-sub-trees",
        "title": "How to perform a check on multiple sub-trees"
    },
    {
        "tags": [
            "json",
            "shell",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 17,
                "is_accepted": true,
                "score": 17,
                "last_activity_date": 1652806284,
                "creation_date": 1652806284,
                "answer_id": 72277909,
                "question_id": 72277908,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "actually `jq` has built-in filters `ascii_downcase` and `ascii_upcase` you can use like this `jq &#39;sort_by(.title | ascii_downcase)&#39; data.json` to get proper result.\r\n\r\n```json\r\n[\r\n  {&quot;title&quot;: &quot;first&quot;, &quot;description&quot;: &quot;foo&quot;},\r\n  {&quot;title&quot;: &quot;Second&quot;, &quot;description&quot;: &quot;bar&quot;}\r\n]\r\n```\r\n",
                "title": "how to sort case insensitive using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 10,
        "last_activity_date": 1662852927,
        "creation_date": 1652806284,
        "last_edit_date": 1652816818,
        "question_id": 72277908,
        "body_markdown": "Does `jq` support case insensitive sorting?\r\n\r\nfor instance I have `data.json` like this\r\n\r\n```json\r\n[\r\n  {&quot;title&quot;: &quot;first&quot;, &quot;description&quot;: &quot;foo&quot;},\r\n  {&quot;title&quot;: &quot;Second&quot;, &quot;description&quot;: &quot;bar&quot;}\r\n]\r\n```\r\n\r\nsimple `jq &#39;sort_by(.title)&#39; data.json` returns\r\n\r\n```json\r\n[\r\n  {&quot;title&quot;: &quot;Second&quot;, &quot;description&quot;: &quot;bar&quot;},\r\n  {&quot;title&quot;: &quot;first&quot;, &quot;description&quot;: &quot;foo&quot;}\r\n]\r\n```",
        "link": "https://stackoverflow.com/questions/72277908/how-to-sort-case-insensitive-using-jq",
        "title": "how to sort case insensitive using jq"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1652858469,
                "creation_date": 1652858469,
                "answer_id": 72284749,
                "question_id": 72284649,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Use a `map` to retain the array while modifying (here: reducing) it to your needs:\r\n~~~sh\r\njq &#39;.data[] | {id, arr: .arr | map({arrId})}&#39;\r\n~~~\r\n~~~json\r\n{\r\n  &quot;id&quot;: &quot;id1&quot;,\r\n  &quot;arr&quot;: [\r\n    {\r\n      &quot;arrId&quot;: &quot;arrId11&quot;\r\n    },\r\n    {\r\n      &quot;arrId&quot;: &quot;arrId12&quot;\r\n    }\r\n  ]\r\n}\r\n{\r\n  &quot;id&quot;: &quot;id2&quot;,\r\n  &quot;arr&quot;: [\r\n    {\r\n      &quot;arrId&quot;: &quot;arrId21&quot;\r\n    },\r\n    {\r\n      &quot;arrId&quot;: &quot;arrId22&quot;\r\n    }\r\n  ]\r\n}\r\n~~~\r\n[Demo](https://jqplay.org/s/l2bkUBXJKVy)",
                "title": "How to print nested values along with parent level values using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1652858469,
        "creation_date": 1652857974,
        "question_id": 72284649,
        "body_markdown": "I have the following json\r\n```\r\n{\r\n\t&quot;data&quot;: [\r\n\t\t{\r\n\t\t\t&quot;id&quot;: id1,\r\n\t\t\t&quot;arr&quot;: [\r\n\t\t\t\t{\r\n\t\t\t\t\t&quot;arrId&quot;: arrId11,\r\n\t\t\t\t\t&quot;someOtherKey1&quot;: xxx,\r\n\t\t\t\t\t&quot;someOtherKey2&quot;: xxx,\r\n\t\t\t\t},\r\n\t\t\t\t{\r\n\t\t\t\t\t&quot;arrId&quot;: arrId12,\r\n\t\t\t\t\t&quot;someOtherKey1&quot;: xxx,\r\n\t\t\t\t\t&quot;someOtherKey2&quot;: xxx,\r\n\t\t\t\t}\r\n\t\t\t],\r\n\t\t\t&quot;otherParentLevelKey&quot;: yyyyy\r\n\t\t},\r\n\t\t{\r\n\t\t\t&quot;id&quot;: id2,\r\n\t\t\t&quot;arr&quot;: [\r\n\t\t\t\t{\r\n\t\t\t\t\t&quot;arrId&quot;: arrId21,\r\n\t\t\t\t\t&quot;someOtherKey1&quot;: xxx,\r\n\t\t\t\t\t&quot;someOtherKey2&quot;: xxx,\r\n\t\t\t\t},\r\n\t\t\t\t{\r\n\t\t\t\t\t&quot;arrId&quot;: arrId22,\r\n\t\t\t\t\t&quot;someOtherKey1&quot;: xxx,\r\n\t\t\t\t\t&quot;someOtherKey2&quot;: xxx,\r\n\t\t\t\t}\r\n\t\t\t],\r\n\t\t\t&quot;otherParentLevelKey&quot;: yyyyy\r\n\t\t}\r\n\t]\r\n}\r\n```\r\nAnd I want the following output\r\n```\r\n{\r\n\t&quot;id&quot;: id1,\r\n\t&quot;arr&quot;: [\r\n\t\t{\r\n\t\t\t&quot;arrId&quot;: arrId11\r\n\t\t},\r\n\t\t{\r\n\t\t\t&quot;arrId&quot;: arrId11\r\n\t\t}\r\n\t]\r\n}\r\n{\r\n\t&quot;id&quot;: id2,\r\n\t&quot;arr&quot;: [\r\n\t\t{\r\n\t\t\t&quot;arrId&quot;: arrId21\r\n\t\t},\r\n\t\t{\r\n\t\t\t&quot;arrId&quot;: arrId21\r\n\t\t}\r\n\t],\r\n}\r\n```\r\nI tried the following query but it’s not syntactically correct\r\n```\r\njsonArray | jq &#39;.data[] | {id, arr[].arrId}&#39;\r\n```\r\nThe approach I am using right now is something like the below. The output is something I can manage but I was wondering if there is a way with jq to achieve the one I wanted above.\r\n```\r\njsonArray | jq &#39;.data[] | [{(.id): .arr[].arrId}]&#39;\r\n```",
        "link": "https://stackoverflow.com/questions/72284649/how-to-print-nested-values-along-with-parent-level-values-using-jq",
        "title": "How to print nested values along with parent level values using jq"
    },
    {
        "tags": [
            "jquery",
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1652885635,
                "creation_date": 1652885635,
                "answer_id": 72291466,
                "question_id": 72291224,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Iterate through the levels, and collect what you want to print in variables. Use `? // empty` on elements to skip if inexistent, and `keys_unsorted` to get a list of field names. Finally, put all your items in an array, and use `join` to concatenate with a separator.\r\n~~~sh\r\njq -r &#39;\r\n  .name as $name | .Subject? // empty | keys_unsorted[] as $key\r\n  | [$name, $key, .[$key].Score] | join(&quot;,&quot;)\r\n&#39;\r\n~~~\r\n~~~json\r\nAmit,Maths,10\r\nAmit,Science,20\r\n~~~\r\n[Demo](https://jqplay.org/s/ppl-DqWEx-T)",
                "title": "Jq help to parse json data"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -1,
        "last_activity_date": 1652885635,
        "creation_date": 1652884646,
        "question_id": 72291224,
        "body_markdown": "I have below json data. Need help in parsing it.\r\n\r\n```\r\n{\r\n  &quot;name&quot;: &quot;Amit&quot;,\r\n  &quot;Subject&quot;: {\r\n    &quot;Maths&quot;: {\r\n      &quot;Score&quot;: 10,\r\n      &quot;ttl&quot;: 480\r\n    },\r\n    &quot;Science&quot;: {\r\n      &quot;Score&quot;: 20,\r\n      &quot;ttl&quot;: 480\r\n    }\r\n  }\r\n}\r\n````\r\n\r\nI need output like below. It could be possible that Subject tag is missing so that record should be skipped.\r\n\r\n```\r\nAmit,Maths,10\r\nAmit,Science,20\r\n```\r\n",
        "link": "https://stackoverflow.com/questions/72291224/jq-help-to-parse-json-data",
        "title": "Jq help to parse json data"
    },
    {
        "tags": [
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1652886272,
                "post_id": 72291596,
                "comment_id": 127716652,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1189145,
                    "reputation": 430,
                    "user_id": 4724021,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/08d2ccd0d3649766c145467cd73031c9?s=256&d=identicon&r=PG",
                    "display_name": "Sascha",
                    "link": "https://stackoverflow.com/users/4724021/sascha"
                },
                "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": 1652886842,
                "post_id": 72291596,
                "comment_id": 127716852,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1652887501,
                "creation_date": 1652887501,
                "answer_id": 72291923,
                "question_id": 72291596,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The function `to_entries`, &quot;converts between an object and an array of key-value pairs&quot; (see the [manual](https://stedolan.github.io/jq/manual/#to_entries,from_entries,with_entries)). To rename the preset `key` and `value` fields, just reassign them to a new name with a new object as in `{valueReference: .key, value}`.\r\n~~~sh\r\njq &#39;\r\n  .pathOptions.parameters |= (\r\n    to_entries | map({\r\n      pathParameterName: .key,\r\n      datasetParameter: (\r\n        .value | .filter.valuesMap |= (\r\n          to_entries | map({valueReference: .key, value})\r\n        )\r\n      )\r\n    })\r\n  )\r\n&#39;\r\n~~~\r\n~~~json\r\n{\r\n  &quot;pathOptions&quot;: {\r\n    &quot;parameters&quot;: [\r\n      {\r\n        &quot;pathParameterName&quot;: &quot;raw_date&quot;,\r\n        &quot;datasetParameter&quot;: {\r\n          &quot;name&quot;: &quot;raw_date&quot;,\r\n          &quot;type&quot;: &quot;Datetime&quot;,\r\n          &quot;datetimeOptions&quot;: {\r\n            &quot;localeCode&quot;: &quot;en-GB&quot;\r\n          },\r\n          &quot;createColumn&quot;: true,\r\n          &quot;filter&quot;: {\r\n            &quot;expression&quot;: &quot;(after :date1)&quot;,\r\n            &quot;valuesMap&quot;: [\r\n              {\r\n                &quot;valueReference&quot;: &quot;:date1&quot;,\r\n                &quot;value&quot;: &quot;2022-03-08T00:00:00.000Z&quot;\r\n              }\r\n            ]\r\n          }\r\n        }\r\n      }\r\n    ]\r\n  }\r\n}\r\n~~~\r\n[Demo](https://jqplay.org/s/ztWkHkGThDa)",
                "title": "How can I change a json structure into an object and rename keys with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1652887501,
        "creation_date": 1652886122,
        "last_edit_date": 1652886762,
        "question_id": 72291596,
        "body_markdown": "Using jq I am trying to convert the rawe json below into the desired json outcome.\r\nObjectives:\r\n`name` renamed to `pathParameterName`\r\n`type` renamed to `datasetParameter`\r\n\r\n\r\nRaw Json I&#39;m trying to convert\r\n```\r\n{\r\n&quot;pathOptions&quot;: {\r\n        &quot;parameters&quot;: {\r\n            &quot;raw_date&quot;: {\r\n                &quot;name&quot;: &quot;raw_date&quot;,\r\n                &quot;type&quot;: &quot;Datetime&quot;,\r\n                &quot;datetimeOptions&quot;: {\r\n                    &quot;localeCode&quot;: &quot;en-GB&quot;\r\n                },\r\n                &quot;createColumn&quot;: true,\r\n                &quot;filter&quot;: {\r\n                    &quot;expression&quot;: &quot;(after :date1)&quot;,\r\n                    &quot;valuesMap&quot;: {\r\n                        &quot;:date1&quot;: &quot;2022-03-08T00:00:00.000Z&quot;\r\n                    }\r\n                }\r\n            }\r\n        }\r\n    }\r\n  }\r\n\r\n```\r\nJson desired outcome:\r\n\r\n```\r\n{\r\n  &quot;pathOptions&quot;: {\r\n    &quot;parameters&quot;: [\r\n      {\r\n        &quot;pathParameterName&quot;: &quot;raw_date&quot;,\r\n        &quot;datasetParameter&quot;: {\r\n          &quot;name&quot;: &quot;raw_date&quot;,\r\n          &quot;type&quot;: &quot;Datetime&quot;,\r\n          &quot;datetimeOptions&quot;: {\r\n            &quot;localeCode&quot;: &quot;en-GB&quot;\r\n          },\r\n          &quot;createColumn&quot;: true,\r\n          &quot;filter&quot;: {\r\n            &quot;expression&quot;: &quot;(after :date1)&quot;,\r\n            &quot;valuesMap&quot;: [\r\n              {\r\n                &quot;valueReference&quot;: &quot;:date1&quot;,\r\n                &quot;value&quot;: &quot;2022-03-08T00:00:00.000Z&quot;\r\n              }\r\n            ]\r\n          }\r\n        }\r\n      }\r\n    ]\r\n  }\r\n }\r\n\r\n\r\n```\r\n\r\nThis is what I have so far:\r\n```\r\nmap_values(if type == &quot;object&quot; then to_entries else . end)\r\n\r\n```\r\nThis is what my code above currently produces. -I&#39;m struggling with the key renaming.\r\n```\r\n{\r\n  &quot;pathOptions&quot;: [\r\n    {\r\n      &quot;key&quot;: &quot;parameters&quot;,\r\n      &quot;value&quot;: [\r\n        {\r\n          &quot;pathParameterName&quot;: &quot;raw_date&quot;,\r\n          &quot;datasetParameter&quot;: {\r\n            &quot;name&quot;: &quot;raw_date&quot;,\r\n            &quot;type&quot;: &quot;Datetime&quot;,\r\n            &quot;datetimeOptions&quot;: {\r\n              &quot;localeCode&quot;: &quot;en-GB&quot;\r\n            },\r\n            &quot;createColumn&quot;: true,\r\n            &quot;filter&quot;: {\r\n              &quot;expression&quot;: &quot;(after :date1)&quot;,\r\n              &quot;valuesMap&quot;: [\r\n                {\r\n                  &quot;valueReference&quot;: &quot;:date1&quot;,\r\n                  &quot;value&quot;: &quot;2022-03-08T00:00:00.000Z&quot;\r\n                }\r\n              ]\r\n            }\r\n          }\r\n        }\r\n      ]\r\n    }\r\n  ]\r\n}\r\n```\r\n\r\n",
        "link": "https://stackoverflow.com/questions/72291596/how-can-i-change-a-json-structure-into-an-object-and-rename-keys-with-jq",
        "title": "How can I change a json structure into an object and rename keys with jq"
    },
    {
        "tags": [
            "json",
            "linux",
            "search",
            "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": 1652899042,
                "post_id": 72294351,
                "comment_id": 127721416,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 13381263,
                    "reputation": 47,
                    "user_id": 9656454,
                    "user_type": "registered",
                    "profile_image": "https://lh3.googleusercontent.com/-g6SCwKVYxKM/AAAAAAAAAAI/AAAAAAAABKo/WWvJXFJ3yJk/s256-rj/photo.jpg",
                    "display_name": "RHSkinner",
                    "link": "https://stackoverflow.com/users/9656454/rhskinner"
                },
                "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": 1652899176,
                "post_id": 72294351,
                "comment_id": 127721470,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 13381263,
                    "reputation": 47,
                    "user_id": 9656454,
                    "user_type": "registered",
                    "profile_image": "https://lh3.googleusercontent.com/-g6SCwKVYxKM/AAAAAAAAAAI/AAAAAAAABKo/WWvJXFJ3yJk/s256-rj/photo.jpg",
                    "display_name": "RHSkinner",
                    "link": "https://stackoverflow.com/users/9656454/rhskinner"
                },
                "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": 1652900464,
                "post_id": 72294351,
                "comment_id": 127721947,
                "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": 1652901226,
                "post_id": 72294351,
                "comment_id": 127722201,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1652988054,
                "last_edit_date": 1652988054,
                "creation_date": 1652987890,
                "answer_id": 72310018,
                "question_id": 72294351,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "All credit to [pmf][1] for the solution\r\n\r\n    jq -r &#39;.items[] | select(.product | contains([&quot;bitbucket&quot;]))? | .cidr&#39;\r\n\r\nThis worked perfectly\r\n\r\n\r\n  [1]: https://stackoverflow.com/users/2158479/pmf",
                "title": "JSON - Get all matching objects using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1652988054,
        "creation_date": 1652898847,
        "last_edit_date": 1652899056,
        "question_id": 72294351,
        "body_markdown": "I&#39;m trying to set up automation for an IP address whitelist.\r\n\r\nThe JSON can be found here: https://ip-ranges.atlassian.com/\r\n\r\nI need to generate a list of every &quot;item&quot; in the JSON where &quot;product&quot; contains &quot;bitbucket&quot; (for example).\r\n\r\n    curl https://ip-ranges.atlassian.com/ | jq -c &#39;.items | select(.[].product | contains(&quot;bitbucket&quot;))&#39;\r\n\r\nThe output is\r\n\r\n    jq: error (at &lt;stdin&gt;:1834): array ([&quot;confluenc...) and string (&quot;bitbucket&quot;) cannot have their containment checked\r\n\r\nWhat am I doing wrong here?\r\n\r\nSmall sample of the JSON from the URL above:\r\n\r\n    {\r\n      &quot;syncToken&quot;: 1644822802,\r\n      &quot;creationDate&quot;: &quot;2022-02-14T07:13:22.789203&quot;,\r\n      &quot;items&quot;: [\r\n        {\r\n          &quot;direction&quot;: [\r\n            &quot;ingress&quot;,\r\n            &quot;egress&quot;\r\n          ],\r\n          &quot;network&quot;: &quot;3.26.128.128&quot;,\r\n          &quot;mask_len&quot;: 26,\r\n          &quot;region&quot;: [\r\n            &quot;ap-southeast-2&quot;\r\n          ],\r\n          &quot;mask&quot;: &quot;255.255.255.192&quot;,\r\n          &quot;product&quot;: [\r\n            &quot;confluence&quot;,\r\n            &quot;jira&quot;,\r\n            &quot;bitbucket&quot;,\r\n            &quot;opsgenie&quot;,\r\n            &quot;statuspage&quot;,\r\n            &quot;halp&quot;,\r\n            &quot;trello&quot;\r\n          ],\r\n          &quot;cidr&quot;: &quot;3.26.128.128/26&quot;\r\n        },.........",
        "link": "https://stackoverflow.com/questions/72294351/json-get-all-matching-objects-using-jq",
        "title": "JSON - Get all matching objects using jq"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1652900951,
                "creation_date": 1652900951,
                "answer_id": 72294735,
                "question_id": 72294619,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Save the IP in a variable, and make your selection one level deeper. Then, print out if it matched:\r\n~~~sh\r\njq -r &#39;.[].result.hits[] | .ip as $ip | .services[] | select(.service_name == &quot;HTTP&quot;) | &quot;\\($ip):\\(.port)&quot;&#39;\r\n~~~\r\n~~~json\r\n2.14.11.41:80\r\n2.14.11.41:8001\r\n2.22.22.102:80\r\n2.22.22.102:8001\r\n2.22.22.102:8089\r\n4.54.84.19:443\r\n~~~\r\n[Demo](https://jqplay.org/s/TUKX1QCj1Al)",
                "title": "jq: only required fields if the field n is equal to x"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1659983545,
                "creation_date": 1659983545,
                "answer_id": 73282562,
                "question_id": 72294619,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "With your shown samples and attempts please try following `jq` code. Concept wise same as already posted answer but a bit different in looping wise. Using `-r` option to get output in raw format, along with that using `select` function to check condition on service_name field is HTTP or not.\r\n\r\n    jq -r &#39;.[].result.hits[] | &quot;\\(.ip):\\(.services[] | select(.service_name==&quot;HTTP&quot;).port)&quot;&#39; file",
                "title": "jq: only required fields if the field n is equal to x"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1659983545,
        "creation_date": 1652900283,
        "question_id": 72294619,
        "body_markdown": "I have the following file:\r\n```\r\n[\r\n{\r\n  &quot;code&quot;: 200,\r\n  &quot;status&quot;: &quot;OK&quot;,\r\n  &quot;result&quot;: {\r\n    &quot;query&quot;: &quot;123&quot;,\r\n    &quot;hits&quot;: [\r\n      {\r\n        &quot;ip&quot;: &quot;2.14.11.41&quot;,\r\n        &quot;services&quot;: [\r\n          {\r\n            &quot;port&quot;: 22,\r\n            &quot;service_name&quot;: &quot;SSH&quot;,\r\n            &quot;transport_protocol&quot;: &quot;TCP&quot;\r\n          },\r\n          {\r\n            &quot;port&quot;: 80,\r\n            &quot;service_name&quot;: &quot;HTTP&quot;,\r\n            &quot;transport_protocol&quot;: &quot;TCP&quot;\r\n          },\r\n          {\r\n            &quot;port&quot;: 5900,\r\n            &quot;service_name&quot;: &quot;VNC&quot;,\r\n            &quot;transport_protocol&quot;: &quot;TCP&quot;\r\n          },\r\n          {\r\n            &quot;port&quot;: 8001,\r\n            &quot;service_name&quot;: &quot;HTTP&quot;,\r\n            &quot;certificate&quot;: &quot;62345a087218e&quot;,\r\n            &quot;transport_protocol&quot;: &quot;TCP&quot;\r\n          }\r\n        ],\r\n        &quot;location&quot;: {\r\n          &quot;continent&quot;: &quot;Asia&quot;,\r\n          &quot;country&quot;: &quot;Israel&quot;,\r\n          &quot;country_code&quot;: &quot;IL&quot;,\r\n          &quot;timezone&quot;: &quot;Asia/Jerusalem&quot;,\r\n          &quot;coordinates&quot;: {\r\n            &quot;latitude&quot;: 31.5,\r\n            &quot;longitude&quot;: 34.75\r\n          },\r\n          &quot;registered_country&quot;: &quot;Israel&quot;,\r\n          &quot;registered_country_code&quot;: &quot;IL&quot;\r\n        },\r\n        &quot;autonomous_system&quot;: {\r\n          &quot;asn&quot;: 12400,\r\n          &quot;description&quot;: &quot;PARTNER-AS&quot;,\r\n          &quot;bgp_prefix&quot;: &quot;2.54.0.0/17&quot;,\r\n          &quot;name&quot;: &quot;PARTNER-AS&quot;,\r\n          &quot;country_code&quot;: &quot;IL&quot;\r\n        },\r\n        &quot;last_updated_at&quot;: &quot;2022-05-18T13:09:19.288Z&quot;\r\n      },\r\n      {\r\n        &quot;ip&quot;: &quot;2.22.22.102&quot;,\r\n        &quot;services&quot;: [\r\n          {\r\n            &quot;port&quot;: 22,\r\n            &quot;service_name&quot;: &quot;SSH&quot;,\r\n            &quot;transport_protocol&quot;: &quot;TCP&quot;\r\n          },\r\n          {\r\n            &quot;port&quot;: 80,\r\n            &quot;service_name&quot;: &quot;HTTP&quot;,\r\n            &quot;transport_protocol&quot;: &quot;TCP&quot;\r\n          },\r\n          {\r\n            &quot;port&quot;: 5901,\r\n            &quot;service_name&quot;: &quot;VNC&quot;,\r\n            &quot;transport_protocol&quot;: &quot;TCP&quot;\r\n          },\r\n          {\r\n            &quot;port&quot;: 8001,\r\n            &quot;service_name&quot;: &quot;HTTP&quot;,\r\n            &quot;certificate&quot;: &quot;6875897649b700a087218e&quot;,\r\n            &quot;transport_protocol&quot;: &quot;TCP&quot;\r\n          },\r\n          {\r\n            &quot;port&quot;: 8089,\r\n            &quot;service_name&quot;: &quot;HTTP&quot;,\r\n            &quot;transport_protocol&quot;: &quot;TCP&quot;\r\n          }\r\n        ],\r\n        &quot;location&quot;: {\r\n          &quot;continent&quot;: &quot;Asia&quot;,\r\n          &quot;country&quot;: &quot;Israel&quot;,\r\n          &quot;country_code&quot;: &quot;IL&quot;,\r\n          &quot;city&quot;: &quot;Herzliya&quot;,\r\n          &quot;timezone&quot;: &quot;Asia/Jerusalem&quot;,\r\n          &quot;province&quot;: &quot;Tel Aviv&quot;,\r\n          &quot;coordinates&quot;: {\r\n            &quot;latitude&quot;: 32.1679,\r\n            &quot;longitude&quot;: 34.834\r\n          },\r\n          &quot;registered_country&quot;: &quot;Israel&quot;,\r\n          &quot;registered_country_code&quot;: &quot;IL&quot;\r\n        },\r\n        &quot;autonomous_system&quot;: {\r\n          &quot;asn&quot;: 12400,\r\n          &quot;description&quot;: &quot;PARTNER-AS&quot;,\r\n          &quot;bgp_prefix&quot;: &quot;2.55.0.0/17&quot;,\r\n          &quot;name&quot;: &quot;PARTNER-AS&quot;,\r\n          &quot;country_code&quot;: &quot;IL&quot;\r\n        },\r\n        &quot;last_updated_at&quot;: &quot;2022-05-18T13:50:58.807Z&quot;\r\n      },\r\n      {\r\n        &quot;ip&quot;: &quot;4.54.84.19&quot;,\r\n        &quot;services&quot;: [\r\n          {\r\n            &quot;port&quot;: 22,\r\n            &quot;service_name&quot;: &quot;SSH&quot;,\r\n            &quot;transport_protocol&quot;: &quot;TCP&quot;\r\n          },\r\n          {\r\n            &quot;port&quot;: 443,\r\n            &quot;service_name&quot;: &quot;HTTP&quot;,\r\n            &quot;certificate&quot;: &quot;8120978819a83e&quot;,\r\n            &quot;transport_protocol&quot;: &quot;TCP&quot;\r\n          },\r\n          {\r\n            &quot;port&quot;: 502,\r\n            &quot;service_name&quot;: &quot;MODBUS&quot;,\r\n            &quot;transport_protocol&quot;: &quot;TCP&quot;\r\n          },\r\n          {\r\n            &quot;port&quot;: 5900,\r\n            &quot;service_name&quot;: &quot;VNC&quot;,\r\n            &quot;transport_protocol&quot;: &quot;TCP&quot;\r\n          }\r\n        ],\r\n        &quot;location&quot;: {\r\n          &quot;continent&quot;: &quot;Asia&quot;,\r\n          &quot;country&quot;: &quot;Israel&quot;,\r\n          &quot;country_code&quot;: &quot;IL&quot;,\r\n          &quot;city&quot;: &quot;Ashdod&quot;,\r\n          &quot;timezone&quot;: &quot;Asia/Jerusalem&quot;,\r\n          &quot;province&quot;: &quot;Southern District&quot;,\r\n          &quot;coordinates&quot;: {\r\n            &quot;latitude&quot;: 31.7915,\r\n            &quot;longitude&quot;: 34.6497\r\n          },\r\n          &quot;registered_country&quot;: &quot;Israel&quot;,\r\n          &quot;registered_country_code&quot;: &quot;IL&quot;\r\n        },\r\n        &quot;autonomous_system&quot;: {\r\n          &quot;asn&quot;: 12400,\r\n          &quot;description&quot;: &quot;PARTNER-AS&quot;,\r\n          &quot;bgp_prefix&quot;: &quot;2.55.0.0/17&quot;,\r\n          &quot;name&quot;: &quot;PARTNER-AS&quot;,\r\n          &quot;country_code&quot;: &quot;IL&quot;\r\n        },\r\n        &quot;last_updated_at&quot;: &quot;2022-05-18T12:36:13.141Z&quot;\r\n      }\r\n    ],\r\n    &quot;links&quot;: {\r\n      &quot;next&quot;: &quot;eyJ9I6MH0=&quot;,\r\n      &quot;prev&quot;: &quot;&quot;\r\n    }\r\n  }\r\n}\r\n]\r\n```\r\nI&#39;m trying to get the following format out of it:\r\n```\r\n2.14.11.41:80\r\n2.14.11.41:8001\r\n2.22.22.102:80\r\n2.22.22.102:8001\r\n2.22.22.102:8089\r\n4.54.84.19:443\r\n```\r\ni.e. select *IP* and port if *service_name* is equal to *HTTP*. I know how to get IP `jq -r &#39;.[].result.hits[] | select(.services[].service_name == &quot;HTTP&quot;) | .ip&#39;` and also how to get only ports `jq -r &#39;.[].result.hits[].services[] | select(.service_name == &quot;HTTP&quot;) | .port&#39;`, but I do not understand how to combine it properly in one command. Could someone please point to a right direction?",
        "link": "https://stackoverflow.com/questions/72294619/jq-only-required-fields-if-the-field-n-is-equal-to-x",
        "title": "jq: only required fields if the field n is equal to x"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1653014513,
                "last_edit_date": 1653014513,
                "creation_date": 1652916598,
                "answer_id": 72297039,
                "question_id": 72296903,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Try this (assuming your file is named `so72297039.json`):\r\n\r\n```sh\r\njq &#39;[.[] | to_entries] | flatten | from_entries&#39; &lt; so72297039.json\r\n```\r\n\r\n(Edit: OP edited question, so here&#39;s relevant answer)",
                "title": "jq flatten list of objects into one object"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1652938344,
                "creation_date": 1652938344,
                "answer_id": 72299091,
                "question_id": 72296903,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Since duplicate keys are not possible (see other answer) you can use to format like this:\r\n```\r\n{\r\n  &quot;artist&quot;: [\r\n    &quot;deadmau5&quot;,\r\n    &quot;swedish house mafia&quot;\r\n  ],\r\n  &quot;genre&quot;: [\r\n    &quot;deep house&quot;,\r\n    &quot;progressive house&quot;,\r\n    &quot;dubstep&quot;\r\n  ],\r\n  &quot;song&quot;: [\r\n    &quot;escape&quot;\r\n  ]\r\n}\r\n```\r\n\r\nwith a `jq` call like this:\r\n\r\n```\r\njq &#39;\r\n    map(to_entries)\r\n    | flatten\r\n    | group_by(.key)\r\n    | map({key: first.key, value: map(.value)})\r\n    | from_entries\r\n&#39; input.json\r\n```\r\n\r\nIf the keys `artist`, `genre`, `song` are known in advance an easier to understand expression can be used.",
                "title": "jq flatten list of objects into one object"
            },
            {
                "up_vote_count": 6,
                "is_accepted": false,
                "score": 6,
                "last_activity_date": 1652977805,
                "creation_date": 1652977805,
                "answer_id": 72308082,
                "question_id": 72296903,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "[jq&#39;s add function](https://stedolan.github.io/jq/manual/#add) does exactly this\r\n\r\n    jq &#39;add&#39;",
                "title": "jq flatten list of objects into one object"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 2,
        "last_activity_date": 1653409000,
        "creation_date": 1652915302,
        "last_edit_date": 1653409000,
        "question_id": 72296903,
        "body_markdown": "I want to go from\r\n\r\n```json\r\n[\r\n  {&quot;key_skjdghkbs&quot;: &quot;deep house&quot;},\r\n  {&quot;key_kjsskjbgs&quot;: &quot;deadmau5&quot;},\r\n  {&quot;key_jhw98w4hl&quot;: &quot;progressive house&quot;},\r\n  {&quot;key_sjkh348vg&quot;: &quot;swedish house mafia&quot;},\r\n  {&quot;key_js3485jwh&quot;: &quot;dubstep&quot;},\r\n  {&quot;key_jsg587jhs&quot;: &quot;escape&quot;}\r\n]\r\n```\r\n\r\nto \r\n\r\n```json\r\n{\r\n  &quot;key_skjdghkbs&quot;: &quot;deep house&quot;,\r\n  &quot;key_kjsskjbgs&quot;: &quot;deadmau5&quot;\r\n  &quot;key_jhw98w4hl&quot;: &quot;progressive house&quot;,\r\n  &quot;key_sjkh348vg&quot;: &quot;swedish house mafia&quot;,\r\n  &quot;key_js3485jwh&quot;: &quot;dubstep&quot;,\r\n  &quot;key_jsg587jhs&quot;: &quot;escape&quot;\r\n}\r\n```\r\n\r\nEach object in the original list has exactly one key but the keys are unique.\r\n\r\nI could do something like `jq .[] .genre` if the keys were the same but they&#39;re not.",
        "link": "https://stackoverflow.com/questions/72296903/jq-flatten-list-of-objects-into-one-object",
        "title": "jq flatten list of objects into one object"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1652923885,
                "creation_date": 1652923885,
                "answer_id": 72297683,
                "question_id": 72297298,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "`\\e` and `\\a` are not valid in a JSON string; to encode the escape and bell control characters, you need to use `\\u001b` and `\\u0007` respectively. You probably also want use the `-r` option to `jq` to make it output raw strings (rather than JSON-encoded).\r\n\r\nI would also strongly recommend double-quoting shell variable references (to avoid weird effects from word splitting and wildcard expansion), and using lower- or mixed-case variable names to avoid conflicts with the many all-caps names that have special meanings or functions.\r\n\r\nSo something like this:\r\n\r\n    echo &quot;$results&quot; | jq -r &#39;.results[] | &quot;\\u001b]8;;\\(.url)\\u0007\\(.title)\\u001b]8;;\\u0007&quot;&#39;\r\n\r\nOr, in bash (but not all other shells) you can use a here-string instead of `echo`:\r\n\r\n    jq -r &#39;.results[] | &quot;\\u001b]8;;\\(.url)\\u0007\\(.title)\\u001b]8;;\\u0007&quot;&#39; &lt;&lt;&lt;&quot;$results&quot;",
                "title": "how can I build bash hyperlink strings from json fields?"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1652956503,
                "creation_date": 1652956503,
                "answer_id": 72303017,
                "question_id": 72297298,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can keep your original jq script using bash escape sequence `$` :\r\n\r\n```\r\njq -r $&#39;.results[] | &quot;\\e]8;;\\(.url)\\a\\(.title)\\e]8;;\\a&quot;&#39; &lt;&lt;&lt; &quot;$results&quot;\r\n```\r\n\r\nHere bash will convert `\\e` to character `0x1b`.",
                "title": "how can I build bash hyperlink strings from json fields?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 2,
        "last_activity_date": 1652956503,
        "creation_date": 1652919418,
        "last_edit_date": 1652920964,
        "question_id": 72297298,
        "body_markdown": "I am getting some JSON data from the NYTimes API.  I can get things to this form:\r\n\r\n```\r\n&quot;results&quot;: [\r\n{\r\n  &quot;headline&quot;: &quot;such and such&quot;,\r\n  &quot;url&quot;: &quot;http://such.and.such.com&quot;,\r\n  ...\r\n},\r\n{\r\n  &quot;headline&quot;: &quot;so and so&quot;,\r\n  &quot;url&quot;: &quot;http://so.and.so.com&quot;,\r\n  ...\r\n},\r\n...\r\n]\r\n```\r\n\r\nI want to echo 1 string for every object in the array, so that the string text displays the headline, and the string is clickable to the url.\r\n\r\nI know how I want the string to be built:\r\n\r\n```echo -e &quot;\\e]8;;$URL\\a$TITLE\\e]8;;\\a&quot;```\r\n\r\nI can&#39;t figure out how to use ```jq``` to populate those variable portions of the string.\r\n\r\n```\r\n&gt; echo $RESULTS | jq &#39;.results[] | &quot;\\e]8;;\\(.url)\\a\\(.title)\\e]8;;\\a&quot;&#39;\r\njq: error: Invalid escape at line 1, column 4 (while parsing &#39;&quot;\\e&quot;&#39;) at &lt;top-level&gt;, line 1:\r\n.results[] | &quot;\\e]8;;\\(.url)\\a\\(.title)\\e]8;;\\a&quot;\r\njq: error: Invalid escape at line 1, column 4 (while parsing &#39;&quot;\\a&quot;&#39;) at &lt;top-level&gt;, line 1:\r\n.results[] | &quot;\\e]8;;\\(.url)\\a\\(.title)\\e]8;;\\a&quot;\r\njq: error: Invalid escape at line 1, column 4 (while parsing &#39;&quot;\\e&quot;&#39;) at &lt;top-level&gt;, line 1:\r\n.results[] | &quot;\\e]8;;\\(.url)\\a\\(.title)\\e]8;;\\a&quot;\r\njq: error: Invalid escape at line 1, column 4 (while parsing &#39;&quot;\\a&quot;&#39;) at &lt;top-level&gt;, line 1:\r\n.results[] | &quot;\\e]8;;\\(.url)\\a\\(.title)\\e]8;;\\a&quot;\r\njq: 4 compile errors\r\n```",
        "link": "https://stackoverflow.com/questions/72297298/how-can-i-build-bash-hyperlink-strings-from-json-fields",
        "title": "how can I build bash hyperlink strings from json fields?"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq",
            "export-to-csv",
            "nested-lists"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1652949723,
                "creation_date": 1652949723,
                "answer_id": 72301311,
                "question_id": 72300979,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Save the name into a variable before you go down to the tags\r\n~~~sh\r\njq -r &#39;.images[] | .name as $name | .tags[] | [$name, .] | @tsv&#39;\r\n~~~\r\n~~~json\r\nubuntu\tlatest\r\ndebian\tlatest\r\ndebian\t10.0\r\n~~~\r\n[Demo](https://jqplay.org/s/6oTmSM1jp5n)",
                "title": "How tabulize nested JSON lists using jq in bash"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1652961207,
        "creation_date": 1652948248,
        "last_edit_date": 1652961207,
        "question_id": 72300979,
        "body_markdown": "I would like to parse data from a JSON-file into a tsv-file, but I cannot make it work.\r\n\r\n# Input\r\n    {\r\n      &quot;images&quot;: [\r\n        {\r\n          &quot;id&quot;: &quot;592a77a5-614e-4ed8-b846-d4db1f27edbf&quot;,\r\n          &quot;name&quot;: &quot;ubuntu&quot;,\r\n          &quot;tags&quot;: [\r\n            &quot;latest&quot;\r\n          ]\r\n        },\r\n        {\r\n          &quot;id&quot;: &quot;592da7a5-614e-4ed8-b846-d4db1f27edbf&quot;,\r\n          &quot;name&quot;: &quot;debian&quot;,\r\n          &quot;tags&quot;: [\r\n            &quot;latest&quot;,\r\n    \t\t&quot;10.0&quot;\r\n          ]\r\n        }\t\r\n      ]\r\n    }\r\n# Desired output\r\nThe desired output is a tab-separated table\r\n\r\n    ubuntu    latest\r\n    debian    latest\r\n    debian    10.0\r\n\r\n# What I have tried\r\n    # My data\r\n    echo &#39;{&quot;images&quot;:[{&quot;id&quot;:&quot;592a77a5-614e-4ed8-b846-d4db1f27edbf&quot;,&quot;name&quot;:&quot;ubuntu&quot;,&quot;tags&quot;:[&quot;latest&quot;]},{&quot;id&quot;:&quot;592da7a5-614e-4ed8-b846-d4db1f27edbf&quot;,&quot;name&quot;:&quot;debian&quot;,&quot;tags&quot;:[&quot;latest&quot;,&quot;10.0&quot;]}]}&#39; &gt; my.json\r\n\r\n    # My query\r\n    jq -r &#39;.images | map({id} + (.tags | fromjson[])) | @tsv&#39; my.json &gt; my.tsv\r\nFirst I access the images-list, then I want to make an operation over all ids, where I want the tags. I borrowed the map from a [similar post][1], but it does not seem to work. The only difference between my query and theirs is the extra layer with the **.images**.\r\n\r\n\r\n  [1]: https://stackoverflow.com/questions/52614115/flatten-nested-json-with-jq",
        "link": "https://stackoverflow.com/questions/72300979/how-tabulize-nested-json-lists-using-jq-in-bash",
        "title": "How tabulize nested JSON lists using jq in bash"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1652970113,
                "last_edit_date": 1652970113,
                "creation_date": 1652968269,
                "answer_id": 72305801,
                "question_id": 72305617,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "    jq &#39;[.[] | .id = .instances[0].id | del(.instances)]&#39; file.json\r\n\r\nIf there are more instances, just iterate over all of them to distribute the account_id to each of them:\r\n\r\n    jq &#39;[.[] | .id = .instances[].id | del(.instances)]&#39; file.json\r\n                               ~~",
                "title": "Use Jq to insert property of an object in another property"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1652970113,
        "creation_date": 1652967579,
        "last_edit_date": 1652969574,
        "question_id": 72305617,
        "body_markdown": "I have a json file that looks like this:\r\n```json\r\n[\r\n  {\r\n    &quot;account_id&quot;: 123, \r\n    &quot;instances&quot;: [\r\n      {&quot;id&quot;: 1},\r\n      {&quot;id&quot;: 2}\r\n    ]\r\n  },\r\n  {\r\n    &quot;account_id&quot;: 456, \r\n    &quot;instances&quot;: [\r\n      {&quot;id&quot;: 1}\r\n    ]\r\n  }\r\n]\r\n```\r\n\r\nI would like to flatten the instances into a single list and insert the account_id into each instance. Here is the result that I want.\r\n\r\n```json\r\n[\r\n  {&quot;id&quot;: 1, &quot;account_id&quot;: 123},\r\n  {&quot;id&quot;: 2, &quot;account_id&quot;: 123},\r\n  {&quot;id&quot;: 1, &quot;account_id&quot;: 456}\r\n]\r\n```\r\n\r\n-------------\r\nHere is a alternate solution that I came up with while waiting on an answer.\r\n\r\n```\r\njq &#39;.|map(.instances[]+{&quot;account_id&quot;: .account_id})&#39; file.json\r\n```",
        "link": "https://stackoverflow.com/questions/72305617/use-jq-to-insert-property-of-an-object-in-another-property",
        "title": "Use Jq to insert property of an object in another property"
    },
    {
        "tags": [
            "python",
            "arrays",
            "json",
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 2578132,
                    "reputation": 1921,
                    "user_id": 2235381,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/0061f9bd5384a544637692774a6e108f?s=256&d=identicon&r=PG",
                    "display_name": "lojza",
                    "link": "https://stackoverflow.com/users/2235381/lojza"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1652974587,
                "post_id": 72306955,
                "comment_id": 127742975,
                "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": 1652978342,
                "post_id": 72306955,
                "comment_id": 127744325,
                "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": 1653020143,
                "post_id": 72306955,
                "comment_id": 127753386,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 3315306,
                    "reputation": 1,
                    "user_id": 2787831,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/79c9c5c2441c8944d47080c3c1a0604f?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "baggio10",
                    "link": "https://stackoverflow.com/users/2787831/baggio10"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1653033576,
                "post_id": 72306955,
                "comment_id": 127756593,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1653045913,
                "creation_date": 1653045913,
                "answer_id": 72318165,
                "question_id": 72306955,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You could employ `reduce` to iterate over the items while extracting their `id`, `mount_point` and `root_container`. Then, if a `root_container` was present, delete that entry and add its `mount_point` to the entry whose `id` matches their `root_container`. For convenience, I also employed `INDEX` on the items&#39; `id` fields to simplify their access as `.[$id]` and `.[$root_container]`, which had to be undone at the end using `map(.)`.\r\n~~~sh\r\njq &#39;\r\n  reduce .[] as {$id, properties: {$mount_point, $root_container}} (\r\n    INDEX(.id);\r\n    if $root_container then\r\n      del(.[$id])\r\n      | .[$root_container].properties.file_system += [$mount_point]\r\n    else . end\r\n  )\r\n  | map(.)\r\n&#39;\r\n~~~\r\n~~~json\r\n[\r\n  {\r\n    &quot;id&quot;: &quot;3333&quot;,\r\n    &quot;properties&quot;: {\r\n      &quot;label&quot;: &quot;Computer&quot;,\r\n      &quot;name&quot;: &quot;My-Laptop&quot;,\r\n      &quot;file_system&quot;: [\r\n        &quot;/opt&quot;,\r\n        &quot;/var&quot;\r\n      ]\r\n    }\r\n  }\r\n]\r\n~~~\r\n[Demo](https://jqplay.org/s/L74vx5AGpKV)",
                "title": "JSON jq/python file manipulation with specific key name aggregation"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1653045913,
        "creation_date": 1652972814,
        "last_edit_date": 1653033675,
        "question_id": 72306955,
        "body_markdown": "I need to modify the structure of this json file:\r\n``` \r\n[\r\n   {\r\n      &quot;id&quot;:&quot;3333&quot;,\r\n      &quot;properties&quot;:{\r\n         &quot;label&quot;:&quot;Computer&quot;,\r\n\t     &quot;name&quot;:&quot;My-Laptop&quot;\r\n      }\r\n   },\r\n   {\r\n      &quot;id&quot;:&quot;9998&quot;,\r\n      &quot;type&quot;:&quot;file_system&quot;,\r\n      &quot;properties&quot;:{\r\n         &quot;mount_point&quot;:&quot;/opt&quot;,\r\n         &quot;name&quot;:&quot;/dev/mapper/rhel-opt&quot;,\r\n         &quot;root_container&quot;:&quot;3333&quot;\r\n      },\r\n      &quot;label&quot;:&quot;FileSystem&quot;\r\n   },\r\n   {\r\n      &quot;id&quot;:&quot;9999&quot;,\r\n      &quot;type&quot;:&quot;file_system&quot;,\r\n      &quot;properties&quot;:{\r\n         &quot;mount_point&quot;:&quot;/var&quot;,\r\n         &quot;name&quot;:&quot;/dev/mapper/rhel-var&quot;,\r\n         &quot;root_container&quot;:&quot;3333&quot;\r\n      },\r\n      &quot;label&quot;:&quot;FileSystem&quot;\r\n   }\r\n]\r\n``` \r\n\r\nin order to have this kind of output:\r\n```\r\n[\r\n   {\r\n      &quot;id&quot;:&quot;3333&quot;,\r\n      &quot;properties&quot;:{\r\n         &quot;label&quot;:&quot;Computer&quot;,\r\n         &quot;name&quot;:&quot;My-Laptop&quot;,\r\n         &quot;file_system&quot;:[\r\n            &quot;/opt&quot;,\r\n            &quot;/var&quot;\r\n         ]\r\n      }\r\n   }\r\n]\r\n```\r\n\r\nThe idea is to have, in the new json structure, the visibility of my laptop with the two file-system partition in an array named &quot;file_system&quot;.\r\nAs you can see the two partition are related to the first by the ```id``` and ```root_container```.\r\nSo, imagine to have not only one laptop, bat thousands of laptop, with different ```id``` and every one of these have different partition, related to the laptop by the ```root_container``` key.\r\n\r\nIs there an option to do this with ```jq``` functions or ```python``` script?\r\nMany thanks",
        "link": "https://stackoverflow.com/questions/72306955/json-jq-python-file-manipulation-with-specific-key-name-aggregation",
        "title": "JSON jq/python file manipulation with specific key name aggregation"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1652973831,
                "creation_date": 1652973831,
                "answer_id": 72307195,
                "question_id": 72307114,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You could do something like\r\n```\r\njq -s &#39;.[1] as $insert | .[0].Settings |= $insert | .[0]&#39; settings.json insert.json\r\n```\r\n\r\nWhere we :\r\n- `slurp` both files \r\n- Save `insert.json` to a variable called `$insert`\r\n- Append (`|=`) `$insert` to `.[0].Settings`\r\n- Show only the first file `.[0]`\r\n\r\nSo the output will become:\r\n```json\r\n{\r\n  &quot;Logging&quot;: {\r\n    &quot;MinimumLevel&quot;: {\r\n      &quot;Default&quot;: &quot;Information&quot;,\r\n      &quot;Override&quot;: &quot;Warning&quot;\r\n    },\r\n    &quot;WriteTo&quot;: [\r\n      {\r\n        &quot;Name&quot;: &quot;File&quot;,\r\n        &quot;Args&quot;: {\r\n          &quot;path&quot;: &quot;./logs/log-.txt&quot;,\r\n          &quot;rollingInterval&quot;: &quot;Day&quot;\r\n        }\r\n      }\r\n    ]\r\n  },\r\n  &quot;Settings&quot;: {\r\n    &quot;DataServerUrl&quot;: &quot;https://dev.server.addr.com&quot;,\r\n    &quot;ServerKey&quot;: &quot;2a4d99233efea456b95114aa23ed342ae&quot;\r\n  }\r\n}\r\n```",
                "title": "Integrate json values into another file"
            },
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1652977736,
                "creation_date": 1652977736,
                "answer_id": 72308063,
                "question_id": 72307114,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The simplest way is to provide both files and address the second one using `input`. That way, all you need is the assignment:\r\n~~~sh\r\njq &#39;.Settings = input&#39; settings.json insert.json\r\n~~~\r\n~~~json\r\n{\r\n  &quot;Logging&quot;: {\r\n    &quot;MinimumLevel&quot;: {\r\n      &quot;Default&quot;: &quot;Information&quot;,\r\n      &quot;Override&quot;: &quot;Warning&quot;\r\n    },\r\n    &quot;WriteTo&quot;: [\r\n      {\r\n        &quot;Name&quot;: &quot;File&quot;,\r\n        &quot;Args&quot;: {\r\n          &quot;path&quot;: &quot;./logs/log-.txt&quot;,\r\n          &quot;rollingInterval&quot;: &quot;Day&quot;\r\n        }\r\n      }\r\n    ]\r\n  },\r\n  &quot;Settings&quot;: {\r\n    &quot;DataServerUrl&quot;: &quot;https://dev.server.addr.com&quot;,\r\n    &quot;ServerKey&quot;: &quot;2a4d99233efea456b95114aa23ed342ae&quot;\r\n  }\r\n}\r\n~~~\r\n[Demo](https://jqplay.org/s/7mlsvIi5YTb)",
                "title": "Integrate json values into another file"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1652977736,
        "creation_date": 1652973467,
        "question_id": 72307114,
        "body_markdown": "I&#39;m trying to update an existing json file from values in another json file using jq in a bash shell.\r\n\r\nI&#39;ve got a settings json file\r\n\r\n````\r\n{\r\n  &quot;Logging&quot;: {\r\n    &quot;MinimumLevel&quot;: {\r\n      &quot;Default&quot;: &quot;Information&quot;,\r\n      &quot;Override&quot;: &quot;Warning&quot;\r\n    },\r\n    &quot;WriteTo&quot;: [\r\n      {\r\n        &quot;Name&quot;: &quot;File&quot;,\r\n        &quot;Args&quot;: {\r\n          &quot;path&quot;: &quot;./logs/log-.txt&quot;,\r\n          &quot;rollingInterval&quot;: &quot;Day&quot;\r\n        }\r\n      }\r\n    ]\r\n  },\r\n  &quot;Settings&quot;: {\r\n    &quot;DataServerUrl&quot;: &quot;https://address.to.server.com&quot;,\r\n    &quot;ServerKey&quot;: &quot;1f969476798adfe95114dd28ed3a3ff&quot;\r\n    &quot;ServerTimeZone&quot;: &quot;Mountain Standard Time&quot;,\r\n    &quot;MaxOccupantCount&quot;: 6\r\n  }\r\n}\r\n````\r\n\r\nIn an integration step, I&#39;m attempting to incorporate values for specific environments (think dev/staging/prod) from an external json file with limited setting values. An example of such a file is\r\n\r\n````\r\n{\r\n    &quot;DataServerUrl&quot;: &quot;https://dev.server.addr.com&quot;,\r\n    &quot;ServerKey&quot;: &quot;2a4d99233efea456b95114aa23ed342ae&quot;\r\n}\r\n````\r\n\r\nI can get to the data using jq. I can update the data using jq if I hard-code the updates. I&#39;m looking for something general to take in any environment settings values and update them in the base settings file. My searches suggest I can do this in a single step without knowing the specific values. A command similar to\r\n\r\n````\r\njq -r &#39;to_entries[]&#39; settings.dev.json |\r\n  while IFS= read -r key value; do\r\n    jq -r &#39;.[$key] |= [$value]&#39; settings.json\r\n  done\r\n````\r\n\r\nWhat happens is I get error messages stating ````jq: error: $key is not defined at &lt;top-level&gt;```` (as well as the same message for $value). The messages appear several times in pairs. settings.json is not changed. Now, this makes partial sense because the output from just ````jq -r &#39;to_entries[]&#39; settings.dev.json```` looks like (empty space in this output is included as produced by the command).\r\n\r\n````\r\n \r\n  &quot;key&quot;: &quot;DataServerUrl&quot;,\r\n  &quot;value&quot;: &quot;https://dev.server.addr.com&quot;\r\n\r\n\r\n  &quot;key&quot;: &quot;ServerKey&quot;,\r\n  &quot;value&quot;: &quot;2a4d99233efea456b95114aa23ed342ae&quot;\r\n\r\n\r\n````\r\n\r\nHow do I go about iterating over the values in the environment settings file such that I can use those values to update the base settings file for further processing (i.e., publishing to the target environment)?",
        "link": "https://stackoverflow.com/questions/72307114/integrate-json-values-into-another-file",
        "title": "Integrate json values into another file"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1653026252,
                "creation_date": 1653026252,
                "answer_id": 72314170,
                "question_id": 72314169,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The solution was to use `cat file.json | jq -c .` (note the dot that&#39;s added) in AWS.\r\n\r\nAfter some experimenting, I found out that this happens only in jq 1.5 (I had jq 1.6 locally), and only when using `jq -c` instead of `jq -c .` in a detached terminal. My AWS pipeline uses jq 1.5.\r\n\r\nI reproduced it locally by downloading jq 1.5 and running:\r\n\r\n    $ cat input.json | ./jq1.5 -c &gt;output.txt &amp;\r\n    [1] 822\r\n    jq - commandline JSON processor [version 1.5]\r\n    Usage: C:\\Workspace\\jq\\jq1.5.exe [options] &lt;jq filter&gt; [file...]\r\n\r\nNote that the ampersand executes it in the background which simulates a detached terminal.\r\n\r\nWhat works:\r\n\r\n    cat input.json | ./jq1.6 -c &gt;output.txt &amp;\r\n    cat input.json | ./jq1.5 -c . &gt;output.txt &amp;\r\n    cat input.json | ./jq1.5 -c &gt;output.txt\r\n\r\nTo sum up, if using jq1.5 in a detached terminal, also use the dot.\r\n\r\n",
                "title": "jq -c fails in AWS pipeline"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1653059773,
                "creation_date": 1653059773,
                "answer_id": 72321268,
                "question_id": 72314169,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "That&#39;s not the right question. `jq -c` (with no further argument) *should* fail. According to the very output you obtained from `jq`,  `jq` always requires at least one argument: a program.&lt;sup&gt;[1]&lt;/sup&gt; That fact that it sometimes doesn&#39;t fail when no program is provided is a bug. One that appears to have been fixed in 1.6.&lt;sup&gt;[2]&lt;/sup&gt;\r\n\r\nIf you simply want to reformat the JSON, you can use the trivial program `.`.\r\n\r\n```sh\r\ncat input.json | jq -c .\r\n```\r\n\r\nIf the input really is a file, the following is better:\r\n\r\n```sh\r\njq -c . input.json\r\n```\r\n\r\n---\r\n\r\n1. Or the name of a file containing the program if `-f` is used. \r\n2. Meaning I wasn&#39;t able to reproduce the lack of error in 1.6 after trying using Windows, Cygwin and Ubuntu builds.\r\n",
                "title": "jq -c fails in AWS pipeline"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1653059773,
        "creation_date": 1653026252,
        "question_id": 72314169,
        "body_markdown": "I use `cat file.json | jq -c` to print out a minified json file in the logs in an AWS pipeline step. I&#39;ve tested that it works locally but in the pipeline it fails and prints out the system usage:\r\n\r\n    jq - commandline JSON processor [version 1.5]\r\n    Usage: jq [options] &lt;jq filter&gt; [file...]\r\n    \r\n    ...\r\n    \r\nWhy does it fail in the pipeline but not locally?",
        "link": "https://stackoverflow.com/questions/72314169/jq-c-fails-in-aws-pipeline",
        "title": "jq -c fails in AWS pipeline"
    },
    {
        "tags": [
            "jq",
            "xargs"
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1653074758,
                "last_edit_date": 1653074758,
                "creation_date": 1653073814,
                "answer_id": 72323800,
                "question_id": 72323773,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The second `[]` will bring you down to the elements you want to align. Omit it (but keep the first, as you want to access the elements of the `.prices` array), and format that array. You can, for instance, have the items tab-separated by using `@tsv`. Alternatively, you can use the `join` function with a separator string.\r\n~~~sh\r\ncurl … | jq -r &#39;.prices[] | @tsv&#39;\r\n~~~\r\n~~~json\r\n1652227200000\t2344.797715643986\r\n1652313600000\t2080.910243657776\r\n1652400000000\t1966.6991711336661\r\n1652486400000\t2010.214051125259\r\n1652572800000\t2064.229357512243\r\n1652659200000\t2147.047447880575\r\n1652745600000\t2025.8886983912162\r\n1652832000000\t2095.178884796724\r\n1652918400000\t1915.1771232664505\r\n1653004800000\t2023.8482593608173\r\n1653073654000\t1942.3670724677067\r\n~~~\r\n[Demo](https://jqplay.org/s/EcJZTa67Noh)\r\n\r\n~~~sh\r\ncurl … | jq -r &#39;.prices[] | join(&quot; | &quot;)&#39;\r\n~~~\r\n~~~json\r\n1652227200000 | 2344.797715643986\r\n1652313600000 | 2080.910243657776\r\n1652400000000 | 1966.6991711336661\r\n1652486400000 | 2010.214051125259\r\n1652572800000 | 2064.229357512243\r\n1652659200000 | 2147.047447880575\r\n1652745600000 | 2025.8886983912162\r\n1652832000000 | 2095.178884796724\r\n1652918400000 | 1915.1771232664505\r\n1653004800000 | 2023.8482593608173\r\n1653073654000 | 1942.3670724677067\r\n~~~\r\n[Demo](https://jqplay.org/s/7jW16LRuPC6)\r\n\r\n---\r\n\r\nTo format the milliseconds column, convert it to seconds (divide by 1000), then use `strftime` (or `strflocaltime` for local time) with a format string. To round the price column to two decimals, multiply it by 100, use `round` and divide again.\r\n\r\n~~~sh\r\ncurl … | jq -r &#39;.prices[]\r\n  | .[0] |= (./1000 | strftime(&quot;%d-%m-%Y&quot;))\r\n  | .[1] |= (. * 100 | round / 100)\r\n  | @tsv\r\n&#39;\r\n~~~\r\n~~~json\r\n11-05-2022\t2344.8\r\n12-05-2022\t2080.91\r\n13-05-2022\t1966.7\r\n14-05-2022\t2010.21\r\n15-05-2022\t2064.23\r\n16-05-2022\t2147.05\r\n17-05-2022\t2025.89\r\n18-05-2022\t2095.18\r\n19-05-2022\t1915.18\r\n20-05-2022\t2023.85\r\n20-05-2022\t1942.37\r\n~~~\r\n[Demo](https://jqplay.org/s/lkE3h1qXBY0)",
                "title": "How to join two fields in JSON array with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1653074758,
        "creation_date": 1653073662,
        "question_id": 72323773,
        "body_markdown": "I&#39;m trying to get output in one line for 2 fields in the array using &#39;jq&#39;&lt;br&gt;\r\n\r\n    curl -X &#39;GET&#39; &quot;https://api.coingecko.com/api/v3/coins/ethereum/market_chart?vs_currency=USD&amp;days=10&amp;interval=daily&quot; -H &#39;accept: application/json&#39;|jq &#39;.prices[][]\r\ngives me output like this:\r\n\r\n    1652227200000\r\n    2344.797715643986\r\n    1652313600000\r\n    2080.910243657776\r\n    1652400000000\r\n    1966.6991711336661\r\n    1652486400000\r\n    2010.214051125259\r\n    1652572800000\r\n    2064.229357512243\r\n    1652659200000\r\n    2147.047447880575\r\n    1652745600000\r\n    2025.8886983912162\r\n    1652832000000\r\n    2095.178884796724\r\n    1652918400000\r\n    1915.1771232664505\r\n    1653004800000\r\n    2023.8482593608173\r\n    1653070323000\r\n    1931.3963167096579\r\n\r\nand I would like output to have date price (in one line) with space or tab in between like\r\n\r\n    1653004800000    2023.8482593608173\r\n    1653070323000    1931.3963167096579\r\n\r\nI&#39;ve tried with `&#39;.price[][]|join(&quot; &quot;)&#39;` but it didn&#39;t work.\r\npossibly also format price to have 2 decimal places.  I was able to do it if I output only price like: \r\n\r\n    ...|jq .price[][1]| xargs printf &quot;%&#39;.2f\\n&quot;\r\nnot sure how to do it if I have 2 values. \r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/72323773/how-to-join-two-fields-in-json-array-with-jq",
        "title": "How to join two fields in JSON array with jq"
    },
    {
        "tags": [
            "github",
            "graphql",
            "jq",
            "github-actions"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1653145926,
                "creation_date": 1653145926,
                "answer_id": 72330796,
                "question_id": 72324237,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "This is a GitHub token permission issue ",
                "title": "Using GraphQL in a GitHub Action does not return anything for `requiredApprovingReviewCount`"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": -1,
        "last_activity_date": 1653145926,
        "creation_date": 1653076703,
        "question_id": 72324237,
        "body_markdown": "I am writing a GitHub Action to try and automate our (beta) project board. I need to take into account the number of required reviews before I move the issue or PR into the `Approved` column.\r\n\r\nIn trying to get the count of required reviews it always returns nothing. I have run this exact query in the [GitHub GraphQL Explorer][1] and also checked my jq query in this [JQ Play snippet][2]. These both return the correct value (in my test case this is `1`).\r\n\r\nHowever when moving this to a GitHub Action it returns: `REVIEW_REQUIRED_COUNT= `\r\n\r\nMy expected output is: `REVIEW_REQUIRED_COUNT= 1`\r\n\r\nI have also tried to play around with the GITHUB_TOKEN permissions, as I think this could be the error but to no avail, I have hit a brick wall - please can someone help?\r\n\r\n```\r\n---\r\n\r\nname: MY ACTION\r\n\r\n&quot;on&quot;:\r\n  pull_request:\r\n    branches: [develop, master]\r\n\r\nenv:\r\n  PR_URL: ${{ github.event.pull_request.html_url }}\r\n  GITHUB_TOKEN: ${{ secrets.MY_GITHUB_TOKEN }}\r\n\r\njobs:\r\n    my-job:\r\n      name: My Job \r\n      runs-on: ubuntu-latest\r\n      permissions: read-all\r\n      steps:\r\n        - name: Get req review count\r\n          id: review-count\r\n          run: |\r\n            gh api graphql -f query=&#39;\r\n              query($pr_url: URI!) {\r\n                resource(url: $pr_url) {\r\n                  ... on PullRequest {\r\n                    baseRepository {\r\n                      branchProtectionRules(first: 1) {\r\n                        nodes {\r\n                          requiredApprovingReviewCount\r\n                        }\r\n                      }\r\n                    }\r\n                  }\r\n                }\r\n              }&#39;  -f pr_url=$PR_URL &gt; data.json\r\n            echo &#39;REVIEW_REQUIRED_COUNT=&#39;$(jq &#39;.data.resource.baseRepository.branchProtectionRules.nodes[] | .requiredApprovingReviewCount&#39; data.json) &gt;&gt; $GITHUB_ENV\r\n\r\n        - run: env\r\n\r\n```\r\n\r\n  [1]: https://docs.github.com/en/graphql/overview/explorer\r\n  [2]: https://jqplay.org/s/QISpYx7_VBs",
        "link": "https://stackoverflow.com/questions/72324237/using-graphql-in-a-github-action-does-not-return-anything-for-requiredapproving",
        "title": "Using GraphQL in a GitHub Action does not return anything for `requiredApprovingReviewCount`"
    },
    {
        "tags": [
            "json",
            "linux",
            "bash",
            "jq",
            "xargs"
        ],
        "comments": [
            {
                "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": 1,
                "creation_date": 1653078281,
                "post_id": 72324366,
                "comment_id": 127772135,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 9629731,
                    "reputation": 51350,
                    "user_id": 10248678,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d8f818402f22d485b135a3b685ef908e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "oguz ismail",
                    "link": "https://stackoverflow.com/users/10248678/oguz-ismail"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1653078502,
                "post_id": 72324366,
                "comment_id": 127772189,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 8531407,
                    "reputation": 1305,
                    "user_id": 6394941,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://lh6.googleusercontent.com/-c87IOIWr0QU/AAAAAAAAAAI/AAAAAAAAB-g/i2VM2saO040/s256-rj/photo.jpg",
                    "display_name": "Guido Muscioni",
                    "link": "https://stackoverflow.com/users/6394941/guido-muscioni"
                },
                "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": 1653078674,
                "post_id": 72324366,
                "comment_id": 127772228,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 8340816,
                    "reputation": 1,
                    "user_id": 6266192,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/94cb40bd8ab263ab93628c8823a54ded?s=256&d=identicon&r=PG",
                    "display_name": "Dudi Boy",
                    "link": "https://stackoverflow.com/users/6266192/dudi-boy"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1653080743,
                "post_id": 72324366,
                "comment_id": 127772726,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1653081914,
                "creation_date": 1653081914,
                "answer_id": 72324923,
                "question_id": 72324366,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "As commented by @Fravadona:\r\n\r\n&gt;\r\n&gt;&gt;&quot;the | in unix, it takes the output of the first command and sends it to the second so STDIN will contain all of the lines&quot; \r\n\r\n&gt;No, the commands in a pipe run in parallel; each command might do a little buffering internally for optimizing IO though.\r\n\r\nSo the indicated command has the expected behavior.",
                "title": "Iteratively split output of a stream in stdin"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1653081914,
        "creation_date": 1653077617,
        "last_edit_date": 1653080676,
        "question_id": 72324366,
        "body_markdown": "I have a large JSON file that I am streaming with `jq`. \r\n\r\nThis can be used as a test file:\r\n```\r\n{\r\n    &quot;a&quot;: &quot;some&quot;,\r\n    &quot;b&quot;: [\r\n        {\r\n            &quot;d&quot;: &quot;some&quot;\r\n        },\r\n        {\r\n            &quot;d&quot;: &quot;some&quot;\r\n        },\r\n        {\r\n            &quot;d&quot;: &quot;some&quot;\r\n        },\r\n        {\r\n            &quot;d&quot;: &quot;some&quot;\r\n        },\r\n        {\r\n            &quot;d&quot;: &quot;some&quot;\r\n        },\r\n        {\r\n            &quot;d&quot;: &quot;some&quot;\r\n        },\r\n        {\r\n            &quot;d&quot;: &quot;some&quot;\r\n        },\r\n        {\r\n            &quot;d&quot;: &quot;some&quot;\r\n        },\r\n        {\r\n            &quot;d&quot;: &quot;some&quot;\r\n        },\r\n        {\r\n            &quot;d&quot;: &quot;some&quot;\r\n        }\r\n    ]\r\n}\r\n```\r\n\r\nI am trying to save separate files once a defined number of lines has been provided in STDIN. Multiple answers (\r\n\r\nhttps://stackoverflow.com/questions/19031144/how-can-i-split-one-text-file-into-multiple-txt-files, \r\n\r\nhttps://stackoverflow.com/questions/2016894/how-can-i-split-a-large-text-file-into-smaller-files-with-an-equal-number-of-lin, \r\n\r\nhttps://stackoverflow.com/questions/49808581/using-jq-how-can-i-split-a-very-large-json-file-into-multiple-files-each-a-spec, \r\n\r\nhttps://stackoverflow.com/questions/40385830/split-a-json-array-into-multiple-files-using-command-line-tools) \r\n\r\nsuggest the use of `split` piped to the initial command.\r\n\r\n```\r\njq -c --stream &#39;fromstream(0|truncate_stream(inputs|select(.[0][0]==&quot;b&quot;)| del(.[0][0:2])))&#39; ex.json | split -l 4 --numeric-suffixes=1 - part_ --additional-suffix=.json\r\n```\r\n\r\nThis works, however, based on my knowledge of the `|` in unix, it takes the output of the first command and sends it to the second so STDIN will contain all of the lines (making the stream useless, although STDIN will likely not go out of memory as it can be saved on disk). \r\n\r\nI have read that `xargs` can send a predefined number of lines to a command, so I tried this:\r\n```\r\njq -c --stream &#39;fromstream(0|truncate_stream(inputs|select(.[0][0]==&quot;b&quot;)| del(.[0][0:2])))&#39; ex.json | xargs -I -l5 split -l 4 --numeric-suffixes=1 - part_ --additional-suffix=.json\r\n```\r\n\r\nHowever, no output is generate, plus the `|` is still there so I am assuming I would get the same behavior. In addition, I believe split will overwrite the previously created files as it would be a new invocation. \r\n\r\nDoes anyone have any advice? Am I missing something in my `unix` terminal knowledge?\r\n\r\n(This question https://stackoverflow.com/questions/7161821/how-to-grep-a-continuous-stream lists how to grep a continuous stream using the `--line-buffered` approach, is there an equivalent for split?)",
        "link": "https://stackoverflow.com/questions/72324366/iteratively-split-output-of-a-stream-in-stdin",
        "title": "Iteratively split output of a stream in stdin"
    },
    {
        "tags": [
            "arrays",
            "json",
            "bash",
            "scripting",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1653255436,
                "last_edit_date": 1653255436,
                "creation_date": 1653255077,
                "answer_id": 72341420,
                "question_id": 72341360,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Depending on what level you can expect your search value, here&#39;s a quite narrow solution using all keys from the example: First, iterate over the `.response` array, then keep only those items for which `any` of the values in `.sources[].sample_retrieve_cmd` `contains` the given string, then output the value of `.piece_cid` as raw text using `-r`.\r\n~~~sh\r\nCAR=&quot;baga6e~tlwdcmli__QmbHKa~G65fMXzh.car&quot;\r\njq -r --arg car &quot;$CAR&quot; &#39;\r\n  .response[]\r\n  | select(any(.sources[].sample_retrieve_cmd; contains($car)))\r\n  | .piece_cid\r\n&#39;\r\n~~~\r\n~~~json\r\nbaga6ea4seaqa24ucggxkliw4la4tkgvhevv3dacavovghsmnnscclt4tlwdcmli\r\n~~~\r\n[Demo](https://jqplay.org/s/kxcYylMx45i)\r\n\r\n---\r\nEdit: To save the output into a variable just wrap the `jq` call as command substitution `$()` and assign the result to your variable:\r\n~~~sh\r\nPIECE_CID=&quot;$(jq -r --arg …)&quot;\r\n~~~\r\nBut keep in mind that (theoretically) more than one match could be present, which the solution from above would print out linewise (giving you a newline-delimited list of results in your bash variable).\r\n\r\nNote: Avoid using uppercase variable names in Bash.",
                "title": "How to search json for a string and output a parent value using jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1653255436,
        "creation_date": 1653254437,
        "last_edit_date": 1653255044,
        "question_id": 72341360,
        "body_markdown": "Trying to pull a value out with jq, but didn&#39;t seem as easy as i originally thought.\r\n\r\nI have a variable of `CAR=&quot;baga6e~tlwdcmli__QmbHKa~G65fMXzh.car&quot;`.\r\n\r\nHow can i use this variable to return the parent `&quot;piece_cid&quot;` ?\r\n\r\n**Example:** Using a bash varible of `$CAR` with a value of `baga6e~tlwdcmli__QmbHKa~G65fMXzh.car`, id be able to get the results saved to `$PIECE_CID` with a value of `baga6ea4seaqa24ucggxkliw4la4tkgvhevv3dacavovghsmnnscclt4tlwdcmli`\r\n\r\n\r\n\r\nI tried some commands and been googling for about 2 hours but nothing has came up for what im seeking. Completely new to jq. Hopefully someone can push me in right direction?\r\n\r\n```\r\n{\r\n  &quot;response_code&quot;: 200,\r\n  &quot;response_entries&quot;: 2,\r\n  &quot;response&quot;: [\r\n    {\r\n      &quot;piece_cid&quot;: &quot;baga6ea4seaqa24ucggxkliw4la4tkgvhevv3dacavovghsmnnscclt4tlwdcmli&quot;,\r\n      &quot;dataset&quot;: &quot;genome-ark&quot;,\r\n      &quot;padded_piece_size&quot;: 34359738368,\r\n      &quot;payload_cids&quot;: [\r\n        &quot;QmbHKaq6z321PqEG1BVLEAMpapq6YjkhdXpcs3G65fMXzh&quot;\r\n      ],\r\n      &quot;sources&quot;: [\r\n        {\r\n          &quot;source_type&quot;: &quot;Filecoin&quot;,\r\n          &quot;provider_id&quot;: &quot;f0402371&quot;,\r\n          &quot;deal_id&quot;: 1928414,\r\n          &quot;original_payload_cid&quot;: &quot;QmbHKaq6z321PqEG1BVLEAMpapq6YjkhdXpcs3G65fMXzh&quot;,\r\n          &quot;deal_expiration&quot;: &quot;2022-05-22T21:14:30Z&quot;,\r\n          &quot;is_filplus&quot;: false,\r\n          &quot;sector_id&quot;: null,\r\n          &quot;sector_expires&quot;: null,\r\n          &quot;sample_retrieve_cmd&quot;: &quot;lotus client retrieve --provider f0402371 --maxPrice 0 --allow-local --car &#39;QmbHKaq6z321PqEG1BVLEAMpapq6YjkhdXpcs3G65fMXzh&#39; $(pwd)/baga6e~tlwdcmli__QmbHKa~G65fMXzh.car&quot;\r\n        }\r\n      ],\r\n      &quot;sample_request_cmd&quot;: &quot;echo curl -sLH \\&quot;Authorization: $( ./fil-spid.bash f01826669 )\\&quot; https://api.evergreen.filecoin.io/request_piece/baga6ea4seaqa24ucggxkliw4la4tkgvhevv3dacavovghsmnnscclt4tlwdcmli | sh&quot;\r\n    },\r\n    {\r\n      &quot;piece_cid&quot;: &quot;baga6ea4seaqa2acwhwril5pm6n4muqlsrdkk27cgrqowz67himgbcwc3jhitina&quot;,\r\n      &quot;dataset&quot;: &quot;genome-ark&quot;,\r\n      &quot;padded_piece_size&quot;: 34359738368,\r\n      &quot;payload_cids&quot;: [\r\n        &quot;QmSJc7g8sdUZKt2MqSDnrd1DXxxHow6XwKQZLcoCoCeW42&quot;\r\n      ],\r\n      &quot;sources&quot;: [\r\n        {\r\n          &quot;source_type&quot;: &quot;Filecoin&quot;,\r\n          &quot;provider_id&quot;: &quot;f0402371&quot;,\r\n          &quot;deal_id&quot;: 1927852,\r\n          &quot;original_payload_cid&quot;: &quot;QmSJc7g8sdUZKt2MqSDnrd1DXxxHow6XwKQZLcoCoCeW42&quot;,\r\n          &quot;deal_expiration&quot;: &quot;2022-05-22T20:11:00Z&quot;,\r\n          &quot;is_filplus&quot;: false,\r\n          &quot;sector_id&quot;: null,\r\n          &quot;sector_expires&quot;: null,\r\n          &quot;sample_retrieve_cmd&quot;: &quot;lotus client retrieve --provider f0402371 --maxPrice 0 --allow-local --car &#39;QmSJc7g8sdUZKt2MqSDnrd1DXxxHow6XwKQZLcoCoCeW42&#39; $(pwd)/baga6e~3jhitina__QmSJc7~oCoCeW42.car&quot;\r\n        }\r\n      ],\r\n      &quot;sample_request_cmd&quot;: &quot;echo curl -sLH \\&quot;Authorization: $( ./fil-spid.bash f01826669 )\\&quot; https://api.evergreen.filecoin.io/request_piece/baga6ea4seaqa2acwhwril5pm6n4muqlsrdkk27cgrqowz67himgbcwc3jhitina | sh&quot;\r\n    }\r\n  ]\r\n}\r\n```",
        "link": "https://stackoverflow.com/questions/72341360/how-to-search-json-for-a-string-and-output-a-parent-value-using-jq",
        "title": "How to search json for a string and output a parent value using jq?"
    },
    {
        "tags": [
            "amazon-web-services",
            "yaml",
            "jq",
            "wildcard",
            "yq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1653386352,
                "creation_date": 1653386352,
                "answer_id": 72360892,
                "question_id": 72360274,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Have you tried using the object iterator `[]`?\r\n~~~sh\r\nyq &#39;.Resources[].Properties.Name&#39; cft/*.yaml\r\n~~~\r\n",
                "title": "Using a wildcard in nested YAML value"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1653386352,
        "creation_date": 1653383825,
        "last_edit_date": 1653383907,
        "question_id": 72360274,
        "body_markdown": "I need to retrieve a value from a yaml which I&#39;m currently using yq for, like this: \r\n\r\n    yq &#39;.Resources.TestGlueJob.Properties.Name&#39; cft/*.yaml\r\n\r\nwhere TestGlueJob can have different values. So I&#39;m trying to use a wildcard like this, but that is giving me null as return value:\r\n\r\n    yq &#39;.Resources.*.Properties.Name&#39; cft/*.yaml\r\n",
        "link": "https://stackoverflow.com/questions/72360274/using-a-wildcard-in-nested-yaml-value",
        "title": "Using a wildcard in nested YAML value"
    },
    {
        "tags": [
            "json",
            "jq",
            "pii"
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1653435074,
                "last_edit_date": 1653435074,
                "creation_date": 1653433147,
                "answer_id": 72370301,
                "question_id": 72369864,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Using a user function for *picking* specific paths from a JSON:\r\n``` none\r\ndef pick(paths):\r\n  . as $in\r\n  | reduce path(paths) as $path (null;\r\n    setpath($path; $in | getpath($path))\r\n  );\r\npick(.customers[] | .id, .preferences[].&quot;preference-id&quot;)\r\n```\r\n&lt;sup&gt;[Online demo](https://jqplay.org/s/5H3HeQPe3wk)&lt;/sup&gt;",
                "title": "How to retain only a set of specified fields in a complex JSON object?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1653435074,
        "creation_date": 1653429143,
        "last_edit_date": 1653433757,
        "question_id": 72369864,
        "body_markdown": "**Summary:**\r\n\r\nI need to filter PII data from a complex JSON object ***in one-pass*** with JQ.  I&#39;m not in scripting where deconstruct and/or multi-pass.  I want to retain non-PII properties rather than remove PII properties because I want to avoid a PII leakage exposure if the backend adds a new PII property and doesn&#39;t let me know.  \r\n\r\nIn simple cases, I can easily &quot;reconstruct&quot; the desired JSON object from the input object like this:\r\n\r\n    {\r\n     &quot;data&quot;: {\r\n       &quot;id&quot;: &quot;123&quot;,\r\n       &quot;pii&quot;: &quot;sensitve&quot;\r\n     }\r\n     &quot;return-code&quot;: 200\r\n    }\r\n\r\n```jq &#39;{data: {id: .data.id }, return-code: .return-code}&#39;```\r\n\r\nOnce arrays are added to the mix, I&#39;m not seeing how to use this approach to solve this problem.\r\n\r\n**Simplified Example of the Complex Object**\r\n\r\nInput:\r\n\r\n    {\r\n      &quot;customers&quot;: [\r\n        {\r\n          &quot;id&quot;: &quot;00000000001&quot;,\r\n          &quot;dateOfBirth&quot;: &quot;sensitive DOB&quot;,\r\n          &quot;preferences&quot;: [\r\n            {\r\n              &quot;preference-id&quot;: &quot;0001&quot;,\r\n              &quot;pii-value&quot;: &quot;senstive value 1&quot;\r\n            },\r\n            {\r\n              &quot;preference-id&quot;: &quot;0002&quot;,\r\n              &quot;pii-value&quot;: &quot;senstive value 2&quot;\r\n            }\r\n          ]\r\n        },\r\n        {\r\n          &quot;id&quot;: &quot;00000000002&quot;,\r\n          &quot;dateOfBirth&quot;: &quot;sensitive DOB&quot;,\r\n          &quot;preferences&quot;: [\r\n            {\r\n              &quot;preference-id&quot;: &quot;0003&quot;,\r\n              &quot;pii-value&quot;: &quot;senstive value 3&quot;\r\n            },\r\n            {\r\n              &quot;preference-id&quot;: &quot;0004&quot;,\r\n              &quot;pii-value&quot;: &quot;senstive value 4&quot;\r\n            }\r\n          ]\r\n        }\r\n      ]\r\n    }\r\n\r\n**Desired Output:**\r\n\r\n    {\r\n      &quot;customers&quot;: [\r\n        {\r\n          &quot;id&quot;: &quot;00000000001&quot;,\r\n          &quot;preferences&quot;: [\r\n            {\r\n              &quot;preference-id&quot;: &quot;0001&quot;\r\n            },\r\n            {\r\n              &quot;preference-id&quot;: &quot;0002&quot;\r\n            }\r\n          ]\r\n        },\r\n        {\r\n          &quot;id&quot;: &quot;00000000002&quot;,\r\n          &quot;preferences&quot;: [\r\n            {\r\n              &quot;preference-id&quot;: &quot;0003&quot;\r\n            },\r\n            {\r\n              &quot;preference-id&quot;: &quot;0004&quot;\r\n            }\r\n          ]\r\n        }\r\n      ]\r\n    }\r\n\r\n**Attempted Approach with Arrays:**\r\n\r\n```jq &#39;{ customers: [ { id: .customers[].id, preferences: [ .customers[].preferences ] } ]}&#39;```\r\n\r\nResult starts pulling together permutations across different customers\r\n\r\n    {\r\n      &quot;customers&quot;: [\r\n        {\r\n          &quot;id&quot;: &quot;00000000001&quot;,\r\n          &quot;preferences&quot;: [\r\n            [\r\n              {\r\n                &quot;preference-id&quot;: &quot;0001&quot;,\r\n                &quot;pii-value&quot;: &quot;senstive value 1&quot;\r\n              },\r\n              {\r\n                &quot;preference-id&quot;: &quot;0002&quot;,\r\n                &quot;pii-value&quot;: &quot;senstive value 2&quot;\r\n              }\r\n            ],\r\n            [\r\n              {\r\n                &quot;preference-id&quot;: &quot;0003&quot;,\r\n                &quot;pii-value&quot;: &quot;senstive value 3&quot;\r\n              },\r\n              {\r\n                &quot;preference-id&quot;: &quot;0004&quot;,\r\n                &quot;pii-value&quot;: &quot;senstive value 4&quot;\r\n              }\r\n            ]\r\n          ]\r\n        },\r\n        {\r\n          &quot;id&quot;: &quot;00000000002&quot;,\r\n          &quot;preferences&quot;: [\r\n            [\r\n              {\r\n                &quot;preference-id&quot;: &quot;0001&quot;,\r\n                &quot;pii-value&quot;: &quot;senstive value 1&quot;\r\n              },\r\n              {\r\n                &quot;preference-id&quot;: &quot;0002&quot;,\r\n                &quot;pii-value&quot;: &quot;senstive value 2&quot;\r\n              }\r\n            ],\r\n            [\r\n              {\r\n                &quot;preference-id&quot;: &quot;0003&quot;,\r\n                &quot;pii-value&quot;: &quot;senstive value 3&quot;\r\n              },\r\n              {\r\n                &quot;preference-id&quot;: &quot;0004&quot;,\r\n                &quot;pii-value&quot;: &quot;senstive value 4&quot;\r\n              }\r\n            ]\r\n          ]\r\n        }\r\n      ]\r\n    }\r\n\r\nI really don&#39;t think this approach will work at all and I&#39;m at a loss for other approaches.  This is a simplified example, the actual JSON is quite large with many arrays at various nested levels.\r\n\r\nAny suggestions for what approach I might investigate?  \r\n",
        "link": "https://stackoverflow.com/questions/72369864/how-to-retain-only-a-set-of-specified-fields-in-a-complex-json-object",
        "title": "How to retain only a set of specified fields in a complex JSON object?"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1653692554,
                "post_id": 72411746,
                "comment_id": 127920878,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1653702521,
                "creation_date": 1653702521,
                "answer_id": 72412365,
                "question_id": 72411746,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "To sort, you need an array, which you can obtain using `--slurp`/`-s`.\r\n\r\n```sh\r\njq -sc &#39;sort_by( .foo )[]&#39; input.log\r\n```\r\n\r\n[Demo](https://jqplay.org/s/BHxDP19jvdD) on jqplay",
                "title": "jq transform to array and sort"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1655107895,
        "creation_date": 1653692216,
        "last_edit_date": 1655107895,
        "question_id": 72411746,
        "body_markdown": "Suppose I have the following input.log file:\r\n\r\n    {&quot;foo&quot;: &quot;1&quot;, &quot;foo2&quot;: &quot;2&quot;}\r\n    {&quot;foo&quot;: &quot;3&quot;, &quot;foo2&quot;: &quot;4&quot;}\r\n    {&quot;foo&quot;: &quot;5&quot;, &quot;foo2&quot;: &quot;6&quot;}\r\n    {&quot;foo&quot;: &quot;7&quot;, &quot;foo2&quot;: &quot;8&quot;}\r\n\r\nI want to parse this using **jq** and sort the result based on the value of some common key, lets say the **&quot;foo&quot;** key. \r\n\r\nHow could I accomplish that?",
        "link": "https://stackoverflow.com/questions/72411746/jq-transform-to-array-and-sort",
        "title": "jq transform to array and sort"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1653745316,
                "creation_date": 1653745316,
                "answer_id": 72416162,
                "question_id": 72415703,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "It&#39;s easier to reconstruct `chapters` than update.\r\n```\r\n[.book + {price} + .chapters[]]\r\n```\r\n&lt;sup&gt;[Online demo](https://jqplay.org/s/IC0pEGIuvIr)&lt;/sup&gt;",
                "title": "Prepending an already existing field to every element of an array in JSON"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1653777265,
        "creation_date": 1653740870,
        "last_edit_date": 1653777265,
        "question_id": 72415703,
        "body_markdown": "I am trying to transform JSON data using JQ in Windows CLI. The data is in the form.\r\n\r\n```\r\n{\r\n  &quot;book&quot;: {\r\n     &quot;title&quot;: &quot;Some title&quot;,\r\n     &quot;subtitle&quot;: &quot;Some subtitle&quot;\r\n    },\r\n  &quot;price&quot;: &quot;&#163;19.99&quot;,\r\n  &quot;chapters&quot;: [\r\n    {\r\n      &quot;Chapter_no&quot;: &quot;1&quot;,\r\n      &quot;chapter_title&quot;:&quot;foo&quot;\r\n      },\r\n    {\r\n      &quot;Chapter_no&quot;: &quot;2&quot;,\r\n      &quot;chapter_title&quot;: &quot;bar&quot;\r\n      },\r\n    {\r\n      &quot;Chapter_no&quot;: &quot;3&quot;,\r\n      &quot;chapter_title&quot;: &quot;foobar&quot;\r\n      }\r\n    {\r\n      &quot;Chapter_no&quot;: &quot;4&quot;,\r\n      &quot;chapter_title&quot;: &quot;fooandbar&quot;\r\n    }\r\n  ]\r\n}\r\n```\r\n\r\nI am trying to transform the data to the form.\r\n```json\r\n[\r\n {\r\n   &quot;title&quot;: &quot;Some title&quot;,\r\n   &quot;subtitle&quot;: &quot;Some subtitle&quot;\r\n   &quot;price&quot;: &quot;&#163;19.99&quot;,\r\n   &quot;Chapter_no&quot;: &quot;1&quot;,\r\n   &quot;chapter_title&quot;:&quot;foo&quot;,\r\n },\r\n {\r\n   &quot;title&quot;: &quot;Some title&quot;,\r\n   &quot;subtitle&quot;: &quot;Some subtitle&quot;\r\n   &quot;price&quot;: &quot;&#163;19.99&quot;,\r\n   &quot;Chapter_no&quot;: &quot;2&quot;,\r\n   &quot;chapter_title&quot;:&quot;bar&quot;,\r\n },\r\n ...\r\n]\r\n```\r\n\r\nIn other words display the values for `title`, `subtitle`, and `price` above every `chapter` and `chapter_no` fields.\r\n\r\nSo far I have been successful in outputting the `chapter` and `chapter_no` fields using the command:\r\n```\r\ntype &quot;books.json&quot; | jq -s --raw-output &quot;.[].chapters[] | [.chapter_no, .chapter_title]&quot; &gt; &quot;books_new.json&quot;\r\n```\r\n\r\nBut I&#39;m having difficulty trying to work out how to extract the fields from the previous arrays and add them to the chapter fields. I have searched the site already and as suggested tried various combinations of using `+=` but to no avail. I thought maybe I should be using `map` but couldn&#39;t figure it out.\r\n",
        "link": "https://stackoverflow.com/questions/72415703/prepending-an-already-existing-field-to-every-element-of-an-array-in-json",
        "title": "Prepending an already existing field to every element of an array in JSON"
    },
    {
        "tags": [
            "json",
            "linux",
            "bash",
            "ubuntu",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 3441337,
                    "reputation": 17125,
                    "user_id": 2883245,
                    "user_type": "registered",
                    "accept_rate": 88,
                    "profile_image": "https://i.sstatic.net/NPpPG.jpg?s=256",
                    "display_name": "erip",
                    "link": "https://stackoverflow.com/users/2883245/erip"
                },
                "edited": false,
                "score": 3,
                "creation_date": 1653833981,
                "post_id": 72416842,
                "comment_id": 127942911,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1653840928,
                "last_edit_date": 1653840928,
                "creation_date": 1653836950,
                "answer_id": 72424813,
                "question_id": 72416842,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "This is not a jq problem, but how output redirection works in shells. When you redirect to a file with `&gt;`, the file is truncated _before_ the command is executed.\r\n\r\nYou have to write to a different file and then copy it over your old file. (Or use `sponge`).\r\n\r\nAs (generalized) code:\r\n\r\n```\r\n$ cmd &lt; file &gt; file.tmp\r\n$ mv file.tmp file\r\n```\r\n\r\nor\r\n\r\n```\r\n$ cmd file &gt; file.tmp\r\n$ mv file.tmp file\r\n```",
                "title": "Contents missing using jq to update a JSON file"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1653840928,
        "creation_date": 1653750970,
        "last_edit_date": 1653752309,
        "question_id": 72416842,
        "body_markdown": "If we have a `hello.json`\r\n```\r\n$ echo &#39;{&quot;hello&quot;: &quot;world&quot;}&#39; &gt; hello.json\r\n$ cat hello.json\r\n{&quot;hello&quot;: &quot;world&quot;}\r\n```\r\nand try to add `&quot;foo&quot;: &quot;bar&quot;` to it using `jq`, the file `hello.json` becomes an empty file.\r\n\r\n```\r\n$ cat hello.json | jq --arg bar bar &#39;. + {foo: $bar}&#39;  &gt; hello.json\r\n$ cat hello.json \r\n```\r\n\r\nOn the other hand, if we had instead written the new JSON payload to `world.json`, we get the expected contents in `world.json`.\r\n\r\n```\r\n$ echo &#39;{&quot;hello&quot;: &quot;world&quot;}&#39; &gt; hello.json\r\n$ cat hello.json\r\n{&quot;hello&quot;: &quot;world&quot;}\r\n```\r\n```\r\n$ cat hello.json | jq --arg bar bar &#39;. + {foo: $bar}&#39;  &gt; world.json\r\n$ cat world.json \r\n{\r\n  &quot;hello&quot;: &quot;world&quot;,\r\n  &quot;foo&quot;: &quot;bar&quot;\r\n}\r\n```\r\n\r\nIs there a way to do this **without installing new utilities** like `sponge`?\r\n",
        "link": "https://stackoverflow.com/questions/72416842/contents-missing-using-jq-to-update-a-json-file",
        "title": "Contents missing using jq to update a JSON file"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 15204726,
                    "reputation": 18070,
                    "user_id": 10971581,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/XPQr1.png?s=256",
                    "display_name": "jhnc",
                    "link": "https://stackoverflow.com/users/10971581/jhnc"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1653771805,
                "post_id": 72417184,
                "comment_id": 127933968,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 25412567,
                    "reputation": 1,
                    "user_id": 19220118,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/db81cf95d6c1ab9906a712c61b227365?s=256&d=identicon&r=PG",
                    "display_name": "JimTaylor19",
                    "link": "https://stackoverflow.com/users/19220118/jimtaylor19"
                },
                "reply_to_user": {
                    "account_id": 15204726,
                    "reputation": 18070,
                    "user_id": 10971581,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/XPQr1.png?s=256",
                    "display_name": "jhnc",
                    "link": "https://stackoverflow.com/users/10971581/jhnc"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1653772909,
                "post_id": 72417184,
                "comment_id": 127934119,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 15204726,
                    "reputation": 18070,
                    "user_id": 10971581,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/XPQr1.png?s=256",
                    "display_name": "jhnc",
                    "link": "https://stackoverflow.com/users/10971581/jhnc"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1653773282,
                "post_id": 72417184,
                "comment_id": 127934168,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 25412567,
                    "reputation": 1,
                    "user_id": 19220118,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/db81cf95d6c1ab9906a712c61b227365?s=256&d=identicon&r=PG",
                    "display_name": "JimTaylor19",
                    "link": "https://stackoverflow.com/users/19220118/jimtaylor19"
                },
                "reply_to_user": {
                    "account_id": 15204726,
                    "reputation": 18070,
                    "user_id": 10971581,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/XPQr1.png?s=256",
                    "display_name": "jhnc",
                    "link": "https://stackoverflow.com/users/10971581/jhnc"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1653836587,
                "post_id": 72417184,
                "comment_id": 127943471,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 15204726,
                    "reputation": 18070,
                    "user_id": 10971581,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/XPQr1.png?s=256",
                    "display_name": "jhnc",
                    "link": "https://stackoverflow.com/users/10971581/jhnc"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1653839740,
                "post_id": 72417184,
                "comment_id": 127944199,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1653878211,
                "creation_date": 1653878211,
                "answer_id": 72428629,
                "question_id": 72417184,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Given the following JSON as input:\r\n```\r\n{ &quot;book&quot;: {\r\n    &quot;title&quot;: &quot;Some title&quot;,\r\n    &quot;subtitle&quot;: &quot;Some subtitle&quot;\r\n  }\r\n}\r\n```\r\nyou could run the following to extract the value `&quot;Some subtitle&quot;`:\r\n\r\n```\r\njq .book.subtitle\r\n```\r\n",
                "title": "Extracting a field from a JSON array and using it in arg"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": -2,
        "last_activity_date": 1653878211,
        "creation_date": 1653753727,
        "question_id": 72417184,
        "body_markdown": "In JQ I am trying to extract the value &quot;some subtitle&quot; from the array\r\n```\r\n  &quot;book&quot;: {\r\n    &quot;title&quot;: &quot;Some title&quot;,\r\n    &quot;subtitle&quot;: &quot;Some subtitle&quot;\r\n  },&quot;\r\n```\r\nto use as an argument in an output. I have tried\r\n```\r\n--arg subtitle &quot;.book[].subtitle&quot;\r\n```\r\n\r\nbut then $subtitle outputs &quot;.book[].subtitle&quot; as a literal text string, but using\r\n```\r\n--argjson subtitle &quot;.book[].subtitle&quot;\r\n```\r\n\r\nerrors.",
        "link": "https://stackoverflow.com/questions/72417184/extracting-a-field-from-a-json-array-and-using-it-in-arg",
        "title": "Extracting a field from a JSON array and using it in arg"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1653775242,
                "creation_date": 1653775242,
                "answer_id": 72419545,
                "question_id": 72419470,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can use `to_entries` to convert an object into an array of key-value pairs, then access `.key` and `.value` of its items to your own likings. For instance:\r\n~~~sh\r\njq -r &#39;.rows[] | to_entries[] | [.key, .value.tags[0,1]] | join(&quot;\\n &quot;)&#39;\r\n~~~\r\n~~~json\r\nhostname1\r\n  owner:TEAM_A\r\n  friendlyname:myhost1\r\nhostname2\r\n  friendlyname:myhost2\r\n  owner:TEAM_A\r\nhostname3\r\n  owner:TEAM_A\r\n  x:ghi\r\n~~~\r\n[Demo](https://jqplay.org/s/3Hv5RdLm3BB)\r\n\r\nAnother example:\r\n~~~sh\r\njq -r &#39;\r\n  .rows[] | to_entries[] | [.key, (\r\n    .value.tags[] | select(startswith(&quot;owner:&quot;, &quot;friendlyname:&quot;))\r\n  )] | join(&quot;\\n &quot;)\r\n&#39;\r\n~~~\r\n~~~json\r\nhostname1\r\n  owner:TEAM_A\r\n  friendlyname:myhost1\r\nhostname2\r\n  friendlyname:myhost2\r\n  owner:TEAM_A\r\nhostname3\r\n  owner:TEAM_A\r\n  friendlyname:myhost3\r\n~~~\r\n[Demo](https://jqplay.org/s/UG4S2EGcBkE)\r\n",
                "title": "Index string array by prefix in JQ"
            },
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1653790323,
                "creation_date": 1653790323,
                "answer_id": 72420465,
                "question_id": 72419470,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Turning `tags` into an object first would make it easier to retrieve tags in a particular order.\r\n``` none\r\n.rows[][].tags | INDEX(sub(&quot;:.*&quot;; &quot;&quot;)) | .owner, .friendlyname\r\n```\r\n&lt;sup&gt;[Online demo](https://jqplay.org/s/8_EJ8g-LGhj)&lt;/sup&gt;\r\n\r\nAnd it seems like you don&#39;t need a shell loop for this task, JQ can do all that and even more on its own.\r\n``` none\r\n.rows[]\r\n| keys_unsorted[] as $hostname\r\n| .[$hostname].tags\r\n| INDEX(sub(&quot;:.*&quot;; &quot;&quot;))\r\n| $hostname, &quot;\\t&quot; + (.owner, .friendlyname)\r\n```\r\n&lt;sup&gt;[Online demo](https://jqplay.org/s/fhj1F4Iwtb3)&lt;/sup&gt;",
                "title": "Index string array by prefix in JQ"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1653790469,
        "creation_date": 1653774332,
        "last_edit_date": 1653790469,
        "question_id": 72419470,
        "body_markdown": "I&#39;m trying to figure out how to print name of keys and specific sub-sub values from it.\r\nMy JSON is:\r\n```json\r\n{\r\n  &quot;results&quot;: 3,\r\n  &quot;rows&quot;: [\r\n    {\r\n      &quot;hostname1&quot;: {\r\n        &quot;tags&quot;: [\r\n          &quot;owner:TEAM_A&quot;,\r\n          &quot;friendlyname:myhost1&quot;,\r\n          &quot;x:abc&quot;,\r\n          &quot;y:jkl&quot;\r\n        ]\r\n      }\r\n    },\r\n    {\r\n      &quot;hostname2&quot;: {\r\n        &quot;tags&quot;: [\r\n          &quot;friendlyname:myhost2&quot;,\r\n          &quot;owner:TEAM_A&quot;,\r\n          &quot;x:def&quot;,\r\n          &quot;q:jkl&quot;\r\n        ]\r\n      }\r\n    },\r\n    {\r\n      &quot;hostname3&quot;: {\r\n        &quot;tags&quot;: [\r\n          &quot;owner:TEAM_A&quot;,\r\n          &quot;x:ghi&quot;,\r\n          &quot;friendlyname:myhost3&quot;,\r\n          &quot;q:jkl&quot;\r\n        ]\r\n      }\r\n    }\r\n  ]\r\n}\r\n```\r\nWhat I&#39;ve already achieved is to print just keys of hostnames:\r\n\r\n    jq -r &#39;.rows[] | keys[]&#39; example.json\r\n    hostname1\r\n    hostname2\r\n    hostname3\r\n\r\nI know how to print key:values from tags array:\r\n\r\n    jq -r .rows[0].hostname1.tags[0,1] example.json\r\n    owner:TEAM_A\r\n    friendlyname:myhost1\r\n\r\nBut I can&#39;t figure out how to print\r\n\r\n    hostname1\r\n              &quot;owner:TEAM_A&quot;,\r\n              &quot;friendlyname:myhost1&quot;,\r\n    hostname2\r\n              &quot;owner:TEAM_A&quot;,\r\n              &quot;friendlyname:myhost2&quot;,\r\n    hostname3\r\n              &quot;owner:TEAM_A&quot;,\r\n              &quot;friendlyname:myhost3&quot;,\r\n\r\nBe aware, that the keys in tags array has different order, so I cannot reach it through `.rows[0].hostname1.tags[0,1]` I&#39;m looking for something like `.rows[0].all_keys.tags[owner,friendlyname]`\r\n\r\nMy bash script was very close, but the order of keys brokes it.\r\n\r\n    hostnames=`jq -r &#39;.rows[] | keys[]&#39; example.json`\r\n    count=0\r\n    for i in $hostnames\r\n    do\r\n       jq -r .rows[$count].$i\\.tags[0,1] example.json\r\n       echo $i\r\n       ((count=count+1))\r\n    done\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/72419470/index-string-array-by-prefix-in-jq",
        "title": "Index string array by prefix in JQ"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1653792891,
                "creation_date": 1653792891,
                "answer_id": 72420596,
                "question_id": 72420520,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here is one way:\r\n``` none\r\npath(.[] | select(.country == &quot;United Kingdom&quot;))[0]\r\n```\r\n&lt;sup&gt;[Online demo](https://jqplay.org/s/AvKnPxwRSII)&lt;/sup&gt;",
                "title": "Select object by field and print parent key in JQ"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1653811684,
                "creation_date": 1653811684,
                "answer_id": 72421947,
                "question_id": 72420520,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "```jq\r\nto_entries[] | select( .value.country_short == &quot;gb&quot; ) | .key\r\n```\r\n\r\n[Demo](https://jqplay.org/s/isCbmTdOUTP) on jqplay\r\n\r\n",
                "title": "Select object by field and print parent key in JQ"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1653811915,
        "creation_date": 1653791440,
        "last_edit_date": 1653811915,
        "question_id": 72420520,
        "body_markdown": "I&#39;m looking to find a way to pull the parent key name from a JSON list that looks something like this:\r\n\r\n```json\r\n{\r\n    &quot;london1.perfect-privacy.com&quot;: {\r\n        &quot;city&quot;: &quot;London&quot;,\r\n        &quot;city_short&quot;: &quot;lo&quot;,\r\n        &quot;country&quot;: &quot;United Kingdom&quot;,\r\n        &quot;country_short&quot;: &quot;gb&quot;,\r\n        &quot;lati&quot;: &quot;51.511214&quot;,\r\n        &quot;longi&quot;: &quot;-0.119824&quot;\r\n    },\r\n    &quot;london2.perfect-privacy.com&quot;: {\r\n        &quot;city&quot;: &quot;London&quot;,\r\n        &quot;city_short&quot;: &quot;lo&quot;,\r\n        &quot;country&quot;: &quot;United Kingdom&quot;,\r\n        &quot;country_short&quot;: &quot;gb&quot;,\r\n        &quot;lati&quot;: &quot;51.511214&quot;,\r\n        &quot;longi&quot;: &quot;-0.119824&quot;\r\n    },\r\n    &quot;rotterdam2.perfect-privacy.com&quot;: {\r\n        &quot;city&quot;: &quot;Rotterdam&quot;,\r\n        &quot;city_short&quot;: &quot;ro&quot;,\r\n        &quot;country&quot;: &quot;Netherlands&quot;,\r\n        &quot;country_short&quot;: &quot;nl&quot;,\r\n        &quot;lati&quot;: &quot;51.924216&quot;,\r\n        &quot;longi&quot;: &quot;4.481776&quot; \r\n    }\r\n}\r\n```\r\n\r\nParent keys in this case are server names, and want to use JQ by to pull these over by selecting a specific country.  This code below lets me pull all the parent keys, but I&#39;m having trouble narrowing it down to just those that belong to a specific country:\r\n\r\n```sh\r\njq -r &#39;keys&#39; serverlocations.json\r\n```\r\n\r\nResults:\r\n\r\n```none\r\nlondon1.perfect-privacy.com\r\nlondon2.perfect-privacy.com\r\nrotterdam2.perfect-privacy.com\r\n```\r\n\r\n\r\nSo when I try something like this, I get a big fat error...\r\n\r\n```sh\r\njq -r &#39;keys | select(.country == &quot;United Kingdom&quot;)&#39; serverlocations.json&quot;\r\n```\r\n\r\nError:\r\n\r\n```none\r\njq: error (at &lt;stdin&gt;:0): Cannot index array with string &quot;country&quot;\r\n```\r\n\r\nI would have expected and want these results back:\r\n\r\n```none\r\nlondon1.perfect-privacy.com\r\nlondon2.perfect-privacy.com\r\n````\r\n\r\nYour advice and expertise is greatly appreciated!",
        "link": "https://stackoverflow.com/questions/72420520/select-object-by-field-and-print-parent-key-in-jq",
        "title": "Select object by field and print parent key in JQ"
    },
    {
        "tags": [
            "linux",
            "variables",
            "curl",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 3249716,
                    "reputation": 2081,
                    "user_id": 2740367,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/r7OsG.png?s=256",
                    "display_name": "leu",
                    "link": "https://stackoverflow.com/users/2740367/leu"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1653832305,
                "post_id": 72423939,
                "comment_id": 127942580,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1535561,
                    "reputation": 8861,
                    "user_id": 1431720,
                    "user_type": "registered",
                    "accept_rate": 89,
                    "profile_image": "https://www.gravatar.com/avatar/f5a1388d4d3b2bf03b11bb5658c68c29?s=256&d=identicon&r=PG",
                    "display_name": "Robert",
                    "link": "https://stackoverflow.com/users/1431720/robert"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1653862288,
                "post_id": 72423939,
                "comment_id": 127948717,
                "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": 1653876927,
                "post_id": 72423939,
                "comment_id": 127950662,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1653877878,
                "creation_date": 1653877878,
                "answer_id": 72428606,
                "question_id": 72423939,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "One of the fundamental problems with your script is that it\r\nassumes that jq can make sense of:\r\n```\r\njq -r --arg e &quot;tagInfo.id&quot; &#39;.[$e]&#39; &lt;&lt;&lt; &#39;{&quot;tagInfo&quot;:{ &quot;id&quot;: &quot;12&quot; , &quot;name&quot;: &quot;aname&quot;}}&#39;\r\n```\r\nHere are two workarounds:\r\n\r\n1. Use a shell variable:\r\n```\r\ne=&quot;tagInfo.id&quot;\r\njq -r &quot;.[$e]&quot; &lt;&lt;&lt; &#39;{&quot;tagInfo&quot;:{ &quot;id&quot;: &quot;12&quot; , &quot;name&quot;: &quot;aname&quot;}}&#39;\r\n```\r\n2. Specify the path as an array:\r\n```\r\njq -r --argjson e &#39;[&quot;tagInfo&quot;, &quot;id&quot;]&#39; &#39;getpath($e)&#39; &lt;&lt;&lt; &#39;{&quot;tagInfo&quot;:{ &quot;id&quot;: &quot;12&quot; , &quot;name&quot;: &quot;aname&quot;}}&#39;\r\n```\r\n\r\nSince (1) above is somewhat fragile, it would probably be better to go with (2).",
                "title": "Jq returning null value for nested key in my shell script"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1653877878,
        "creation_date": 1653829922,
        "question_id": 72423939,
        "body_markdown": "I am trying to output the value for nested json key but for some reason I get null value. \r\n```\r\n    SP=$(curl --proxy ...my apicall)\r\n    declare -A prop_map=(\r\n                [&quot;ID&quot;] = &quot;tagInfo.id&quot;\r\n    )\r\n\r\n    for key in ${!prop_map[@]}; do\r\n    pn=${prop_map[&quot;$key&quot;]}\r\n    val=$(jq -r --arg e &quot;$pn&quot; &#39;.[$e]&#39; &lt;&lt;&lt; \r\n    &quot;$SP&quot;)\r\n    echo $val\r\n```\r\n\r\nCurl response looks like this \r\n{\r\ntag info:{ id: &quot;12&quot;  , name:...}}\r\n\r\n\r\nCan anyone please guide ..been stuck on this for so long",
        "link": "https://stackoverflow.com/questions/72423939/jq-returning-null-value-for-nested-key-in-my-shell-script",
        "title": "Jq returning null value for nested key in my shell script"
    },
    {
        "tags": [
            "json",
            "key",
            "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": 1,
                "creation_date": 1653909150,
                "post_id": 72432986,
                "comment_id": 127958752,
                "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": 1653911431,
                "post_id": 72432986,
                "comment_id": 127959563,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 22359733,
                    "reputation": 13,
                    "user_id": 16576425,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/QwLYP.jpg?s=256",
                    "display_name": "Johannes_K",
                    "link": "https://stackoverflow.com/users/16576425/johannes-k"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1653911440,
                "post_id": 72432986,
                "comment_id": 127959570,
                "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": 1653911528,
                "post_id": 72432986,
                "comment_id": 127959596,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 22359733,
                    "reputation": 13,
                    "user_id": 16576425,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/QwLYP.jpg?s=256",
                    "display_name": "Johannes_K",
                    "link": "https://stackoverflow.com/users/16576425/johannes-k"
                },
                "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": 1653912265,
                "post_id": 72432986,
                "comment_id": 127959875,
                "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": 1653912540,
                "post_id": 72432986,
                "comment_id": 127959997,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1653912432,
                "last_edit_date": 1653912432,
                "creation_date": 1653912087,
                "answer_id": 72434008,
                "question_id": 72432986,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Instead off `has`, you can use a `select` with an `|=` opertator:\r\n\r\n```none\r\n.records |= map(.id as $id | (.location.coordinates | (if type == &quot;array&quot; then .[0] else . end) as $q | ({ $id, lat: null, lon: null } + $q) ))\r\n```\r\n\r\nThis generates:\r\n```json\r\n{\r\n  &quot;records&quot;: [\r\n    {\r\n      &quot;id&quot;: 1,\r\n      &quot;lat&quot;: 42,\r\n      &quot;lon&quot;: -71\r\n    },\r\n    {\r\n      &quot;id&quot;: 2,\r\n      &quot;lat&quot;: 40,\r\n      &quot;lon&quot;: -73\r\n    },\r\n    {\r\n      &quot;id&quot;: 3,\r\n      &quot;lat&quot;: null,\r\n      &quot;lon&quot;: null\r\n    }\r\n  ]\r\n}\r\n\r\n```\r\n\r\nAs you can try in this [online demo](https://jqplay.org/s/HquJhGqPZKo).\r\n\r\n\r\n----------\r\n\r\n\r\nSo, the above explained:\r\n1. Loop over `records` and update them \\\r\n`.records |= map()`\r\n3. Save the id\\\r\n`.id as $id`\r\n4. Continue on the coordinates\\\r\n`.location.coordinates | `\r\n5. Check for an array, if so, get the fist object, otherwise, just keep it, save as `$q`\\\r\n`(if type == &quot;array&quot; then .[0] else . end) as $q`\r\n6. Create the final object, start with an object with just the `id` and `lat` and `lon` set to `null`, then we combine `$q` to get the actual values from the coordinates\\\r\n`({ $id, lat: null, lon: null } + $q)`\r\n\r\n\r\n----------\r\n\r\nThis could most probably be simplified, so waiting for another answer that has the same idea, but more optimised.\r\n\r\n",
                "title": "jq - check for subkey without filtering"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1653920162,
                "last_edit_date": 1653920162,
                "creation_date": 1653919681,
                "answer_id": 72435681,
                "question_id": 72432986,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can also use alternative operator `//` :\r\n\r\n```\r\njq &#39;.records[] |= {id}+((.location.coordinates? |\r\n                         if type == &quot;array&quot; then .[0] else . end\r\n                        ) // {}\r\n                       )&#39; input.json\r\n```",
                "title": "jq - check for subkey without filtering"
            },
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1653928451,
                "creation_date": 1653928451,
                "answer_id": 72437487,
                "question_id": 72432986,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You could use the [error suppression operator](https://stedolan.github.io/jq/manual/#ErrorSuppression/OptionalOperator:?) `?` in combination with the [alterative operator](https://stedolan.github.io/jq/manual/#Alternativeoperator://) `//` to fall back to another case if the previous one fails:\r\n~~~sh\r\n.records[] |= (.location.coordinates | .[0]? // .) as {$lat,$lon} | {id,$lat,$lon}\r\n~~~\r\n~~~json\r\n{\r\n  &quot;records&quot;: [\r\n    {\r\n      &quot;id&quot;: 1,\r\n      &quot;lat&quot;: 42,\r\n      &quot;lon&quot;: -71\r\n    },\r\n    {\r\n      &quot;id&quot;: 2,\r\n      &quot;lat&quot;: 40,\r\n      &quot;lon&quot;: -73\r\n    },\r\n    {\r\n      &quot;id&quot;: 3,\r\n      &quot;lat&quot;: null,\r\n      &quot;lon&quot;: null\r\n    }\r\n  ]\r\n}\r\n~~~\r\n[Demo](https://jqplay.org/s/A0NSbuco7Fh)\r\n",
                "title": "jq - check for subkey without filtering"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1653970110,
                "creation_date": 1653970110,
                "answer_id": 72442185,
                "question_id": 72432986,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "With version 1.6, `jq` has introduced the [destructuring alternative operator](https://stedolan.github.io/jq/manual/#DestructuringAlternativeOperator:?//) `?//` which\r\n&gt; provides a concise mechanism for destructuring an input that can take one of several forms\r\n\r\nThat way, you could define one case with an array, and another one without, using the same variable names. As &quot;unmatched&quot; variables (in the alternative that succeeded) are set to `null`, there&#39;s no need to explicitly deal with the third case.\r\n~~~sh\r\njq &#39;.records |= map(\r\n  .location as {coordinates: [{$lat, $lon}]} ?// {coordinates: {$lat, $lon}}\r\n  | {id, $lat, $lon}\r\n)&#39;\r\n~~~\r\n~~~json\r\n{\r\n  &quot;records&quot;: [\r\n    {\r\n      &quot;id&quot;: 1,\r\n      &quot;lat&quot;: 42,\r\n      &quot;lon&quot;: -71\r\n    },\r\n    {\r\n      &quot;id&quot;: 2,\r\n      &quot;lat&quot;: 40,\r\n      &quot;lon&quot;: -73\r\n    },\r\n    {\r\n      &quot;id&quot;: 3,\r\n      &quot;lat&quot;: null,\r\n      &quot;lon&quot;: null\r\n    }\r\n  ]\r\n}\r\n~~~\r\n[Demo](https://jqplay.org/s/ocISRTlxWXf)",
                "title": "jq - check for subkey without filtering"
            }
        ],
        "is_answered": true,
        "answer_count": 4,
        "score": 0,
        "last_activity_date": 1653970110,
        "creation_date": 1653907172,
        "last_edit_date": 1653914590,
        "question_id": 72432986,
        "body_markdown": "I would like to check for the presence of a subkey (or for its type) in a JSON file using jq without filtering the data. I need this to obtain a list of all entities from the following JSON file, with the first pair of coordinates if more than one pair is available. The problem is the partly nested structure: The &quot;location&quot; object is only available for some entries, and the &quot;coordinates&quot; element is an array only if multiple locations are available.\r\n```\r\n{&quot;records&quot;:[\r\n{\r\n    &quot;id&quot;: 1,\r\n    &quot;location&quot;: {\r\n        &quot;coordinates&quot;: {\r\n            &quot;lat&quot;: 42,\r\n            &quot;lon&quot;: -71\r\n        }\r\n    }\r\n},\r\n{\r\n    &quot;id&quot;: 2,\r\n    &quot;location&quot;: {\r\n        &quot;coordinates&quot;: [\r\n            {\r\n                &quot;lat&quot;: 40,\r\n                &quot;lon&quot;: -73\r\n            },\r\n            {\r\n                &quot;lat&quot;: 39,\r\n                &quot;lon&quot;: -75\r\n            }\r\n        ]\r\n    }\r\n},\r\n{\r\n    &quot;id&quot;: 3,\r\n    &quot;location&quot;: null\r\n}]}\r\n```\r\nSo I tried the &quot;has&quot; function, which does not seem to work for subkeys. I imagined something like this:\r\n```\r\ncat file.json | jq &#39;.records[] | if has(&quot;location.coordinates&quot;) then [do something] else [do something else] end&#39;\r\n```\r\nIs there any way to check for subkeys? As I need to maintain all entries in the dataset, filtering via &quot;select&quot; etc. does not seem to be an option.\r\n\r\nTo clarify my question: I hoped to get a JSON output similar to this (but I would be happy to handle other formats):\r\n```\r\n{&quot;records&quot;:[\r\n{&quot;id&quot;: 1, &quot;lat&quot;, xx, &quot;lon&quot;: xx}\r\n{&quot;id&quot;: 2, &quot;lat&quot;, yy, &quot;lon&quot;: yy}\r\n{&quot;id&quot;: 3, &quot;lat&quot;, null, &quot;lon&quot;: null}\r\n]}\r\n```",
        "link": "https://stackoverflow.com/questions/72432986/jq-check-for-subkey-without-filtering",
        "title": "jq - check for subkey without filtering"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1654020343,
                "creation_date": 1654020343,
                "answer_id": 72452336,
                "question_id": 72452280,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Do the same thing with each `b` that you did with each `a`. Use the `-r` option to get the raw text, rather than JSON string values.\r\n\r\n    % jq -r &#39;.a[].b[]&#39; tmp.json\r\n    x1\r\n    x2\r\n    y1\r\n    y2\r\n\r\nThat is, `.b` outputs the list; `.b[]` outputs each element of the list.",
                "title": "How do I use JQ to flatten JSON-lines where each is an array into an item-per-line?"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1659812784,
                "creation_date": 1659812784,
                "answer_id": 73262573,
                "question_id": 72452280,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "With your shown samples, attempts you could try following `jq` code also. Using `-r` option of `jq` to send input in raw form. Then appropriately getting values as per requirement here.\r\n\r\n```jq\r\njq -r &#39;(.[] | .[].b)[]&#39;  Input_file\r\n```\r\n\r\nOutput will be as follows:\r\n\r\n    x1\r\n    x2\r\n    y1\r\n    y2\r\n\r\n",
                "title": "How do I use JQ to flatten JSON-lines where each is an array into an item-per-line?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1659812784,
        "creation_date": 1654020048,
        "last_edit_date": 1654067437,
        "question_id": 72452280,
        "body_markdown": "I have the JSON as at bottom. If I send it to `jq &#39;.a[].b` I get\r\n\r\n    [\r\n      &quot;x1&quot;,\r\n      &quot;x2&quot;\r\n    ]\r\n    [\r\n      &quot;y1&quot;,\r\n      &quot;y2&quot;\r\n    ]\r\n\r\nHow do I instead get line-by-line output, no brackets, quotes, or commas, like this:\r\n\r\n    x1\r\n    x2\r\n    y1\r\n    y2\r\n\r\n\r\nThe input JSON is:\r\n\r\n    {\r\n      &quot;a&quot;: [\r\n        {\r\n          &quot;b&quot;: [\r\n            &quot;x1&quot;,\r\n            &quot;x2&quot;\r\n          ],\r\n          &quot;z&quot;: &quot;z&quot;\r\n        },\r\n        {\r\n          &quot;b&quot;: [\r\n            &quot;y1&quot;,\r\n            &quot;y2&quot;\r\n          ],\r\n          &quot;w&quot;: &quot;w&quot;\r\n        }\r\n      ]\r\n    }\r\n\r\n",
        "link": "https://stackoverflow.com/questions/72452280/how-do-i-use-jq-to-flatten-json-lines-where-each-is-an-array-into-an-item-per-li",
        "title": "How do I use JQ to flatten JSON-lines where each is an array into an item-per-line?"
    },
    {
        "tags": [
            "bash",
            "parsing",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 5225716,
                    "reputation": 3975,
                    "user_id": 4177828,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/GHCgC.jpg?s=256",
                    "display_name": "ufopilot",
                    "link": "https://stackoverflow.com/users/4177828/ufopilot"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1654025013,
                "post_id": 72452978,
                "comment_id": 127992746,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1654025012,
                "last_edit_date": 1654025012,
                "creation_date": 1654024205,
                "answer_id": 72453015,
                "question_id": 72452978,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You are trying to construct a JQ filter using string interpretation, which is typically the wrong thing to do.\r\n\r\nInstead, pass the number as an *argument* to the filter.\r\n\r\n    ID=2\r\n    jq --raw-output --arg x &quot;$ID&quot;  &#39;.[$x].job&#39; data.txt\r\n    # jq --raw-output --argjson x &quot;\\&quot;$ID\\&quot;&quot; &#39;.[$x].job&#39; data.txt\r\n    \r\n    # ID=&#39;&quot;2&quot;&#39;\r\n    # jq --raw-output --argjson x &quot;$ID&quot; &#39;.[$x].job&#39; data.txt\r\n\r\n`--arg` encodes the value as a JSON string; `--argjson` assumes that the value is already a JSON value.",
                "title": "How to escape a double quotation marks AND using a env var in JQ"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1654025558,
        "creation_date": 1654023940,
        "last_edit_date": 1654025558,
        "question_id": 72452978,
        "body_markdown": "I have the following file: **data.txt**\r\n\r\n```json\r\n{\r\n  &quot;1&quot;: {\r\n    &quot;job&quot;: &quot;Plumber&quot;,\r\n    &quot;age&quot;: &quot;23&quot;\r\n  },\r\n  &quot;2&quot;: {\r\n    &quot;job&quot;: &quot;SEO&quot;,\r\n    &quot;age&quot;: &quot;45&quot;\r\n  }\r\n}\r\n```\r\nAnd I can do the following query without problem:\r\n\r\n    jq --raw-output &#39;.&quot;2&quot;.job&#39; data.txt\r\n\r\nBut, in the script that I am doing, the number is given from another command, something similar to this next for simplicity. And at the time of executing it, it does not parse the variable or the quotes well. So the result be null.\r\n\r\n    ID=$(echo &quot;2&quot;)\r\n    jq --raw-output &#39;.&quot;$ID&quot;.job&#39; README.md\r\n\r\nI&#39;ve tried escaping the variable with `\\`, escaping the quotes with `\\`, escaping both with `\\`. Also to use `--arg` and `.[&quot;$env.ID&quot;]` and everything that come to my head. Unsuccessfully. If anyone knows how to parse quotes and a variable at same time I would be very grateful,\r\nregards.\r\n",
        "link": "https://stackoverflow.com/questions/72452978/how-to-escape-a-double-quotation-marks-and-using-a-env-var-in-jq",
        "title": "How to escape a double quotation marks AND using a env var in JQ"
    },
    {
        "tags": [
            "string",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1654072032,
                "creation_date": 1654072032,
                "answer_id": 72458613,
                "question_id": 72458534,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can use the `sub` filter:\r\n\r\n    &quot;20220601101600&quot; | sub(&quot;^(?&lt;year&gt;....)(?&lt;mo&gt;..)(?&lt;day&gt;..)(?&lt;h&gt;..)(?&lt;m&gt;..)(?&lt;s&gt;..)$&quot;; &quot;\\(.year)-\\(.mo)-\\(.day) \\(.h):\\(.m):\\(.s)&quot;)",
                "title": "slice a field with jq and put extra characters"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1654072273,
                "creation_date": 1654072273,
                "answer_id": 72458658,
                "question_id": 72458534,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "To slice by position, use the `.[&lt;from&gt;:&lt;to&gt;]` notation:\r\n~~~sh\r\n.startTime | &quot;\\(.[0:4])-\\(.[4:6])-\\(.[6:8]) \\(.[8:10]):\\(.[10:12]):\\(.[12:14])&quot;\r\n~~~\r\n",
                "title": "slice a field with jq and put extra characters"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 2,
        "last_activity_date": 1654137166,
        "creation_date": 1654071641,
        "last_edit_date": 1654137166,
        "question_id": 72458534,
        "body_markdown": "I get a field with jq with:\r\n\r\n    jq -r &#39;.statuses[]   | &quot;\\(.name);\\(.startTime);\\(.ord);\\(.app);\\(.group)&quot;&#39;\r\n\r\nIt gives me:\r\n\r\n    HOSUE;20220601101600;220601;BANDOL;FLASH\r\n\r\nI would like to get:\r\n\r\n    HOUSE;2022-06-01 10:16:00;220601;BANDOL;FLASH\r\n\r\nDo you know if it&#39;s possible to make that with jq?\r\n\r\nThanks\r\n\r\n\r\n\r\n\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/72458534/slice-a-field-with-jq-and-put-extra-characters",
        "title": "slice a field with jq and put extra characters"
    },
    {
        "tags": [
            "mysql",
            "docker",
            "shell",
            "jq",
            "dockerhub"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1654110205,
                "last_edit_date": 1654110205,
                "creation_date": 1654085749,
                "answer_id": 72461747,
                "question_id": 72461219,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Extract any sequence of digits using `scan(&quot;\\\\d+&quot;)`, convert the strings to numbers using `tonumber`, and use that as argument for `sort_by` on the initial array, from which you can then output the last item using index `-1`.\r\n~~~sh\r\njq -r &#39;map(.name) | sort_by(scan(&quot;\\\\d+&quot;) | tonumber)[-1]&#39;\r\n~~~\r\n~~~json\r\n8.0.29-oracle\r\n~~~\r\n[Demo](https://jqplay.org/s/TtKR-azf88A)\r\n\r\n---\r\nIf for the output you only want the pure version number (`8.0.29` instead of `8.0.29-oracle`), ditch everything after and including the dash sign:\r\n~~~sh\r\njq -r &#39;map(.name | .[:index(&quot;-&quot;)]) | sort_by(scan(&quot;\\\\d+&quot;) | tonumber)[-1]&#39;\r\n~~~\r\n~~~json\r\n8.0.29\r\n~~~\r\n[Demo](https://jqplay.org/s/J0pgBivUwpM)\r\n",
                "title": "Fetch latest valid mysql tag from docker hub using jq"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1654098314,
                "creation_date": 1654098314,
                "answer_id": 72464709,
                "question_id": 72461219,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The latest version has the `latest` tag. &quot;stable&quot; is in the eye of the beholder and not computable with the given information.",
                "title": "Fetch latest valid mysql tag from docker hub using jq"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1654112544,
                "creation_date": 1654112544,
                "answer_id": 72467265,
                "question_id": 72461219,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "&gt; _I tried using xidel but could not find solution_\r\n\r\nIf you&#39;re still interested, it&#39;s not that hard:\r\n```\r\n$ xidel -s &quot;https://registry.hub.docker.com/v1/repositories/mysql/tags&quot; -e &#39;\r\n  (\r\n    for $x in $json()/name[matches(.,&quot;^\\d+\\.\\d+\\.\\d+$&quot;)]\r\n    order by $x\r\n    return $x\r\n  )[last()]\r\n&#39;\r\n8.0.29\r\n```\r\n- `[matches(.,&quot;^\\d+\\.\\d+\\.\\d+$&quot;)]` returns only those `name`s with just digits.\r\n- `order by $x` for sorting.\r\n- `(`...`)[last()]` to return the last item of the sequence (in this case the latest version).\r\n\r\nAlternatively and even shorter, you can use `max()`:\r\n```\r\n$ xidel -s &quot;https://registry.hub.docker.com/v1/repositories/mysql/tags&quot; -e &#39;\r\n  max($json()/name[matches(.,&quot;^\\d+\\.\\d+\\.\\d+$&quot;)])\r\n&#39;\r\n8.0.29\r\n```",
                "title": "Fetch latest valid mysql tag from docker hub using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 0,
        "last_activity_date": 1654112544,
        "creation_date": 1654083494,
        "question_id": 72461219,
        "body_markdown": "I am using following command to fetch all release tags from mysql on docker hub :\r\n\r\n    wget -q https://registry.hub.docker.com/v1/repositories/mysql/tags -O - | jq -r .[].name\r\n\r\nOutput is:\r\n\r\n    5.7.38\r\n    5.7.38-debian\r\n    5.7.38-oracle\r\n    5.7.4\r\n    5.7.4-m14\r\n    5.7.5\r\n    5.7.5-m15\r\n    5.7.6\r\n    5.7.6-m16\r\n    5.7.7\r\n    5.7.7-rc\r\n    5.7.8\r\n    5.7.8-rc\r\n    5.7.9\r\n    8\r\n    8-debian\r\n    8-oracle\r\n    8.0\r\n    8.0-debian\r\n    8.0-oracle\r\n    8.0.0\r\n    8.0.1\r\n    8.0.11\r\n    8.0.12\r\n    8.0.13\r\n    8.0.14\r\n    8.0.15\r\n    8.0.16\r\n    8.0.17\r\n    8.0.18\r\n    8.0.19\r\n    8.0.2\r\n    8.0.20\r\n    8.0.21\r\n    8.0.22\r\n    8.0.23\r\n    8.0.24\r\n    8.0.25\r\n    8.0.26\r\n    8.0.27\r\n    8.0.28\r\n    8.0.28-debian\r\n    8.0.28-oracle\r\n    8.0.29\r\n    8.0.29-debian\r\n    8.0.29-oracle\r\n    8.0.3\r\n    8.0.4\r\n    8.0.4-rc\r\n    debian\r\n    oracle\r\n\r\nIs there a way i can fetch the latest stable version only? For example , i want to fetch 8.0.29 as it is the latest stable version for 8x version . And next time when 8.0.30 comes i get the output from the same command?\r\n\r\nCan anybody please help or point me to right direction? I tried using xidel but could not find solution",
        "link": "https://stackoverflow.com/questions/72461219/fetch-latest-valid-mysql-tag-from-docker-hub-using-jq",
        "title": "Fetch latest valid mysql tag from docker hub using jq"
    },
    {
        "tags": [
            "arrays",
            "json",
            "bash",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 5,
                "is_accepted": false,
                "score": 5,
                "last_activity_date": 1654090990,
                "creation_date": 1654090990,
                "answer_id": 72462890,
                "question_id": 72462640,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can use `+` to add two objects together by combining their fields; if both objects have the same one the value of the right hand one is used. So if you make your existing object the RHS:\r\n\r\n```sh\r\n&#160;jq &#39;[ .Results[] | {Severity:&quot;&quot;, InstalledVersion:&quot;&quot;, FixedVersion:&quot;&quot;, VulnerabilityID:&quot;&quot;} + . ]&#39; input.json   \r\n[\r\n  {\r\n    &quot;Severity&quot;: &quot;LOW&quot;,\r\n    &quot;InstalledVersion&quot;: &quot;1.21.1ubuntu2&quot;,\r\n    &quot;FixedVersion&quot;: &quot;1.21.1ubuntu2.1&quot;,\r\n    &quot;VulnerabilityID&quot;: &quot;&quot;\r\n  },\r\n  {\r\n    &quot;Severity&quot;: &quot;LOW&quot;,\r\n    &quot;InstalledVersion&quot;: &quot;1.21.1ubuntu2&quot;,\r\n    &quot;FixedVersion&quot;: &quot;&quot;,\r\n    &quot;VulnerabilityID&quot;: &quot;&quot;\r\n  },\r\n  {\r\n    &quot;Severity&quot;: &quot;HIGH&quot;,\r\n    &quot;InstalledVersion&quot;: &quot;&quot;,\r\n    &quot;FixedVersion&quot;: &quot;&quot;,\r\n    &quot;VulnerabilityID&quot;: &quot;CVE-2016-2781&quot;\r\n  }\r\n]\r\n```",
                "title": "Best way to iterate over JSON array with variable keys with jq/bash"
            },
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1654091040,
                "creation_date": 1654091040,
                "answer_id": 72462899,
                "question_id": 72462640,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Another way of adding the fallbacks to a empty string:\r\n```\r\n[ .Results[] | . + { VulnerabilityID: (.VulnerabilityID // &quot;&quot;), FixedVersion: (.FixedVersion // &quot;&quot;), InstalledVersion: (.InstalledVersion // &quot;&quot;) } ]\r\n```\r\n\r\n```json\r\n[\r\n  {\r\n    &quot;Severity&quot;: &quot;LOW&quot;,\r\n    &quot;InstalledVersion&quot;: &quot;1.21.1ubuntu2&quot;,\r\n    &quot;FixedVersion&quot;: &quot;1.21.1ubuntu2.1&quot;,\r\n    &quot;VulnerabilityID&quot;: &quot;&quot;\r\n  },\r\n  {\r\n    &quot;Severity&quot;: &quot;LOW&quot;,\r\n    &quot;InstalledVersion&quot;: &quot;1.21.1ubuntu2&quot;,\r\n    &quot;VulnerabilityID&quot;: &quot;&quot;,\r\n    &quot;FixedVersion&quot;: &quot;&quot;\r\n  },\r\n  {\r\n    &quot;Severity&quot;: &quot;HIGH&quot;,\r\n    &quot;VulnerabilityID&quot;: &quot;CVE-2016-2781&quot;,\r\n    &quot;FixedVersion&quot;: &quot;&quot;,\r\n    &quot;InstalledVersion&quot;: &quot;&quot;\r\n  }\r\n]\r\n```\r\n\r\n### [Online demo](https://jqplay.org/s/PA8xGQgIglS)",
                "title": "Best way to iterate over JSON array with variable keys with jq/bash"
            },
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1654091460,
                "creation_date": 1654091460,
                "answer_id": 72463008,
                "question_id": 72462640,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "One more variation\r\n```sh\r\njq &#39;[\r\n    .Results[]\r\n    | .FixedVersion //= &quot;&quot;\r\n    | .VulnerabilityID //= &quot;&quot;\r\n    | .InstalledVersion //= &quot;&quot;\r\n]&#39; file.json\r\n```",
                "title": "Best way to iterate over JSON array with variable keys with jq/bash"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1654158306,
                "last_edit_date": 1654158306,
                "creation_date": 1654100820,
                "answer_id": 72465222,
                "question_id": 72462640,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "A more generic approach :\r\n\r\n```\r\njq &#39;.Results |\r\n    (map(keys)|add|unique|map({key:.,value:&quot;&quot;})|from_entries) as $default |\r\n    map($default + .)\r\n   &#39; input.json\r\n```\r\n\r\nExplanations :\r\n```\r\n1) map(keys)|add|unique\r\n   gets all the keys. If it&#39;s a subset you are interested, you can substitute it with :\r\n   [&quot;FixedVersion&quot;, &quot;VulnerabilityID&quot;, &quot;InstalledVersion&quot;]\r\n2) map({key:.,value:&quot;&quot;})|from_entries) as $default\r\n   constructs a default object with all (or selected) keys.\r\n3) $default + .\r\n   adds a key from default object if the key does not exist.\r\n\r\n",
                "title": "Best way to iterate over JSON array with variable keys with jq/bash"
            }
        ],
        "is_answered": true,
        "answer_count": 4,
        "score": 1,
        "last_activity_date": 1654158306,
        "creation_date": 1654089850,
        "question_id": 72462640,
        "body_markdown": "I have a JSON-file like the one below:\r\n\r\n    {\r\n    \t&quot;Results&quot;: [\r\n    \t\t{\r\n    \t\t\t&quot;Severity&quot;: &quot;LOW&quot;,\r\n    \t\t\t&quot;InstalledVersion&quot;: &quot;1.21.1ubuntu2&quot;,\r\n    \t\t\t&quot;FixedVersion&quot;: &quot;1.21.1ubuntu2.1&quot;\r\n    \t\t},\r\n    \t\t{\r\n    \t\t\t&quot;Severity&quot;: &quot;LOW&quot;,\r\n    \t\t\t&quot;InstalledVersion&quot;: &quot;1.21.1ubuntu2&quot;\r\n    \t\t},\r\n    \t\t{\r\n    \t\t\t&quot;Severity&quot;: &quot;HIGH&quot;,\r\n    \t\t\t&quot;VulnerabilityID&quot;: &quot;CVE-2016-2781&quot;\r\n    \t\t}\r\n    \t]\r\n    }\r\n\r\nI would like to create the following JSON-file:\r\n\r\n    [\r\n    \t{\r\n    \t\t&quot;Severity&quot;: &quot;LOW&quot;,\r\n    \t\t&quot;InstalledVersion&quot;: &quot;1.21.1ubuntu2&quot;,\r\n    \t\t&quot;FixedVersion&quot;: &quot;1.21.1ubuntu2.1&quot;,\r\n    \t\t&quot;VulnerabilityID&quot;: &quot;&quot;\r\n    \t},\r\n    \t{\r\n    \t\t&quot;Severity&quot;: &quot;LOW&quot;,\r\n    \t\t&quot;InstalledVersion&quot;: &quot;1.21.1ubuntu2&quot;,\r\n    \t\t&quot;FixedVersion&quot;: &quot;&quot;,\r\n    \t\t&quot;VulnerabilityID&quot;: &quot;&quot;\r\n    \t},\r\n    \t{\r\n    \t\t&quot;Severity&quot;: &quot;HIGH&quot;,\r\n    \t\t&quot;InstalledVersion&quot;: &quot;&quot;,\r\n    \t\t&quot;FixedVersion&quot;: &quot;&quot;,\r\n    \t\t&quot;VulnerabilityID&quot;: &quot;CVE-2016-2781&quot;\r\n    \t}\r\n    ]\r\n\r\nI have tried iterating over the first JSON-file, but when I do so in the following way, I get random parsing errors (with the real JSON-file I am working with). So I think there is something off about the piping that I am doing.\r\n\r\n    jq -c &#39;.Results[]&#39; my.json | while read i; do\r\n        echo $i;\r\n    done\r\n\r\nIn the JSON-file I am working with **jq -c &#39;.Results[]&#39;** works perfectly, but when I do **jq** operations on the resulting **$i** while iterating, I suddently get several parsing errors. \r\n\r\nIs there better way to iterate over key-value-pairs in a JSON-file? Ofcause I could just install Python/R and do the typical drill, but I would really like for this to work in a shell script.",
        "link": "https://stackoverflow.com/questions/72462640/best-way-to-iterate-over-json-array-with-variable-keys-with-jq-bash",
        "title": "Best way to iterate over JSON array with variable keys with jq/bash"
    },
    {
        "tags": [
            "linux",
            "shell",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1654094351,
                "creation_date": 1654094351,
                "answer_id": 72463727,
                "question_id": 72463522,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Use `to_entries` to access keys and values. To escape with quotes, it may not be sufficient to just put quotes around the names. Depending on your use case, converting to JSON strings using `@json` might be an option:\r\n~~~sh\r\njq -r &#39;to_entries[] | @json &quot;\\(.key) = \\(.value)&quot;&#39;\r\n~~~\r\n~~~json\r\n&quot;bucket&quot; = &quot;sdsd&quot;\r\n&quot;key&quot; = &quot;hghghg&quot;\r\n&quot;region&quot; = &quot;us-east-1&quot;\r\n~~~\r\n[Demo](https://jqplay.org/s/qAoJ2Og7dqD)",
                "title": "JQ raw text to double quoted key value pair"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1654094351,
        "creation_date": 1654093582,
        "question_id": 72463522,
        "body_markdown": "I have this data. \r\n{&quot;bucket&quot;:&quot;sdsd&quot;,&quot;key&quot;:&quot;hghghg&quot;,&quot;region&quot;:&quot;us-east-1&quot;}\r\nI want to convert it into following format. using shell commands.\r\n\r\n - &quot;bucekt&quot;=&quot;sdsd&quot;\r\n - &quot;key&quot;=&quot;hghghg&quot;\r\n - &quot;region&quot;=&quot;us-east-1&quot;\r\n\r\n",
        "link": "https://stackoverflow.com/questions/72463522/jq-raw-text-to-double-quoted-key-value-pair",
        "title": "JQ raw text to double quoted key value pair"
    },
    {
        "tags": [
            "bash",
            "amazon-web-services",
            "jq",
            "securestring"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 22008877,
                    "reputation": 195,
                    "user_id": 16279419,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/CrMxx.jpg?s=256",
                    "display_name": "Sara June",
                    "link": "https://stackoverflow.com/users/16279419/sara-june"
                },
                "reply_to_user": {
                    "account_id": 303420,
                    "reputation": 10895,
                    "user_id": 2378643,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/mt7f4.png?s=256",
                    "display_name": "Anon Coward",
                    "link": "https://stackoverflow.com/users/2378643/anon-coward"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1654101289,
                "post_id": 72465049,
                "comment_id": 128013174,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 22008877,
                    "reputation": 195,
                    "user_id": 16279419,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/CrMxx.jpg?s=256",
                    "display_name": "Sara June",
                    "link": "https://stackoverflow.com/users/16279419/sara-june"
                },
                "reply_to_user": {
                    "account_id": 303420,
                    "reputation": 10895,
                    "user_id": 2378643,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/mt7f4.png?s=256",
                    "display_name": "Anon Coward",
                    "link": "https://stackoverflow.com/users/2378643/anon-coward"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1654101811,
                "post_id": 72465049,
                "comment_id": 128013354,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 22008877,
                    "reputation": 195,
                    "user_id": 16279419,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/CrMxx.jpg?s=256",
                    "display_name": "Sara June",
                    "link": "https://stackoverflow.com/users/16279419/sara-june"
                },
                "reply_to_user": {
                    "account_id": 303420,
                    "reputation": 10895,
                    "user_id": 2378643,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/mt7f4.png?s=256",
                    "display_name": "Anon Coward",
                    "link": "https://stackoverflow.com/users/2378643/anon-coward"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1654101816,
                "post_id": 72465049,
                "comment_id": 128013357,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1654100279,
                "creation_date": 1654100279,
                "answer_id": 72465099,
                "question_id": 72465049,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can pipe the `.SecretString` output to jq again like this:\r\n```\r\naws secretsmanager get-secret-value --secret-id $SECRET_ID | jq -r &quot;.SecretString&quot; | jq -r &quot;.ssh_key&quot;\r\n```",
                "title": "How to retrieve values of aws secretsmanager?"
            },
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1654109029,
                "last_edit_date": 1654109029,
                "creation_date": 1654104368,
                "answer_id": 72465871,
                "question_id": 72465049,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "With a single call to `jq` :\r\n\r\n```\r\njq -r &#39;.SecretString|fromjson|.ssh_key&#39;\r\n```\r\n\r\nYou can test existence of `ssh_key` this way :\r\n\r\n```\r\njq -r &#39;.SecretString|fromjson|select(has(&quot;ssh_key&quot;)).ssh_key&#39;\r\n```\r\n\r\nso that if `ssh_key` does not exist, it will output nothing.\r\n",
                "title": "How to retrieve values of aws secretsmanager?"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1677150573,
                "creation_date": 1677150573,
                "answer_id": 75543997,
                "question_id": 72465049,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Additionally you can use awscli&#39;s `--query` :\r\n```\r\naws secretsmanager get-secret-value --secret-id ssh_key --query SecretString --output text | jq -r &quot;.ssh_key&quot;\r\n```",
                "title": "How to retrieve values of aws secretsmanager?"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 2,
        "last_activity_date": 1677150573,
        "creation_date": 1654099999,
        "question_id": 72465049,
        "body_markdown": "I am trying to retrieve a secret value from aws secretsmanager.\r\n\r\nThe individual secret contains multiple key/value pairs.\r\n\r\nkey will be machine IP address and value will be machine ssh key.\r\n\r\nThis is used in our internal automation.\r\n\r\nTo retrieve a value, I ran below command.\r\n\r\nPresent, I got like this.\r\n\r\n    aws secretsmanager get-secret-value --secret-id ssh_key --version-stage AWSCURRENT \r\n    {\r\n        &quot;Name&quot;: &quot;ssh_key&quot;, \r\n        &quot;VersionId&quot;: &quot;1c8acb5c-26e5-4991-b45d-ddd7e7769ebf&quot;,\r\n        &quot;SecretString&quot;: &quot;{\\&quot;10.1.90.198\\&quot;:\\&quot;-----BEGIN RSA PRIVATE KEY----- MIIEpAIBAAKCAQEAsdjy2h9hKD3KmgTPmKttKZEs+BR4xSKVJA+PTm+R5v5Z+JHQ rkRzUPKquEgmiUtzewCvwk0P6AbkQC7Mzv4Ub+dKMPQvHOog4+YHgA0QjG43lzBL wAipWRbEAssELrLXa1aJP1F1I89tp/DwAoV86tNpsgNQDbgNDJQVdhy1fnWorxIC 88HsVUYPh/v1lXz0D+kuj/VBdPHvLitqpOIs9hsEWqfZOVzkMZeEcvieJFMCCPY+ J26KSdf09TCKsxibgD9U6N7+ttkYz3/CHVR9wUmE2W4JupujdTBNOMap1/RDhJyS RLwJGy9H31N6OfJE+w+eLG7jVv8EGrgK0ZEa5wIDAQABAoIBAQCupIA2OcJKpgMi I79ICG719p3WLyQ5UbBq7Oyo9V6tGvB265mkx4sF3oZO2GsfP3xzOUVe5BXOn5Xc gRiV22NuUA3G7MKm/jK2GNkcobeybzkfuklolhjWZ0isBXhh8zUfLqcwCmmhdLwV wr+tejAk2N5d9GrUTfxicbhxd9eyCWt4ubZ559fiwBESI3P7KzCIT9lol+LO/3Tt v3CjO/MmdbFD95OCwdYKe/Kg7JZjqpTIWek82O0Yr0+RUspKf6fVM3c6Xsdcly0s o4/Kw5ni1zcRNy+bMUb7n2AN4D9FURjTIsuhl2g2NrxhrpxHBNUawqwnDCYNaaZD jhUPcUHhAoGBAMKeoLkH2BujIjdYfvR3UUDn/1AxAimvRv1ctvNkLRVY74J/WjHq +q4jy0mazLtusJrpw+jh0teRHmX5zsPzcxjYMSFyrron+/Yv8d8kZiy16N+9SkeX NnyUVAYujNUeurkRjPsoCPuV5u8kk1Md3koe5V5+TGYYFJaR9uNIZQGzAoGBAOnw J0WMIgHqa02/Kr/auaW+mAdruKsRu0k3GJlrhduBtA+OzCr6/HQ4BNq8TDBK/eBO 21Ken9fiaUzJohupwq7Kokmee//nCQMac6GE6B/aMNLGMVfvfQKtF0tlDCkQaxSn 32Y27OZbIyKc44QnUrPZQQ3i5WJ+Ca3oRRL871/9AoGAVk/Vhdn1vOQPg64qt67H CVsafu0NQYFroWfh93WBDQuhRSXH0YWd4WccfCs8CxAfIMT1zq2APXwtmBo+2eZ5 FlRv6M4KNA== -----END RSA PRIVATE KEY-----\\&quot;,\\&quot;some\\&quot;:\\&quot;value\\&quot;}&quot;,\r\n        &quot;VersionStages&quot;: [\r\n            &quot;AWSCURRENT&quot;\r\n        ],\r\n        &quot;CreatedDate&quot;: 1654095742.095,\r\n        &quot;ARN&quot;: &quot;arn:aws:secretsmanager:us-west-2:&lt;accountid&gt;:secret:ssh_key-Jmv1r1&quot;\r\n    }\r\n\r\nThe main secret id/name is ssh_key and individual key/value pairs are ipaddress/sshkey pairs.\r\nSo, how to retrieve in a bash script, so that when we provide input as ipaddress, it should retrieve the related sshkey value and save it as a file, like ssh_key.pem.\r\n\r\nI tried something with jq and able to trim metadata and came till SecureString part.\r\n\r\n    aws secretsmanager get-secret-value --secret-id ssh_key --version-stage AWSCURRENT | jq &#39;.SecretString&#39;\r\n    &quot;{\\&quot;ssh_key\\&quot;:\\&quot;-----BEGIN RSA PRIVATE KEY----- MIIEpAIBAAKCAQEAsdjy2h9hKD3KmgTPmKttKZEs+BR4xSKVJA+PTm+R5v5Z+JHQ rkRzUPKquEgmiUtzewCvwk0P6AbkQC7Mzv4Ub+dKMPQvHOog4+YHgA0QjG43lzBL wAipWRbEAssELrLXa1aJP1F1I89tp/DwAoV86tNpsgNQDbgNDJQVdhy1fnWorxIC 88HsVUYPh/v1lXz0D+kuj/VBdPHvLitqpOIs9hsEWqfZOVzkMZeEcvieJFMCCPY+ J26KSdf09TCKsxibgD9U6N7+ttkYz3/CHVR9wUmE2W4JupujdTBNOMap1/RDhJyS RLwJGy9H31N6OfJE+w+eLG7jVv8EGrgK0ZEa5wIDAQABAoIBAQCupIA2OcJKpgMi I79ICG719p3WLyQ5UbBq7Oyo9V6tGvB265mkx4sF3oZO2GsfP3xzOUVe5BXOn5Xc gRiV22NuUA3G7MKm/jK2GNkcobeybzkfuklolhjWZ0isBXhh8zUfLqcwCmmhdLwV wr+tejAk2N5d9GrUTfxicbhxd9eyCWt4ubZ559fiwBESI3P7KzCIT9lol+LO/3Tt v3CjO/MmdbFD95OCwdYKe/Kg7JZjqpTIWek82O0Yr0+RUspKf6fVM3c6Xsdcly0s o4/Kw5ni1zcRNy+bMUb7n2AN4D9FURjTIsuhl2g2NrxhrpxHBNUawqwnDCYNaaZD jhUPcUHhAoGBAMKeoLkH2BujIjdYfvR3UUDn/1AxAimvRv1ctvNkLRVY74J/WjHq U9j57nti1JBvaQuZC9mKekMCgYAdb0Ahug4VW5+AusrwNN8jAaYzWNR1gdek0K/h reu7wMgdJQR/a/ET1nCV7RdRBD6JWKKz9I18JlrFdKFXBbcfMxPUW4KSokk6ALwH 2Kc0SsnV22YeAF4kVg8WR3KOQCiZAr5TKBoKqfDzy/W8jQ4U3wMWcjQWfnFNVmpK h1S/KQKBgQCCdSSZHqjsTTVUg5yLV2IkyuiKzXC6i2xbxUH+stgxvtaVK4Xaz/Qb R9hLBe0R9RAH007ddESsIpd9HgAFMiA2URMpJgO+JCFQoNnNm4N/7HAXTN/zOsBy 8PfXXUY/27b26mWCBkRslz3x59uaPBix7ni0d0Gmv1DiFlRv6M4KNA== -----END RSA PRIVATE KEY-----\\&quot;,\\&quot;some\\&quot;:\\&quot;value\\&quot;}&quot;\r\n\r\nBut when I try to retrieve internal values, getting error as below.\r\n\r\n     aws secretsmanager get-secret-value --secret-id ssh_key --version-stage AWSCURRENT | jq &#39;.SecretString.ssh_key&#39;\r\n    jq: error (at &lt;stdin&gt;:10): Cannot index string with string &quot;ssh_key&quot;\r\n\r\nKindly guide, how to retrieve in a bash script, so that when we provide input as ipaddress, it should retrieve the related sshkey value and save it as a file, like ssh_key.pem.",
        "link": "https://stackoverflow.com/questions/72465049/how-to-retrieve-values-of-aws-secretsmanager",
        "title": "How to retrieve values of aws secretsmanager?"
    },
    {
        "tags": [
            "json",
            "object",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1654108151,
                "last_edit_date": 1654108151,
                "creation_date": 1654107743,
                "answer_id": 72466464,
                "question_id": 72466437,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Use `input` to access the second file, and redirect using `&gt;` into another file\r\n~~~sh\r\njq &#39;.country1 = input&#39; world.json country1.json &gt; world_country1.json\r\n~~~\r\n~~~json\r\n{\r\n  &quot;class&quot;: &quot;world&quot;,\r\n  &quot;version&quot;: &quot;1.1.0&quot;,\r\n  &quot;country1&quot;: {\r\n    &quot;class&quot;: &quot;country&quot;,\r\n    &quot;country_1&quot;: {\r\n      &quot;class&quot;: &quot;city&quot;,\r\n      &quot;name&quot;: &quot;seattle&quot;\r\n    }\r\n  }\r\n}\r\n~~~\r\n[Demo](https://jqplay.org/s/0ytqxwApPKX)\r\n\r\n---\r\nIf you want to utilize the file&#39;s name for the new field&#39;s name, use `input_filename` and cut off the last 5 characters (removing `.json`):\r\n~~~sh\r\njq &#39;. + (input | {(input_filename[:-5]): .})&#39; world.json country1.json &gt; world_country1.json\r\n~~~\r\n\r\n",
                "title": "Add json object into another json object using bash/jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1654108151,
        "creation_date": 1654107606,
        "question_id": 72466437,
        "body_markdown": "I am trying to create a new file adding the object defined in country1.json into world.json. Essentially: \r\n\r\nworld.json\r\n```\r\n{\r\n    &quot;class&quot;: &quot;world&quot;,\r\n    &quot;version&quot;: &quot;1.1.0&quot;\r\n}\r\n```\r\n\r\n``+``\r\n\r\ncountry1.json\r\n```\r\n{\r\n\t&quot;class&quot;: &quot;country&quot;,\r\n\t&quot;country_1&quot;: {\r\n\t\t&quot;class&quot;: &quot;city&quot;,\r\n\t\t&quot;name&quot;: &quot;seattle&quot;\r\n\t}\r\n}\r\n```\r\n\r\n``=``\r\n\r\nworld_country1.json\r\n```\r\n{\r\n\t&quot;class&quot;: &quot;world&quot;,\r\n\t&quot;version&quot;: &quot;1.1.0&quot;,\r\n\t&quot;country1&quot;: {\r\n\t\t&quot;class&quot;: &quot;country&quot;,\r\n\t\t&quot;country_1&quot;: {\r\n\t\t\t&quot;class&quot;: &quot;city&quot;,\r\n\t\t\t&quot;name&quot;: &quot;seattle&quot;\r\n\t\t}\r\n\t}\r\n}\r\n```\r\n\r\nUsing the filename for the objects in country1.json file. I would like to use bash/jq if possible.\r\n\r\nThanks for your help,\r\nBest,\r\nRomain",
        "link": "https://stackoverflow.com/questions/72466437/add-json-object-into-another-json-object-using-bash-jq",
        "title": "Add json object into another json object using bash/jq"
    },
    {
        "tags": [
            "json",
            "bash",
            "if-statement",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1654115739,
                "last_edit_date": 1654115739,
                "creation_date": 1654114280,
                "answer_id": 72467512,
                "question_id": 72467425,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You always need an `else` branch. For readability you can also pull the target up front (otherwise `.` will match the previous context).\r\n~~~sh\r\n.dashboard.panels[].targets[].expr |=\r\n  if contains(&quot;sum((rate&quot;) then . + &quot;TEST&quot; else . end\r\n~~~\r\n[Demo](https://jqplay.org/s/QifxQ6xeCFS)\r\n\r\n~~~sh\r\n.dashboard.panels[].targets[].expr |= . +\r\n  if contains(&quot;sum((rate&quot;) then &quot;TEST&quot; else &quot;&quot; end\r\n~~~\r\n[Demo](https://jqplay.org/s/ItHNfv53mPS)",
                "title": "jq if value contains then append"
            },
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1654117424,
                "last_edit_date": 1654117424,
                "creation_date": 1654114864,
                "answer_id": 72467620,
                "question_id": 72467425,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You should be able to [update-assign](https://stedolan.github.io/jq/manual/v1.6/#Update-assignment:|=) part of your objects:\r\n\r\n```\r\n.dashboard.panels[].targets[].expr |= if contains(&quot;sum((rate&quot;) then . + &quot;TEST&quot; else . end\r\n```\r\n\r\nIt&#39;s also possible to do without the `if` conditional, by first [selecting](https://stedolan.github.io/jq/manual/v1.6/#select(boolean_expression)) all the interesting paths and then modifying only them:\r\n\r\n```\r\n(.dashboard.panels[].targets[].expr | select(contains(&quot;sum((rate&quot;))) += &quot;TEST&quot;\r\n```",
                "title": "jq if value contains then append"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1654117424,
        "creation_date": 1654113698,
        "question_id": 72467425,
        "body_markdown": "This might not be the ideal way to approach this but I am working on bulk update of some Grafana dashboards. When the expr key contains value that includes something like &quot;sum((rate&quot; I want to append to the value another string.  Is this even possible?\r\n\r\n     if (.dashboard.panels[].targets[].expr | contains(&quot;sum((rate&quot;)) then . += &quot;TEST&quot; end&#39;\r\n\r\nI&#39;ve tried a few variations of then action and even removed the concatanation to see if I could get simple replace. But getting \r\n\r\n    jq: error: syntax error, unexpected end (Unix shell quoting issues?) at &lt;top-level&gt;, line 1:",
        "link": "https://stackoverflow.com/questions/72467425/jq-if-value-contains-then-append",
        "title": "jq if value contains then append"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1654168231,
                "post_id": 72475049,
                "comment_id": 128029362,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1654241600,
                "creation_date": 1654241600,
                "answer_id": 72486169,
                "question_id": 72475049,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "As per @pmf suggestion it worked\r\n\r\n    jq -r &#39;values.id&#39; /tmp/output.json",
                "title": "How to fetch only value for particular key from json output?"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1654241600,
        "creation_date": 1654167263,
        "question_id": 72475049,
        "body_markdown": "**Objective:**\r\n\r\nI want to filter json file by specific key name and to get only its value as output\r\n\r\n\r\nfilter to be used: id (in below json)\r\n\r\n\r\n**What I tried:**\r\n\r\n\r\n    cat /tmp/output.json | jq -r &#39;values&#39;\r\n    {\r\n      &quot;name&quot;: &quot;abotcontext7&quot;,\r\n      &quot;id&quot;: &quot;20436855-4635-49c0-8cc9-a389c569233b&quot;,\r\n      &quot;created_at&quot;: &quot;2022-06-02T10:39:48.280Z&quot;\r\n    }\r\n\r\nOutput should be just: `20436855-4635-49c0-8cc9-a389c569233b` \r\n\r\nI tried  `cat /tmp/output.json|jq -r &#39;.id[]`\r\n\r\nIts not working. Any suggestions please\r\n",
        "link": "https://stackoverflow.com/questions/72475049/how-to-fetch-only-value-for-particular-key-from-json-output",
        "title": "How to fetch only value for particular key from json output?"
    },
    {
        "tags": [
            "bash",
            "amazon-web-services",
            "jq",
            "aws-glue"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 1022874,
                    "reputation": 35264,
                    "user_id": 1032785,
                    "user_type": "registered",
                    "accept_rate": 50,
                    "profile_image": "https://www.gravatar.com/avatar/30816b3d787c2bd9d6f036318304f225?s=256&d=identicon&r=PG",
                    "display_name": "jordanm",
                    "link": "https://stackoverflow.com/users/1032785/jordanm"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1654178647,
                "post_id": 72477518,
                "comment_id": 128033414,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1663400932,
                "last_edit_date": 1663400932,
                "creation_date": 1663399709,
                "answer_id": 73752998,
                "question_id": 72477518,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The command line\r\n`aws glue create-job --profile $PROFILE --name $NAME --cli-input-json | jq &#39;.Command.ScriptLocation = &#39;\\&quot;$SCRIPT_LOCATION\\&quot;&#39;&#39; ./resources/config.json`\r\nexecutes the command\r\n`aws glue create-job --profile $PROFILE --name $NAME --cli-input-json`,\r\ntakes its standard output and uses it as input to\r\n`jq &#39;.Command.ScriptLocation = &#39;\\&quot;$SCRIPT_LOCATION\\&quot;&#39;&#39; ./resources/config.json`\r\n(which will ignore the input and read from the file given as argument). Please also note that blanks or spaces in `$SCRIPT_LOCATION` will break your script, because it is not quoted (your quotes are off).\r\n\r\nTo use the output of one command in the argument list of another command, you must use [Command Substitution](https://pubs.opengroup.org/onlinepubs/009604499/utilities/xcu_chap02.html#tag_02_06_03): `outer_command --some-arg &quot;$(inner_command)&quot;`.\r\n\r\nSo your command should become:\r\n\r\n```\r\naws glue create-job --profile $PROFILE --name $NAME --cli-input-json &quot;$(jq &#39;.Command.ScriptLocation = &quot;&#39;&quot;$SCRIPT_LOCATION&quot;&#39;&quot;&#39; ./resources/config.json)&quot;\r\n# or simplified with only double quotes:\r\naws glue create-job --profile $PROFILE --name $NAME --cli-input-json &quot;$(jq &quot;.Command.ScriptLocation = \\&quot;$SCRIPT_LOCATION\\&quot;&quot; ./resources/config.json)&quot;\r\n```\r\n\r\nSee &lt;https://superuser.com/questions/1306071/aws-cli-using-cli-input-json-in-a-pipeline&gt; for additional examples.\r\n\r\nAlthough, I have to admit I am not 100% certain that the JSON content can be passed directly on the command line. From looking at the docs and some official examples, it looks like this parameter expects a file name, not a JSON document&#39;s content. So it could be possible that your command in fact needs to be:\r\n\r\n```\r\n# if &quot;-&quot; filename is specially handled:\r\njq &quot;.Command.ScriptLocation = \\&quot;$SCRIPT_LOCATION\\&quot;&quot; ./resources/config.json | aws glue create-job --profile $PROFILE --name $NAME --cli-input-json -\r\n# &quot;-&quot; filename not recognized:\r\njq &quot;.Command.ScriptLocation = \\&quot;$SCRIPT_LOCATION\\&quot;&quot; ./resources/config.json &gt; ./resources/config.replaced.json &amp;&amp; aws glue create-job --profile $PROFILE --name $NAME --cli-input-json file://./resources/config.replaced.json\r\n```\r\n\r\nLet us know which one worked.\r\n",
                "title": "Passing json to aws glue create-job after replacement done using jq"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1663400932,
        "creation_date": 1654178426,
        "question_id": 72477518,
        "body_markdown": "I have the following bash script that I execute in order to create new Glue Job via CLI:\r\n\r\n    #!/usr/bin/env bash\r\n\r\n    set -e\r\n    NAME=$1\r\n    PROFILE=$2\r\n    SCRIPT_LOCATION=&#39;s3://bucket/scripts/&#39;$1&#39;.py&#39;\r\n    \r\n    echo [*]--- Creating new job on AWS\r\n    aws glue create-job --profile $PROFILE --name $NAME --cli-input-json | jq &#39;.Command.ScriptLocation = &#39;\\&quot;$SCRIPT_LOCATION\\&quot;&#39;&#39; ./resources/config.json\r\n\r\nI&#39;m using **jq** as i need one of the values to be replaced on runtime before i pass the **.json** as *--cli-input-json* argument. How can i pass json with replaced value to this command? As of now, it prints out the json content (although with value already replaced).\r\nRunning the command above causes the following error:\r\n\r\n    [*]--- Creating new job on AWS\r\n    {\r\n      &quot;Description&quot;: &quot;Template for Glue Job&quot;,\r\n      &quot;LogUri&quot;: &quot;&quot;,\r\n      &quot;Role&quot;: &quot;arn:aws:iam::11111111111:role/role&quot;,\r\n      &quot;ExecutionProperty&quot;: {\r\n        &quot;MaxConcurrentRuns&quot;: 1\r\n      },\r\n      &quot;Command&quot;: {\r\n        &quot;Name&quot;: &quot;glueetl&quot;,\r\n        &quot;ScriptLocation&quot;: &quot;s3://bucket/scripts/script.py&quot;,\r\n        &quot;PythonVersion&quot;: &quot;3&quot;\r\n      },\r\n      &quot;DefaultArguments&quot;: {\r\n        &quot;--TempDir&quot;: &quot;s3://temp/admin/&quot;,\r\n        &quot;--job-bookmark-option&quot;: &quot;job-bookmark-disable&quot;,\r\n        &quot;--enable-metrics&quot;: &quot;&quot;,\r\n        &quot;--enable-glue-datacatalog&quot;: &quot;&quot;,\r\n        &quot;--enable-continuous-cloudwatch-log&quot;: &quot;&quot;,\r\n        &quot;--enable-spark-ui&quot;: &quot;true&quot;,\r\n        &quot;--spark-event-logs-path&quot;: &quot;s3://assets/sparkHistoryLogs/&quot;\r\n      },\r\n      &quot;NonOverridableArguments&quot;: {\r\n        &quot;KeyName&quot;: &quot;&quot;\r\n      },\r\n      &quot;MaxRetries&quot;: 0,\r\n      &quot;AllocatedCapacity&quot;: 0,\r\n      &quot;Timeout&quot;: 2880,\r\n      &quot;MaxCapacity&quot;: 0,\r\n      &quot;Tags&quot;: {\r\n        &quot;KeyName&quot;: &quot;&quot;\r\n      },\r\n      &quot;NotificationProperty&quot;: {\r\n        &quot;NotifyDelayAfter&quot;: 60\r\n      },\r\n      &quot;GlueVersion&quot;: &quot;3.0&quot;,\r\n      &quot;NumberOfWorkers&quot;: 2,\r\n      &quot;WorkerType&quot;: &quot;G.1X&quot;\r\n    }\r\n    \r\n    usage: aws [options] &lt;command&gt; &lt;subcommand&gt; [&lt;subcommand&gt; ...] [parameters]\r\n    To see help text, you can run:\r\n    \r\n      aws help\r\n      aws &lt;command&gt; help\r\n      aws &lt;command&gt; &lt;subcommand&gt; help\r\n    \r\n    aws.exe: error: argument --cli-input-json: expected one argument",
        "link": "https://stackoverflow.com/questions/72477518/passing-json-to-aws-glue-create-job-after-replacement-done-using-jq",
        "title": "Passing json to aws glue create-job after replacement done using jq"
    },
    {
        "tags": [
            "json",
            "string",
            "concatenation",
            "escaping",
            "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": 1654182294,
                "post_id": 72478087,
                "comment_id": 128034932,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1654196431,
                "last_edit_date": 1654196431,
                "creation_date": 1654195258,
                "answer_id": 72480930,
                "question_id": 72478087,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "As json.org says, `&quot;any codepoint except &quot; or \\ or control characters&quot;` can be included within a JSON string without being escaped. \r\n\r\nIn the question, the given string does contain both `&quot;` and `\\`, so to convert that string to a valid JSON string, both would need to be escaped.\r\n",
                "title": "jq concatenation with special characters"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1654241565,
                "creation_date": 1654241565,
                "answer_id": 72486165,
                "question_id": 72478087,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You need to escape quotation marks inside a quoted string. And the initial `.|` is redundant:\r\n\r\n```\r\njq &#39;(.dashboard.panels[].targets[].expr | select(contains(&quot;sum((rate(wmi&quot;))) += &quot;) * on(instance, process_id) group_left(name, display_name, run_as) windows_service_info{display_name=~\\&quot;$variable\\&quot;,job=\\&quot;$job\\&quot;})&quot;&#39;\r\n```\r\n\r\n`\\{` and `\\}` must not be escaped. Unless you require a literal `\\{` in your output, then your JQ string must contain `\\\\{` and `\\\\}`.",
                "title": "jq concatenation with special characters"
            }
        ],
        "is_answered": false,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1654241565,
        "creation_date": 1654180925,
        "last_edit_date": 1654194609,
        "question_id": 72478087,
        "body_markdown": "I am trying to append some Grafana dashboard query things to existing queries. The Select works and doing a simple =+ &quot;TEST&quot; added successfully.  \r\n\r\nThe actual append I have has {} * and &quot;&quot;\r\n\r\n    &quot;) * on(instance, process_id) group_left(name, display_name, run_as) windows_service_info\\{display_name=~&quot;$variable&quot;,job=&quot;$job&quot;\\})\r\n\r\nso the jq is\r\n\r\n     jq &#39;. | (.dashboard.panels[].targets[].expr | select(contains(&quot;sum((rate(wmi&quot;))) += &quot;) * on(instance, process_id) group_left(name, display_name, run_as) windows_service_info\\{display_name=~&quot;$variable&quot;,job=&quot;$job&quot;\\})&quot;&#39;\r\n\r\nI tried the string literal\r\n\r\n    @text {&quot;text&quot;:&quot;) * on(instance, process_id) group_left(name, display_name, run_as) windows_service_info\\{display_name=~&quot;$variable&quot;,job=&quot;$job&quot;\\})&quot;}&#39;\r\n\r\ngetting errors like:\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\r\n",
        "link": "https://stackoverflow.com/questions/72478087/jq-concatenation-with-special-characters",
        "title": "jq concatenation with special characters"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1654240829,
                "last_edit_date": 1654240829,
                "creation_date": 1654240218,
                "answer_id": 72485927,
                "question_id": 72485378,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You were almost there. For arrays you could use `IN`. I also used `objects`, `strings` and `arrays` which are shortcuts to a `select` of the according types.\r\n~~~sh\r\njq &#39;[.. | objects.type | select(strings == &quot;null&quot;, IN(arrays[]; &quot;null&quot;))] | length&#39;\r\n~~~\r\n~~~json\r\n2\r\n~~~\r\n[Demo](https://jqplay.org/s/vP_TN4NRIDN)\r\n\r\n---\r\nOn larger structures you could also improve performance by not creating that array of which you would only calculate the length, but by instead just iterating over the matching items (e.g. using `reduce`) and counting on the go.\r\n~~~sh\r\njq &#39;reduce (.. | objects.type | select(strings == &quot;null&quot;, IN(arrays[]; &quot;null&quot;))) as $_ (0; .+1)&#39;\r\n~~~\r\n~~~json\r\n2\r\n~~~\r\n[Demo](https://jqplay.org/s/uLX6eX2masF)",
                "title": "Count number of objects whose attribute are &quot;null&quot; or contain &quot;null&quot;"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1654268866,
                "last_edit_date": 1654268866,
                "creation_date": 1654257884,
                "answer_id": 72489311,
                "question_id": 72485378,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "This answer focuses on efficiency, straightforwardness, and generality.\r\n\r\nIn brief, the following jq program produces 2 for the given example.\r\n\r\n```\r\n  def count(s): reduce s as $x (0; .+1);\r\n\r\n  def hasValue($value):\r\n    has(&quot;type&quot;) and \r\n      (.type | . == $value or (type == &quot;array&quot; and any(. == $value)));\r\n\r\n  count(.. | objects | select(hasValue(&quot;null&quot;)))\r\n```\r\n---\r\nNotice that using this approach, it would be easy to count the number of objects having `null` or `&quot;null&quot;`:\r\n\r\n    count(.. | objects | select(hasValue(&quot;null&quot;) or hasValue(null)))\r\n\r\n    ",
                "title": "Count number of objects whose attribute are &quot;null&quot; or contain &quot;null&quot;"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 2,
        "last_activity_date": 1654268866,
        "creation_date": 1654236752,
        "question_id": 72485378,
        "body_markdown": "I have the following JSON. From there I&#39;d like to count how many objects I have which type attribute is either &quot;null&quot; or has an array that contains the value &quot;null&quot;. In the following example, the answer would be two. Note that the JSON could also be deeply nested.\r\n\r\n```\r\n{\r\n  &quot;A&quot;: {\r\n    &quot;type&quot;: &quot;string&quot;\r\n  },\r\n  &quot;B&quot;: {\r\n    &quot;type&quot;: &quot;null&quot;\r\n  },\r\n  &quot;C&quot;: {\r\n    &quot;type&quot;: [\r\n      &quot;null&quot;,\r\n      &quot;string&quot;\r\n    ]\r\n  }\r\n}\r\n```\r\n\r\nI came up with the following, but obviously this doesn&#39;t work since it misses the arrays. Any hints how to solve this?\r\n\r\n`jq &#39;[..|select(.type?==&quot;null&quot;)] | length&#39;`\r\n",
        "link": "https://stackoverflow.com/questions/72485378/count-number-of-objects-whose-attribute-are-null-or-contain-null",
        "title": "Count number of objects whose attribute are &quot;null&quot; or contain &quot;null&quot;"
    },
    {
        "tags": [
            "json",
            "yaml",
            "jq",
            "yq"
        ],
        "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": 1654259070,
                "post_id": 72488570,
                "comment_id": 128054297,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 3760928,
                    "reputation": 351,
                    "user_id": 3125943,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/Y7Sqi.jpg?s=256",
                    "display_name": "Arockiasmy K",
                    "link": "https://stackoverflow.com/users/3125943/arockiasmy-k"
                },
                "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": 1654259933,
                "post_id": 72488570,
                "comment_id": 128054574,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 289134,
                    "reputation": 389369,
                    "user_id": 589924,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/b2cf53d5a3d25f95c0db4e025aed4153?s=256&d=identicon&r=PG",
                    "display_name": "ikegami",
                    "link": "https://stackoverflow.com/users/589924/ikegami"
                },
                "reply_to_user": {
                    "account_id": 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": 1654274247,
                "post_id": 72488570,
                "comment_id": 128059732,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1654305639,
                "last_edit_date": 1654305639,
                "creation_date": 1654298004,
                "answer_id": 72495954,
                "question_id": 72488570,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "This produces the desired output and might be close to what you want:\r\n```\r\ngojq -n --yaml-input --yaml-output &#39;\r\n  input as $data\r\n  | input as $map\r\n  | reduce ($map | keys[]) as $k ({}; .[$k] = $data[$k])\r\n&#39; data.yaml map.yaml\r\n```\r\n\r\nThen again, maybe this is even closer:\r\n```\r\ngojq -n --yaml-input --yaml-output &#39;\r\n  input as $data\r\n  | input as $map\r\n  | reduce ($map | tostream | select(length==2)) as [$k, $_] ({}; setpath($k; $data | getpath($k)) )\r\n&#39; data.yaml map.yaml\r\n```",
                "title": "Merge 2 YAML files with update in-place only"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1654305639,
        "creation_date": 1654253753,
        "question_id": 72488570,
        "body_markdown": "I have a need to merge two YAML files with YQ/JQ update only on the map file. Let me explain my scenario.\r\n\r\n`data.yaml`\r\n```yaml\r\ndata1:\r\n  subkey1: subvalue1\r\n  subkey2: subvalue2\r\n\r\ndata2: value2\r\n\r\ndata3:\r\n  subkey3: subvalue3\r\n```\r\n\r\n`map.yaml`\r\n```yaml\r\ndata1:\r\n\r\ndata3:\r\n  subkey3:\r\n```\r\n\r\n**Expected outcome:**\r\n\r\n```yaml\r\ndata1:\r\n  subkey1: subvalue1\r\n  subkey2: subvalue2\r\n\r\ndata3:\r\n  subkey3: subvalue3\r\n```\r\n\r\nI tried to look up and couldn&#39;t find any solution to achieve this. The data &amp; map are supposed to be changing.  Is there any way to achieve this in jq or yq?",
        "link": "https://stackoverflow.com/questions/72488570/merge-2-yaml-files-with-update-in-place-only",
        "title": "Merge 2 YAML files with update in-place only"
    },
    {
        "tags": [
            "arrays",
            "json",
            "bash",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1654255667,
                "creation_date": 1654255667,
                "answer_id": 72488925,
                "question_id": 72488855,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Running `jq -c &#39;.[]&#39;` produces:\r\n\r\n```\r\n$ jq -c &#39;.[]&#39; data.json\r\n{&quot;PkgName&quot;:&quot;perl-base&quot;,&quot;Severity&quot;:&quot;MEDIUM&quot;,&quot;VulnerabilityID&quot;:&quot;CVE-2020-16156&quot;,&quot;InstalledVersion&quot;:&quot;5.34.0-3ubuntu1&quot;,&quot;FixedVersion&quot;:&quot;&quot;,&quot;Title&quot;:&quot;perl-CPAN: Bypass of verification of signatures in CHECKSUMS files&quot;,&quot;PrimaryURL&quot;:&quot;https://avd.aquasec.com/nvd/cve-2020-16156&quot;,&quot;namespace&quot;:&quot;la&quot;,&quot;image&quot;:&quot;&quot;}\r\n{&quot;PkgName&quot;:&quot;tar&quot;,&quot;Severity&quot;:&quot;LOW&quot;,&quot;VulnerabilityID&quot;:&quot;CVE-2019-9923&quot;,&quot;InstalledVersion&quot;:&quot;1.34+dfsg-1build3&quot;,&quot;FixedVersion&quot;:&quot;&quot;,&quot;Title&quot;:&quot;tar: null-pointer dereference in pax_decode_header in sparse.c&quot;,&quot;PrimaryURL&quot;:&quot;https://avd.aquasec.com/nvd/cve-2019-9923&quot;,&quot;namespace&quot;:&quot;la&quot;,&quot;image&quot;:&quot;&quot;}\r\n```",
                "title": "Write JSON-array to stdout with one line pr element"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -1,
        "last_activity_date": 1654255667,
        "creation_date": 1654255292,
        "question_id": 72488855,
        "body_markdown": "I have a JSON-array that I would like to write to the STDOUT with one element pr line such that our logging tool, Grafana, can more easily pick it up.\r\n\r\n    # Our data\r\n    [\r\n      {\r\n        &quot;PkgName&quot;: &quot;perl-base&quot;,\r\n        &quot;Severity&quot;: &quot;MEDIUM&quot;,\r\n        &quot;VulnerabilityID&quot;: &quot;CVE-2020-16156&quot;,\r\n        &quot;InstalledVersion&quot;: &quot;5.34.0-3ubuntu1&quot;,\r\n        &quot;FixedVersion&quot;: &quot;&quot;,\r\n        &quot;Title&quot;: &quot;perl-CPAN: Bypass of verification of signatures in CHECKSUMS files&quot;,\r\n        &quot;PrimaryURL&quot;: &quot;https://avd.aquasec.com/nvd/cve-2020-16156&quot;,\r\n        &quot;namespace&quot;: &quot;la&quot;,\r\n        &quot;image&quot;: &quot;&quot;\r\n      },\r\n      {\r\n        &quot;PkgName&quot;: &quot;tar&quot;,\r\n        &quot;Severity&quot;: &quot;LOW&quot;,\r\n        &quot;VulnerabilityID&quot;: &quot;CVE-2019-9923&quot;,\r\n        &quot;InstalledVersion&quot;: &quot;1.34+dfsg-1build3&quot;,\r\n        &quot;FixedVersion&quot;: &quot;&quot;,\r\n        &quot;Title&quot;: &quot;tar: null-pointer dereference in pax_decode_header in sparse.c&quot;,\r\n        &quot;PrimaryURL&quot;: &quot;https://avd.aquasec.com/nvd/cve-2019-9923&quot;,\r\n        &quot;namespace&quot;: &quot;la&quot;,\r\n        &quot;image&quot;: &quot;&quot;\r\n      }\r\n    ]\r\n\r\nWhat I need:\r\n\r\n    {&quot;PkgName&quot;: &quot;perl-base&quot;, &quot;Severity&quot;: &quot;MEDIUM&quot;, &quot;VulnerabilityID&quot;: &quot;CVE-2020-16156&quot;, &quot;InstalledVersion&quot;: &quot;5.34.0-3ubuntu1&quot;, &quot;FixedVersion&quot;: &quot;&quot;, &quot;Title&quot;: &quot;perl-CPAN: Bypass of verification of signatures in CHECKSUMS files&quot;, &quot;PrimaryURL&quot;: &quot;https://avd.aquasec.com/nvd/cve-2020-16156&quot;, &quot;namespace&quot;: &quot;la&quot;, &quot;image&quot;: &quot;&quot;}\r\n    {&quot;PkgName&quot;: &quot;tar&quot;,&quot;Severity&quot;: &quot;LOW&quot;,&quot;VulnerabilityID&quot;: &quot;CVE-2019-9923&quot;,&quot;InstalledVersion&quot;: &quot;1.34+dfsg-1build3&quot;,&quot;FixedVersion&quot;: &quot;&quot;,&quot;Title&quot;: &quot;tar: null-pointer dereference in pax_decode_header in sparse.c&quot;,&quot;PrimaryURL&quot;: &quot;https://avd.aquasec.com/nvd/cve-2019-9923&quot;,&quot;namespace&quot;: &quot;la&quot;,&quot;image&quot;: &quot;&quot;}\r\n\r\nIs there an easy way to achieve this using **jq** or a similar **default** ubuntu tool?",
        "link": "https://stackoverflow.com/questions/72488855/write-json-array-to-stdout-with-one-line-pr-element",
        "title": "Write JSON-array to stdout with one line pr element"
    },
    {
        "tags": [
            "json",
            "filter",
            "nested",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1654356973,
                "last_edit_date": 1654356973,
                "creation_date": 1654354954,
                "answer_id": 72500794,
                "question_id": 72500269,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The `&amp;&amp;` must be replaced with `and`. On the result you can use `| flatten` to convert &quot;array of arrays of objects&quot; into just &quot;array of objects&quot;.\r\n\r\nBonus A: Use the `-c/--compact-output` flag of `jq` together with `| flatten[]` instead of just `| flatten`.\r\n\r\nTogether: \r\n\r\n```\r\njq -c &#39;\r\n[\r\n    ..\r\n    | objects\r\n    | ( .QueryString, .Params )\r\n    | select(. != null and . != [])\r\n]\r\n| flatten[]&#39; input.json\r\n```\r\n\r\nAlthough this expression can be simplified into `.. | objects | .QueryString[]?, .Params[]?`\r\nThe output is:\r\n```\r\n{&quot;Name&quot;:&quot;ClassName&quot;,&quot;Value&quot;:&quot;PRODUCT&quot;}\r\n{&quot;Name&quot;:&quot;ListID&quot;,&quot;Value&quot;:&quot;Products&quot;}\r\n{&quot;Name&quot;:&quot;Mode &quot;,&quot;Value&quot;:&quot;1&quot;}\r\n{&quot;Name&quot;:&quot;Dept&quot;,&quot;Value&quot;:&quot;5&quot;}\r\n{&quot;Name&quot;:&quot;HasPrevOrder&quot;,&quot;Value&quot;:&quot;&quot;}\r\n{&quot;Name&quot;:&quot;IsOrdered&quot;,&quot;Value&quot;:&quot;1&quot;}\r\n{&quot;Name&quot;:&quot;TimeStamp&quot;,&quot;Value&quot;:&quot;11654116426247&quot;}\r\n{&quot;Name&quot;:&quot;IsOrdered&quot;,&quot;Value&quot;:&quot;1&quot;}\r\n{&quot;Name&quot;:&quot;TimeStamp&quot;,&quot;Value&quot;:&quot;11654116426247&quot;}\r\n```",
                "title": "How to make jq to pick name value pairs"
            },
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1654393062,
                "last_edit_date": 1654393062,
                "creation_date": 1654374296,
                "answer_id": 72502921,
                "question_id": 72500269,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "To get the Name/Value objects, one per line, you could go with:\r\n```\r\njq -c &#39;.. | objects | (.QueryString, .Params) | .. | objects | select( .Name and .Value)&#39; \r\n```\r\nor more cavalierly:\r\n```\r\n    jq -c &#39;.. | objects | select( .Name and .Value)&#39;\r\n```",
                "title": "How to make jq to pick name value pairs"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1654393062,
        "creation_date": 1654350466,
        "last_edit_date": 1654351018,
        "question_id": 72500269,
        "body_markdown": "Might be more or less the same ask as https://stackoverflow.com/questions/57510887/how-to-get-jq-name-value-pair-from-nested-array-response, but that question and example there is way too convoluted than what I&#39;m asking --\r\n\r\nGiving the input jason as in https://jqplay.org/s/jyKBnpx9NYX  \r\nPick out all the name/value pair under `.QueryString, .Params` into the same unnested array\r\n\r\nE.g., for an input of \r\n\r\n```js\r\n{\r\n    &quot;Some&quot;: &quot;Random stuff&quot;,\r\n    &quot;One&quot;: {\r\n        &quot;QueryString&quot;: [\r\n           { &quot;Name&quot;: &quot;IsOrdered&quot;,    &quot;Value&quot;: &quot;1&quot;              },\r\n           { &quot;Name&quot;: &quot;TimeStamp&quot;,    &quot;Value&quot;: &quot;11654116426247&quot; }\r\n        ]\r\n    },\r\n    &quot;Two&quot;: {\r\n        &quot;QueryString&quot;: [\r\n           { &quot;Name&quot;: &quot;IsOrdered&quot;,    &quot;Value&quot;: &quot;1&quot;              },\r\n           { &quot;Name&quot;: &quot;TimeStamp&quot;,    &quot;Value&quot;: &quot;11654116426247&quot; }\r\n        ]\r\n    },\r\n    &quot;Params&quot;: [\r\n       { &quot;Name&quot;: &quot;ClassName&quot;,    &quot;Value&quot;: &quot;PRODUCT&quot;        },\r\n       { &quot;Name&quot;: &quot;ListID&quot;,       &quot;Value&quot;: &quot;Products&quot;       },\r\n       { &quot;Name&quot;: &quot;Mode &quot;,        &quot;Value&quot;: &quot;1&quot;              },\r\n       { &quot;Name&quot;: &quot;Dept&quot;  ,       &quot;Value&quot;: &quot;5&quot;              },\r\n       { &quot;Name&quot;: &quot;HasPrevOrder&quot;, &quot;Value&quot;: &quot;&quot;               }\r\n    ],\r\n    &quot;And&quot;: {\r\n        &quot;QueryString&quot;:[]\r\n    },\r\n    &quot;More&quot;: &quot;like&quot;,\r\n    &quot;More+&quot;: &quot;this&quot;\r\n}\r\n```\r\n\r\nThe output would be:\r\n\r\n```js\r\n  [\r\n    {\r\n      &quot;Name&quot;: &quot;IsOrdered&quot;,\r\n      &quot;Value&quot;: &quot;1&quot;\r\n    },\r\n    {\r\n      &quot;Name&quot;: &quot;TimeStamp&quot;,\r\n      &quot;Value&quot;: &quot;11654116426247&quot;\r\n    },\r\n    {\r\n      &quot;Name&quot;: &quot;IsOrdered&quot;,\r\n      &quot;Value&quot;: &quot;1&quot;\r\n    },\r\n    {\r\n      &quot;Name&quot;: &quot;TimeStamp&quot;,\r\n      &quot;Value&quot;: &quot;11654116426247&quot;\r\n    },\r\n    {\r\n      &quot;Name&quot;: &quot;ClassName&quot;,\r\n      &quot;Value&quot;: &quot;PRODUCT&quot;\r\n    },\r\n    {\r\n      &quot;Name&quot;: &quot;ListID&quot;,\r\n      &quot;Value&quot;: &quot;Products&quot;\r\n    },\r\n  ...\r\n  ],\r\n\r\n```\r\n\r\nwithout any empty arrays output (`[]`), while keep the repeated values in the array.\r\n\r\nI tried to remove empty arrays output (`[]`) by changing the jq expression from\r\n\r\n`[( .. | objects | ( .QueryString, .Params ) | select( . != null) )]`\r\n\r\nto\r\n\r\n`[( .. | objects | ( .QueryString, .Params ) | select( . != null &amp;&amp; . != []) )]`\r\n\r\nbut it failed. \r\n\r\nAnd the final output need to be unnested into a single array too.\r\n\r\nBonus Q: Would it be possible to output each name/value pair on one line of their own like the following?\r\n\r\n\r\n           { &quot;Name&quot;: &quot;IsOrdered&quot;,    &quot;Value&quot;: &quot;1&quot;              },\r\n           { &quot;Name&quot;: &quot;TimeStamp&quot;,    &quot;Value&quot;: &quot;11654116426247&quot; },\r\n           { &quot;Name&quot;: &quot;IsOrdered&quot;,    &quot;Value&quot;: &quot;1&quot;              },\r\n           { &quot;Name&quot;: &quot;TimeStamp&quot;,    &quot;Value&quot;: &quot;11654116426247&quot; },\r\n",
        "link": "https://stackoverflow.com/questions/72500269/how-to-make-jq-to-pick-name-value-pairs",
        "title": "How to make jq to pick name value pairs"
    },
    {
        "tags": [
            "bash",
            "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": 1654438970,
                "post_id": 72507808,
                "comment_id": 128086047,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 4879,
                    "reputation": 248190,
                    "user_id": 7552,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/b60298053f87465641c1b1192338c8cd?s=256&d=identicon&r=PG",
                    "display_name": "glenn jackman",
                    "link": "https://stackoverflow.com/users/7552/glenn-jackman"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1654445904,
                "post_id": 72507808,
                "comment_id": 128087645,
                "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": 1654449697,
                "post_id": 72507808,
                "comment_id": 128088524,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1654436932,
                "creation_date": 1654436932,
                "answer_id": 72507862,
                "question_id": 72507808,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I can&#39;t reproduce the problem you&#39;ve described. If I start with your `base_dependencies.txt` file, and run:\r\n\r\n```\r\n$ base_modules=$(echo | jq &#39;.modules[]&#39; base_dependencies.txt )\r\n```\r\n\r\nI get:\r\n\r\n```\r\n$ echo $base_modules\r\n{ &quot;properties&quot;: {}, &quot;type&quot;: &quot;generic&quot;, &quot;id&quot;: &quot;test&quot;, &quot;artifacts&quot;: [ { &quot;type&quot;: &quot;jar&quot;, &quot;sha1&quot;: &quot;bef8dd3&quot;, &quot;sha256&quot;: &quot;1c2ba8cb5369d&quot;, &quot;md5&quot;: &quot;f60031d2a0ef13dd8505b61af90c1c44&quot;, &quot;name&quot;: &quot;test-0-SNAPSHOT16.jar&quot;, &quot;path&quot;: &quot;libs-release-local/libs7/test-0-SNAPSHOT16.jar&quot; } ] }\r\n```\r\n\r\nOr with quotes:\r\n\r\n```\r\n$ echo &quot;$base_modules&quot;\r\n{\r\n  &quot;properties&quot;: {},\r\n  &quot;type&quot;: &quot;generic&quot;,\r\n  &quot;id&quot;: &quot;test&quot;,\r\n  &quot;artifacts&quot;: [\r\n    {\r\n      &quot;type&quot;: &quot;jar&quot;,\r\n      &quot;sha1&quot;: &quot;bef8dd3&quot;,\r\n      &quot;sha256&quot;: &quot;1c2ba8cb5369d&quot;,\r\n      &quot;md5&quot;: &quot;f60031d2a0ef13dd8505b61af90c1c44&quot;,\r\n      &quot;name&quot;: &quot;test-0-SNAPSHOT16.jar&quot;,\r\n      &quot;path&quot;: &quot;libs-release-local/libs7/test-0-SNAPSHOT16.jar&quot;\r\n    }\r\n  ]\r\n}\r\n```\r\n\r\n---\r\n\r\nNote that the command you&#39;re using to set `base_modules` doesn&#39;t need\r\nthat `echo`; it should be:\r\n\r\n```\r\n$ base_modules=$(jq &#39;.modules[]&#39; base_dependencies.txt )\r\n```",
                "title": "jq bash variable is showing incomplete value"
            },
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1654454621,
                "creation_date": 1654454621,
                "answer_id": 72510180,
                "question_id": 72507808,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The output `}path&quot;: ` makes me think, that this is -- once again -- a DOS/Unix EOL mismatch where a Windows `jq` executable is called from a Git4Windows/Cygwin/WSL `bash`.\r\n\r\nTry if this works:\r\n\r\n    base_modules=$(jq &#39;.modules[]&#39; base_dependency.txt | dos2unix)\r\n\r\nSee https://stackoverflow.com/a/72296242/947357 for a similar problem.",
                "title": "jq bash variable is showing incomplete value"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1654454710,
        "creation_date": 1654436417,
        "last_edit_date": 1654454710,
        "question_id": 72507808,
        "body_markdown": "I have a JSON file and want to copy modules array into a bash variable.\r\nThe problem I am trying to solve is I have two dependencies (similar) as below. It has modules array in each. I want to merge these two modules arrays.\r\n\r\n    base_dependencies.txt\r\n\r\n    {\r\n        &quot;version&quot;: &quot;1.0.1&quot;,\r\n        &quot;name&quot;: &quot;test&quot;,\r\n        &quot;number&quot;: &quot;1990&quot;,\r\n        &quot;buildAgent&quot;: {\r\n            &quot;name&quot;: &quot;GENERIC&quot;,\r\n            &quot;version&quot;: &quot;2.16.4&quot;\r\n        },\r\n        &quot;agent&quot;: {\r\n            &quot;name&quot;: &quot;jfrog-cli-go&quot;,\r\n            &quot;version&quot;: &quot;2.16.4&quot;\r\n        },\r\n        &quot;started&quot;: &quot;2022-05-20T15:01:48.827-0500&quot;,\r\n        &quot;durationMillis&quot;: 0,\r\n        &quot;artifactoryPrincipal&quot;: &quot;test&quot;,\r\n        &quot;modules&quot;: [{\r\n            &quot;properties&quot;: {},\r\n            &quot;type&quot;: &quot;generic&quot;,\r\n            &quot;id&quot;: &quot;test&quot;,\r\n            &quot;artifacts&quot;: [{\r\n                &quot;type&quot;: &quot;jar&quot;,\r\n                &quot;sha1&quot;: &quot;bef8dd3&quot;,\r\n                &quot;sha256&quot;: &quot;1c2ba8cb5369d&quot;,\r\n                &quot;md5&quot;: &quot;f60031d2a0ef13dd8505b61af90c1c44&quot;,\r\n                &quot;name&quot;: &quot;test-0-SNAPSHOT16.jar&quot;,\r\n                &quot;path&quot;: &quot;libs-release-local/libs7/test-0-SNAPSHOT16.jar&quot;\r\n            }]\r\n        }]\r\n    }\r\n\r\nWhen i run\r\n\r\n    jq &#39;.modules[]&#39; base_dependency.txt\r\n\r\ni am getting following output \r\n\r\n        {\r\n      &quot;properties&quot;: {},\r\n      &quot;type&quot;: &quot;generic&quot;,\r\n      &quot;id&quot;: &quot;test&quot;,\r\n      &quot;artifacts&quot;: [\r\n        {\r\n          &quot;type&quot;: &quot;jar&quot;,\r\n          &quot;sha1&quot;: &quot;bef8dd3&quot;,\r\n          &quot;sha256&quot;: &quot;1c2ba8cb5369d&quot;,\r\n          &quot;md5&quot;: &quot;f60031d2a0ef13dd8505b61af90c1c44&quot;,\r\n          &quot;name&quot;: &quot;test-0-SNAPSHOT16.jar&quot;,\r\n          &quot;path&quot;: &quot;libs-release-local/libs7/test-0-SNAPSHOT16.jar&quot;\r\n        }\r\n      ]\r\n    }\r\n\r\nTrying to assign the this to a variable so that i can merge both the variables.\r\n\r\n    base_modules=$(echo | jq &#39;.modules[]&#39; base_dependency.txt )\r\n\r\nBut when i echo base_modules in git bash\r\n\r\n    $ echo $base_modules\r\n     }path&quot;: &quot;libs-release-local/libs7/test-0-SNAPSHOT16.jar&quot;\r\n\r\nWhat am doing wrong.\r\n",
        "link": "https://stackoverflow.com/questions/72507808/jq-bash-variable-is-showing-incomplete-value",
        "title": "jq bash variable is showing incomplete value"
    },
    {
        "tags": [
            "json",
            "filter",
            "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": 1654458640,
                "post_id": 72510429,
                "comment_id": 128090628,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2435926,
                    "reputation": 23422,
                    "user_id": 2125837,
                    "user_type": "registered",
                    "accept_rate": 83,
                    "profile_image": "https://www.gravatar.com/avatar/760b6ec2b6e1cba2b0218178425f4cde?s=256&d=identicon&r=PG",
                    "display_name": "xpt",
                    "link": "https://stackoverflow.com/users/2125837/xpt"
                },
                "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": 1654460089,
                "post_id": 72510429,
                "comment_id": 128090960,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1654469091,
                "last_edit_date": 1654469091,
                "creation_date": 1654467439,
                "answer_id": 72511477,
                "question_id": 72510429,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can chain as many assignments as necessary :\r\n\r\n```\r\njq &#39;( .. | objects | ( .QueryString, .Params ) | select(.) )\r\n         |= ( map( @uri &quot;\\( .Name )=\\( .Value )&quot; ) | join(&quot;&amp;&quot;) )\r\n    |\r\n    ( .. | objects | .Headers | select(.) )\r\n         |= map(select(.Name|IN(&quot;Accept&quot;, &quot;Referer&quot;, &quot;User-Agent&quot;)))\r\n   &#39;\r\n```\r\n\r\nUsing `walk` is more performant :\r\n\r\n```\r\njq &#39;walk(\r\n      ( objects | ( .QueryString, .Params ) | select(.) )\r\n         |= ( map( @uri &quot;\\( .Name )=\\( .Value )&quot; ) | join(&quot;&amp;&quot;) )\r\n      |\r\n      ( objects | .Headers | select(.) )\r\n         |= map(select(.Name|IN(&quot;Accept&quot;, &quot;Referer&quot;, &quot;User-Agent&quot;)))\r\n   )&#39;\r\n```",
                "title": "jq to change one thing and filter another"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1654469091,
        "creation_date": 1654456635,
        "last_edit_date": 1654459621,
        "question_id": 72510429,
        "body_markdown": "Following on https://stackoverflow.com/questions/72500269/how-to-make-jq-to-pick-name-value-pairs, which will change/transform the name value pairs. Would it be possible to filter on *another* field in the same go, or I have to pipe the result to another jq to do the extra filtering?\r\n\r\nHere is the test data:\r\nhttps://jqplay.org/s/_HqPFze-PhZ\r\n\r\nThe change/transform of the name value pairs under `.QueryString, .Params` has already been done.\r\nNow I want to further filter the result on the `Headers` record, and would only need the fields of `Accept`, `User-Agent`, and `Referer`, and discard any other fields that might exist. I.e.,\r\n\r\nThe final result would be the same as \r\nhttps://jqplay.org/s/_HqPFze-PhZ\r\nexcept that the the `Headers` record now only has the `Accept`, `User-Agent`, and `Referer` remains:\r\n\r\n```js\r\n. . .\r\n    &quot;Headers&quot;: [\r\n      {\r\n        &quot;Name&quot;: &quot;Accept&quot;,\r\n        &quot;Value&quot;: &quot;text/html, application/xhtml+xml&quot;\r\n      },\r\n      {\r\n        &quot;Name&quot;: &quot;User-Agent&quot;,\r\n        &quot;Value&quot;: &quot;Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/102.0.0.0 Safari/537.36&quot;\r\n      },\r\n      {\r\n        &quot;Name&quot;: &quot;Referer&quot;,\r\n        &quot;Value&quot;: &quot;http://mytest.com/sign_in&quot;\r\n      }\r\n    ]\r\n. . .\r\n```\r\n\r\nEverything else should *remain the same* as the sample output.\r\n",
        "link": "https://stackoverflow.com/questions/72510429/jq-to-change-one-thing-and-filter-another",
        "title": "jq to change one thing and filter another"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1654527276,
                "creation_date": 1654527276,
                "answer_id": 72519500,
                "question_id": 72519351,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Your idea was right. You need to move the second condition _inside_ the select statement to add a boolean AND logic. All `select` needs is a boolean `true/false` to be evaluated, depending on any set of conditions inside. If the conditions evaluate to `true`, the object is selected for output, else it is not.\r\n\r\n\r\n```none\r\nselect((.state != &quot;ProfileApplied&quot;) and (.name | contains(&quot;3par&quot;) | not))\r\n```",
                "title": "jq filter to add multiple conditions to select statement"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1654527470,
        "creation_date": 1654526562,
        "last_edit_date": 1654527470,
        "question_id": 72519351,
        "body_markdown": "I have a json file with contents like: \r\n\r\n```json\r\n{\r\n    &quot;name&quot;: &quot;pp-site1-r1-n2&quot;,\r\n    &quot;state&quot;: &quot;Monitored&quot;,\r\n    &quot;stateReason&quot;: &quot;NotApplicable&quot;\r\n}\r\n{\r\n    &quot;name&quot;: &quot;bb-site2-3par-ilo&quot;,\r\n    &quot;state&quot;: &quot;Monitored&quot;,\r\n    &quot;stateReason&quot;: &quot;NotApplicable&quot;\r\n}\r\n{\r\n    &quot;name&quot;: &quot;tm-site1-r3-n4-ilo&quot;,\r\n    &quot;state&quot;: &quot;ProfileError&quot;,\r\n    &quot;stateReason&quot;: &quot;NotApplicable&quot;\r\n}\r\n{\r\n    &quot;name&quot;: &quot;tm-site3-r1-n6-ilo&quot;,\r\n    &quot;state&quot;: &quot;ProfileApplied&quot;,\r\n    &quot;stateReason&quot;: &quot;NotApplicable&quot;\r\n}\r\n```\r\n\r\nThe normal state for servers is ProfileApplied.  So, I want to see all non-normal server states.  So, I run: \r\n\r\n```none\r\njq &#39;. | select(.state!=&quot;ProfileApplied&quot;)&#39;\r\n```\r\n\r\nwhich gives: \r\n\r\n```json\r\n{\r\n  &quot;name&quot;: &quot;pp-site1-r1-n2&quot;,\r\n  &quot;state&quot;: &quot;Monitored&quot;,\r\n  &quot;stateReason&quot;: &quot;NotApplicable&quot;\r\n}\r\n{\r\n  &quot;name&quot;: &quot;bb-site2-3par-ilo&quot;,\r\n  &quot;state&quot;: &quot;Monitored&quot;,\r\n  &quot;stateReason&quot;: &quot;NotApplicable&quot;\r\n}\r\n{\r\n  &quot;name&quot;: &quot;tm-site1-r3-n4-ilo&quot;,\r\n  &quot;state&quot;: &quot;ProfileError&quot;,\r\n  &quot;stateReason&quot;: &quot;NotApplicable&quot;\r\n}\r\n```\r\n\r\nwhich is good.  However, I&#39;m also not interested in the 3par devices.  If I add to the query with: \r\n\r\n```none\r\njq &#39;. | select(.state!=&quot;ProfileApplied&quot;) | .name | contains(&quot;3par&quot;)|not&#39;\r\n```  \r\n\r\nit gives me: \r\n\r\n```none\r\ntrue\r\nfalse\r\ntrue\r\n```\r\n\r\nwhich is correct, but I really want the json object returned to match the &quot;true&quot; values.  Does anyone know how I achieve that?",
        "link": "https://stackoverflow.com/questions/72519351/jq-filter-to-add-multiple-conditions-to-select-statement",
        "title": "jq filter to add multiple conditions to select statement"
    },
    {
        "tags": [
            "jq",
            "kubectl"
        ],
        "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": 1654533055,
                "post_id": 72520369,
                "comment_id": 128107795,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1654533393,
                "post_id": 72520369,
                "comment_id": 128107908,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1654535723,
                "creation_date": 1654535723,
                "answer_id": 72521209,
                "question_id": 72520369,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You need to include `.metadata.name` :\r\n\r\n```\r\nkubectl get deploy -o json |\r\n  jq -r &#39;.items[] | &quot;\\(.metadata.name) \\(.spec.template.spec.containers[].name)&quot;&#39;\r\n```",
                "title": "Use kubectl find out how many Deployments don&#39;t have a container called &quot;main&quot;"
            },
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1654632616,
                "last_edit_date": 1654632616,
                "creation_date": 1654539738,
                "answer_id": 72521945,
                "question_id": 72520369,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The below command would print the deployment name and the container names. `grep -v` would filter out whatever you need to remove. \r\n\r\n    kubectl get deployment  -o custom-columns=&#39;&quot;DEPLOYMENT-NAME&quot;:.metadata.name,&quot;CONTAINER-NAME&quot;:.spec.template.spec.containers[*].name&#39;\r\n    \r\n    DEPLOYMENT-NAME   CONTAINER-NAME\r\n    foo               httpd\r\n    foobar            nginx\r\n    foobar007         nginx\r\n    foobar123         nginx\r\n    zoo               nginx,main\r\n    zoo1              busybox,main\r\n\r\nThe above command may be further modified to trim the output header.\r\n\r\n    kubectl get deployment --no-headers -o custom-columns=&#39;&quot;&quot;:.metadata.name,&quot;&quot;:.spec.template.spec.containers[*].name&#39;\r\n    foo               httpd\r\n    foobar            nginx\r\n    foobar007         nginx\r\n    foobar123         nginx\r\n    zoo               nginx,main\r\n    zoo1              busybox,main\r\n\r\n \r\n",
                "title": "Use kubectl find out how many Deployments don&#39;t have a container called &quot;main&quot;"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1654632616,
        "creation_date": 1654531135,
        "last_edit_date": 1654631932,
        "question_id": 72520369,
        "body_markdown": "I want to be able to quickly figure out how many Deployments in a namespace don&#39;t have a container named &quot;main&quot;. \r\n\r\nThis is as close as I have got so far, using jq, which gives me a list of all container names: \r\n\r\n```bash\r\nkubectl get deploy -o json | jq &#39;.items[].spec.template.spec.containers[].name&#39;\r\n\r\n&quot;main&quot;\r\n&quot;main&quot;\r\n&quot;healthchecker&quot;\r\n&quot;main&quot;\r\n&quot;main&quot;\r\n&quot;service&quot;\r\n&quot;main&quot;\r\n&quot;main&quot;\r\n```\r\n\r\nThe problem with that is, I can&#39;t see which containers belong to which Deployments.\r\n",
        "link": "https://stackoverflow.com/questions/72520369/use-kubectl-find-out-how-many-deployments-dont-have-a-container-called-main",
        "title": "Use kubectl find out how many Deployments don&#39;t have a container called &quot;main&quot;"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1654548367,
                "post_id": 72523173,
                "comment_id": 128112383,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1654549551,
                "creation_date": 1654549551,
                "answer_id": 72523471,
                "question_id": 72523173,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Would the following work for you?\r\n\r\n```\r\ngroup_by(.some_id) | map({\r\nsome_id: map(.some_id) | first,\r\nitems_1: map(.items_1) | add | unique,\r\nitems_2: map(.items_2) | add | unique })\r\n```\r\n\r\n[demo](https://jqplay.org/s/qIi3HA4-XMa)",
                "title": "JQ: Merging array entities with same attribute name"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1654549551,
        "creation_date": 1654547489,
        "last_edit_date": 1654548703,
        "question_id": 72523173,
        "body_markdown": "I have a data structure like this:\r\n\r\n```\r\n[\r\n    {\r\n      &quot;some_id&quot;: &quot;123&quot;,\r\n      &quot;items_1&quot;: [\r\n        {\r\n          &quot;label&quot;: &quot;my_name&quot;\r\n        }\r\n      ],\r\n      &quot;items_2&quot;: []\r\n    },\r\n    {\r\n      &quot;some_id&quot;: &quot;123&quot;,\r\n      &quot;items_1&quot;: [],\r\n      &quot;items_2&quot;: [\r\n        &quot;value_1&quot;,\r\n        &quot;value_3&quot;\r\n      ]\r\n    },\r\n    {\r\n      &quot;some_id&quot;: &quot;123&quot;,\r\n      &quot;items_1&quot;: [],\r\n      &quot;items_2&quot;: [\r\n        &quot;value_1&quot;,\r\n        &quot;value_2&quot;\r\n      ]\r\n    }\r\n]\r\n```\r\n\r\nAnd I want to modify the data into something like\r\n\r\n```\r\n\r\n[\r\n    {\r\n      &quot;some_id&quot;: &quot;123&quot;,\r\n      &quot;items_1&quot;: [\r\n        {\r\n          &quot;label&quot;: &quot;my_name&quot;\r\n        }\r\n      ],\r\n      &quot;items_2&quot;: [\r\n        &quot;value_1&quot;,\r\n        &quot;value_2&quot;,\r\n        &quot;value_3&quot;\r\n      ]\r\n    }\r\n]\r\n```\r\n\r\nBasically taking any fields that are the same and concatenating the arrays together. Similarly, items_1 can have some value for the same id down the line and I want to concatenate that array with another if needed.\r\n\r\n\r\nI have tried using JQ with something like\r\n\r\n```\r\njq -Mr &#39;[ group_by(.media_url)[] | add | tojson ] | join(&quot;,\\n&quot;)&#39; test.json\r\n```\r\n\r\nHowever this doesnt seem to be working.",
        "link": "https://stackoverflow.com/questions/72523173/jq-merging-array-entities-with-same-attribute-name",
        "title": "JQ: Merging array entities with same attribute name"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1654595100,
                "creation_date": 1654595100,
                "answer_id": 72529082,
                "question_id": 72528017,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Use `has` to check for the presence of that key, in combination with `not` to invert the result:\r\n~~~sh\r\njq &#39;has(&quot;blacklisted_library_found&quot;) | not&#39;\r\n~~~\r\nThis produces `true` for the first example, and `false` for the second.\r\n[Demo](https://jqplay.org/s/ga6w0rSrFci)",
                "title": "jq - return true when key is not present"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1654595100,
        "creation_date": 1654589927,
        "last_edit_date": 1654590057,
        "question_id": 72528017,
        "body_markdown": "I have a test that uses jq results and returns **&quot;true&quot;** when a key name does ***not*** exist in my json and **false** when it does\r\n\r\nSpecifically I have JSON like this ( first example)\r\n```json\r\n{\r\n  &quot;control&quot;: &quot;library_blacklist&quot;,\r\n  &quot;policy_id&quot;: 13,\r\n  &quot;policy_name&quot;: &quot;the-policy&quot;\r\n}\r\n```\r\nHowever when a blacklisted library is found then the output looks like this (second example)\r\n\r\n```json\r\n{\r\n  &quot;blacklisted_library_found&quot;: [\r\n    &quot;library.dll&quot;\r\n  ],\r\n  &quot;control&quot;: &quot;library_blacklist&quot;,\r\n  &quot;failed&quot;: true,\r\n  &quot;policy_id&quot;: 13,\r\n  &quot;policy_name&quot;: &quot;the-policy&quot;\r\n}\r\n```\r\nSo I need a jq query that will resolve to true in the first example where key &quot;blacklisted_library_found&quot; is *not* present and false in the second example where key blacklisted_library_found *is* present\r\n",
        "link": "https://stackoverflow.com/questions/72528017/jq-return-true-when-key-is-not-present",
        "title": "jq - return true when key is not present"
    },
    {
        "tags": [
            "python",
            "json",
            "amazon-web-services",
            "aws-cloudformation",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1654651820,
                "creation_date": 1654651820,
                "answer_id": 72539106,
                "question_id": 72532938,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You could use the following jq fragment in your pipeline:\r\n```\r\nwith_entries( select(.key|contains(&quot;cdkpipelinePipeline&quot;)|not) )\r\n```",
                "title": "Using JQ to delete blocks from CloudFormation.template.json"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": -1,
        "last_activity_date": 1654651820,
        "creation_date": 1654611947,
        "last_edit_date": 1654612264,
        "question_id": 72532938,
        "body_markdown": "I&#39;m using jq (on bash) to delete blocks from json templates. I&#39;m currently deleting 50% of what I want, by using the &quot;Type&quot; element from CloudFormation templates : \r\n\r\n```jq &#39;(del(.Resources | .[] | select(.Type==&quot;AWS::CodePipeline::Pipeline&quot;)))&#39; $fileName &gt; newTemplate1.json``` \r\n\r\nI Would also need to delete every resources that contains &quot;cdkpipelinePipeline&quot;, before the Type block : \r\n\r\n```{\r\n  { &quot;developcdkpipelinePipeline&quot;: {\r\n      &quot;Type&quot;: &quot;AWS::CodePipeline::Pipeline&quot;,\r\n      &quot;Properties&quot;: {\r\n        &quot;RoleArn&quot;: {\r\n          &quot;Fn::GetAtt&quot;: [\r\n            &quot;developcdkpipelinePipelineRole&quot;,\r\n            &quot;Arn&quot;\r\n          ]\r\n        }\r\n    }\r\n  },\r\n\r\n    &quot;developcdkpipelinePipelineRole&quot;: {\r\n      &quot;Type&quot;: &quot;AWS::IAM::Role&quot;,\r\n      &quot;Properties&quot;: {\r\n        &quot;AssumeRolePolicyDocument&quot;: {\r\n          &quot;Statement&quot;: [\r\n            {\r\n              &quot;Action&quot;: &quot;sts:AssumeRole&quot;,\r\n              &quot;Effect&quot;: &quot;Allow&quot;,\r\n              &quot;Principal&quot;: {\r\n                &quot;Service&quot;: &quot;codepipeline.amazonaws.com&quot;\r\n              }\r\n            }\r\n          ],\r\n          &quot;Version&quot;: &quot;2012-10-17&quot;\r\n        },\r\n        &quot;Tags&quot;: [\r\n          {\r\n            &quot;Key&quot;: &quot;Application&quot;,\r\n            &quot;Value&quot;: &quot;develop&quot;\r\n          }\r\n        ]\r\n      },\r\n      &quot;DependsOn&quot;: [\r\n        &quot;AuroraNestedStackAuroraNestedStackResource&quot;\r\n      ],\r\n      &quot;Metadata&quot;: {\r\n        &quot;aws:cdk:path&quot;: &quot;develop-cicd-stack/develop-cdkpipeline/Pipeline/Role/Resource&quot;\r\n      }\r\n    }\r\n  }, \r\n...\r\n```\r\n\r\nDo you have any clue on how to achieve that ? I Basically want thoses two blocks to be removed from my template.\r\n\r\nThank you already",
        "link": "https://stackoverflow.com/questions/72532938/using-jq-to-delete-blocks-from-cloudformation-template-json",
        "title": "Using JQ to delete blocks from CloudFormation.template.json"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1654613022,
                "creation_date": 1654613022,
                "answer_id": 72533219,
                "question_id": 72533054,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can use `all` to give a condition all items must meet. Here, all values in `.tags[].id` must be unequal `!=` to `&quot;red&quot;`:\r\n~~~sh\r\njq &#39;.data[] | select(all(.tags[].id; . != &quot;red&quot;))&#39;\r\n~~~\r\n~~~json\r\n{\r\n  &quot;name&quot;: &quot;banana&quot;,\r\n  &quot;tags&quot;: [\r\n    {\r\n      &quot;id&quot;: &quot;yellow&quot;\r\n    },\r\n    {\r\n      &quot;id&quot;: &quot;long&quot;\r\n    }\r\n  ]\r\n}\r\n{\r\n  &quot;name&quot;: &quot;orange&quot;,\r\n  &quot;tags&quot;: [\r\n    {\r\n      &quot;id&quot;: &quot;orange&quot;\r\n    },\r\n    {\r\n      &quot;id&quot;: &quot;round&quot;\r\n    },\r\n    {\r\n      &quot;id&quot;: &quot;colored&quot;\r\n    }\r\n  ]\r\n}\r\n~~~\r\n[Demo](https://jqplay.org/s/VWEZfa8AsNH)\r\n\r\nAdd `.name` and use the `-r` option to only get the names:\r\n~~~sh\r\njq -r &#39;.data[] | select(all(.tags[].id; . != &quot;red&quot;)).name&#39;\r\n~~~\r\n~~~json\r\nbanana\r\norange\r\n~~~\r\n[Demo](https://jqplay.org/s/1viKd9pfrGO)",
                "title": "JQ does not contain for &quot;key&quot;: &quot;value&quot; JSON structure"
            },
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1654613040,
                "creation_date": 1654613040,
                "answer_id": 72533228,
                "question_id": 72533054,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "`index` works on an array, your current filter does not pass `index` to an array, therefore you&#39;re getting other results then expected.\r\n\r\n----------\r\n\r\n```\r\n.data[] | select([ .tags[].id ] | index(&quot;red&quot;) | not)\r\n```\r\n\r\nHere we create an array with all the id&#39;s `[ .tags[].id ]` and use that array to check for `red`: `| index(&quot;red&quot;) | not`\r\n\r\n\r\n----------\r\n\r\nThe above filter gives the following output:\r\n```json\r\n{\r\n  &quot;name&quot;: &quot;banana&quot;,\r\n  &quot;tags&quot;: [\r\n    {\r\n      &quot;id&quot;: &quot;yellow&quot;\r\n    },\r\n    {\r\n      &quot;id&quot;: &quot;long&quot;\r\n    }\r\n  ]\r\n}\r\n{\r\n  &quot;name&quot;: &quot;orange&quot;,\r\n  &quot;tags&quot;: [\r\n    {\r\n      &quot;id&quot;: &quot;orange&quot;\r\n    },\r\n    {\r\n      &quot;id&quot;: &quot;round&quot;\r\n    },\r\n    {\r\n      &quot;id&quot;: &quot;colored&quot;\r\n    }\r\n  ]\r\n}\r\n```\r\n\r\n[Demo](https://jqplay.org/s/IBFyTOvvVyE)\r\n\r\n----------\r\n\r\n\r\nIf you want to exclude &#39;colored&#39;, use `contains()`:\r\n```\r\n.data[] | select([ .tags[].id ] | contains([&quot;red&quot;]) | not)\r\n```\r\n```json\r\n{\r\n  &quot;name&quot;: &quot;banana&quot;,\r\n  &quot;tags&quot;: [\r\n    {\r\n      &quot;id&quot;: &quot;yellow&quot;\r\n    },\r\n    {\r\n      &quot;id&quot;: &quot;long&quot;\r\n    }\r\n  ]\r\n}\r\n```\r\n[Demo](https://jqplay.org/s/tb1Y14lZbSy)",
                "title": "JQ does not contain for &quot;key&quot;: &quot;value&quot; JSON structure"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1654613040,
        "creation_date": 1654612340,
        "question_id": 72533054,
        "body_markdown": "The question is similar to [THIS][1], but the JSON structure is different.\r\n\r\nIn my usecase JSON has an arrays with key:value data:\r\n\r\n    {\r\n       &quot;data&quot;:[\r\n          {\r\n             &quot;name&quot;:&quot;banana&quot;,\r\n             &quot;tags&quot;:[\r\n                {\r\n                   &quot;id&quot;:&quot;yellow&quot;\r\n                },\r\n                {\r\n                   &quot;id&quot;:&quot;long&quot;\r\n                }\r\n             ]\r\n          },\r\n          {\r\n             &quot;name&quot;:&quot;apple&quot;,\r\n             &quot;tags&quot;:[\r\n                {\r\n                   &quot;id&quot;:&quot;red&quot;\r\n                },\r\n                {\r\n                   &quot;id&quot;:&quot;round&quot;\r\n                }\r\n             ]\r\n          },\r\n          {\r\n             &quot;name&quot;:&quot;orange&quot;,\r\n             &quot;tags&quot;:[\r\n                {\r\n                   &quot;id&quot;:&quot;orange&quot;\r\n                },\r\n                {\r\n                   &quot;id&quot;:&quot;round&quot;\r\n                },\r\n                {\r\n                   &quot;id&quot;:&quot;colored&quot;\r\n                }\r\n             ]\r\n          }\r\n       ]\r\n    }\r\n\r\n\r\nWhat required is to filter the only elements that do not have certain keyword - &quot;red&quot; for instance.\r\n\r\nWhen i use `jq &#39;.data[] | select(.tags[].id | index( &quot;red&quot; ))&#39;` it brings me the correct resut of &#39;apple&#39; (as it has `&quot;id&quot;: &quot;red&quot;`) and &#39;orange&#39; (as it has `&quot;id&quot;: &quot;colored&quot;`).\r\n\r\n\r\nHowever, when i add the negation `jq &#39;.data[] | select(.tags[].id | index( &quot;red&quot; ) | not)&#39;` the results are more than strange, with elements&#39; duplication, totally enigmatic.\r\n\r\nHow can i use jq to filter the result the way it returns only elements that do not have **the exact** match among the array values?\r\n\r\n  [1]: https://stackoverflow.com/questions/53512985/jq-filter-array-does-not-contain",
        "link": "https://stackoverflow.com/questions/72533054/jq-does-not-contain-for-key-value-json-structure",
        "title": "JQ does not contain for &quot;key&quot;: &quot;value&quot; JSON structure"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1654624654,
                "creation_date": 1654624654,
                "answer_id": 72535660,
                "question_id": 72535594,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can modify `.key` inside your `with_entries` just as you can filter on it:\r\n\r\n```\r\njq -r &#39;\r\n  .dependencies\r\n  | select(. != null)\r\n  | with_entries(\r\n      select(.key | contains(&quot;@example&quot;))\r\n      | .key |= &quot;**/\\(.)&quot;\r\n    )&#39; package.json\r\n```",
                "title": "Prefix every key with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1654626315,
        "creation_date": 1654624306,
        "last_edit_date": 1654626315,
        "question_id": 72535594,
        "body_markdown": "I am parsing a `package.json` file and pulling out all the dependencies that start with `@example`. \r\n\r\npackage.json\r\n```\r\n{\r\n  &quot;name&quot;: &quot;Example&quot;,\r\n  &quot;dependencies&quot;: { \r\n    &quot;@example/alpha&quot; : &quot;1.2.3&quot;,\r\n    &quot;@example/bravo&quot; : &quot;1.2.3&quot;,\r\n    &quot;@example/charlie&quot; : &quot;1.2.3&quot;\r\n  }\r\n}\r\n```\r\n\r\nThe following is working fine.\r\n\r\n```bash\r\njq -r &#39;.dependencies | select(. != null) | with_entries(select(.key | contains(&quot;@example&quot;)))&#39; package.json\r\n```\r\n\r\nThis gives me:\r\n```\r\n{ \r\n  &quot;@example/alpha&quot; : &quot;1.2.3&quot;,\r\n  &quot;@example/bravo&quot; : &quot;1.2.3&quot;,\r\n  &quot;@example/charlie&quot; : &quot;1.2.3&quot;\r\n}\r\n```\r\n\r\nHowever I also need to transform the keys, by adding a prefix of `**/`, so that I end up with:\r\n```\r\n{ \r\n  &quot;**/@example/alpha&quot; : &quot;1.2.3&quot;,\r\n  &quot;**/@example/bravo&quot; : &quot;1.2.3&quot;,\r\n  &quot;**/@example/charlie&quot; : &quot;1.2.3&quot;\r\n}\r\n```\r\n\r\n**How can I add the prefix to every key?**\r\n",
        "link": "https://stackoverflow.com/questions/72535594/prefix-every-key-with-jq",
        "title": "Prefix every key with jq"
    },
    {
        "tags": [
            "json",
            "bash",
            "shell",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1654632526,
                "last_edit_date": 1654632526,
                "creation_date": 1654632422,
                "answer_id": 72537006,
                "question_id": 72536963,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Check if `any` of the list&#39;s element equals `==` the given string:\r\n~~~sh\r\njq &#39;map(select(any(.list[]; . == &quot;element1&quot;)))&#39;\r\n~~~\r\n~~~json\r\n[\r\n  {\r\n    &quot;prop1&quot;: &quot;prop11&quot;,\r\n    &quot;prop2&quot;: &quot;prop21&quot;,\r\n    &quot;list&quot;: [\r\n      &quot;element1&quot;,\r\n      &quot;element2&quot;,\r\n      &quot;element3&quot;\r\n    ]\r\n  },\r\n  {\r\n    &quot;prop1&quot;: &quot;prop12&quot;,\r\n    &quot;prop2&quot;: &quot;prop22&quot;,\r\n    &quot;list&quot;: [\r\n      &quot;element1&quot;,\r\n      &quot;element3&quot;\r\n    ]\r\n  }\r\n]\r\n~~~\r\n[Demo](https://jqplay.org/s/_x11qEVoSoi)\r\n\r\n---\r\nUse `.[] | …` instead of `map(…)` to get rid of the outer array:\r\n~~~sh\r\njq &#39;.[] | select(any(.list[]; . == &quot;element1&quot;))&#39;\r\n~~~\r\n~~~json\r\n{\r\n  &quot;prop1&quot;: &quot;prop11&quot;,\r\n  &quot;prop2&quot;: &quot;prop21&quot;,\r\n  &quot;list&quot;: [\r\n    &quot;element1&quot;,\r\n    &quot;element2&quot;,\r\n    &quot;element3&quot;\r\n  ]\r\n}\r\n{\r\n  &quot;prop1&quot;: &quot;prop12&quot;,\r\n  &quot;prop2&quot;: &quot;prop22&quot;,\r\n  &quot;list&quot;: [\r\n    &quot;element1&quot;,\r\n    &quot;element3&quot;\r\n  ]\r\n}\r\n~~~\r\n[Demo](https://jqplay.org/s/JLhtx9tJty4)",
                "title": "Filter element based on property&#39;s list bash/jq"
            },
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1654637916,
                "creation_date": 1654637916,
                "answer_id": 72537814,
                "question_id": 72536963,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "`index` makes for a short and in practice quite fast solution:\r\n\r\n```\r\njq &#39;map(select(.list|index(&quot;element1&quot;)))&#39;\r\n```\r\n\r\nor\r\n```\r\njq -c &#39;.[] | select(.list|index(&quot;element1&quot;))&#39;\r\n```\r\n\r\n\r\n\r\n\r\n",
                "title": "Filter element based on property&#39;s list bash/jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1654637916,
        "creation_date": 1654632209,
        "last_edit_date": 1654632461,
        "question_id": 72536963,
        "body_markdown": "Given the List:\r\n```\r\n[\r\n    {\r\n        &quot;prop1&quot;: &quot;prop11&quot;,\r\n        &quot;prop2&quot;: &quot;prop21&quot;,\r\n        &quot;list&quot;: [&quot;element1&quot;, &quot;element2&quot;, &quot;element3&quot;]\r\n    },\r\n    {\r\n        &quot;prop1&quot;: &quot;prop12&quot;,\r\n        &quot;prop2&quot;: &quot;prop22&quot;,\r\n        &quot;list&quot;: [&quot;element1&quot;, &quot;element3&quot;]\r\n    },\r\n    {\r\n        &quot;prop1&quot;: &quot;prop13&quot;,\r\n        &quot;prop2&quot;: &quot;prop23&quot;,\r\n        &quot;list&quot;: [&quot;element2&quot;, &quot;element3&quot;]\r\n    }\r\n]\r\n```\r\n\r\nWhile using jq, how to filter only the root&#39;s list elements by the children&#39;s lists.\r\nFor example, return all elements whose list contains element1. The output should be:\r\n```\r\n[\r\n    {\r\n        &quot;prop1&quot;: &quot;prop11&quot;,\r\n        &quot;prop2&quot;: &quot;prop21&quot;,\r\n        &quot;list&quot;: [&quot;element1&quot;, &quot;element2&quot;, &quot;element3&quot;]\r\n    },\r\n    {\r\n        &quot;prop1&quot;: &quot;prop12&quot;,\r\n        &quot;prop2&quot;: &quot;prop22&quot;,\r\n        &quot;list&quot;: [&quot;element1&quot;, &quot;element3&quot;]\r\n    }\r\n]\r\n```\r\nor \r\n```\r\n{&quot;prop1&quot;: &quot;prop11&quot;,&quot;prop2&quot;: &quot;prop21&quot;,&quot;list&quot;: [&quot;element1&quot;, &quot;element2&quot;, &quot;element3&quot;]}\r\n{&quot;prop1&quot;: &quot;prop12&quot;,&quot;prop2&quot;: &quot;prop22&quot;,&quot;list&quot;: [&quot;element1&quot;, &quot;element3&quot;]}\r\n```\r\n\r\n",
        "link": "https://stackoverflow.com/questions/72536963/filter-element-based-on-propertys-list-bash-jq",
        "title": "Filter element based on property&#39;s list bash/jq"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 166270,
                    "reputation": 135171,
                    "user_id": 390278,
                    "user_type": "registered",
                    "accept_rate": 86,
                    "profile_image": "https://www.gravatar.com/avatar/84715fec547362389d02f5be0ed12814?s=256&d=identicon&r=PG",
                    "display_name": "Jeff Mercado",
                    "link": "https://stackoverflow.com/users/390278/jeff-mercado"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1654682995,
                "post_id": 72543799,
                "comment_id": 128147523,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1654684746,
                "last_edit_date": 1654684746,
                "creation_date": 1654683645,
                "answer_id": 72544008,
                "question_id": 72543799,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Remove the spaces and make the capture non-greedy by adding a `?` to `.*` (otherwise it will read until the `:` also in the second case):\r\n~~~sh\r\n.image | match(&quot;(?&lt;=\\\\/)(.*?)(?=\\\\:|\\\\@)&quot;).captures[].string\r\n~~~\r\n[Demo](https://jqplay.org/s/wttwqzvZk72)\r\n\r\nYou may also want to remove the escaping where it is not needed:\r\n~~~sh\r\n.image | match(&quot;(?&lt;=/)(.*?)(?=:|@)&quot;).captures[].string\r\n~~~\r\n[Demo](https://jqplay.org/s/xtY9q0J3E25)",
                "title": "JQ - extract text with multiple regex expressions"
            },
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1654731491,
                "creation_date": 1654731491,
                "answer_id": 72553277,
                "question_id": 72543799,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You have spaces that shouldn&#39;t be there (unless you add the `x` modifier), but the main issue is `.*` matches too much.\r\n\r\nIt was suggested that you replace `.*` with `.*?`, but that&#39;s a really bad habbit that will bite you one day. You should replace it with `[^:@]*` instead.\r\n\r\nAll you need is this:\r\n\r\n```jq\r\n.image | match(&quot;/([^:@]+)&quot;).captures[].string\r\n```\r\n\r\n[Demo](https://jqplay.org/s/h3OSR2ElUT9) on jqplay\r\n",
                "title": "JQ - extract text with multiple regex expressions"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1654731491,
        "creation_date": 1654682737,
        "question_id": 72543799,
        "body_markdown": "I have keys that sometimes looks like this ```docker/nginx:latest``` and sometimes looks like this `docker/nginx@sha256:9560f8528a3cd`\r\n\r\nI can extract the image name between the Repo name and tag using the following\r\n\r\n    .image | match(&quot;(?&lt;=\\\\/)(.*)(?=\\\\:)&quot;).captures[].string \r\n\r\n\r\nHowever how do I add multiple conditions to capture both conditions ?\r\n\r\nI have tried this but it doesn&#39;t work\r\n\r\n    .image | match(&quot;(?&lt;=\\\\/)(.*)(?=\\\\: | \\\\@)&quot;).captures[].string\r\n\r\nSample Json\r\n\r\n    {\r\n     &quot;image&quot;: &quot;docker/nginx:latest&quot;\r\n    }\r\n\r\nor\r\n\r\n    {\r\n     &quot;image&quot;: &quot;docker/nginx@sha256:9560f8528a3cd&quot;\r\n    }\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/72543799/jq-extract-text-with-multiple-regex-expressions",
        "title": "JQ - extract text with multiple regex expressions"
    },
    {
        "tags": [
            "json",
            "sed",
            "jenkins-pipeline",
            "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": 1654751231,
                "post_id": 72553653,
                "comment_id": 128167395,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1976031,
                    "reputation": 30404,
                    "user_id": 1773798,
                    "user_type": "registered",
                    "accept_rate": 75,
                    "profile_image": "https://i.sstatic.net/4Ljqn.png?s=256",
                    "display_name": "Renaud Pacalet",
                    "link": "https://stackoverflow.com/users/1773798/renaud-pacalet"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1654763025,
                "post_id": 72553653,
                "comment_id": 128170788,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 7750510,
                    "reputation": 134447,
                    "user_id": 5866580,
                    "user_type": "registered",
                    "accept_rate": 25,
                    "profile_image": "https://www.gravatar.com/avatar/f69cec226400d61f887446d813471488?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "RavinderSingh13",
                    "link": "https://stackoverflow.com/users/5866580/ravindersingh13"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1659723758,
                "post_id": 72553653,
                "comment_id": 129370712,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1654737040,
                "creation_date": 1654737040,
                "answer_id": 72553696,
                "question_id": 72553653,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Use this Perl one-liner:\r\n```\r\nperl -i.bak -pe &#39;s{http[^&quot;]+/}{}g&#39; in_file\r\n```\r\n\r\nThe Perl one-liner uses these command line flags:  \r\n`-e` : Tells Perl to look for code in-line, instead of in a file.  \r\n`-p` : Loop over the input one line at a time, assigning it to `$_` by default. Add `print $_` after each loop iteration.  \r\n`-i.bak` : Edit input files in-place (overwrite the input file). Before overwriting, save a backup copy of the original file by appending to its name the extension `.bak`.  \r\n\r\n\r\nThe regex uses this modifier:  \r\n`/g` : Match the pattern repeatedly.  \r\n\r\n`http[^&quot;]+/` : literal `http`, followed by any character *other than* `&quot;`, repeated 1 or more times.  \r\n\r\n**SEE ALSO:**  \r\n[`perldoc perlrun`: how to execute the Perl interpreter: command line switches](https://perldoc.perl.org/perlrun.html#Command-Switches)   \r\n[`perldoc perlre`: Perl regular expressions (regexes)](https://perldoc.perl.org/perlre.html)  \r\n[`perldoc perlre`: Perl regular expressions (regexes): Quantifiers; Character Classes and other Special Escapes; Assertions; Capture groups](https://perldoc.perl.org/perlre.html#Regular-Expressions)  \r\n[`perldoc perlrequick`: Perl regular expressions quick start](https://perldoc.perl.org/perlrequick)  ",
                "title": "Only want filename from url in json file"
            },
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1654751193,
                "creation_date": 1654751193,
                "answer_id": 72554950,
                "question_id": 72553653,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Assuming your JSON snippet is fixed and using `jq` is an option, you could do\r\n\r\n```none\r\njq &#39;.sources[] |= ( split(&quot;/&quot;) | last )&#39;\r\n```",
                "title": "Only want filename from url in json file"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": -1,
        "last_activity_date": 1654751193,
        "creation_date": 1654736448,
        "last_edit_date": 1654751157,
        "question_id": 72553653,
        "body_markdown": "I have the following json file below:\r\n```\r\n{&quot;cloud&quot;:&quot;https://cloudfronturl/folder/folder&quot;,\r\n&quot;env&quot;: &quot;int&quot;\r\n&quot;sources&quot;:[&quot;https://www.example.com/some.tar.gz&quot;,&quot;https://www.example2.com/folder1/folder2/another.tar.gz&quot;],\r\n&quot;owner&quot;: &quot;some manager&quot;\r\n}\r\n```\r\n\r\nHow can I modify the file to read like below, where only the file names stripped from sources url? Don&#39;t want to touch cloud value\r\n```\r\n{&quot;cloud&quot;:&quot;https://cloudfronturl/folder/folder&quot;,\r\n&quot;env&quot;: &quot;int&quot;\r\n&quot;sources&quot;:[&quot;some.tar.gz&quot;,&quot;another.tar.gz&quot;],\r\n&quot;owner&quot;: &quot;some manager&quot;\r\n}\r\n```\r\n\r\n",
        "link": "https://stackoverflow.com/questions/72553653/only-want-filename-from-url-in-json-file",
        "title": "Only want filename from url in json file"
    },
    {
        "tags": [
            "json",
            "command-line",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1655186347,
                "last_edit_date": 1655186347,
                "creation_date": 1654776026,
                "answer_id": 72559876,
                "question_id": 72559679,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "```\r\njq -s &#39;.[] | .category as $c | .athletes_list | to_entries[] | ({ a: .value.athlete_name, r: .key, c: $c })&#39; triathlon swimming\r\n```\r\n\r\nWill produce:\r\n```json\r\n{\r\n  &quot;a&quot;: &quot;Ubain Solt&quot;,\r\n  &quot;r&quot;: 0,\r\n  &quot;c&quot;: &quot;triathlon&quot;\r\n}\r\n{\r\n  &quot;a&quot;: &quot;Jon Snow&quot;,\r\n  &quot;r&quot;: 1,\r\n  &quot;c&quot;: &quot;triathlon&quot;\r\n}\r\n{\r\n  &quot;a&quot;: &quot;Mickey Mouse&quot;,\r\n  &quot;r&quot;: 2,\r\n  &quot;c&quot;: &quot;triathlon&quot;\r\n}\r\n{\r\n  &quot;a&quot;: &quot;Picheal Phelms&quot;,\r\n  &quot;r&quot;: 0,\r\n  &quot;c&quot;: &quot;swimming&quot;\r\n}\r\n{\r\n  &quot;a&quot;: &quot;Lacky Kedetie&quot;,\r\n  &quot;r&quot;: 1,\r\n  &quot;c&quot;: &quot;swimming&quot;\r\n}\r\n```\r\n\r\nThe &#39;trick&#39; is to use `to_entries` so we can use `.key` as the &#39;index&#39;.",
                "title": "use jq to extract ranking from a list"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1655186347,
        "creation_date": 1654775035,
        "question_id": 72559679,
        "body_markdown": "I want to extract a ranking from a list of elements inside a json object whose order shows the position of the item in the respective category. That should be done by using only command line tools.\r\n\r\nE.g.\r\nI have a file with these 2 samples (each json object should be one-line but parsed with indentation here for readability ) :\r\n```json\r\n{\r\n\t&quot;category&quot;:&quot;triathlon&quot;,\r\n\t&quot;athletes_list&quot;:[\r\n\t\t{\r\n\t\t\t&quot;athlete_name&quot;: &quot;Ubain Solt&quot;\r\n\t\t}\r\n\t\t,\r\n\t\t{\r\n\t\t&quot;athlete_name&quot;: &quot;Jon Snow&quot;\r\n\t\t}\r\n\t\t,\r\n\t\t{\r\n\t\t&quot;athlete_name&quot;: &quot;Mickey Mouse&quot;\r\n\t\t}\r\n\t]\r\n\r\n}\r\n{\r\n\t&quot;category&quot;:&quot;swimming&quot;,\r\n\t&quot;athletes_list&quot;:[\r\n\t\t{\r\n\t\t&quot;athlete_name&quot;: &quot;Picheal Phelms&quot;\r\n\t\t},\r\n\t\t{\r\n\t\t&quot;athlete_name&quot;:&quot;Lacky Kedetie&quot;\r\n\t\t}\r\n\t]\r\n}\r\n```\r\nand want as output:\r\n\r\n```json\r\n{&quot;a&quot;:&quot;Ubain Solt&quot;, &quot;r&quot;:0, &quot;c&quot;:&quot;triathlon&quot;}\r\n{&quot;a&quot;:&quot;Jon Snow&quot;, &quot;r&quot;:1, &quot;c&quot;:&quot;triathlon&quot;}\r\n{&quot;a&quot;: &quot;Mickey Mouse&quot;, &quot;r&quot;:2, &quot;c&quot;:&quot;triathlon&quot;}\r\n{&quot;a&quot;: &quot;Picheal Phelms&quot;, &quot;r&quot;:0, &quot;c&quot;:&quot;swimming&quot;}\r\n{&quot;a&quot;: &quot;Lacky Kedetie&quot;, &quot;r&quot;:1, &quot;c&quot;:&quot;swimming&quot;}\r\n```\r\nRequirements are to use jq and solution must be 1-liner.",
        "link": "https://stackoverflow.com/questions/72559679/use-jq-to-extract-ranking-from-a-list",
        "title": "use jq to extract ranking from a list"
    },
    {
        "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": 1654779049,
                "post_id": 72560468,
                "comment_id": 128176628,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1654781223,
                "post_id": 72560468,
                "comment_id": 128177573,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 25514499,
                    "reputation": 23,
                    "user_id": 19305572,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/63c63524994707cbe78852ac17bec0bd?s=256&d=identicon&r=PG",
                    "display_name": "freljord",
                    "link": "https://stackoverflow.com/users/19305572/freljord"
                },
                "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": 1654784283,
                "post_id": 72560468,
                "comment_id": 128178962,
                "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": 1654785604,
                "post_id": 72560468,
                "comment_id": 128179562,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 25514499,
                    "reputation": 23,
                    "user_id": 19305572,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/63c63524994707cbe78852ac17bec0bd?s=256&d=identicon&r=PG",
                    "display_name": "freljord",
                    "link": "https://stackoverflow.com/users/19305572/freljord"
                },
                "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": 1654786675,
                "post_id": 72560468,
                "comment_id": 128180042,
                "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": 1654788244,
                "post_id": 72560468,
                "comment_id": 128180679,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 25514499,
                    "reputation": 23,
                    "user_id": 19305572,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/63c63524994707cbe78852ac17bec0bd?s=256&d=identicon&r=PG",
                    "display_name": "freljord",
                    "link": "https://stackoverflow.com/users/19305572/freljord"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1654790590,
                "post_id": 72560468,
                "comment_id": 128181621,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1654951034,
                "creation_date": 1654951034,
                "answer_id": 72584388,
                "question_id": 72560468,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You are looking for a solution that &quot;merges&quot; objects **and** arrays. For the former you have already found `+` (or `add`) for a top-level merge, and `*` for a recursive merge, but merging arrays (namely the two `.movies` fields) needs more specification from your end as there is no canonical solution for that.\r\n\r\nIn a [comment](https://stackoverflow.com/questions/72560468/how-to-correctly-merge-2-json-files-including-arrays-using-jq#comment128181621_72560468) you state\r\n&gt; `.movies[0]` always correspond to the same movie in both files\r\n\r\nThis enables you to use `transpose` to align the items from both arrays, and then apply object-merging on each pair of corresponding items. If you want to merge deeper arrays as well (e.g. `.movies[].actors` or `.movies[].actors[].names`) you need to extend this approach accordingly. Here&#39;s a solution using plain `add` for the merging of the array items as well as of the other top-level fields:\r\n\r\n~~~sh\r\njq -s &#39;add + {movies: map(.movies) | transpose | map(add)}&#39; file1 file2\r\n~~~\r\n~~~json\r\n{\r\n  &quot;series&quot;: &quot;Harry Potter Movie Series&quot;,\r\n  &quot;writer&quot;: &quot;J.K. Rowling&quot;,\r\n  &quot;movies&quot;: [\r\n    {\r\n      &quot;title&quot;: &quot;Harry Potter and the Philosopher&#39;s Stone&quot;,\r\n      &quot;actors&quot;: [\r\n        {\r\n          &quot;names&quot;: [\r\n            &quot;Emma Watson&quot;,\r\n            &quot;Other actor&quot;\r\n          ],\r\n          &quot;other&quot;: &quot;Some value&quot;\r\n        }\r\n      ],\r\n      &quot;year&quot;: &quot;2001&quot;\r\n    },\r\n    {\r\n      &quot;title&quot;: &quot;Harry Potter and the Chamber of Secrets&quot;,\r\n      &quot;actors&quot;: [\r\n        {\r\n          &quot;names&quot;: [\r\n            &quot;Emma Watson&quot;\r\n          ],\r\n          &quot;other&quot;: &quot;Some value&quot;\r\n        }\r\n      ],\r\n      &quot;year&quot;: &quot;2002&quot;\r\n    }\r\n  ],\r\n  &quot;producer&quot;: &quot;David Heyman&quot;\r\n}\r\n~~~\r\n[Demo](https://jqplay.org/s/ubqoADHFE3z)\r\n",
                "title": "How to merge 2 JSON files including objects and arrays using jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1654972590,
        "creation_date": 1654778528,
        "last_edit_date": 1654972590,
        "question_id": 72560468,
        "body_markdown": "I&#39;m using jq to try and merge 2 json files into one unique file.\r\n \r\nThe result is close to what I was looking for, but not just right.\r\n\r\n**File 1:**\r\n```\r\n{\r\n  &quot;series&quot;: &quot;Harry Potter Movie Series&quot;,\r\n  &quot;writer&quot;: &quot;J.K. Rowling&quot;,\r\n  &quot;movies&quot;: [\r\n    {\r\n      &quot;title&quot;: &quot;Harry Potter and the Philosopher&#39;s Stone&quot;,\r\n      &quot;actors&quot;: [\r\n        {\r\n          &quot;names&quot;: [\r\n            &quot;Emma Watson&quot;,\r\n            &quot;Other actor&quot;\r\n          ],\r\n          &quot;other&quot;: &quot;Some value&quot;\r\n        }\r\n      ]\r\n    },\r\n    {\r\n      &quot;title&quot;: &quot;Harry Potter and the Chamber of Secrets&quot;,\r\n      &quot;actors&quot;: [\r\n        {\r\n          &quot;names&quot;: [\r\n            &quot;Emma Watson&quot;\r\n          ],\r\n          &quot;other&quot;: &quot;Some value&quot;\r\n        }\r\n      ]\r\n    }\r\n  ]\r\n}\r\n```\r\n\r\n**File 2:**\r\n```\r\n{\r\n  &quot;series&quot;: &quot;Harry Potter Movie Series&quot;,\r\n  &quot;producer&quot;: &quot;David Heyman&quot;,\r\n  &quot;movies&quot;: [\r\n    {\r\n      &quot;title&quot;: &quot;Harry Potter and the Philosopher&#39;s Stone&quot;,\r\n      &quot;year&quot;: &quot;2001&quot;\r\n    },\r\n    {\r\n      &quot;title&quot;: &quot;Harry Potter and the Chamber of Secrets&quot;,\r\n      &quot;year&quot;: &quot;2002&quot;\r\n    }\r\n  ]\r\n}\r\n```\r\n\r\n**Expected result:**\r\n```\r\n{\r\n  &quot;series&quot;: &quot;Harry Potter Movie Series&quot;,\r\n  &quot;writer&quot;: &quot;J.K. Rowling&quot;,\r\n  &quot;movies&quot;: [\r\n    {\r\n      &quot;title&quot;: &quot;Harry Potter and the Philosopher&#39;s Stone&quot;,\r\n      &quot;year&quot;: &quot;2001&quot;,\r\n      &quot;actors&quot;: [\r\n        {\r\n          &quot;names&quot;: [\r\n            &quot;Emma Watson&quot;,\r\n            &quot;Other actor&quot;\r\n          ],\r\n          &quot;other&quot;: &quot;Some value&quot;\r\n        }\r\n      ]\r\n    },\r\n    {\r\n      &quot;title&quot;: &quot;Harry Potter and the Chamber of Secrets&quot;,\r\n      &quot;year&quot;: &quot;2001&quot;,\r\n      &quot;actors&quot;: [\r\n        {\r\n          &quot;names&quot;: [\r\n            &quot;Emma Watson&quot;\r\n          ],\r\n          &quot;other&quot;: &quot;Some value&quot;\r\n        }\r\n      ]\r\n    }\r\n  ],\r\n  &quot;producer&quot;: &quot;David Heyman&quot;\r\n}\r\n```\r\n\r\nBest result I&#39;ve got so far (only arrays with actors are missing):\r\n```\r\n{\r\n  &quot;series&quot;: &quot;Harry Potter Movie Series&quot;,\r\n  &quot;writer&quot;: &quot;J.K. Rowling&quot;,\r\n  &quot;movies&quot;: [\r\n    {\r\n      &quot;title&quot;: &quot;Harry Potter and the Philosopher&#39;s Stone&quot;,\r\n      &quot;year&quot;: &quot;2001&quot;\r\n    },\r\n    {\r\n      &quot;title&quot;: &quot;Harry Potter and the Chamber of Secrets&quot;,\r\n      &quot;year&quot;: &quot;2002&quot;\r\n    }\r\n  ],\r\n  &quot;producer&quot;: &quot;David Heyman&quot;\r\n}\r\n```\r\n\r\nUsing one of the commands below:\r\n\r\n`jq -s &#39;.[0] * .[1]&#39; file1 file2`\r\n\r\n`jq --slurp &#39;add&#39; file1 file2`\r\n\r\n`jq &#39;. * input&#39; file1 file2`\r\n\r\n----\r\nIf I switch order of files I either end up losing &#39;actors&#39; from file1 or &#39;year&#39; from file2.\r\n\r\nHow it should work:\r\n- the elements in file 2 will be leading and should replace the matching elements in file 1.\r\n- the elements in file 1 that doesn&#39;t exist in file 2 (like writer and movies[].actors elements) shouldn&#39;t be deleted\r\n- the elements in file 2 that doesn&#39;t exist yet in file 1 will be added (like producer and movies[].year).\r\n- a title is unique and should by default not occur more then once, but if it does remove the duplicates.\r\n\r\nI would assume there is a solution to get these movies arrays perfectly merged with jq. ",
        "link": "https://stackoverflow.com/questions/72560468/how-to-merge-2-json-files-including-objects-and-arrays-using-jq",
        "title": "How to merge 2 JSON files including objects and arrays using jq?"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1654780258,
                "creation_date": 1654780258,
                "answer_id": 72560900,
                "question_id": 72560678,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If `usernamevalue` and `passwordvalue` have only one occurrence as in your sample file, you can `add` the `fields` object, and then extract from it as you would with the outside keys:\r\n~~~sh\r\njq &#39;map({id, updated_at} + (.fields | add | {usernamevalue, passwordvalue}))&#39; \r\n~~~\r\n~~~json\r\n[\r\n  {\r\n    &quot;id&quot;: &quot;xxxx&quot;,\r\n    &quot;updated_at&quot;: &quot;xxxx&quot;,\r\n    &quot;usernamevalue&quot;: &quot;xxxx&quot;,\r\n    &quot;passwordvalue&quot;: &quot;xxxx&quot;\r\n  },\r\n  {\r\n    &quot;id&quot;: &quot;xxxx&quot;,\r\n    &quot;updated_at&quot;: &quot;xxxx&quot;,\r\n    &quot;usernamevalue&quot;: &quot;xxxx&quot;,\r\n    &quot;passwordvalue&quot;: &quot;xxxx&quot;\r\n  }\r\n]\r\n~~~\r\n[Demo](https://jqplay.org/s/ciHR06lwqo1)\r\n\r\n---\r\nIf your ultimate goal is a CSV output of the values, you&#39;d rather go for an array than an object, which could be something like:\r\n~~~sh\r\njq -r &#39;.[] | [.id, .updated_at, (.fields | add | .usernamevalue, .passwordvalue)] | @csv&#39;\r\n~~~\r\n~~~json\r\n&quot;xxxx&quot;,&quot;xxxx&quot;,&quot;xxxx&quot;,&quot;xxxx&quot;\r\n&quot;xxxx&quot;,&quot;xxxx&quot;,&quot;xxxx&quot;,&quot;xxxx&quot;\r\n~~~\r\n[Demo](https://jqplay.org/s/HP7Ia6PK04K)",
                "title": "Flatten JSON data file"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1654780456,
                "creation_date": 1654780456,
                "answer_id": 72560938,
                "question_id": 72560678,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You could parse the JSON object through their keys.\r\n\r\n    var jsonObject = [\r\n    {\r\n        &quot;foo&quot;: &quot;bar&quot;,\r\n        &quot;foo1&quot;: &quot;bar1&quot;,\r\n        &quot;field&quot;: [\r\n\t\t\t{\r\n\t\t\t\t&quot;username&quot;: &quot;john@gm.com&quot;,\r\n\t\t\t\t&quot;context&quot;: &quot;foob&quot;\r\n\t\t\t}, \r\n\t\t\t{\r\n\t\t\t\t&quot;password&quot;: &quot;kek&quot;,\r\n\t\t\t\t&quot;context&quot;: &quot;bar1&quot;\r\n\t\t\t},\r\n\t\t\t{\r\n\t\t\t\t&quot;other&quot;: &quot;foobar&quot;,\r\n\t\t\t\t&quot;context&quot;: &quot;foobarbar&quot;\r\n\t\t\t}\r\n        ]\r\n    }\r\n    ]\r\n\t\r\n\tfor (var i = 0; i &lt; jsonObject.field.length; i++)\r\n\t{\r\n\t\tfor(var key in jsonObject.field[i])\r\n\t\t{\r\n\t\t\tif(key == &quot;username&quot;) \r\n\t\t\t{\r\n\t\t\t\tjsonObject.usernamevalue = jsonObject.field[i].username;\r\n\t\t\t} else if(key == &quot;password&quot;)\r\n\t\t\t{\r\n\t\t\t\tjsonObject.passwordvalue = jsonObjecct.field[i].password;\r\n\t\t\t}\r\n\t\t}\r\n\t}\r\n\t\r\n\t//Afterwards, you can delete the field \r\n\tdelete jsonObject.field;",
                "title": "Flatten JSON data file"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1654780456,
        "creation_date": 1654779335,
        "question_id": 72560678,
        "body_markdown": "I&#39;m a JQ newb, and have been wrestling with this task for while.\r\nOur source JSON file looks like this...\r\n\r\n    [\r\n    {\r\n      &quot;id&quot;: &quot;xxxx&quot;,\r\n      &quot;title&quot;: &quot;xxxx&quot;,\r\n      &quot;created_at&quot;: &quot;xxxx&quot;,\r\n      &quot;updated_at&quot;: &quot;xxxx&quot;,\r\n      &quot;fields&quot;: [\r\n        {\r\n          &quot;usernamevalue&quot;: &quot;xxxx&quot;,\r\n          &quot;reference&quot;: &quot;xxxx&quot;\r\n        },\r\n        {\r\n          &quot;passwordvalue&quot;: &quot;xxxx&quot;,\r\n          &quot;reference&quot;: &quot;xxxx&quot;\r\n        },\r\n        {\r\n          &quot;otherlabel&quot;: &quot;xxxx&quot;,\r\n          &quot;otherreference&quot;: &quot;xxxx&quot;\r\n    \t}\r\n      ]\r\n    },\r\n    {\r\n      &quot;id&quot;: &quot;xxxx&quot;,\r\n      &quot;title&quot;: &quot;xxxx&quot;,\r\n      &quot;created_at&quot;: &quot;xxxx&quot;,\r\n      &quot;updated_at&quot;: &quot;xxxx&quot;,\r\n      &quot;fields&quot;: [\r\n        {\r\n          &quot;usernamevalue&quot;: &quot;xxxx&quot;,\r\n          &quot;reference&quot;: &quot;xxxx&quot;\r\n        },\r\n        {\r\n          &quot;passwordvalue&quot;: &quot;xxxx&quot;,\r\n          &quot;reference&quot;: &quot;xxxx&quot;\r\n        },\r\n        {\r\n          &quot;otherlabel&quot;: &quot;xxxx&quot;,\r\n          &quot;otherreference&quot;: &quot;xxxx&quot;\r\n    \t}\r\n      ]\r\n    }\r\n    ]\r\n\r\nWe are trying to end up with...\r\n\r\n    [\r\n    {\r\n      &quot;title&quot;: &quot;xxxx&quot;,\r\n      &quot;updated_at&quot;: &quot;xxxx&quot;,\r\n      &quot;usernamevalue&quot;: &quot;xxxx&quot;,\r\n      &quot;passwordvalue&quot;: &quot;xxxx&quot;\r\n    },\r\n    {\r\n      &quot;title&quot;: &quot;xxxx&quot;,\r\n      &quot;updated_at&quot;: &quot;xxxx&quot;,\r\n      &quot;usernamevalue&quot;: &quot;xxxx&quot;,\r\n      &quot;passwordvalue&quot;: &quot;xxxx&quot;\r\n    }\r\n    ]\r\n\r\nAs such, the goals are...\r\nEnd up with one, &quot;flat&quot; item for each entry -- so that we can then convert it to a CSV.\r\nOnly get the &quot;title&quot; and &quot;updated_at&quot; fields from the top level.\r\nOnly get fields with keys = &quot;usernamevalue&quot; and &quot;passwordvalue&quot; from the subordinate &quot;fields&quot; array, and move those fields to the top level.\r\n\r\nAny guidance would be GREATLY appreciated!\r\n(I&#39;ve already spent more hours on this than I care to admit.)\r\nTHANK YOU  \r\n\r\n",
        "link": "https://stackoverflow.com/questions/72560678/flatten-json-data-file",
        "title": "Flatten JSON data file"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 6313442,
                    "reputation": 45115,
                    "user_id": 5625547,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/oqCND.jpg?s=256",
                    "display_name": "0stone0",
                    "link": "https://stackoverflow.com/users/5625547/0stone0"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1654782149,
                "post_id": 72561279,
                "comment_id": 128178040,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1901149,
                    "reputation": 2535,
                    "user_id": 1716999,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/06a58106c9a1013f1ca791c46579d664?s=256&d=identicon&r=PG",
                    "display_name": "Johannes Riecken",
                    "link": "https://stackoverflow.com/users/1716999/johannes-riecken"
                },
                "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": 1654782473,
                "post_id": 72561279,
                "comment_id": 128178185,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1654783902,
                "last_edit_date": 1654783902,
                "creation_date": 1654782131,
                "answer_id": 72561391,
                "question_id": 72561279,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "```\r\n.[].children |= map(select(.color))\r\n```\r\n\r\nWill remove `children` that does not `has` an `color` so the output becomes:\r\n```json\r\n[\r\n  {\r\n    &quot;name&quot;: &quot;foo&quot;,\r\n    &quot;children&quot;: [\r\n      {\r\n        &quot;name&quot;: &quot;foo.0&quot;,\r\n        &quot;color&quot;: &quot;red&quot;\r\n      }\r\n    ]\r\n  },\r\n  {\r\n    &quot;name&quot;: &quot;bar&quot;,\r\n    &quot;children&quot;: [\r\n      {\r\n        &quot;name&quot;: &quot;bar.0&quot;,\r\n        &quot;color&quot;: &quot;green&quot;\r\n      }\r\n    ]\r\n  },\r\n  {\r\n    &quot;name&quot;: &quot;baz&quot;,\r\n    &quot;children&quot;: []\r\n  }\r\n]\r\n```\r\n\r\n\r\n##### [Online demo](https://jqplay.org/s/vzdkOizU9HS)\r\n\r\n\r\n----------\r\n\r\nRegarding *why* your filter does not seem to like `empty`;\\\r\nThis [git issue](https://github.com/stedolan/jq/issues/2051) seems to be the cause, multiple elements with `empty` will fail.",
                "title": "Filtering deeply within tree"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1654783015,
                "creation_date": 1654783015,
                "answer_id": 72561627,
                "question_id": 72561279,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "There must be a bug with assigning `empty` to multiple paths.\r\n\r\nIn this case you can use `del` instead:\r\n```\r\ndel(.[].children[] | select(has(&quot;color&quot;) | not))\r\n```\r\n&lt;sup&gt;[Online demo](https://jqplay.org/s/UlJAUB6MQ7c)&lt;/sup&gt;",
                "title": "Filtering deeply within tree"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1664702665,
        "creation_date": 1654781716,
        "last_edit_date": 1664702665,
        "question_id": 72561279,
        "body_markdown": "I&#39;m trying to prune nodes deeply within a JSON structure and I&#39;m puzzled why `empty` behaves seemingly different from a normal value here.\r\n\r\n# Input\r\n\r\n``` json\r\n[\r\n    {\r\n        &quot;name&quot;: &quot;foo&quot;,\r\n        &quot;children&quot;: [{\r\n            &quot;name&quot;: &quot;foo.0&quot;,\r\n            &quot;color&quot;: &quot;red&quot;\r\n        }]\r\n    },\r\n    {\r\n        &quot;name&quot;: &quot;bar&quot;,\r\n        &quot;children&quot;: [{\r\n            &quot;name&quot;: &quot;bar.0&quot;,\r\n            &quot;color&quot;: &quot;green&quot;\r\n        },\r\n        {\r\n            &quot;name&quot;: &quot;bar.1&quot;\r\n        }]\r\n    },\r\n    {\r\n        &quot;name&quot;: &quot;baz&quot;,\r\n        &quot;children&quot;: [{\r\n            &quot;name&quot;: &quot;baz.0&quot;\r\n        },\r\n        {\r\n            &quot;name&quot;: &quot;baz.1&quot;\r\n        }]\r\n    }\r\n]\r\n\r\n```\r\n\r\n# Program\r\n\r\n`jq &#39;(.[].children|.[])|=if has(&quot;color&quot;) then . else empty end&#39; foo.json`\r\n\r\n# Actual output\r\n\r\n``` json\r\n[\r\n  {\r\n    &quot;name&quot;: &quot;foo&quot;,\r\n    &quot;children&quot;: [\r\n      {\r\n        &quot;name&quot;: &quot;foo.0&quot;,\r\n        &quot;color&quot;: &quot;red&quot;\r\n      }\r\n    ]\r\n  },\r\n  {\r\n    &quot;name&quot;: &quot;bar&quot;,\r\n    &quot;children&quot;: [\r\n      {\r\n        &quot;name&quot;: &quot;bar.0&quot;,\r\n        &quot;color&quot;: &quot;green&quot;\r\n      }\r\n    ]\r\n  },\r\n  {\r\n    &quot;name&quot;: &quot;baz&quot;,\r\n    &quot;children&quot;: [\r\n      {\r\n        &quot;name&quot;: &quot;baz.1&quot;\r\n      }\r\n    ]\r\n  }\r\n]\r\n```\r\n\r\n# Expected output\r\n\r\nThe output I get, except without the `baz.1` child, as that one doesn&#39;t have a color.\r\n\r\n# Question\r\n\r\nApart from the right solution, I&#39;m also curious why replacing `empty` in the script by a regular value like `42` would replace the children without colors with 42 as expected, but when replacing with `empty`, it looks like the `else` branch doesn&#39;t get executed?",
        "link": "https://stackoverflow.com/questions/72561279/filtering-deeply-within-tree",
        "title": "Filtering deeply within tree"
    },
    {
        "tags": [
            "json",
            "algorithm",
            "tree",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 6196394,
                    "reputation": 86601,
                    "user_id": 5291015,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/4tAvO.jpg?s=256",
                    "display_name": "Inian",
                    "link": "https://stackoverflow.com/users/5291015/inian"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1654783487,
                "post_id": 72561553,
                "comment_id": 128178616,
                "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"
                },
                "reply_to_user": {
                    "account_id": 6196394,
                    "reputation": 86601,
                    "user_id": 5291015,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/4tAvO.jpg?s=256",
                    "display_name": "Inian",
                    "link": "https://stackoverflow.com/users/5291015/inian"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1654785083,
                "post_id": 72561553,
                "comment_id": 128179312,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 13965446,
                    "reputation": 396,
                    "user_id": 10085368,
                    "user_type": "registered",
                    "profile_image": "https://lh5.googleusercontent.com/-g0JjywCuKsg/AAAAAAAAAAI/AAAAAAAAAAA/AAnnY7qJG1W9yY6rVFoYOyt3Py5QONPU6w/mo/s256-rj/photo.jpg",
                    "display_name": "wass rubleff",
                    "link": "https://stackoverflow.com/users/10085368/wass-rubleff"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1654789169,
                "post_id": 72561553,
                "comment_id": 128181082,
                "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": 1654789494,
                "post_id": 72561553,
                "comment_id": 128181209,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 13965446,
                    "reputation": 396,
                    "user_id": 10085368,
                    "user_type": "registered",
                    "profile_image": "https://lh5.googleusercontent.com/-g0JjywCuKsg/AAAAAAAAAAI/AAAAAAAAAAA/AAnnY7qJG1W9yY6rVFoYOyt3Py5QONPU6w/mo/s256-rj/photo.jpg",
                    "display_name": "wass rubleff",
                    "link": "https://stackoverflow.com/users/10085368/wass-rubleff"
                },
                "reply_to_user": {
                    "account_id": 6196394,
                    "reputation": 86601,
                    "user_id": 5291015,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/4tAvO.jpg?s=256",
                    "display_name": "Inian",
                    "link": "https://stackoverflow.com/users/5291015/inian"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1654790931,
                "post_id": 72561553,
                "comment_id": 128181756,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1654804691,
                "last_edit_date": 1654804691,
                "creation_date": 1654804280,
                "answer_id": 72565910,
                "question_id": 72561553,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The following is fairly efficient, and for the given input produces the desired result,\r\nbut the requirements are unclear so please do not use the following blindly.\r\n\r\nThe following assumes that jq is invoked with the -n command-line option.\r\n```\r\n# Try to find the origin_id of the input object, given a dictionary of objects indexed by .id\r\ndef origin_id($dict):\r\n  .parent_id as $p\r\n  | if $p == null then .id\r\n    elif .origin_id then .origin_id\r\n    else $dict[.parent_id] | origin_id($dict)\r\n    end;\r\n    \r\nINDEX(inputs| if .parent_id == null then .origin_id=.id else . end; .id) as $ids\r\n| $ids[]\r\n| .origin_id = origin_id($ids)\r\n```",
                "title": "JQ: How to efficiently find root nodes given objects each referring to immediate parent"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -1,
        "last_activity_date": 1654834818,
        "creation_date": 1654782763,
        "last_edit_date": 1654834818,
        "question_id": 72561553,
        "body_markdown": "I have a stream of objects looking like this:\r\n\r\n    {\r\n      &quot;id&quot;: &quot;123456789012345&quot;,\r\n      &quot;parent_id&quot;: &quot;123456789012344&quot;\r\n    }\r\n    {\r\n      &quot;id&quot;: &quot;123456789012346&quot;,\r\n      &quot;parent_id&quot;: &quot;123456789012345&quot;\r\n    }\r\n    {\r\n      &quot;id&quot;: &quot;123456789012344&quot;\r\n    }\r\n\r\nWhat is the most computationally efficient way to lookup and add `root_id` attribute to those objects that have `parent_id` set?\r\n\r\nE.g. desired output for the above input would be:\r\n\r\n    {\r\n      &quot;id&quot;: &quot;123456789012345&quot;,\r\n      &quot;parent_id&quot;: &quot;123456789012344&quot;\r\n      &quot;root_id&quot;: &quot;123456789012344&quot;\r\n    }\r\n    {\r\n      &quot;id&quot;: &quot;123456789012346&quot;,\r\n      &quot;parent_id&quot;: &quot;123456789012345&quot;,\r\n      &quot;root_id&quot;: &quot;123456789012344&quot;\r\n    }\r\n    {\r\n      &quot;id&quot;: &quot;123456789012344&quot;,\r\n      &quot;root_id&quot;: &quot;123456789012344&quot;\r\n    }\r\n    \r\nThat is:\r\n  \r\n\r\n - for the second object (IDed 12345678901234**6**), immediate parent is 123456789012345 (which is first object)\r\n - in turn, for the first object, parent is 12345678901234**4** -- which is grandparent for second object (12345678901234**6**)\r\n  - and 12345678901234**4** has no parents, therefore it becomes a root node for itself and all the other objects it is a (grand)parent for.\r\n----\r\nI [used to consider](https://unix.stackexchange.com/questions/526241/bash-how-to-efficiently-find-root-nodes-given-set-of-parent-child) using a bash script, but ideally would prefer JQ for a problem I have in hand today.",
        "link": "https://stackoverflow.com/questions/72561553/jq-how-to-efficiently-find-root-nodes-given-objects-each-referring-to-immediate",
        "title": "JQ: How to efficiently find root nodes given objects each referring to immediate parent"
    },
    {
        "tags": [
            "json",
            "bash",
            "command-line-interface",
            "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": 1654785394,
                "post_id": 72562169,
                "comment_id": 128179454,
                "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": 1654785430,
                "post_id": 72562169,
                "comment_id": 128179468,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1654785467,
                "creation_date": 1654785467,
                "answer_id": 72562232,
                "question_id": 72562169,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can create an object with the `date` and `ip` key in which you&#39;ll assign the first and second index accordingly:\r\n\r\n```\r\nsplit(&quot;IP&quot;) | { date: .[0], ip: .[1] }\r\n```\r\nWill produce\r\n```json\r\n{\r\n  &quot;date&quot;: &quot;Thu Jun 9 10:09:14 AM EDT 2022&quot;,\r\n  &quot;ip&quot;: &quot;86.75.30.9&quot;\r\n}\r\n```\r\n\r\n\r\n----------\r\n\r\n##### [Online example](https://jqplay.org/s/eFY48fR6ZOu)",
                "title": "assigning keys to values in JQ"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1654785772,
                "creation_date": 1654785772,
                "answer_id": 72562320,
                "question_id": 72562169,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Using `capture` might come in handy:\r\n~~~sh\r\njq -R &#39;capture(&quot;(?&lt;date&gt;.*)IP(?&lt;ip&gt;.*)&quot;)&#39;\r\n~~~\r\n~~~json\r\n{\r\n  &quot;date&quot;: &quot;Thu Jun 9 10:09:14 AM EDT 2022&quot;,\r\n  &quot;ip&quot;: &quot;86.75.30.9&quot;\r\n}\r\n~~~\r\n[Demo](https://jqplay.org/s/srQUDFBQrWg)",
                "title": "assigning keys to values in JQ"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1654789749,
                "creation_date": 1654789749,
                "answer_id": 72563231,
                "question_id": 72562169,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Mixing [tag:jq] with [Shell Parameter Expansion](https://www.gnu.org/software/bash/manual/bash.html#Shell-Parameter-Expansion):\r\n```sh\r\nline=&#39;Thu Jun 9 10:09:14 AM EDT 2022IP86.75.30.9&#39;\r\njq -n --arg date &quot;${line%IP*}&quot; --arg ip &quot;${line#*IP}&quot; &#39;$ARGS.named&#39;\r\n```\r\n```json\r\n{\r\n  &quot;date&quot;: &quot;Thu Jun 9 10:09:14 AM EDT 2022&quot;,\r\n  &quot;ip&quot;: &quot;86.75.30.9&quot;\r\n}\r\n```",
                "title": "assigning keys to values in JQ"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 0,
        "last_activity_date": 1654789749,
        "creation_date": 1654785194,
        "question_id": 72562169,
        "body_markdown": "Is there a way in jq to go from this stdout:\r\n```\r\nThu Jun 9 10:09:14 AM EDT 2022IP86.75.30.9\r\n```\r\nto this?:\r\n```\r\n{\r\n\t&quot;date&quot;: &quot;Thu Jun 9 10:09:14 AM EDT 2022&quot;,\r\n\t&quot;ip&quot;: &quot;86.75.30.9&quot;\r\n}\r\n```\r\nI was able to get part of the way there\r\n\r\nwith this:\r\n```\r\necho $(date)IP$(myip.sh) | jq -R &#39;split(&quot;IP&quot;)&#39;\r\n```\r\n\r\nthat outputs this: \r\n```\r\n[\r\n  &quot;Thu Jun 9 10:09:14 AM EDT 2022&quot;,\r\n  &quot;86.75.30.9&quot;\r\n]\r\n```\r\n\r\nthanks!!",
        "link": "https://stackoverflow.com/questions/72562169/assigning-keys-to-values-in-jq",
        "title": "assigning keys to 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": 0,
                "creation_date": 1654790121,
                "post_id": 72563252,
                "comment_id": 128181453,
                "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": 1654790150,
                "post_id": 72563252,
                "comment_id": 128181466,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1654790747,
                "post_id": 72563252,
                "comment_id": 128181689,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": false,
                "score": 4,
                "last_activity_date": 1654791032,
                "last_edit_date": 1654791032,
                "creation_date": 1654790288,
                "answer_id": 72563356,
                "question_id": 72563252,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can compare to the empty object `{}`, so `. == {}` or `. != {}` produce a boolean, which should do what you want.\r\n\r\nFurthermore, you could use jq&#39;s `-e` option which sets the exit code based on the result, for integration into the shell:\r\n~~~sh\r\n&lt;&quot;$baskets&quot; jq -L $HOME &#39;check_dups&#39; &gt; &quot;$dups&quot;\r\nif jq -e &#39;. == {}&#39; &lt;&quot;$dups&quot; &gt;/dev/null\r\n  then ...\r\n  else ...\r\nfi\r\n~~~",
                "title": "How to check if a json is empty using bash or jq?"
            },
            {
                "up_vote_count": 6,
                "is_accepted": true,
                "score": 6,
                "last_activity_date": 1654790639,
                "last_edit_date": 1654790639,
                "creation_date": 1654790329,
                "answer_id": 72563368,
                "question_id": 72563252,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can use `error()` to cause a failure if your input is identical to `{}`, and proceed otherwise.\r\n\r\n```\r\njq &#39;\r\n  if . == {} then error(&quot;empty document found&quot;) else . end\r\n  | ...rest of your processing here...\r\n&#39;\r\n```\r\n\r\nAs a quick example:\r\n\r\n```\r\n&lt;&lt;&lt;&quot;{}&quot; jq &#39;if . == {} then error(&quot;empty document found&quot;) else . end | {&quot;output&quot;: (.)}&#39;\r\n```\r\n\r\n...emits a nonzero exit status even without `jq -e`.\r\n\r\n---\r\n\r\n(Addressing a concern [@Thomas](https://stackoverflow.com/users/14637/thomas) brought up, `error()` has a different exit status than an input parsing error; the former is 4, the latter is 5, while compile errors are 3; so should there be a need to distinguish them it&#39;s entirely possible).",
                "title": "How to check if a json is empty using bash or jq?"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1654844833,
                "creation_date": 1654844833,
                "answer_id": 72570334,
                "question_id": 72563252,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You could stick with your approach using the shell&#39;s `-s` test by arranging for your jq command to emit nothing instead of `{}`.  This could be done using the following at the end of your jq program:\r\n\r\n    if . == {} then empty else . end",
                "title": "How to check if a json is empty using bash or jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 8,
        "last_activity_date": 1654844833,
        "creation_date": 1654789876,
        "question_id": 72563252,
        "body_markdown": "I have a function that checks for duplicate values held within objects inside a json file. When duplicates are found the function returns something like this:\r\n\r\n```\r\n{\r\n  &quot;Basket1&quot;: [\r\n    Apple,\r\n    Orange\r\n  ],\r\n  &quot;Basket2&quot;: [\r\n    Apple,\r\n    Orange\r\n  ]\r\n}\r\n```\r\n\r\nIf no duplicates are found then it returns am empty list:\r\n```\r\n{}\r\n```\r\nCurrently I am using ```-s``` in bash like such to check if the there are dups found within the output:\r\n\r\n```\r\n&lt;&quot;$baskets&quot; jq -L $HOME &#39;check_dups&#39; &gt; &quot;$dups&quot;\r\n  if [[ ! -s &quot;$dups&quot; ]];\r\n    then\r\n      echo -e &quot;${RED}[Error]${NC} Duplicates found! Please review duplicates below&quot; &gt;&amp;2\r\n      echo &quot;$(cat &quot;$dups&quot; | jq &#39;.&#39;)&quot;\r\n    else\r\n      echo -e &quot;${GREEN}[SUCCESS]${NC} No duplicates found&quot; &gt;&amp;2\r\n  fi\r\n```\r\nHowever empty object returned if no dups are found will cause the -s file check in bash to succeed regardless. What would be the best way using jq or bash to check whether the output of this function is an empty object or not?      ",
        "link": "https://stackoverflow.com/questions/72563252/how-to-check-if-a-json-is-empty-using-bash-or-jq",
        "title": "How to check if a json is empty using bash or jq?"
    },
    {
        "tags": [
            "javascript",
            "makefile",
            "jq",
            "package.json"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 904308,
                    "reputation": 101782,
                    "user_id": 939557,
                    "user_type": "registered",
                    "accept_rate": 78,
                    "profile_image": "https://i.sstatic.net/3VPea.png?s=256",
                    "display_name": "MadScientist",
                    "link": "https://stackoverflow.com/users/939557/madscientist"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1654796100,
                "post_id": 72564278,
                "comment_id": 128183506,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 10230422,
                    "reputation": 31,
                    "user_id": 7551391,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/dbc1e2b1d5dd69c792de2b4d59da6883?s=256&d=identicon&r=PG",
                    "display_name": "Justin Grabenbauer",
                    "link": "https://stackoverflow.com/users/7551391/justin-grabenbauer"
                },
                "reply_to_user": {
                    "account_id": 904308,
                    "reputation": 101782,
                    "user_id": 939557,
                    "user_type": "registered",
                    "accept_rate": 78,
                    "profile_image": "https://i.sstatic.net/3VPea.png?s=256",
                    "display_name": "MadScientist",
                    "link": "https://stackoverflow.com/users/939557/madscientist"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1654801414,
                "post_id": 72564278,
                "comment_id": 128185149,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 904308,
                    "reputation": 101782,
                    "user_id": 939557,
                    "user_type": "registered",
                    "accept_rate": 78,
                    "profile_image": "https://i.sstatic.net/3VPea.png?s=256",
                    "display_name": "MadScientist",
                    "link": "https://stackoverflow.com/users/939557/madscientist"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1654801641,
                "post_id": 72564278,
                "comment_id": 128185200,
                "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": 1654804416,
                "post_id": 72564278,
                "comment_id": 128186028,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1654804535,
                "creation_date": 1654804535,
                "answer_id": 72565953,
                "question_id": 72564278,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Since you are using `jq`, \r\n```\r\njq &#39;.devDependencies[&quot;@applitools/eyes-testcafe&quot;]&#39; package.json\r\n```\r\n\r\n\r\n# Is it useful?\r\nI question the validity/usefulness of using a Make wrapper around NPM. You&#39;re wrapping a build tool in a build tool. Why? I&#39;m guessing to make it more familiar to developers coming from a C/Make ecosystem. But mixing Make and NPM like this confuses Node/NPM developers, and NPM scripts can run CLI commands just like Make does. \r\n\r\nIs `npm i` really more complicated than `make npm`? Seems like this information is better off in a README, and Make developers should be educated on how to use NPM (e.g. you can run CLI commands from inside NPM scripts). Adding Make scripts isn&#39;t adding any value here, but YMMV, maybe this is particularly useful inside your org.\r\n\r\nAlso don&#39;t use `sudo` when running `npm`. ",
                "title": "Grep package.json dependency versions and interpolate them in a MakeFile"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1654804535,
        "creation_date": 1654795272,
        "last_edit_date": 1654803986,
        "question_id": 72564278,
        "body_markdown": "I am trying to get the current `dependencies` and `devDependencies` versions that are set in the package.json file so that when the MakeFile is run for a new user, it installs the versions listed there and not just the latest version. So for the example below, instead of just saying `npm install @applitools/eyes-testcafe` we would grab the version `1.16.1` from the package.json and interpolate it there in the MakeFile like `${eyes_version}` or something like that.\r\n\r\nAny idea on how to do this? Thanks!\r\n\r\n### package.json\r\n```\r\n&quot;devDependencies&quot;: {\r\n        &quot;@applitools/eyes-testcafe&quot;: &quot;^1.16.1&quot;,\r\n        &quot;testcafe&quot;: &quot;^1.18.6&quot;,\r\n        &quot;testcafe-reporter-xunit&quot;: &quot;*&quot;\r\n}\r\n``` \r\n\r\n### MakeFile\r\n```\r\ninstall-testcafe: npm ffmpeg applitools testcafe\r\n\r\n# Installs all dependencies necessary for testcafe and node to run.\r\nnpm:\r\n\tnpm install\r\n\r\n# Installs the ffmpeg video recorder. This is recursive as sometimes it doesn&#39;t install automatically.\r\nffmpeg:\r\n\tnpm install @ffmpeg-installer/ffmpeg\r\n\r\n# Installs the applitools dependency. This is recursive as sometimes it doesn&#39;t install automatically.\r\napplitools:\r\n\tnpm install @applitools/eyes-testcafe\r\n\r\n# Installs TestCafe globally. This is recursive as sometimes it doesn&#39;t install automatically.\r\ntestcafe:\r\n\tsudo npm install -g testcafe\r\n```",
        "link": "https://stackoverflow.com/questions/72564278/grep-package-json-dependency-versions-and-interpolate-them-in-a-makefile",
        "title": "Grep package.json dependency versions and interpolate them in a MakeFile"
    },
    {
        "tags": [
            "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": 1654814978,
                "post_id": 72567396,
                "comment_id": 128188520,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1654815638,
                "creation_date": 1654815638,
                "answer_id": 72567487,
                "question_id": 72567396,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Create an array with those 3 *filters*, then pass it on to `join(&quot;, &quot;)` \\\r\n(or `@csv` if you don&#39;t need those spaces)\r\n```\r\n.[].Messages[] | [ .MessageId,  (.Attributes.SentTimestamp | tonumber / 1000 | strftime(&quot;%Y-%m-%dT%H:%M:%S %Z&quot;)), (.Body | fromjson | .eTag) ] | join(&quot;, &quot;)\r\n```\r\n\r\nGives (with `--raw output`):\r\n```csv\r\n3ee11508-b7d0-4116-aed4-8c4abe399fd4, 2022-06-07T05:58:07 UTC, 506f370e6a184b38ae4ad9988e396384\r\n3ee11508-b7d0-4116-aed4-8c4abe399fd7, 2022-06-07T05:58:07 UTC, 506f370e6a184b38ae4ad9988e396384\r\n```\r\n&lt;sup&gt;(The last filter had a missing key, so I&#39;ve picked another for the example)&lt;/sup&gt;\r\n\r\n#### [Online demo](https://jqplay.org/s/pOr2ogwZALm)",
                "title": "Combine 3 jq commands into one command to yield a comma-delimited file"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1654815638,
        "creation_date": 1654814777,
        "last_edit_date": 1654815303,
        "question_id": 72567396,
        "body_markdown": "I have the following jq commands I want to run for each JSON object in an array that I&#39;m processing:\r\n\r\n```\r\njq -r &#39;.[].Messages | .[].MessageId&#39; combinded.json\r\njq -r &#39;.[].Messages | .[].Attributes.SentTimestamp|tonumber|(. /1000) | strftime(&quot;%Y-%m-%dT%H:%M:%S %Z&quot;)&#39; combinded.json\r\njq -r &#39;.[].Messages | .[].Body | fromjson | .fileLocation.key&#39; combinded.json\r\n```\r\n\r\nThe output should appear as: `MessageId, date-time, filelocation-key`\r\n\r\nI tried the usual things and nothing worked. Any suggestions?\r\n\r\nThis is sample JSON:\r\n\r\n```\r\n[\r\n  {\r\n    &quot;Messages&quot;: [\r\n      {\r\n        &quot;MessageId&quot;: &quot;3ee11508-b7d0-4116-aed4-8c4abe399fd4&quot;,\r\n        &quot;Body&quot;: &quot;{\\&quot;key\\&quot;:\\&quot;tmp/20220607_015010_163546.pgp\\&quot;,\\&quot;eTag\\&quot;:\\&quot;506f370e6a184b38ae4ad9988e396384\\&quot;,\\&quot;versionId\\&quot;:null}&quot;,\r\n        &quot;Attributes&quot;: {\r\n          &quot;SentTimestamp&quot;: &quot;1654581487500&quot;\r\n        }\r\n      }\r\n    ]\r\n  },\r\n  {\r\n    &quot;Messages&quot;: [\r\n      {\r\n        &quot;MessageId&quot;: &quot;3ee11508-b7d0-4116-aed4-8c4abe399fd7&quot;,\r\n        &quot;Body&quot;: &quot;{\\&quot;key\\&quot;:\\&quot;tmp/20220607_015010_163547.pgp\\&quot;,\\&quot;eTag\\&quot;:\\&quot;506f370e6a184b38ae4ad9988e396384\\&quot;,\\&quot;versionId\\&quot;:null}&quot;,\r\n        &quot;Attributes&quot;: {\r\n          &quot;SentTimestamp&quot;: &quot;1654581487700&quot;\r\n        }\r\n      }\r\n    ]\r\n  }\r\n]\r\n```",
        "link": "https://stackoverflow.com/questions/72567396/combine-3-jq-commands-into-one-command-to-yield-a-comma-delimited-file",
        "title": "Combine 3 jq commands into one command to yield a comma-delimited file"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1654863104,
                "creation_date": 1654863104,
                "answer_id": 72574106,
                "question_id": 72573945,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can just use `+` on each item of both arrays. Assuming the two arrays are stored in variables `$a` and `$b`, then it&#39;d be:\r\n~~~sh\r\njq &#39;[$a[] + $b[]]&#39;\r\n~~~\r\n~~~json\r\n[\r\n  {\r\n    &quot;foo&quot;: &quot;foo1&quot;,\r\n    &quot;bar&quot;: &quot;bar1&quot;\r\n  },\r\n  {\r\n    &quot;foo&quot;: &quot;foo2&quot;,\r\n    &quot;bar&quot;: &quot;bar1&quot;\r\n  },\r\n  {\r\n    &quot;foo&quot;: &quot;foo1&quot;,\r\n    &quot;bar&quot;: &quot;bar2&quot;\r\n  },\r\n  {\r\n    &quot;foo&quot;: &quot;foo2&quot;,\r\n    &quot;bar&quot;: &quot;bar2&quot;\r\n  },\r\n  {\r\n    &quot;foo&quot;: &quot;foo1&quot;,\r\n    &quot;bar&quot;: &quot;bar3&quot;\r\n  },\r\n  {\r\n    &quot;foo&quot;: &quot;foo2&quot;,\r\n    &quot;bar&quot;: &quot;bar3&quot;\r\n  },\r\n  {\r\n    &quot;foo&quot;: &quot;foo1&quot;,\r\n    &quot;bar&quot;: &quot;bar4&quot;\r\n  },\r\n  {\r\n    &quot;foo&quot;: &quot;foo2&quot;,\r\n    &quot;bar&quot;: &quot;bar4&quot;\r\n  }\r\n]\r\n~~~\r\n[Demo](https://jqplay.org/s/PuoGYLlmkeC)\r\n\r\nYou may change the order of the array by flipping the summands as in `[$b[] + $a[]]`. The order with each object should matter as they are identical comparisonwise.",
                "title": "Combine two different object arrays into one"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1654863104,
        "creation_date": 1654862325,
        "last_edit_date": 1654862684,
        "question_id": 72573945,
        "body_markdown": "I have two JSON object arrays:\r\n\r\n```json\r\n[\r\n  {\r\n    &quot;foo&quot;: &quot;foo1&quot;\r\n  },\r\n  {\r\n    &quot;foo&quot;: &quot;foo2&quot;\r\n  },\r\n]\r\n```\r\n\r\n```json\r\n[\r\n  {\r\n    &quot;bar&quot;: &quot;bar1&quot;\r\n  },\r\n  {\r\n    &quot;bar&quot;: &quot;bar2&quot;\r\n  },\r\n  {\r\n    &quot;bar&quot;: &quot;bar3&quot;\r\n  },\r\n  {\r\n    &quot;bar&quot;: &quot;bar4&quot;\r\n  },\r\n]\r\n```\r\n\r\nI would like to combine these into one array of objects which would end up looking like this:\r\n\r\n```json\r\n[\r\n  {\r\n    &quot;foo&quot;: &quot;foo1&quot;\r\n    &quot;bar&quot;: &quot;bar1&quot;\r\n  },\r\n  {\r\n    &quot;foo&quot;: &quot;foo1&quot;\r\n    &quot;bar&quot;: &quot;bar2&quot;\r\n  },\r\n  {\r\n    &quot;foo&quot;: &quot;foo1&quot;\r\n    &quot;bar&quot;: &quot;bar3&quot;\r\n  },\r\n  {\r\n    &quot;foo&quot;: &quot;foo1&quot;\r\n    &quot;bar&quot;: &quot;bar4&quot;\r\n  },\r\n  {\r\n    &quot;foo&quot;: &quot;foo2&quot;\r\n    &quot;bar&quot;: &quot;bar1&quot;\r\n  },\r\n  {\r\n    &quot;foo&quot;: &quot;foo2&quot;\r\n    &quot;bar&quot;: &quot;bar2&quot;\r\n  },\r\n  {\r\n    &quot;foo&quot;: &quot;foo2&quot;\r\n    &quot;bar&quot;: &quot;bar3&quot;\r\n  },\r\n  {\r\n    &quot;foo&quot;: &quot;foo2&quot;\r\n    &quot;bar&quot;: &quot;bar4&quot;\r\n  },\r\n]\r\n```\r\n\r\nThis would generate the GitHub Actions matrix I need.\r\n\r\nI&#39;m struggling to get the desired output. `jq -s &#39;transpose | map(add)&#39;` is kind of close.",
        "link": "https://stackoverflow.com/questions/72573945/combine-two-different-object-arrays-into-one",
        "title": "Combine two different object arrays into one"
    }
]