[
    {
        "tags": [
            "json",
            "linux",
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1661197619,
                "post_id": 73449842,
                "comment_id": 129710378,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1661195999,
                "creation_date": 1661195999,
                "answer_id": 73450084,
                "question_id": 73449842,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Your first query produces a JSON array, so in this response, I&#39;ll assume it will suffice to produce an array of the eight values of interest in the order you&#39;ve specified.\r\n\r\nWith your input, the following invocation produces the eight values as shown below:\r\n```\r\njq &#39;.executions[]\r\n  | [.href, .status, .project,\r\n     (.&quot;date-started&quot; | (.unixtime, .date)),\r\n     (.&quot;date-ended&quot; | (.unixtime, .date)),\r\n     .job.name]&#39; \r\n```\r\nOutput:\r\n```\r\n[\r\n  &quot;https://localhost.com.br/rundeck/api/40/execution/2340&quot;,\r\n  &quot;succeeded&quot;,\r\n  &quot;PROJETO&quot;,\r\n  1660793400012,\r\n  &quot;2022-08-18T03:30:00Z&quot;,\r\n  1660793409694,\r\n  &quot;2022-08-18T03:30:09Z&quot;,\r\n  &quot;proc_limpeza_saft&quot;\r\n]\r\n```\r\n\r\n",
                "title": "How to filter an array of json with jq in linux?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1661197304,
        "creation_date": 1661194576,
        "last_edit_date": 1661197304,
        "question_id": 73449842,
        "body_markdown": "I have the following JSON input:\r\n\r\n    {\r\n      &quot;paging&quot;: {\r\n        &quot;count&quot;: 0,\r\n        &quot;total&quot;: 0,\r\n        &quot;offset&quot;: 0,\r\n        &quot;max&quot;: 0\r\n      },\r\n      &quot;executions&quot;: [\r\n        {\r\n          &quot;id&quot;: 5,\r\n          &quot;href&quot;: &quot;https://localhost.com.br&quot;,\r\n          &quot;permalink&quot;: &quot;https://localhost.com.br&quot;,\r\n          &quot;status&quot;: &quot;succeeded&quot;,\r\n          &quot;project&quot;: &quot;PROJETO&quot;,\r\n          &quot;executionType&quot;: &quot;scheduled&quot;,\r\n          &quot;date-started&quot;: {\r\n            &quot;unixtime&quot;: 1660793400012,\r\n            &quot;date&quot;: &quot;2022-08-18T03:30:00Z&quot;\r\n          },\r\n          &quot;date-ended&quot;: {\r\n            &quot;unixtime&quot;: 1660793409694,\r\n            &quot;date&quot;: &quot;2022-08-18T03:30:09Z&quot;\r\n          },\r\n          &quot;job&quot;: {\r\n            &quot;id&quot;: &quot;cdkwednweoi-8745bjdf-kcjkjr8745&quot;,\r\n            &quot;averageDuration&quot;: 0,\r\n            &quot;name&quot;: &quot;routine&quot;,\r\n            &quot;group&quot;: &quot;&quot;,\r\n            &quot;project&quot;: &quot;PROJECT&quot;,\r\n            &quot;description&quot;: &quot;&quot;,\r\n            &quot;href&quot;: &quot;https://localhost.com.br&quot;,\r\n            &quot;permalink&quot;: &quot;https://localhost.com.br&quot;\r\n          },\r\n          &quot;description&quot;: &quot;runner&quot;,\r\n          &quot;argstring&quot;: null,\r\n          &quot;serverUUID&quot;: &quot;jdnsdnasldnaje382nf5ubv&quot;,\r\n          &quot;successfulNodes&quot;: [\r\n            &quot;84jsk937nf&quot;\r\n          ]\r\n        }\r\n      ]\r\n    }\r\n\r\nFirst I want to select an array by a property name. And then I want to select an object of the array by the value of the propertyes.\r\n\r\nExample of the desired informations on output:\r\n\r\n      &quot;href&quot;\r\n      &quot;status&quot;\r\n      &quot;project&quot;\r\n    \r\n      &quot;date-started&quot;: \r\n       &quot;unixtime&quot;: 48298437239847,\r\n       &quot;date&quot;: &quot;2022-07-17&quot;\r\n    \r\n     &quot;date-ended&quot;: \r\n       &quot;unixtime&quot;: 48298437239847,\r\n       &quot;date&quot;: &quot;2022-07-17&quot;\r\n    \r\n      &quot;job&quot;:\r\n      &quot;name&quot;: &quot;cleaner&quot;\r\n\r\nI knew how to get the firts values:\r\njq -r &#39;.executions[] | [.href, .status, .project&#39;]\r\n\r\nBut the other ones I don&#39;t know how to do, I&#39;ve tried with:\r\njq &#39;.executions[] | with_entries( select(.value | has(&quot;date-started&quot;) ) )&#39;\r\n\r\nBut it doesn&#39;t works. \r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/73449842/how-to-filter-an-array-of-json-with-jq-in-linux",
        "title": "How to filter an array of json with jq in linux?"
    },
    {
        "tags": [
            "json",
            "merge",
            "jq",
            "json-ld"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 4618618,
                    "reputation": 57176,
                    "user_id": 3744304,
                    "user_type": "registered",
                    "accept_rate": 75,
                    "profile_image": "https://i.sstatic.net/17uwe.jpg?s=256",
                    "display_name": "connexo",
                    "link": "https://stackoverflow.com/users/3744304/connexo"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1661210693,
                "post_id": 73451819,
                "comment_id": 129713289,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1661215342,
                "last_edit_date": 1661215342,
                "creation_date": 1661214925,
                "answer_id": 73452248,
                "question_id": 73451819,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "As @peak has pointed out, some aspects are underspecified. For instance, what should happen with `.customerId` and `.id`? Are they always the same across all files (as suggested by the sample files provided)? Do you want the items of the `.emails` array just thrown into one large array, or do you want to have them &quot;merged&quot; by some criteria (e.g. by a common value in their `.address` field)? Here are some stubs to start from:\r\n\r\n- Simply concatenate the `.emails` arrays and take all other parts from the first file:\r\n~~~sh\r\njq &#39;reduce inputs as $in (.; .emails += $in.emails)&#39; file*.json\r\n\r\n# or simpler\r\njq &#39;.emails += [inputs.emails[]]&#39; file*.json\r\n~~~\r\n[Demo](https://jqplay.org/s/PW6Gk5ZYYRh) [Demo](https://jqplay.org/s/xRNu-FGWZtU)\r\n~~~json\r\n{\r\n  &quot;emails&quot;: [\r\n    {\r\n      &quot;address&quot;: &quot;cc@xx.com&quot;\r\n    },\r\n    {\r\n      &quot;address&quot;: &quot;james@zz.com&quot;,\r\n      &quot;customType&quot;: &quot;&quot;,\r\n      &quot;type&quot;: &quot;custom&quot;\r\n    },\r\n    {\r\n      &quot;address&quot;: &quot;james@x.com&quot;\r\n    },\r\n    {\r\n      &quot;address&quot;: &quot;sales@x.com&quot;,\r\n      &quot;primary&quot;: true\r\n    },\r\n    {\r\n      &quot;address&quot;: &quot;info@x.com&quot;\r\n    },\r\n    {\r\n      &quot;address&quot;: &quot;james@x.com&quot;\r\n    },\r\n    {\r\n      &quot;address&quot;: &quot;sales@x.com&quot;,\r\n      &quot;primary&quot;: true\r\n    },\r\n    {\r\n      &quot;address&quot;: &quot;info@x.com&quot;\r\n    }\r\n  ],\r\n  &quot;customerId&quot;: &quot;xx&quot;,\r\n  &quot;id&quot;: &quot;654&quot;\r\n}\r\n~~~\r\n\r\n- Merge the objects in the `.emails` array by a common value in their `.address` field, with latter values overwriting former values for other fields with colliding names, and discard all other parts from the files:\r\n~~~sh\r\njq -n &#39;reduce inputs.emails[] as $e ({}; .[$e.address] += $e) | map(.)&#39; file*.json\r\n~~~\r\n[Demo](https://jqplay.org/s/BY2mJa-cxIi)\r\n~~~json\r\n[\r\n  {\r\n    &quot;address&quot;: &quot;cc@xx.com&quot;\r\n  },\r\n  {\r\n    &quot;address&quot;: &quot;james@zz.com&quot;,\r\n    &quot;customType&quot;: &quot;&quot;,\r\n    &quot;type&quot;: &quot;custom&quot;\r\n  },\r\n  {\r\n    &quot;address&quot;: &quot;james@x.com&quot;\r\n  },\r\n  {\r\n    &quot;address&quot;: &quot;sales@x.com&quot;,\r\n    &quot;primary&quot;: true\r\n  },\r\n  {\r\n    &quot;address&quot;: &quot;info@x.com&quot;\r\n  }\r\n]\r\n~~~\r\n\r\n- If you are only interested in a list of unique field names for a given address, regardless of the counts and values used, you can also go with:\r\n~~~sh\r\njq -n &#39;\r\n  reduce inputs.emails[] as $e ({}; .[$e.address][$e | keys_unsorted[]] = 1)\r\n  | map_values(keys)\r\n&#39;\r\n~~~\r\n[Demo](https://jqplay.org/s/xFuzYcguHCZ)\r\n~~~json\r\n{\r\n  &quot;cc@xx.com&quot;: [\r\n    &quot;address&quot;\r\n  ],\r\n  &quot;james@zz.com&quot;: [\r\n    &quot;address&quot;,\r\n    &quot;customType&quot;,\r\n    &quot;type&quot;\r\n  ],\r\n  &quot;james@x.com&quot;: [\r\n    &quot;address&quot;\r\n  ],\r\n  &quot;sales@x.com&quot;: [\r\n    &quot;address&quot;,\r\n    &quot;primary&quot;\r\n  ],\r\n  &quot;info@x.com&quot;: [\r\n    &quot;address&quot;\r\n  ]\r\n}\r\n~~~",
                "title": "Merging multiple JSON Lines files into a single JSON object"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1661217301,
                "creation_date": 1661217301,
                "answer_id": 73452433,
                "question_id": 73451819,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "&gt; The structure of the objects contained in `file1.json` is unknown, so the solution must be agnostic of any keys/values and the solution must not assume any structure or depth.\r\n\r\nYou can use the `--stream` flag to break down the structure into an array of paths and values, discard the values part and make the paths unique:\r\n~~~sh\r\njq --stream -nc &#39;[inputs[0]] | unique[]&#39; file*.json\r\n~~~\r\n~~~json\r\n[&quot;customerId&quot;]\r\n[&quot;emails&quot;]\r\n[&quot;emails&quot;,0,&quot;address&quot;]\r\n[&quot;emails&quot;,0,&quot;customType&quot;]\r\n[&quot;emails&quot;,0,&quot;primary&quot;]\r\n[&quot;emails&quot;,0,&quot;type&quot;]\r\n[&quot;emails&quot;,1,&quot;address&quot;]\r\n[&quot;emails&quot;,2]\r\n[&quot;emails&quot;,2,&quot;address&quot;]\r\n[&quot;emails&quot;,2,&quot;primary&quot;]\r\n[&quot;emails&quot;,3]\r\n[&quot;emails&quot;,3,&quot;address&quot;]\r\n[&quot;id&quot;]\r\n~~~\r\nTrying to build a representation of this, similar to any of the input files, comes with a lot of caveats. For instance, how would you represent in a single structure if one file had `.emails` as an array of objects, and another had `.emails` as just an atomic value, say, a string. You would not be able to represent this plurality without introducing new, possibly ambiguous structures (e.g. putting all possibilities into an array).\r\n\r\nTherefore, having a list of paths could be a fair compromise. Judging by your desired output, you want to focus more on the object structure, so you could further reduce complexity by discarding the array indices. Depending on your use case, you could replace them with a single value to retain the information of the presence of an array, or discard them entirely:\r\n\r\n~~~sh\r\njq --stream -nc &#39;[inputs[0] | map(numbers = 0)] | unique[]&#39; file*.json\r\n~~~\r\n~~~json\r\n[&quot;customerId&quot;]\r\n[&quot;emails&quot;]\r\n[&quot;emails&quot;,0]\r\n[&quot;emails&quot;,0,&quot;address&quot;]\r\n[&quot;emails&quot;,0,&quot;customType&quot;]\r\n[&quot;emails&quot;,0,&quot;primary&quot;]\r\n[&quot;emails&quot;,0,&quot;type&quot;]\r\n[&quot;id&quot;]\r\n~~~\r\n\r\n~~~sh\r\njq --stream -nc &#39;[inputs[0] | map(strings)] | unique[]&#39; file*.json\r\n~~~\r\n~~~json\r\n[&quot;customerId&quot;]\r\n[&quot;emails&quot;]\r\n[&quot;emails&quot;,&quot;address&quot;]\r\n[&quot;emails&quot;,&quot;customType&quot;]\r\n[&quot;emails&quot;,&quot;primary&quot;]\r\n[&quot;emails&quot;,&quot;type&quot;]\r\n[&quot;id&quot;]\r\n~~~",
                "title": "Merging multiple JSON Lines files into a single JSON object"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1661222523,
                "last_edit_date": 1661222523,
                "creation_date": 1661221136,
                "answer_id": 73452481,
                "question_id": 73451819,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The following program meets these two key requirements:\r\n1. &quot;all keys from input objects must be present in output object&quot;;\r\n2. &quot;the solution must be agnostic of any keys/values and the solution must not assume any structure or depth.&quot;\r\n\r\nThe approach is the same as one suggested by @pmf, and for the example given in the Q, produces results that are very similar to the one that is shown:\r\n\r\n```\r\njq -n --stream &#39;\r\n  def squish: map(select(type == &quot;string&quot;));\r\n  reduce (inputs | select(length==2)) as [$p, $v] ({};\r\n    setpath($p|squish; $v))\r\n&#39;\r\n```\r\nWith the given input, this produces:\r\n```\r\n{\r\n  &quot;customerId&quot;: &quot;xx&quot;,\r\n  &quot;emails&quot;: {\r\n    &quot;address&quot;: &quot;peter@x.com&quot;,\r\n    &quot;customType&quot;: &quot;&quot;,\r\n    &quot;type&quot;: &quot;custom&quot;,\r\n    &quot;primary&quot;: true\r\n  },\r\n  &quot;id&quot;: &quot;654&quot;\r\n}\r\n```",
                "title": "Merging multiple JSON Lines files into a single JSON object"
            },
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1661224805,
                "last_edit_date": 1661224805,
                "creation_date": 1661222432,
                "answer_id": 73452586,
                "question_id": 73451819,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here is a solution that produces the expected result in the sample example, and seems to meet all the stated requirements.  It is similar to one proposed by @pmf on this page.\r\n```\r\njq -n --stream &#39;\r\n  def squish: map(if type == &quot;number&quot; then 0 else . end);\r\n  reduce (inputs | select(length==2)) as [$p, $v] ({}; setpath($p|squish; $v))\r\n&#39;\r\n```\r\n\r\n### Output\r\nFor the example given in the Q, the output is:\r\n```\r\n{\r\n  &quot;customerId&quot;: &quot;xx&quot;,\r\n  &quot;emails&quot;: [\r\n    {\r\n      &quot;address&quot;: &quot;peter@x.com&quot;,\r\n      &quot;customType&quot;: &quot;&quot;,\r\n      &quot;type&quot;: &quot;custom&quot;,\r\n      &quot;primary&quot;: true\r\n    }\r\n  ],\r\n  &quot;id&quot;: &quot;654&quot;\r\n}\r\n```\r\n\r\n\r\n",
                "title": "Merging multiple JSON Lines files into a single JSON object"
            }
        ],
        "is_answered": true,
        "answer_count": 4,
        "score": 1,
        "last_activity_date": 1661291469,
        "creation_date": 1661209659,
        "last_edit_date": 1661291469,
        "question_id": 73451819,
        "body_markdown": "I&#39;m trying to merge / reduce many JSON objects and somehow I&#39;m not getting the expected result.\r\n\r\nI&#39;m only interested in getting all keys, the values and the number of items inside arrays are irrelevant.\r\n\r\n`file1.json`:\r\n\r\n```\r\n{\r\n  &quot;customerId&quot;: &quot;xx&quot;,\r\n  &quot;emails&quot;: [\r\n    {\r\n      &quot;address&quot;: &quot;james@zz.com&quot;,\r\n      &quot;customType&quot;: &quot;&quot;,\r\n      &quot;type&quot;: &quot;custom&quot;\r\n    },\r\n    {\r\n      &quot;address&quot;: &quot;sales@x.com&quot;,\r\n      &quot;primary&quot;: true\r\n    },\r\n    {\r\n      &quot;address&quot;: &quot;info@x.com&quot;\r\n    }\r\n  ]\r\n}\r\n{\r\n  &quot;id&quot;: &quot;654&quot;,\r\n  &quot;emails&quot;: [\r\n    {\r\n      &quot;address&quot;: &quot;peter@x.com&quot;,\r\n      &quot;primary&quot;: true\r\n    }\r\n  ]\r\n}\r\n```\r\nThe desired output is a JSON object with all possible keys from all input objects. The values are irrelevant, any value from any input object is OK. But all keys from input objects must be present in output object:\r\n```\r\n{\r\n  &quot;emails&quot;: [\r\n    {\r\n      &quot;address&quot;: &quot;james@zz.com&quot;, &lt;--- any existing value works\r\n      &quot;customType&quot;: &quot;&quot;, &lt;--- any existing value works\r\n      &quot;type&quot;: &quot;custom&quot;, &lt;--- any existing value works\r\n      &quot;primary&quot;: true &lt;--- any existing value works\r\n    }\r\n  ],\r\n  &quot;customerId&quot;: &quot;xx&quot;, &lt;--- any existing value works\r\n  &quot;id&quot;: &quot;654&quot; &lt;--- any existing value works\r\n}\r\n```\r\nI tried reducing it, but it misses many of the keys in the array:\r\n\r\n```\r\n$ jq -s &#39;reduce .[] as $item ({}; . + $item)&#39; file1.json\r\n{\r\n  &quot;customerId&quot;: &quot;xx&quot;,\r\n  &quot;emails&quot;: [\r\n    {\r\n      &quot;address&quot;: &quot;peter@x.com&quot;,\r\n      &quot;primary&quot;: true\r\n    }\r\n  ],\r\n  &quot;id&quot;: &quot;654&quot;\r\n}\r\n```\r\n\r\nThe structure of the objects contained in `file1.json` is unknown, so the solution must be agnostic of any keys/values and the solution must not assume any structure or depth.\r\n\r\nIs it possible to fix this somehow considering how `jq` works? Or is it possible to solve this issue using another tool?\r\n\r\nPS: For those of you that are curious, this is useful to infer a schema that can be created in a database. Given an arbitrary number of JSON objects with an arbitrary structure, it&#39;s easy to create a single JSON squished/merged/fused structure that will &quot;accommodate&quot; all JSON objects. \r\n\r\n[BigQuery is able to autodetect a schema][1], but only 500 lines are analyzed to come up with it. This presents problems if objects have different structures past that 500 line mark.\r\n\r\nWith this approach I can squish a JSON Lines file with 1000000s of objects into one line that can be then imported into BigQuery with the `autodetect` schema flag and it will work every time since BigQuery only has one line to analyze and this line is the &quot;super-schema&quot; of all the objects. After extracting the autodetected schema I can manually fine tune it to make sure types are correct and then recreate the table specifying my tuned schema:\r\n\r\n```\r\n$ ls -1 users*.json | wc --lines\r\n3672\r\n$ cat users*.json &gt; users-all.json\r\n$ cat users-all.json | wc --lines\r\n146482633\r\n$ jq &#39;squish&#39; users-all.json &gt; users-all-squished.json\r\n$ cat users-all-squished.json | wc --lines\r\n1\r\n$ bq load --autodetect users users-all-squished.json\r\n$ bq show schema --format=prettyjson users &gt; users-schema.json\r\n$ vi users-schema.json\r\n$ bq rm --table users\r\n$ bq mk --table users --schema=users-schema.json\r\n$ bq load users users-all.json\r\n```\r\n[Some options are missing or changed for readability]\r\n\r\n\r\n  [1]: https://cloud.google.com/bigquery/docs/schema-detect",
        "link": "https://stackoverflow.com/questions/73451819/merging-multiple-json-lines-files-into-a-single-json-object",
        "title": "Merging multiple JSON Lines files into a single 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": 1661260848,
                "post_id": 73458432,
                "comment_id": 129725753,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 26138911,
                    "reputation": 1,
                    "user_id": 19828571,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/79d1e22594957afd4ae17f37b3da545d?s=256&d=identicon&r=PG",
                    "display_name": "def0to",
                    "link": "https://stackoverflow.com/users/19828571/def0to"
                },
                "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": 1661263339,
                "post_id": 73458432,
                "comment_id": 129727050,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1661891495,
                "creation_date": 1661891495,
                "answer_id": 73548146,
                "question_id": 73458432,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Suppress the error and provide an alternative for empty values:\r\n\r\n```\r\n.result | map(\r\n    &quot;https://vuldb.com/?id.\\(.entry.id)&quot;,\r\n    (\r\n        .software |\r\n        .vendor // &quot;empty&quot;,\r\n        .name // &quot;empty&quot;,\r\n        (.version[] | tostring // &quot;empty&quot;)? // &quot;no version&quot;,\r\n        .type // &quot;empty&quot;,\r\n        .platform // &quot;empty&quot;\r\n    )\r\n)",
                "title": "Jq to string filter"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1661891495,
        "creation_date": 1661256332,
        "last_edit_date": 1661764414,
        "question_id": 73458432,
        "body_markdown": "Trying to filter the output from Json, so far the filter used works as expected when , the software version is found .However when the software version is not present , jq will result in a error. Basically how do I escape the () and return empty in the csv file.\r\n\r\n```\r\n.result [] | [ &quot;https://vuldb.com/?id.&quot; + .entry.id ,.software.vendor // &quot;empty&quot;\r\n,.software.name // &quot;empty&quot;, (.software.version []| tostring // &quot;empty&quot;)\r\n,.software.type // &quot;empty&quot;\r\n,.software.platform //&quot;empty&quot; ]\r\n```\r\n\r\n```\r\n    &quot;result&quot;: [\r\n        {\r\n            &quot;entry&quot;: {\r\n                &quot;id&quot;: &quot;206880&quot;,\r\n                &quot;title&quot;: &quot;CrowdStrike Falcon 6.31.14505.0\\/6.42.15610 Uninstallation authorization&quot;,\r\n                &quot;summary&quot;: &quot;A vulnerability was found in CrowdStrike Falcon 6.31.14505.0\\/6.42.15610. It has been classified as problematic. Affected is some unknown functionality of the component Uninstallation Handler. There is no information about possible countermeasures known. It may be suggested to replace the affected object with an alternative product.&quot;,\r\n                &quot;details&quot;: {\r\n                    &quot;affected&quot;: &quot;A vulnerability was found in CrowdStrike Falcon 6.31.14505.0\\/6.42.15610. It has been classified as problematic.&quot;,\r\n                    &quot;vulnerability&quot;: &quot;CWE is classifying the issue as CWE-862. The software does not perform an authorization check when an actor attempts to access a resource or perform an action.&quot;,\r\n                    &quot;impact&quot;: &quot;This is going to have an impact on availability.&quot;,\r\n                    &quot;exploit&quot;: &quot;It is declared as functional. The vulnerability was handled as a non-public zero-day exploit for at least 54 days. During that time the estimated underground price was around $0-$5k.&quot;,\r\n                    &quot;countermeasure&quot;: &quot;There is no information about possible countermeasures known. It may be suggested to replace the affected object with an alternative product.&quot;,\r\n                    &quot;sources&quot;: &quot;Further details are available at modzero.com.&quot;\r\n                },\r\n                &quot;timestamp&quot;: {\r\n                    &quot;create&quot;: &quot;1661155277&quot;,\r\n                    &quot;change&quot;: &quot;1661155462&quot;\r\n                },\r\n                &quot;changelog&quot;: [\r\n                    &quot;vulnerability_cvss3_meta_basescore&quot;,\r\n                    &quot;vulnerability_cvss3_meta_tempscore&quot;,\r\n                    &quot;vulnerability_cvss3_researcher_basescore&quot;\r\n                ]\r\n            },\r\n            &quot;software&quot;: {\r\n                &quot;vendor&quot;: &quot;CrowdStrike&quot;,\r\n                &quot;name&quot;: &quot;Falcon&quot;,\r\n                &quot;version&quot;: [\r\n                    &quot;6.31.14505.0&quot;,\r\n                    &quot;6.42.15610&quot;\r\n                ],\r\n```",
        "link": "https://stackoverflow.com/questions/73458432/jq-to-string-filter",
        "title": "Jq to string filter"
    },
    {
        "tags": [
            "decimal",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 7883072,
                    "reputation": 8834,
                    "user_id": 5956261,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/ccc55a85ea2fad1e8ea5155bcd0738cc?s=256&d=identicon&r=PG",
                    "display_name": "jthulhu",
                    "link": "https://stackoverflow.com/users/5956261/jthulhu"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1661269526,
                "post_id": 73461555,
                "comment_id": 129729795,
                "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": 1661270987,
                "post_id": 73461555,
                "comment_id": 129730347,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 4271620,
                    "reputation": 219,
                    "user_id": 3493315,
                    "user_type": "registered",
                    "accept_rate": 33,
                    "profile_image": "https://www.gravatar.com/avatar/652dfa0126a15bc9455f80e2e02e5c19?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Madhuprathap",
                    "link": "https://stackoverflow.com/users/3493315/madhuprathap"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1661272307,
                "post_id": 73461555,
                "comment_id": 129730774,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1661273385,
                "creation_date": 1661273385,
                "answer_id": 73462437,
                "question_id": 73461555,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The sum is correct, just not precise, a (general) limitation of floating-point arithmetics. You should always consider rounding, when dealing with (especially comparing to) floating-point numbers (or operations potentially producing them). \r\n\r\n&gt; Can you help me to round it off two decimal places? i.e. 134.40999999999985 to 134.41 My number can be of any length not just 3 digits.\r\n\r\n##### Round the numbers for display:\r\n~~~sh\r\nmap(\r\n  .sum = .prebalance + .amount\r\n  | .sum |= (. * 100 | round / 100)\r\n)\r\n~~~\r\n~~~json\r\n[\r\n  {\r\n    &quot;prebalance&quot;: -2865.59,\r\n    &quot;amount&quot;: 3000,\r\n    &quot;balance&quot;: 134.41,\r\n    &quot;sum&quot;: 134.41\r\n  },\r\n  {\r\n    &quot;prebalance&quot;: -1865.59,\r\n    &quot;amount&quot;: 2000,\r\n    &quot;balance&quot;: 134.41,\r\n    &quot;sum&quot;: 134.41\r\n  }\r\n]\r\n~~~\r\n[Demo](https://jqplay.org/s/JNnVn7Lf67g)\r\n\r\n##### Compare the absolute difference to a given epsilon for equality tests:\r\n~~~sh\r\n1e-9 as $epsilon | map(\r\n  .sum = .prebalance + .amount\r\n  | .equal = (.sum - .balance | fabs &lt; $epsilon)\r\n)\r\n~~~\r\n~~~json\r\n[\r\n  {\r\n    &quot;prebalance&quot;: -2865.59,\r\n    &quot;amount&quot;: 3000,\r\n    &quot;balance&quot;: 134.41,\r\n    &quot;sum&quot;: 134.40999999999985,\r\n    &quot;equal&quot;: true\r\n  },\r\n  {\r\n    &quot;prebalance&quot;: -1865.59,\r\n    &quot;amount&quot;: 2000,\r\n    &quot;balance&quot;: 134.41,\r\n    &quot;sum&quot;: 134.41000000000008,\r\n    &quot;equal&quot;: true\r\n  }\r\n]\r\n~~~\r\n[Demo](https://jqplay.org/s/y8GotBij51o)",
                "title": "jq | how to add two decimals correctly"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1661306270,
        "creation_date": 1661269314,
        "last_edit_date": 1661306270,
        "question_id": 73461555,
        "body_markdown": "For data below when I try to add prebalance, amount to match with balance, why I am getting wrong sum value. How can I get the correct values.\r\n\r\n````[\r\n{\r\n\t&quot;prebalance&quot;: -2865.59,\r\n\t&quot;amount&quot;: 3000.00,\r\n\t&quot;balance&quot;: 134.41\r\n},\r\n{\r\n\t&quot;prebalance&quot;: -1865.59,\r\n\t&quot;amount&quot;: 2000.00,\r\n\t&quot;balance&quot;: 134.41\r\n}\r\n]\r\n````\r\n\r\nJQ Play link for sample data.\r\n\r\nhttps://jqplay.org/s/T4gL4kOkj7X\r\n\r\n",
        "link": "https://stackoverflow.com/questions/73461555/jq-how-to-add-two-decimals-correctly",
        "title": "jq | how to add two decimals correctly"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1661363866,
                "last_edit_date": 1661363866,
                "creation_date": 1661341719,
                "answer_id": 73472604,
                "question_id": 73472165,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can use `transpose` here, which can play a key role in converting the arrays to key/value pairs\r\n\r\n```none\r\n.data[] |= {place} + \r\n   ([ .id, .values ] | transpose | map({(.[0]): { value: .[1] } }) | add)\r\n```\r\n\r\nThe solution works by converting the array-of-arrays `[.id, .values]` by transposing them, i.e. converting\r\n\r\n```json\r\n[[&quot;7_day_A&quot;,&quot;7_day_B&quot;,&quot;7_day_C&quot;,&quot;7_day_D&quot;],[0,30,23,43]]\r\n[[&quot;1_day_A&quot;,&quot;1_day_B&quot;,&quot;1_day_C&quot;,&quot;1_day_D&quot;],[4,45,100,9]]\r\n```\r\n\r\nto\r\n\r\n```json\r\n[[&quot;7_day_A&quot;,0],[&quot;7_day_B&quot;,30],[&quot;7_day_C&quot;,23],[&quot;7_day_D&quot;,43]]\r\n[[&quot;1_day_A&quot;,4],[&quot;1_day_B&quot;,45],[&quot;1_day_C&quot;,100],[&quot;1_day_D&quot;,9]]\r\n``` \r\n\r\nWith the transformation done, we construct an object with key as the zeroth index element and value as an object comprising of the value of first index element, and combine the results together with `add`\r\n\r\nDemo - [jqplay][1]\r\n\r\n\r\n  [1]: https://jqplay.org/s/AdxDDFFUeN5",
                "title": "Is there a way to transform these 2 arrays by using jq, into a set of objects, like in the example down below?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1661363866,
        "creation_date": 1661339786,
        "last_edit_date": 1661341813,
        "question_id": 73472165,
        "body_markdown": "Example json data:\r\n\r\n``` \r\n{\r\n  &quot;data&quot;: [\r\n    {\r\n      &quot;place&quot;: &quot;FM346&quot;,\r\n      &quot;id&quot;: [\r\n        &quot;7_day_A&quot;,\r\n        &quot;7_day_B&quot;,\r\n        &quot;7_day_C&quot;,\r\n        &quot;7_day_D&quot;\r\n      ],\r\n      &quot;values&quot;: [\r\n        0,\r\n        30,\r\n        23,\r\n        43\r\n      ]\r\n    },\r\n    {\r\n      &quot;place&quot;: &quot;LH210&quot;,\r\n      &quot;id&quot;: [\r\n        &quot;1_day_A&quot;,\r\n        &quot;1_day_B&quot;,\r\n        &quot;1_day_C&quot;,\r\n        &quot;1_day_D&quot;\r\n      ],\r\n      &quot;values&quot;: [\r\n        4,\r\n        45,\r\n        100,\r\n        9\r\n      ]\r\n    }\r\n  ]\r\n}\r\n``` \r\nwhat i need to transform it into:\r\n``` \r\n{\r\n  &quot;data&quot;: [\r\n    {\r\n      &quot;place&quot;: &quot;FM346&quot;,\r\n      &quot;7_day_A&quot;: {\r\n        &quot;value&quot;: 0\r\n      },\r\n      &quot;7_day_B&quot;: {\r\n        &quot;value&quot;: 30\r\n      },\r\n      &quot;7_day_C&quot;: {\r\n        &quot;value&quot;: 23\r\n      },\r\n      &quot;7_day_D&quot;: {\r\n        &quot;value&quot;: 43\r\n      }\r\n    },\r\n    {\r\n      &quot;place&quot;: &quot;LH210&quot;,\r\n      &quot;1_day_A&quot;: {\r\n        &quot;value&quot;: 4\r\n      },\r\n      &quot;1_day_B&quot;: {\r\n        &quot;value&quot;: 45\r\n      },\r\n      &quot;1_day_C&quot;: {\r\n        &quot;value&quot;: 100\r\n      },\r\n      &quot;1_day_D&quot;: {\r\n        &quot;value&quot;: 9\r\n      }\r\n    }\r\n  ]\r\n}\r\n\r\n``` \r\ni have tried this:\r\n``` \r\n{\r\n    data:[.data |.[]|\r\n    {   \r\n        place: (.place),\r\n        (.id[]): \r\n        {\r\n            value: (.values[])\r\n        }\r\n    }] \r\n}\r\n``` \r\n(in jqplay: https://jqplay.org/s/f4BBtN9gwmp)\r\n\r\nand this: \r\n```\r\n{\r\n    data:[.data |.[]|\r\n    {   \r\n        place: (.place),\r\n        test:\r\n        [{\r\n            (.id[]): \r\n            {\r\n            value: (.values[])\r\n            }\r\n        }]\r\n    }] \r\n}\r\n``` \r\n(in jqplay: https://jqplay.org/s/pKIvQe1CzgX)\r\n \r\nbut they arent grouped in the way i wanted and it gives each value to each id, not the corresponding one.\r\nI have been trying for some time now, but im new to jq and have no idea how to transform it this way, thanks in advance for any answers.\r\n",
        "link": "https://stackoverflow.com/questions/73472165/is-there-a-way-to-transform-these-2-arrays-by-using-jq-into-a-set-of-objects-l",
        "title": "Is there a way to transform these 2 arrays by using jq, into a set of objects, like in the example down below?"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1661443238,
                "last_edit_date": 1661443238,
                "creation_date": 1661437156,
                "answer_id": 73489186,
                "question_id": 73488511,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Something like this:\r\n\r\n    jq -r &#39;.DataSet.PhysicalTableMap[].CustomSql.DataSourceArn&#39;\r\n\r\nThe part `.DataSet.PhysicalTableMap` returns the object as *one* result, the following filter `[]` takes that object and returns *each* value as *one* result. The following filters take each of these separate results and refines more stuff.\r\n\r\nNote: If the object is the top-level item then the syntax is `.[]` .",
                "title": "Jq: how to address a random-like key in json"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1661443238,
        "creation_date": 1661434553,
        "last_edit_date": 1661435609,
        "question_id": 73488511,
        "body_markdown": "in AWS CLI, the command **aws quicksight describe-data-set blah blah** returns a json document with the following troublesome syntax:\r\n\r\n    {\r\n        &quot;Status&quot;: 200,\r\n        &quot;DataSet&quot;: {\r\n            &quot;Arn&quot;: &quot;arn:aws:quicksight:&lt;region&gt;:&lt;acct&gt;:dataset/b7c87122-e180-47a9-a8a4-19f171e13fc8&quot;,\r\n            &quot;DataSetId&quot;: &quot;b7c87122-e180-47a9-a8a4-19f171e13fc8&quot;,\r\n            &quot;Name&quot;: &quot;MyName&quot;,\r\n            &quot;CreatedTime&quot;: &quot;2022-08-16T12:01:54.948000-05:00&quot;,\r\n            &quot;LastUpdatedTime&quot;: &quot;2022-08-19T08:47:55.553000-05:00&quot;,\r\n            &quot;PhysicalTableMap&quot;: {\r\n                &quot;6fac5dee-3691-4ddd-ba7a-0667168bb80c&quot;: {\r\n                    &quot;CustomSql&quot;: {\r\n                        &quot;DataSourceArn&quot;: &quot;arn:aws:quicksight:&lt;region&gt;:&lt;acct&gt;:datasource/46f83f8b-181e-4575-8d61-84c50125f3aa&quot;,\r\n\r\nI need to address that DataSetArn, but the key &quot;6fac5dee-3691-4ddd-ba7a-0667168bb80c&quot; is unknown to me at runtime.  How do I address it?\r\n\r\nI tried:\r\n    \r\n    jq -r &#39;.DataSet.PhysicalTableMap.*.CustomSql.DataSourceArn&#39;\r\n    jq -r &#39;.DataSet.PhysicalTableMap.\\*.CustomSql.DataSourceArn&#39;\r\n\r\n    jq -r &#39;.DataSet.PhysicalTableMap.?.CustomSql.DataSourceArn&#39;\r\n    jq -r &#39;.DataSet.PhysicalTableMap.\\?.CustomSql.DataSourceArn&#39;\r\n\r\n    jq -r &#39;.DataSet.PhysicalTableMap.%.CustomSql.DataSourceArn&#39;\r\n    jq -r &#39;.DataSet.PhysicalTableMap.\\%.CustomSql.DataSourceArn&#39;\r\n\r\nAll return an error similar to:\r\n    \r\n    jq: error: syntax error, unexpected INVALID_CHARACTER, expecting FORMAT or QQSTRING_START (Unix shell quoting issues?) at &lt;top-level&gt;, line 1:\r\n    .DataSet.PhysicalTableMap.\\?.CustomSql.DataSourceArn\r\n    jq: 1 compile error\r\n    Exception ignored in: &lt;_io.TextIOWrapper name=&#39;&lt;stdout&gt;&#39; mode=&#39;w&#39; encoding=&#39;utf-8&#39;&gt;\r\n    BrokenPipeError: [Errno 32] Broken pipe\r\n\r\nI&#39;m a noob, I know I&#39;m guessing here.  Does anyone have any insight on this?",
        "link": "https://stackoverflow.com/questions/73488511/jq-how-to-address-a-random-like-key-in-json",
        "title": "Jq: how to address a random-like key in json"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1661468519,
                "last_edit_date": 1661468519,
                "creation_date": 1661449670,
                "answer_id": 73491776,
                "question_id": 73491467,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You&#39;ll probably want to take advantage of jq pipes. \r\n\r\n```\r\ncat input.json | jq &#39;{ _meta : { hostvars : (.results | map({key : .name, value :  del(. | .name) }) | from_entries) }}&#39;\r\n```\r\n\r\nMap these results as if they were entries to a new set of entries where the key is `.name`, also removing the `.name` from `.value` as you do so: \r\n\r\n```\r\n.results | map({key : .name, value :  del(. | .name) })\r\n```\r\n\r\nThen, form an object from the entries:\r\n```\r\n... | from_entries\r\n```\r\n\r\n**NOTE:** See Inian&#39;s answer for why the array syntax used by the OP does not work.",
                "title": "Transforming json file using jq so data ends up under a common object"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1661450873,
                "last_edit_date": 1661450873,
                "creation_date": 1661449833,
                "answer_id": 73491812,
                "question_id": 73491467,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Using `.results[]` twice will iterate over the same list twice, giving you the cartesian product of each host with each of the other objects ( 3 x 3 = 9 ). You need to reference it once!\r\n\r\nYou can do something like below. The key to the logic is forming an array of objects, firstly by making the key name as `.name` and the value as the whole sub-object inside.\r\n\r\nOnce you have the array, you can un-wrap into a comma-separated list of objects using `add`.\r\n\r\n```none\r\n{ _meta : { hostvars: ( ( .results | map( { ( .name ) : . } ) | add ) ) } } \r\n```\r\n\r\nDemo - [jqplay][1]\r\n\r\n\r\n  [1]: https://jqplay.org/s/beVIhddGwdM",
                "title": "Transforming json file using jq so data ends up under a common object"
            },
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1661455019,
                "creation_date": 1661455019,
                "answer_id": 73492701,
                "question_id": 73491467,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The crucial part is: Take an array of objects and transform it into one (outer) object where the attribute names of that outer object are given by some attribute value of the inner objects. That&#39;s the job description for `INDEX(filter)`.\r\n\r\nSo:\r\n\r\n    { _meta : { hostvars: ( .results | INDEX(.name) ) } } \r\n\r\n",
                "title": "Transforming json file using jq so data ends up under a common object"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1661460025,
                "creation_date": 1661460025,
                "answer_id": 73493487,
                "question_id": 73491467,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Yet another approach using `from_entries` could be:\r\n~~~sh\r\njq &#39;.results | map({key: .name, value: .}) | {_meta: {hostvars: from_entries}}&#39;\r\n~~~\r\n~~~json\r\n{\r\n  &quot;_meta&quot;: {\r\n    &quot;hostvars&quot;: {\r\n      &quot;hostname1&quot;: {\r\n        &quot;name&quot;: &quot;hostname1&quot;,\r\n        &quot;key1&quot;: &quot;somevalue1&quot;,\r\n        &quot;key2&quot;: &quot;somevalue2&quot;,\r\n        &quot;key3&quot;: &quot;somevalue3&quot;\r\n      },\r\n      &quot;hostname2&quot;: {\r\n        &quot;name&quot;: &quot;hostname2&quot;,\r\n        &quot;key1&quot;: &quot;somevalue12&quot;,\r\n        &quot;key2&quot;: &quot;somevalue22&quot;,\r\n        &quot;key3&quot;: &quot;somevalue32&quot;\r\n      },\r\n      &quot;hostname3&quot;: {\r\n        &quot;name&quot;: &quot;hostname3&quot;,\r\n        &quot;key1&quot;: &quot;somevalue13&quot;,\r\n        &quot;key2&quot;: &quot;somevalue23&quot;,\r\n        &quot;key3&quot;: &quot;somevalue33&quot;\r\n      }\r\n    }\r\n  }\r\n}\r\n~~~\r\n[Demo](https://jqplay.org/s/PSLBjRVS-gS)",
                "title": "Transforming json file using jq so data ends up under a common object"
            }
        ],
        "is_answered": true,
        "answer_count": 4,
        "score": 2,
        "last_activity_date": 1661468519,
        "creation_date": 1661448042,
        "last_edit_date": 1661451000,
        "question_id": 73491467,
        "body_markdown": "I have some json data i get from an API that i need to transform using jq into another json format for later use with ansible as part of an inventory script.\r\n\r\nWhat i have is something like:\r\n```lang-json\r\n{\r\n  &quot;results&quot;: [\r\n    {\r\n      &quot;name&quot;: &quot;hostname1&quot;,\r\n      &quot;key1&quot;: &quot;somevalue1&quot;,\r\n      &quot;key2&quot;: &quot;somevalue2&quot;,\r\n      &quot;key3&quot;: &quot;somevalue3&quot;\r\n    },\r\n    {\r\n      &quot;name&quot;: &quot;hostname2&quot;,\r\n      &quot;key1&quot;: &quot;somevalue12&quot;,\r\n      &quot;key2&quot;: &quot;somevalue22&quot;,\r\n      &quot;key3&quot;: &quot;somevalue32&quot;\r\n    },\r\n    {\r\n      &quot;name&quot;: &quot;hostname3&quot;,\r\n      &quot;key1&quot;: &quot;somevalue13&quot;,\r\n      &quot;key2&quot;: &quot;somevalue23&quot;,\r\n      &quot;key3&quot;: &quot;somevalue33&quot;\r\n    }\r\n  ]\r\n}\r\n```\r\n\r\nand i need to transform this to look like this:\r\n```lang-json\r\n{\r\n  &quot;_meta&quot;: {\r\n    &quot;hostvars&quot;: {\r\n      &quot;hostname1&quot;: {\r\n        &quot;name&quot;: &quot;hostname1&quot;,\r\n        &quot;key1&quot;: &quot;somevalue1&quot;,\r\n        &quot;key2&quot;: &quot;somevalue2&quot;,\r\n        &quot;key3&quot;: &quot;somevalue3&quot;\r\n      },\r\n      &quot;hostname2&quot;: {\r\n        &quot;name&quot;: &quot;hostname2&quot;,\r\n        &quot;key1&quot;: &quot;somevalue12&quot;,\r\n        &quot;key2&quot;: &quot;somevalue22&quot;,\r\n        &quot;key3&quot;: &quot;somevalue32&quot;\r\n      },\r\n      &quot;hostname3&quot;: {\r\n        &quot;name&quot;: &quot;hostname3&quot;,\r\n        &quot;key1&quot;: &quot;somevalue13&quot;,\r\n        &quot;key2&quot;: &quot;somevalue23&quot;,\r\n        &quot;key3&quot;: &quot;somevalue33&quot;\r\n      }\r\n    }\r\n  }\r\n}\r\n```\r\n\r\nThings i have not been able to figure out.\r\nIf i use something like:\r\n```lang-bash\r\ncat input.json | jq &#39;{_meta: { hostvars: { (.results[].name): (.results[]) } }}&#39;\r\n```\r\nThen _meta and hostvars is repeated for each object in the input and that is not at all what i want, i need a common &quot;header&quot; and then the data under there.\r\n\r\nIdeally i would like to also exclude the &quot;name&quot; part in the output since it is already used and duplicated, but this is just a bonus.\r\n\r\nAdvice on how to do this? or is the filter in jq always run against one object at a time?\r\nI experimented a bit with --slurp but didn&#39;t get anywhere",
        "link": "https://stackoverflow.com/questions/73491467/transforming-json-file-using-jq-so-data-ends-up-under-a-common-object",
        "title": "Transforming json file using jq so data ends up under a common object"
    },
    {
        "tags": [
            "json",
            "bash",
            "colors",
            "jq",
            "ansi-escape"
        ],
        "answers": [
            {
                "up_vote_count": 8,
                "is_accepted": true,
                "score": 8,
                "last_activity_date": 1661472707,
                "last_edit_date": 1661472707,
                "creation_date": 1661472157,
                "answer_id": 73494775,
                "question_id": 73494478,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Octal escape sequences are not valid JSON syntax, so you need to encode the ASCII escape character as `\\u001b` rather than `\\033`. Also, to add to the confusion, some versions of `echo` will attempt to interpret backslash (escape) sequences itself before passing them to `jq`, so in cases like this it&#39;s [much safer to use `printf &#39;%s\\n&#39;`](https://unix.stackexchange.com/questions/65803/why-is-printf-better-than-echo):\r\n\r\n    $ printf &#39;%s\\n&#39; &#39;{&quot;a&quot;:&quot;b&quot;,&quot;c&quot;:&quot;\\u001b[31md\\u001b[0m&quot;}&#39; | jq -r .c\r\n    d\r\n\r\n(You can&#39;t see it, but that &quot;d&quot; is red in my terminal.)\r\n\r\nBTW, an easy way to find things like this out is to get `jq` to encode them in JSON for you. Here, I&#39;ll set the shell variable to the actual string (using bash&#39;s `$&#39;...&#39;` string format, which interprets ANSI-C escape sequences like `\\033`), then [use `--arg` to pass that to `jq`](https://stackoverflow.com/questions/62468117/generate-json-out-of-command-line-arguments):\r\n\r\n    $ seq=$&#39;\\033[31md\\033[0m&#39;\r\n    $ jq -nc --arg seq &quot;$seq&quot; &#39;{&quot;a&quot;:&quot;b&quot;,&quot;c&quot;:$seq}&#39;\r\n    {&quot;a&quot;:&quot;b&quot;,&quot;c&quot;:&quot;\\u001b[31md\\u001b[0m&quot;}",
                "title": "ANSI color codes with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1679007310,
        "creation_date": 1661468710,
        "last_edit_date": 1679007310,
        "question_id": 73494478,
        "body_markdown": "Trying to make `jq` work with ANSI color codes.\r\n\r\nTest cases:\r\n```\r\n$ echo &#39;{&quot;a&quot;:&quot;b&quot;,&quot;c&quot;:&quot;d&quot;}&#39; | jq -r .c\r\nd # Matches my expected output\r\n\r\n$ echo &#39;{&quot;a&quot;:&quot;b&quot;,&quot;c&quot;:&quot;\\033[31md\\033[0m&quot;}&#39; | jq -r .c\r\nparse error: Invalid escape at line 1, column 31 # returns err code 4\r\n\r\n$ echo &#39;{&quot;a&quot;:&quot;b&quot;,&quot;c&quot;:&quot;d&quot;}&#39; | jq -r &#39;&quot;foo&quot;+.c+&quot;bar&quot;&#39;\r\nfoodbar # Correct\r\n\r\n$ echo &#39;{&quot;a&quot;:&quot;b&quot;,&quot;c&quot;:&quot;d&quot;}&#39; | jq -r &#39;&quot;\\033[31m&quot;+.c+&quot;\\033[0m&quot;&#39;\r\njq: error: Invalid escape at line 1, column 4 (while parsing &#39;&quot;\\0&quot;&#39;) at &lt;top-level&gt;, line 1:\r\n&quot;\\033[31m&quot;+.c+&quot;\\033[0m&quot;\r\njq: error: Invalid escape at line 1, column 4 (while parsing &#39;&quot;\\0&quot;&#39;) at &lt;top-level&gt;, line 1:\r\n&quot;\\033[31m&quot;+.c+&quot;\\033[0m&quot;\r\njq: 2 compile errors # returns err code 3\r\n\r\n$ jq -rn &#39;&quot;\\033[31mbar\\033[0m&quot;&#39;\r\njq: error: Invalid escape at line 1, column 4 (while parsing &#39;&quot;\\0&quot;&#39;) at &lt;top-level&gt;, line 1:\r\n&quot;\\033[31mbar\\033[0m&quot;\r\njq: error: Invalid escape at line 1, column 4 (while parsing &#39;&quot;\\0&quot;&#39;) at &lt;top-level&gt;, line 1:\r\n&quot;\\033[31mbar\\033[0m&quot;\r\njq: 2 compile errors # returns err code 4\r\n```\r\nP.S. in case it matters, I am using the `bash` shell with version `5.1.16(1)-release` on Linux.\r\n\r\nConslusion: ANSI colors do not work with `jq`, whether in the JSON string or directly concatenating it through the `+` operator.\r\n\r\nQuestion: how to make ANSI colors work in `jq`? Any help would be appreciated.",
        "link": "https://stackoverflow.com/questions/73494478/ansi-color-codes-with-jq",
        "title": "ANSI color codes with jq"
    },
    {
        "tags": [
            "json",
            "filter",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": -1,
                    "reputation": 1,
                    "user_id": -1,
                    "user_type": "moderator",
                    "profile_image": "https://www.gravatar.com/avatar/a007be5a61f6aa8f3e85ae2fc18dd66e?s=256&d=identicon&r=PG",
                    "display_name": "Community",
                    "link": "https://stackoverflow.com/users/-1/community"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1661548063,
                "post_id": 73501741,
                "comment_id": 129806868,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1661539072,
                "creation_date": 1661539072,
                "answer_id": 73505257,
                "question_id": 73501741,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You could use `if ... then ... else ... end`, or more briefly, `select`:\r\n```\r\njq -s &#39;select(.[0].KeyID==.[1].KeyID) | add&#39; file1.json file2.json\r\n```\r\n",
                "title": "JQ combine json with key:value"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": -3,
        "last_activity_date": 1661545282,
        "creation_date": 1661520362,
        "last_edit_date": 1661545282,
        "question_id": 73501741,
        "body_markdown": "I have two Json files\r\n\r\nFirst :\r\n\r\n&#39;&#39;&#39;\r\n{\r\n    &quot;KeyID&quot;: 7532173,\r\n    &quot;KeyDetails&quot;: &quot;Level 12&quot;\r\n  }\r\n&#39;&#39;&#39;\r\n\r\nSecond:\r\n&#39;&#39;&#39;\r\n{\r\n        &quot;KeyID&quot;: 7532173,\r\n        &quot;Level&quot;: &quot;Access Level&quot;\r\n    }\r\n&#39;&#39;&#39;\r\n\r\n\r\nI would like to combine them matching the key:value pair of KeyId\r\n\r\nPlease advise on how to proceed\r\n\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/73501741/jq-combine-json-with-keyvalue",
        "title": "JQ combine json with key:value"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1661542723,
                "last_edit_date": 1661542723,
                "creation_date": 1661541145,
                "answer_id": 73505584,
                "question_id": 73505346,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The requirements aren&#39;t entirely clear to me, but the following does follow the logic of your approach and does produce the required output:\r\n```\r\n   .result\r\n   | [.terms[]\r\n      | if .translation.content|type == &quot;string&quot; then {title: .translation.content}\r\n        else .term as $term\r\n        | .translation\r\n        | (.content|keys) as $keys\r\n        | ([$keys[] as $key | {($term + &quot;_&quot; + $key): .content[$key]}] | add) \r\n        end ]\r\n  | add\r\n\r\n```",
                "title": "Mapping an array of objects to plain array with jq"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1661546509,
                "last_edit_date": 1661546509,
                "creation_date": 1661545319,
                "answer_id": 73506135,
                "question_id": 73505346,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Probably not the most efficient solution, but this oughta work and is kinda readable:\r\n\r\n```\r\n.result.terms\r\n| map(\r\n    (select(.translation.content | type == &quot;object&quot;)\r\n        | .term as $term | .translation.content | to_entries[] | .key |= &quot;\\($term)_\\(.)&quot;),\r\n    (select(.translation.content | type == &quot;string&quot;)\r\n        | { key: .term, value: .translation.content })\r\n)\r\n| from_entries\r\n```\r\n\r\nOr with if-then-else:\r\n\r\n```\r\n.result.terms\r\n| map(\r\n    if .translation.content | type == &quot;object&quot; then\r\n        .term as $term | .translation.content | to_entries[] | .key |= &quot;\\($term)_\\(.)&quot;\r\n    else\r\n        { key: .term, value: .translation.content }\r\n    end\r\n)\r\n| from_entries\r\n```\r\n\r\nCleverly place (and name) the variable and you get down to:\r\n\r\n```\r\n.result.terms\r\n| map(.term as $key\r\n    | .translation.content\r\n    | if type == &quot;object&quot; then\r\n         to_entries[] | .key |= &quot;\\($key)_\\(.)&quot;\r\n    else\r\n        { $key, value: . }\r\n    end\r\n)\r\n| from_entries\r\n```\r\n\r\nEven more concise by combining the optional/error suppression operator with the alternative operator:\r\n\r\n```\r\n.result.terms\r\n| map(.term as $key\r\n    | .translation.content\r\n    | (to_entries[] | .key |= &quot;\\($key)_\\(.)&quot;)? // { $key, value: . }\r\n)\r\n| from_entries\r\n```\r\n\r\nOr, if you prefer (so many possibilities):\r\n\r\n```\r\n.result.terms\r\n| map(\r\n    .term as $key\r\n    | .translation.content as $value | $value\r\n    | (to_entries[] | .key |= &quot;\\($key)_\\(.)&quot;)? // { $key, $value }\r\n)\r\n| from_entries\r\n```\r\n\r\n`&quot;\\($key)_\\(.)&quot;` is string interpolation and equivalent to `($key + &quot;_&quot; + .)`",
                "title": "Mapping an array of objects to plain array with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1661546509,
        "creation_date": 1661539661,
        "last_edit_date": 1661543327,
        "question_id": 73505346,
        "body_markdown": "I&#39;m working on implementing translations in my app, however the format of my translations is not usable for me. I made a shell script that uses `jq` to try to modify this array, but I cannot get the output that I desire.\r\n\r\nThe JSON I get from my service looks something like this.\r\n\r\n    {\r\n      &quot;result&quot;: {\r\n        &quot;terms&quot;: [\r\n          {\r\n            &quot;term&quot;: &quot;title&quot;,\r\n            &quot;translation&quot;: {\r\n              &quot;content&quot;: &quot;Welcome to {{user}}&quot;\r\n            }\r\n          },\r\n          {\r\n            &quot;term&quot;: &quot;car&quot;,\r\n            &quot;translation&quot;: {\r\n              &quot;content&quot;: {\r\n                  &quot;one&quot;: &quot;car&quot;,\r\n                  &quot;other&quot;: &quot;cars&quot;\r\n              }\r\n            }\r\n          }\r\n        ]\r\n      }\r\n    }\r\n\r\nThe output that I want is something like this.\r\n\r\n    {\r\n      &quot;title&quot;: &quot;Welcome to {{user}}&quot;,\r\n      &quot;car_one&quot;: &quot;car&quot;,\r\n      &quot;car_other&quot;: &quot;cars&quot;,\r\n    }\r\n\r\nI&#39;ve managed to strip away the uneeded parts of my objects, but I can&#39;t figure out how to append something to they key, e.g. turning &quot;car&quot; into &quot;car_one&quot;. Or actually just adding the keys properly to the array.\r\n\r\nThis is currently where I&#39;m at https://jqplay.org/s/P6KIEVX5sWp",
        "link": "https://stackoverflow.com/questions/73505346/mapping-an-array-of-objects-to-plain-array-with-jq",
        "title": "Mapping an array of objects to plain array with jq"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1661559909,
                "creation_date": 1661559909,
                "answer_id": 73507572,
                "question_id": 73507518,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If you&#39;re sure that all the variables contain valid JSON expressions, you can use `--argjson` instead of `--arg`:\r\n\r\n```sh\r\n#!/usr/bin/env bash\r\n\r\nname=&#39;&quot;john&quot;&#39;\r\nobjects=&#39;[]&#39;\r\ncount=&#39;1&#39;\r\n\r\n# Note quoting the variables to prevent issues with unwanted expansion\r\ndata=$( jq -n \\\r\n            --argjson na &quot;$name&quot; \\\r\n            --argjson ob &quot;$objects&quot; \\\r\n            --argjson ct &quot;$count&quot; \\\r\n            &#39;{name: $na, objects: $ob, count: $ct}&#39; )\r\n\r\nprintf &quot;%s\\n&quot; &quot;$data&quot;\r\n```\r\n\r\noutputs\r\n\r\n```json\r\n{\r\n  &quot;name&quot;: &quot;john&quot;,\r\n  &quot;objects&quot;: [],\r\n  &quot;count&quot;: 1\r\n}\r\n```\r\n\r\n---\r\n\r\nAlternatively, you can use `fromjson` in the `jq` expression:\r\n\r\n```sh\r\ndata=$( jq -n \\\r\n            --arg na &quot;$name&quot; \\\r\n            --arg ob &quot;$objects&quot; \\\r\n            --arg ct &quot;$count&quot; \\\r\n            &#39;{name: $na|fromjson, objects: $ob|fromjson, count: $ct|fromjson}&#39; )\r\n```",
                "title": "How to create json body using jq from variables, while preserving type"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1661701283,
        "creation_date": 1661559065,
        "last_edit_date": 1661701283,
        "question_id": 73507518,
        "body_markdown": "I am creating a simple bash script and am trying to build a json body using jq\r\n\r\n```\r\nname=&#39;&quot;john&quot;&#39;\r\nobjects=&#39;[]&#39;\r\ncount=&#39;1&#39;\r\n\r\ndata=$( jq -n \\\r\n            --arg na $name \\\r\n            --arg ob $objects \\\r\n            --arg ct $count \\\r\n            &#39;{name: $na, objects: $ob, count: $ct}&#39; )\r\n```\r\n\r\nWhen I echo data, I get\r\n`{ &quot;name&quot;: &quot;\\&quot;john\\&quot;&quot;, &quot;objects&quot;: &quot;[]&quot;, &quot;count&quot;: &quot;1&quot; }`\r\n\r\nHowever, the objects and count values are strings.\r\nInstead I want, `{ &quot;name&quot;: &quot;john&quot;, &quot;objects&quot;: [], &quot;count&quot;: 1 }` ",
        "link": "https://stackoverflow.com/questions/73507518/how-to-create-json-body-using-jq-from-variables-while-preserving-type",
        "title": "How to create json body using jq from variables, while preserving type"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1661727394,
                "last_edit_date": 1661727394,
                "creation_date": 1661708191,
                "answer_id": 73520837,
                "question_id": 73519720,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "One way would be to &quot;slurp&quot; the files, like so:\r\n```\r\njq -s &#39;map( .foo[].bar )&#39; input-*.json\r\n```\r\n\r\nIf you want to save memory, you could go with:\r\n```\r\njq -n &#39;[inputs | .foo[].bar]&#39; input-*.json\r\n```\r\n\r\nIf your shell does not support filename globbing, then you would have to specify the file names in some other way, e.g. as in the Q.",
                "title": "Sending concatenated files to JQ with wrapped as JSON array"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1661727394,
        "creation_date": 1661698425,
        "last_edit_date": 1661699753,
        "question_id": 73519720,
        "body_markdown": "I have a curious problem sending concatenated files to [JQ][1]. I&#39;m using Windows 10, but the problem is surfacing with Bash (via Git Bash) as well.\r\n\r\nI have several input JSON files in the form `input-1.json`, `input-2.json`, `input-3.json`, etc. The contents of each is a nested object that looks like this:\r\n\r\n```json\r\n{\r\n  &quot;blah&quot;: &quot;blah&quot;,\r\n  &quot;foo&quot;: [{\r\n      &quot;bar&quot; {…}\r\n    }, {\r\n      &quot;bar&quot; {…}\r\n    }]\r\n}\r\n```\r\n\r\nI want to concatenate the files and extract all the values of &quot;bar&quot; across all the files into one array. (Note that &quot;foo&quot; is an array of objects, each with &quot;bar&quot; containing its own object.) In other words, I want to end up with (placed on one line for readability here):\r\n\r\n```json\r\n[{…}, {…}, {…}, {…}, {…}]\r\n```\r\n\r\nNote that these are the foo…bars _across all the files_!\r\n\r\nI start with this:\r\n\r\n```\r\ntype input-*.json | jq &quot;.foo[].bar&quot; &gt; output.json\r\n```\r\n\r\nThat gives me\r\n\r\n```\r\n{…}, {…}, {…}, {…}, {…}\r\n```\r\n\r\nClose! Now I just have to wrap them in `[…]`, right? So I do this:\r\n\r\n```\r\ntype input-*.json | jq &quot;[.foo[].bar]&quot; &gt; output.json\r\n```\r\n\r\nUh, oh; it gives me the following:\r\n\r\n```\r\n[{…}, {…}, {…}], [{…}, {…}]\r\n```\r\n\r\nBut why? At the point of `.foo[].bar`, JQ just sees a stream of objects, right? How does JQ &quot;remember&quot; that some of those objects came from different inputs?\r\n\r\nNote that https://stackoverflow.com/q/29404575 and https://stackoverflow.com/q/38061346 seem to be similar questions. They say to use JQ&#39;s `--slurp` mode. But won&#39;t that prevent streaming, i.e. if the output of all the files is really huge, won&#39;t it this have the potential of running out of memory by loading the entire input into memory?\r\n\r\nBesides (and this is the crux of my confusion), if `jq &quot;.foo[].bar&quot;` gives me exactly the `{…}, {…}, {…}], [{…}, {…}` array contents I want, how does JQ &quot;remember&quot; that some of those objects came from different inputs? You&#39;ll see that JQ isn&#39;t wrapping each `{…}` in an array, but actually wrapping several objects based upon which `input-*.json` file it came from. Why?\r\n\r\n\r\n  [1]: https://stedolan.github.io/jq/",
        "link": "https://stackoverflow.com/questions/73519720/sending-concatenated-files-to-jq-with-wrapped-as-json-array",
        "title": "Sending concatenated files to JQ with wrapped as JSON array"
    },
    {
        "tags": [
            "arguments",
            "command-line-interface",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1661708798,
                "post_id": 73520524,
                "comment_id": 129830971,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 164831,
                    "reputation": 1747,
                    "user_id": 387851,
                    "user_type": "registered",
                    "accept_rate": 50,
                    "profile_image": "https://www.gravatar.com/avatar/dedc4888ddabc340b34dac29618095c9?s=256&d=identicon&r=PG",
                    "display_name": "four43",
                    "link": "https://stackoverflow.com/users/387851/four43"
                },
                "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": 1661721403,
                "post_id": 73520524,
                "comment_id": 129833405,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 164831,
                    "reputation": 1747,
                    "user_id": 387851,
                    "user_type": "registered",
                    "accept_rate": 50,
                    "profile_image": "https://www.gravatar.com/avatar/dedc4888ddabc340b34dac29618095c9?s=256&d=identicon&r=PG",
                    "display_name": "four43",
                    "link": "https://stackoverflow.com/users/387851/four43"
                },
                "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": 1661721434,
                "post_id": 73520524,
                "comment_id": 129833408,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1692262242,
                "last_edit_date": 1692262242,
                "creation_date": 1661707579,
                "answer_id": 73520761,
                "question_id": 73520524,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "For suggested ways to use jq as a template engine, see the jq Cookbook:\r\nhttps://github.com/stedolan/jq/wiki/Cookbook#using-jq-as-a-template-engine\r\n\r\nIn your case, it would probably be better to use the &quot;interpolation&quot; approach as per your original SO question: https://stackoverflow.com/questions/47374719/jq-not-replacing-json-value-with-parameter/47375032?noredirect=1#comment129830637_47375032\r\n\r\n#### example.jq:\r\n    {\r\n      &quot;title&quot;: &quot;Where the \\($color) Fern Grows&quot;\r\n    }\r\n\r\n#### Invocation:\r\n\r\n\r\n    jq -n --arg color Red -f example.jq\r\n\r\nor:\r\n\r\n    jq --arg color Red . &lt;(example.jq)\r\n\r\n## Otherwise ...\r\n\r\n... you could use `sub`, though that might be brittle.",
                "title": "Using jq, how do I substitute a variable within a string?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1692262242,
        "creation_date": 1661705437,
        "last_edit_date": 1661721607,
        "question_id": 73520524,
        "body_markdown": "When given a string in JSON where I&#39;d like only a part of it templated/substituted:\r\n\r\n```\r\n{\r\n  &quot;title&quot;: &quot;Where the $color Fern Grows&quot;\r\n}\r\n```\r\n\r\nTrying to template that with `jq` args doesn&#39;t seem to work:\r\n\r\n```\r\ncat example.json | jq --arg color &quot;Red&quot;\r\n```\r\n\r\n`jq` doesn&#39;t like the substitution and returns the un-templated example.json with `$color` in the output\r\n\r\nHow can you tell `jq` to replace variables mid JSON string?\r\n\r\nThanks.\r\n\r\n### Solution:\r\n\r\nThe issue seems to be that `jq` assumes data on stdin is formatted JSON data. This substitution actually only works on a &quot;filter&quot;, which is `jq`&#39;s term for a script. Using the flags `-n` and `-f [filter.json]` to correctly state the input data is a filter, not actual data and using the `\\($var)` syntax, as @peak pointed out works well.\r\n\r\n`example.json` then could become `example.jq`:\r\n```\r\n{\r\n  &quot;title&quot;: &quot;Where the \\($color) Fern Grows&quot;\r\n}\r\n```\r\n\r\nWhich when run, as they suggested:\r\n```\r\njq -n --arg color &quot;Red&quot; -f example.jq\r\n```\r\n\r\nWorks perfectly. The concept between data and filter is important and one I didn&#39;t realize. I thought it was all just interpolation and templating like most other programs. This seems to take more inspiration from `awk` where this is common however.",
        "link": "https://stackoverflow.com/questions/73520524/using-jq-how-do-i-substitute-a-variable-within-a-string",
        "title": "Using jq, how do I substitute a variable within a string?"
    },
    {
        "tags": [
            "filter",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 166270,
                    "reputation": 135171,
                    "user_id": 390278,
                    "user_type": "registered",
                    "accept_rate": 86,
                    "profile_image": "https://www.gravatar.com/avatar/84715fec547362389d02f5be0ed12814?s=256&d=identicon&r=PG",
                    "display_name": "Jeff Mercado",
                    "link": "https://stackoverflow.com/users/390278/jeff-mercado"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1661728084,
                "post_id": 73522843,
                "comment_id": 129834278,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 21612412,
                    "reputation": 5,
                    "user_id": 15938726,
                    "user_type": "registered",
                    "profile_image": "https://lh3.googleusercontent.com/a/AATXAJwCZUcrnLB_dNAGF0g1jcn-I8geaR5PQ6HShbuW=k-s256",
                    "display_name": "Joseph",
                    "link": "https://stackoverflow.com/users/15938726/joseph"
                },
                "reply_to_user": {
                    "account_id": 166270,
                    "reputation": 135171,
                    "user_id": 390278,
                    "user_type": "registered",
                    "accept_rate": 86,
                    "profile_image": "https://www.gravatar.com/avatar/84715fec547362389d02f5be0ed12814?s=256&d=identicon&r=PG",
                    "display_name": "Jeff Mercado",
                    "link": "https://stackoverflow.com/users/390278/jeff-mercado"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1661731070,
                "post_id": 73522843,
                "comment_id": 129834654,
                "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": 1661748013,
                "post_id": 73522843,
                "comment_id": 129836704,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 21612412,
                    "reputation": 5,
                    "user_id": 15938726,
                    "user_type": "registered",
                    "profile_image": "https://lh3.googleusercontent.com/a/AATXAJwCZUcrnLB_dNAGF0g1jcn-I8geaR5PQ6HShbuW=k-s256",
                    "display_name": "Joseph",
                    "link": "https://stackoverflow.com/users/15938726/joseph"
                },
                "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": 1661766162,
                "post_id": 73522843,
                "comment_id": 129841332,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1661729661,
                "creation_date": 1661729661,
                "answer_id": 73522992,
                "question_id": 73522843,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s one way you could approach it. First map out the properties you want copied over, then filter each of the properties you want to filter to add or remove from each.\r\n\r\nIt&#39;s not exactly clear to me how you choose what fields to copy but making some assumptions:\r\n\r\n```\r\nmap(\r\n    # 1. select the properties\r\n\t{\r\n\t\tmatchId,\r\n\t\ttimestamp,\r\n\t\tclubs,\r\n\t\tplayers\r\n\t}\r\n\t|\r\n    # 2. filter the properties\r\n\t.clubs[] |= ( # update each club...\r\n        # 1. select the properties\r\n\t\twith_entries(select(.key | startswith(&quot;p&quot;))) + {shots, toa, details}\r\n\t\t|\r\n        # 2. filter the properties\r\n\t\t.details |= {name, clubId}\r\n\t)\r\n\t|\r\n\t.players[][] |= ( # update each player in the map of players\r\n        # 1. select the properties\r\n\t\twith_entries(select(.key | startswith(&quot;gl&quot;)))\r\n\t\t+\r\n\t\t{opponentClubId, position, posSorted}\r\n\t\t+\r\n\t\twith_entries(select(.key | startswith(&quot;rating&quot;)))\r\n\t\t+\r\n\t\twith_entries(select(.key | startswith(&quot;sk&quot;)))\r\n\t\t+\r\n\t\t{toiseconds, playername}\r\n\t)\r\n)\r\n```\r\n\r\nProduces the result:\r\n\r\n```json\r\n[\r\n  {\r\n    &quot;matchId&quot;: &quot;2234705530498&quot;,\r\n    &quot;timestamp&quot;: 1661657182,\r\n    &quot;clubs&quot;: {\r\n      &quot;79718&quot;: {\r\n        &quot;passa&quot;: &quot;79&quot;,\r\n        &quot;passc&quot;: &quot;58&quot;,\r\n        &quot;ppg&quot;: &quot;0&quot;,\r\n        &quot;ppo&quot;: &quot;0&quot;,\r\n        &quot;shots&quot;: &quot;15&quot;,\r\n        &quot;toa&quot;: &quot;252&quot;,\r\n        &quot;details&quot;: {\r\n          &quot;name&quot;: &quot;NZHL Memphis Make A Wish&quot;,\r\n          &quot;clubId&quot;: 79718\r\n        }\r\n      },\r\n      &quot;145078&quot;: {\r\n        &quot;passa&quot;: &quot;101&quot;,\r\n        &quot;passc&quot;: &quot;79&quot;,\r\n        &quot;ppg&quot;: &quot;2&quot;,\r\n        &quot;ppo&quot;: &quot;5&quot;,\r\n        &quot;shots&quot;: &quot;18&quot;,\r\n        &quot;toa&quot;: &quot;317&quot;,\r\n        &quot;details&quot;: {\r\n          &quot;name&quot;: &quot;NZHL LOCAL CRAFT BEER&quot;,\r\n          &quot;clubId&quot;: 145078\r\n        }\r\n      }\r\n    },\r\n    &quot;players&quot;: {\r\n      &quot;145078&quot;: {\r\n        &quot;169580763&quot;: {\r\n          &quot;glbrksavepct&quot;: &quot;0.00&quot;,\r\n          &quot;glbrksaves&quot;: &quot;0&quot;,\r\n          &quot;glbrkshots&quot;: &quot;0&quot;,\r\n          &quot;gldsaves&quot;: &quot;0&quot;,\r\n          &quot;glga&quot;: &quot;0&quot;,\r\n          &quot;glgaa&quot;: &quot;0.00&quot;,\r\n          &quot;glpensavepct&quot;: &quot;0.00&quot;,\r\n          &quot;glpensaves&quot;: &quot;0&quot;,\r\n          &quot;glpenshots&quot;: &quot;0&quot;,\r\n          &quot;glpkclearzone&quot;: &quot;0&quot;,\r\n          &quot;glpokechecks&quot;: &quot;0&quot;,\r\n          &quot;glsavepct&quot;: &quot;0.00&quot;,\r\n          &quot;glsaves&quot;: &quot;0&quot;,\r\n          &quot;glshots&quot;: &quot;0&quot;,\r\n          &quot;glsoperiods&quot;: &quot;0&quot;,\r\n          &quot;opponentClubId&quot;: &quot;79718&quot;,\r\n          &quot;position&quot;: &quot;rightWing&quot;,\r\n          &quot;posSorted&quot;: &quot;3&quot;,\r\n          &quot;ratingDefense&quot;: &quot;55.00&quot;,\r\n          &quot;ratingOffense&quot;: &quot;85.00&quot;,\r\n          &quot;ratingTeamplay&quot;: &quot;70.00&quot;,\r\n          &quot;skassists&quot;: &quot;0&quot;,\r\n          &quot;skbs&quot;: &quot;0&quot;,\r\n          &quot;skdeflections&quot;: &quot;0&quot;,\r\n          &quot;skfol&quot;: &quot;0&quot;,\r\n          &quot;skfopct&quot;: &quot;0.00&quot;,\r\n          &quot;skfow&quot;: &quot;0&quot;,\r\n          &quot;skgiveaways&quot;: &quot;4&quot;,\r\n          &quot;skgoals&quot;: &quot;2&quot;,\r\n          &quot;skgwg&quot;: &quot;0&quot;,\r\n          &quot;skhits&quot;: &quot;1&quot;,\r\n          &quot;skinterceptions&quot;: &quot;3&quot;,\r\n          &quot;skpassattempts&quot;: &quot;11&quot;,\r\n          &quot;skpasses&quot;: &quot;7&quot;,\r\n          &quot;skpasspct&quot;: &quot;63.64&quot;,\r\n          &quot;skpenaltiesdrawn&quot;: &quot;1&quot;,\r\n          &quot;skpim&quot;: &quot;0&quot;,\r\n          &quot;skpkclearzone&quot;: &quot;0&quot;,\r\n          &quot;skplusmin&quot;: &quot;-5&quot;,\r\n          &quot;skpossession&quot;: &quot;106&quot;,\r\n          &quot;skppg&quot;: &quot;1&quot;,\r\n          &quot;sksaucerpasses&quot;: &quot;0&quot;,\r\n          &quot;skshg&quot;: &quot;0&quot;,\r\n          &quot;skshotattempts&quot;: &quot;12&quot;,\r\n          &quot;skshotonnetpct&quot;: &quot;66.67&quot;,\r\n          &quot;skshotpct&quot;: &quot;25.00&quot;,\r\n          &quot;skshots&quot;: &quot;8&quot;,\r\n          &quot;sktakeaways&quot;: &quot;0&quot;,\r\n          &quot;toiseconds&quot;: &quot;3600&quot;,\r\n          &quot;playername&quot;: &quot;Ababo&quot;\r\n        },\r\n        &quot;174908181&quot;: {\r\n          &quot;glbrksavepct&quot;: &quot;0.00&quot;,\r\n          &quot;glbrksaves&quot;: &quot;0&quot;,\r\n          &quot;glbrkshots&quot;: &quot;0&quot;,\r\n          &quot;gldsaves&quot;: &quot;0&quot;,\r\n          &quot;glga&quot;: &quot;0&quot;,\r\n          &quot;glgaa&quot;: &quot;0.00&quot;,\r\n          &quot;glpensavepct&quot;: &quot;0.00&quot;,\r\n          &quot;glpensaves&quot;: &quot;0&quot;,\r\n          &quot;glpenshots&quot;: &quot;0&quot;,\r\n          &quot;glpkclearzone&quot;: &quot;0&quot;,\r\n          &quot;glpokechecks&quot;: &quot;0&quot;,\r\n          &quot;glsavepct&quot;: &quot;0.00&quot;,\r\n          &quot;glsaves&quot;: &quot;0&quot;,\r\n          &quot;glshots&quot;: &quot;0&quot;,\r\n          &quot;glsoperiods&quot;: &quot;0&quot;,\r\n          &quot;opponentClubId&quot;: &quot;79718&quot;,\r\n          &quot;position&quot;: &quot;defenseMen&quot;,\r\n          &quot;posSorted&quot;: &quot;1&quot;,\r\n          &quot;ratingDefense&quot;: &quot;65.00&quot;,\r\n          &quot;ratingOffense&quot;: &quot;75.00&quot;,\r\n          &quot;ratingTeamplay&quot;: &quot;80.00&quot;,\r\n          &quot;skassists&quot;: &quot;1&quot;,\r\n          &quot;skbs&quot;: &quot;0&quot;,\r\n          &quot;skdeflections&quot;: &quot;0&quot;,\r\n          &quot;skfol&quot;: &quot;0&quot;,\r\n          &quot;skfopct&quot;: &quot;0.00&quot;,\r\n          &quot;skfow&quot;: &quot;0&quot;,\r\n          &quot;skgiveaways&quot;: &quot;4&quot;,\r\n          &quot;skgoals&quot;: &quot;0&quot;,\r\n          &quot;skgwg&quot;: &quot;0&quot;,\r\n          &quot;skhits&quot;: &quot;5&quot;,\r\n          &quot;skinterceptions&quot;: &quot;6&quot;,\r\n          &quot;skpassattempts&quot;: &quot;32&quot;,\r\n          &quot;skpasses&quot;: &quot;28&quot;,\r\n          &quot;skpasspct&quot;: &quot;87.50&quot;,\r\n          &quot;skpenaltiesdrawn&quot;: &quot;0&quot;,\r\n          &quot;skpim&quot;: &quot;0&quot;,\r\n          &quot;skpkclearzone&quot;: &quot;0&quot;,\r\n          &quot;skplusmin&quot;: &quot;-5&quot;,\r\n          &quot;skpossession&quot;: &quot;259&quot;,\r\n          &quot;skppg&quot;: &quot;0&quot;,\r\n          &quot;sksaucerpasses&quot;: &quot;1&quot;,\r\n          &quot;skshg&quot;: &quot;0&quot;,\r\n          &quot;skshotattempts&quot;: &quot;5&quot;,\r\n          &quot;skshotonnetpct&quot;: &quot;20.00&quot;,\r\n          &quot;skshotpct&quot;: &quot;0.00&quot;,\r\n          &quot;skshots&quot;: &quot;1&quot;,\r\n          &quot;sktakeaways&quot;: &quot;3&quot;,\r\n          &quot;toiseconds&quot;: &quot;3600&quot;,\r\n          &quot;playername&quot;: &quot;mikezaw4458&quot;\r\n        },\r\n        &quot;181235555&quot;: {\r\n          &quot;glbrksavepct&quot;: &quot;0.00&quot;,\r\n          &quot;glbrksaves&quot;: &quot;0&quot;,\r\n          &quot;glbrkshots&quot;: &quot;0&quot;,\r\n          &quot;gldsaves&quot;: &quot;0&quot;,\r\n          &quot;glga&quot;: &quot;0&quot;,\r\n          &quot;glgaa&quot;: &quot;0.00&quot;,\r\n          &quot;glpensavepct&quot;: &quot;0.00&quot;,\r\n          &quot;glpensaves&quot;: &quot;0&quot;,\r\n          &quot;glpenshots&quot;: &quot;0&quot;,\r\n          &quot;glpkclearzone&quot;: &quot;0&quot;,\r\n          &quot;glpokechecks&quot;: &quot;0&quot;,\r\n          &quot;glsavepct&quot;: &quot;0.00&quot;,\r\n          &quot;glsaves&quot;: &quot;0&quot;,\r\n          &quot;glshots&quot;: &quot;0&quot;,\r\n          &quot;glsoperiods&quot;: &quot;0&quot;,\r\n          &quot;opponentClubId&quot;: &quot;79718&quot;,\r\n          &quot;position&quot;: &quot;center&quot;,\r\n          &quot;posSorted&quot;: &quot;5&quot;,\r\n          &quot;ratingDefense&quot;: &quot;60.00&quot;,\r\n          &quot;ratingOffense&quot;: &quot;90.00&quot;,\r\n          &quot;ratingTeamplay&quot;: &quot;75.00&quot;,\r\n          &quot;skassists&quot;: &quot;3&quot;,\r\n          &quot;skbs&quot;: &quot;0&quot;,\r\n          &quot;skdeflections&quot;: &quot;1&quot;,\r\n          &quot;skfol&quot;: &quot;14&quot;,\r\n          &quot;skfopct&quot;: &quot;56.25&quot;,\r\n          &quot;skfow&quot;: &quot;18&quot;,\r\n          &quot;skgiveaways&quot;: &quot;8&quot;,\r\n          &quot;skgoals&quot;: &quot;0&quot;,\r\n          &quot;skgwg&quot;: &quot;0&quot;,\r\n          &quot;skhits&quot;: &quot;1&quot;,\r\n          &quot;skinterceptions&quot;: &quot;4&quot;,\r\n          &quot;skpassattempts&quot;: &quot;20&quot;,\r\n          &quot;skpasses&quot;: &quot;14&quot;,\r\n          &quot;skpasspct&quot;: &quot;70.00&quot;,\r\n          &quot;skpenaltiesdrawn&quot;: &quot;2&quot;,\r\n          &quot;skpim&quot;: &quot;0&quot;,\r\n          &quot;skpkclearzone&quot;: &quot;0&quot;,\r\n          &quot;skplusmin&quot;: &quot;-5&quot;,\r\n          &quot;skpossession&quot;: &quot;202&quot;,\r\n          &quot;skppg&quot;: &quot;0&quot;,\r\n          &quot;sksaucerpasses&quot;: &quot;0&quot;,\r\n          &quot;skshg&quot;: &quot;0&quot;,\r\n          &quot;skshotattempts&quot;: &quot;0&quot;,\r\n          &quot;skshotonnetpct&quot;: &quot;0.00&quot;,\r\n          &quot;skshotpct&quot;: &quot;0.00&quot;,\r\n          &quot;skshots&quot;: &quot;1&quot;,\r\n          &quot;sktakeaways&quot;: &quot;2&quot;,\r\n          &quot;toiseconds&quot;: &quot;3600&quot;,\r\n          &quot;playername&quot;: &quot;LedvinKa&quot;\r\n        },\r\n        &quot;1627813040&quot;: {\r\n          &quot;glbrksavepct&quot;: &quot;0.00&quot;,\r\n          &quot;glbrksaves&quot;: &quot;0&quot;,\r\n          &quot;glbrkshots&quot;: &quot;0&quot;,\r\n          &quot;gldsaves&quot;: &quot;0&quot;,\r\n          &quot;glga&quot;: &quot;0&quot;,\r\n          &quot;glgaa&quot;: &quot;0.00&quot;,\r\n          &quot;glpensavepct&quot;: &quot;0.00&quot;,\r\n          &quot;glpensaves&quot;: &quot;0&quot;,\r\n          &quot;glpenshots&quot;: &quot;0&quot;,\r\n          &quot;glpkclearzone&quot;: &quot;0&quot;,\r\n          &quot;glpokechecks&quot;: &quot;0&quot;,\r\n          &quot;glsavepct&quot;: &quot;0.00&quot;,\r\n          &quot;glsaves&quot;: &quot;0&quot;,\r\n          &quot;glshots&quot;: &quot;0&quot;,\r\n          &quot;glsoperiods&quot;: &quot;0&quot;,\r\n          &quot;opponentClubId&quot;: &quot;79718&quot;,\r\n          &quot;position&quot;: &quot;leftWing&quot;,\r\n          &quot;posSorted&quot;: &quot;4&quot;,\r\n          &quot;ratingDefense&quot;: &quot;60.00&quot;,\r\n          &quot;ratingOffense&quot;: &quot;85.00&quot;,\r\n          &quot;ratingTeamplay&quot;: &quot;70.00&quot;,\r\n          &quot;skassists&quot;: &quot;1&quot;,\r\n          &quot;skbs&quot;: &quot;0&quot;,\r\n          &quot;skdeflections&quot;: &quot;0&quot;,\r\n          &quot;skfol&quot;: &quot;0&quot;,\r\n          &quot;skfopct&quot;: &quot;0.00&quot;,\r\n          &quot;skfow&quot;: &quot;0&quot;,\r\n          &quot;skgiveaways&quot;: &quot;12&quot;,\r\n          &quot;skgoals&quot;: &quot;1&quot;,\r\n          &quot;skgwg&quot;: &quot;0&quot;,\r\n          &quot;skhits&quot;: &quot;1&quot;,\r\n          &quot;skinterceptions&quot;: &quot;2&quot;,\r\n          &quot;skpassattempts&quot;: &quot;23&quot;,\r\n          &quot;skpasses&quot;: &quot;18&quot;,\r\n          &quot;skpasspct&quot;: &quot;78.26&quot;,\r\n          &quot;skpenaltiesdrawn&quot;: &quot;2&quot;,\r\n          &quot;skpim&quot;: &quot;0&quot;,\r\n          &quot;skpkclearzone&quot;: &quot;0&quot;,\r\n          &quot;skplusmin&quot;: &quot;-5&quot;,\r\n          &quot;skpossession&quot;: &quot;207&quot;,\r\n          &quot;skppg&quot;: &quot;1&quot;,\r\n          &quot;sksaucerpasses&quot;: &quot;0&quot;,\r\n          &quot;skshg&quot;: &quot;0&quot;,\r\n          &quot;skshotattempts&quot;: &quot;7&quot;,\r\n          &quot;skshotonnetpct&quot;: &quot;100.00&quot;,\r\n          &quot;skshotpct&quot;: &quot;14.29&quot;,\r\n          &quot;skshots&quot;: &quot;7&quot;,\r\n          &quot;sktakeaways&quot;: &quot;1&quot;,\r\n          &quot;toiseconds&quot;: &quot;3600&quot;,\r\n          &quot;playername&quot;: &quot;Justn I87I&quot;\r\n        },\r\n        &quot;1785195119&quot;: {\r\n          &quot;glbrksavepct&quot;: &quot;0.00&quot;,\r\n          &quot;glbrksaves&quot;: &quot;0&quot;,\r\n          &quot;glbrkshots&quot;: &quot;0&quot;,\r\n          &quot;gldsaves&quot;: &quot;0&quot;,\r\n          &quot;glga&quot;: &quot;0&quot;,\r\n          &quot;glgaa&quot;: &quot;0.00&quot;,\r\n          &quot;glpensavepct&quot;: &quot;0.00&quot;,\r\n          &quot;glpensaves&quot;: &quot;0&quot;,\r\n          &quot;glpenshots&quot;: &quot;0&quot;,\r\n          &quot;glpkclearzone&quot;: &quot;0&quot;,\r\n          &quot;glpokechecks&quot;: &quot;0&quot;,\r\n          &quot;glsavepct&quot;: &quot;0.00&quot;,\r\n          &quot;glsaves&quot;: &quot;0&quot;,\r\n          &quot;glshots&quot;: &quot;0&quot;,\r\n          &quot;glsoperiods&quot;: &quot;0&quot;,\r\n          &quot;opponentClubId&quot;: &quot;79718&quot;,\r\n          &quot;position&quot;: &quot;defenseMen&quot;,\r\n          &quot;posSorted&quot;: &quot;2&quot;,\r\n          &quot;ratingDefense&quot;: &quot;35.00&quot;,\r\n          &quot;ratingOffense&quot;: &quot;60.00&quot;,\r\n          &quot;ratingTeamplay&quot;: &quot;60.00&quot;,\r\n          &quot;skassists&quot;: &quot;0&quot;,\r\n          &quot;skbs&quot;: &quot;0&quot;,\r\n          &quot;skdeflections&quot;: &quot;0&quot;,\r\n          &quot;skfol&quot;: &quot;0&quot;,\r\n          &quot;skfopct&quot;: &quot;0.00&quot;,\r\n          &quot;skfow&quot;: &quot;0&quot;,\r\n          &quot;skgiveaways&quot;: &quot;2&quot;,\r\n          &quot;skgoals&quot;: &quot;0&quot;,\r\n          &quot;skgwg&quot;: &quot;0&quot;,\r\n          &quot;skhits&quot;: &quot;0&quot;,\r\n          &quot;skinterceptions&quot;: &quot;6&quot;,\r\n          &quot;skpassattempts&quot;: &quot;13&quot;,\r\n          &quot;skpasses&quot;: &quot;11&quot;,\r\n          &quot;skpasspct&quot;: &quot;84.62&quot;,\r\n          &quot;skpenaltiesdrawn&quot;: &quot;0&quot;,\r\n          &quot;skpim&quot;: &quot;0&quot;,\r\n          &quot;skpkclearzone&quot;: &quot;0&quot;,\r\n          &quot;skplusmin&quot;: &quot;-5&quot;,\r\n          &quot;skpossession&quot;: &quot;93&quot;,\r\n          &quot;skppg&quot;: &quot;0&quot;,\r\n          &quot;sksaucerpasses&quot;: &quot;0&quot;,\r\n          &quot;skshg&quot;: &quot;0&quot;,\r\n          &quot;skshotattempts&quot;: &quot;1&quot;,\r\n          &quot;skshotonnetpct&quot;: &quot;100.00&quot;,\r\n          &quot;skshotpct&quot;: &quot;0.00&quot;,\r\n          &quot;skshots&quot;: &quot;1&quot;,\r\n          &quot;sktakeaways&quot;: &quot;2&quot;,\r\n          &quot;toiseconds&quot;: &quot;3600&quot;,\r\n          &quot;playername&quot;: &quot;bostonsniper4t4&quot;\r\n        },\r\n        &quot;1004176504213&quot;: {\r\n          &quot;glbrksavepct&quot;: &quot;0.00&quot;,\r\n          &quot;glbrksaves&quot;: &quot;0&quot;,\r\n          &quot;glbrkshots&quot;: &quot;0&quot;,\r\n          &quot;gldsaves&quot;: &quot;1&quot;,\r\n          &quot;glga&quot;: &quot;6&quot;,\r\n          &quot;glgaa&quot;: &quot;6.00&quot;,\r\n          &quot;glpensavepct&quot;: &quot;0.00&quot;,\r\n          &quot;glpensaves&quot;: &quot;0&quot;,\r\n          &quot;glpenshots&quot;: &quot;0&quot;,\r\n          &quot;glpkclearzone&quot;: &quot;0&quot;,\r\n          &quot;glpokechecks&quot;: &quot;0&quot;,\r\n          &quot;glsavepct&quot;: &quot;0.60&quot;,\r\n          &quot;glsaves&quot;: &quot;9&quot;,\r\n          &quot;glshots&quot;: &quot;15&quot;,\r\n          &quot;glsoperiods&quot;: &quot;0&quot;,\r\n          &quot;opponentClubId&quot;: &quot;79718&quot;,\r\n          &quot;position&quot;: &quot;goalie&quot;,\r\n          &quot;posSorted&quot;: &quot;0&quot;,\r\n          &quot;ratingDefense&quot;: &quot;70.00&quot;,\r\n          &quot;ratingOffense&quot;: &quot;30.00&quot;,\r\n          &quot;ratingTeamplay&quot;: &quot;45.00&quot;,\r\n          &quot;skassists&quot;: &quot;0&quot;,\r\n          &quot;skbs&quot;: &quot;0&quot;,\r\n          &quot;skdeflections&quot;: &quot;0&quot;,\r\n          &quot;skfol&quot;: &quot;0&quot;,\r\n          &quot;skfopct&quot;: &quot;0.00&quot;,\r\n          &quot;skfow&quot;: &quot;0&quot;,\r\n          &quot;skgiveaways&quot;: &quot;0&quot;,\r\n          &quot;skgoals&quot;: &quot;0&quot;,\r\n          &quot;skgwg&quot;: &quot;0&quot;,\r\n          &quot;skhits&quot;: &quot;0&quot;,\r\n          &quot;skinterceptions&quot;: &quot;0&quot;,\r\n          &quot;skpassattempts&quot;: &quot;0&quot;,\r\n          &quot;skpasses&quot;: &quot;0&quot;,\r\n          &quot;skpasspct&quot;: &quot;0.00&quot;,\r\n          &quot;skpenaltiesdrawn&quot;: &quot;0&quot;,\r\n          &quot;skpim&quot;: &quot;0&quot;,\r\n          &quot;skpkclearzone&quot;: &quot;0&quot;,\r\n          &quot;skplusmin&quot;: &quot;0&quot;,\r\n          &quot;skpossession&quot;: &quot;0&quot;,\r\n          &quot;skppg&quot;: &quot;0&quot;,\r\n          &quot;sksaucerpasses&quot;: &quot;0&quot;,\r\n          &quot;skshg&quot;: &quot;0&quot;,\r\n          &quot;skshotattempts&quot;: &quot;0&quot;,\r\n          &quot;skshotonnetpct&quot;: &quot;0.00&quot;,\r\n          &quot;skshotpct&quot;: &quot;0.00&quot;,\r\n          &quot;skshots&quot;: &quot;0&quot;,\r\n          &quot;sktakeaways&quot;: &quot;0&quot;,\r\n          &quot;toiseconds&quot;: &quot;3600&quot;,\r\n          &quot;playername&quot;: &quot;HABSFAN972651&quot;\r\n        }\r\n      },\r\n      &quot;79718&quot;: {\r\n        &quot;273323046&quot;: {\r\n          &quot;glbrksavepct&quot;: &quot;0.00&quot;,\r\n          &quot;glbrksaves&quot;: &quot;0&quot;,\r\n          &quot;glbrkshots&quot;: &quot;0&quot;,\r\n          &quot;gldsaves&quot;: &quot;0&quot;,\r\n          &quot;glga&quot;: &quot;0&quot;,\r\n          &quot;glgaa&quot;: &quot;0.00&quot;,\r\n          &quot;glpensavepct&quot;: &quot;0.00&quot;,\r\n          &quot;glpensaves&quot;: &quot;0&quot;,\r\n          &quot;glpenshots&quot;: &quot;0&quot;,\r\n          &quot;glpkclearzone&quot;: &quot;0&quot;,\r\n          &quot;glpokechecks&quot;: &quot;0&quot;,\r\n          &quot;glsavepct&quot;: &quot;0.00&quot;,\r\n          &quot;glsaves&quot;: &quot;0&quot;,\r\n          &quot;glshots&quot;: &quot;0&quot;,\r\n          &quot;glsoperiods&quot;: &quot;0&quot;,\r\n          &quot;opponentClubId&quot;: &quot;145078&quot;,\r\n          &quot;position&quot;: &quot;rightWing&quot;,\r\n          &quot;posSorted&quot;: &quot;3&quot;,\r\n          &quot;ratingDefense&quot;: &quot;95.00&quot;,\r\n          &quot;ratingOffense&quot;: &quot;100.00&quot;,\r\n          &quot;ratingTeamplay&quot;: &quot;30.00&quot;,\r\n          &quot;skassists&quot;: &quot;3&quot;,\r\n          &quot;skbs&quot;: &quot;0&quot;,\r\n          &quot;skdeflections&quot;: &quot;0&quot;,\r\n          &quot;skfol&quot;: &quot;0&quot;,\r\n          &quot;skfopct&quot;: &quot;0.00&quot;,\r\n          &quot;skfow&quot;: &quot;0&quot;,\r\n          &quot;skgiveaways&quot;: &quot;2&quot;,\r\n          &quot;skgoals&quot;: &quot;1&quot;,\r\n          &quot;skgwg&quot;: &quot;0&quot;,\r\n          &quot;skhits&quot;: &quot;0&quot;,\r\n          &quot;skinterceptions&quot;: &quot;7&quot;,\r\n          &quot;skpassattempts&quot;: &quot;16&quot;,\r\n          &quot;skpasses&quot;: &quot;12&quot;,\r\n          &quot;skpasspct&quot;: &quot;75.00&quot;,\r\n          &quot;skpenaltiesdrawn&quot;: &quot;0&quot;,\r\n          &quot;skpim&quot;: &quot;2&quot;,\r\n          &quot;skpkclearzone&quot;: &quot;3&quot;,\r\n          &quot;skplusmin&quot;: &quot;5&quot;,\r\n          &quot;skpossession&quot;: &quot;241&quot;,\r\n          &quot;skppg&quot;: &quot;0&quot;,\r\n          &quot;sksaucerpasses&quot;: &quot;1&quot;,\r\n          &quot;skshg&quot;: &quot;0&quot;,\r\n          &quot;skshotattempts&quot;: &quot;3&quot;,\r\n          &quot;skshotonnetpct&quot;: &quot;100.00&quot;,\r\n          &quot;skshotpct&quot;: &quot;33.33&quot;,\r\n          &quot;skshots&quot;: &quot;3&quot;,\r\n          &quot;sktakeaways&quot;: &quot;6&quot;,\r\n          &quot;toiseconds&quot;: &quot;3567&quot;,\r\n          &quot;playername&quot;: &quot;Gronk x L87L&quot;\r\n        },\r\n        &quot;288926878&quot;: {\r\n          &quot;glbrksavepct&quot;: &quot;0.00&quot;,\r\n          &quot;glbrksaves&quot;: &quot;0&quot;,\r\n          &quot;glbrkshots&quot;: &quot;0&quot;,\r\n          &quot;gldsaves&quot;: &quot;0&quot;,\r\n          &quot;glga&quot;: &quot;0&quot;,\r\n          &quot;glgaa&quot;: &quot;0.00&quot;,\r\n          &quot;glpensavepct&quot;: &quot;0.00&quot;,\r\n          &quot;glpensaves&quot;: &quot;0&quot;,\r\n          &quot;glpenshots&quot;: &quot;0&quot;,\r\n          &quot;glpkclearzone&quot;: &quot;0&quot;,\r\n          &quot;glpokechecks&quot;: &quot;0&quot;,\r\n          &quot;glsavepct&quot;: &quot;0.00&quot;,\r\n          &quot;glsaves&quot;: &quot;0&quot;,\r\n          &quot;glshots&quot;: &quot;0&quot;,\r\n          &quot;glsoperiods&quot;: &quot;0&quot;,\r\n          &quot;opponentClubId&quot;: &quot;145078&quot;,\r\n          &quot;position&quot;: &quot;leftWing&quot;,\r\n          &quot;posSorted&quot;: &quot;4&quot;,\r\n          &quot;ratingDefense&quot;: &quot;65.00&quot;,\r\n          &quot;ratingOffense&quot;: &quot;100.00&quot;,\r\n          &quot;ratingTeamplay&quot;: &quot;55.00&quot;,\r\n          &quot;skassists&quot;: &quot;0&quot;,\r\n          &quot;skbs&quot;: &quot;2&quot;,\r\n          &quot;skdeflections&quot;: &quot;0&quot;,\r\n          &quot;skfol&quot;: &quot;0&quot;,\r\n          &quot;skfopct&quot;: &quot;0.00&quot;,\r\n          &quot;skfow&quot;: &quot;0&quot;,\r\n          &quot;skgiveaways&quot;: &quot;5&quot;,\r\n          &quot;skgoals&quot;: &quot;3&quot;,\r\n          &quot;skgwg&quot;: &quot;0&quot;,\r\n          &quot;skhits&quot;: &quot;1&quot;,\r\n          &quot;skinterceptions&quot;: &quot;1&quot;,\r\n          &quot;skpassattempts&quot;: &quot;11&quot;,\r\n          &quot;skpasses&quot;: &quot;8&quot;,\r\n          &quot;skpasspct&quot;: &quot;72.73&quot;,\r\n          &quot;skpenaltiesdrawn&quot;: &quot;0&quot;,\r\n          &quot;skpim&quot;: &quot;0&quot;,\r\n          &quot;skpkclearzone&quot;: &quot;0&quot;,\r\n          &quot;skplusmin&quot;: &quot;5&quot;,\r\n          &quot;skpossession&quot;: &quot;183&quot;,\r\n          &quot;skppg&quot;: &quot;0&quot;,\r\n          &quot;sksaucerpasses&quot;: &quot;0&quot;,\r\n          &quot;skshg&quot;: &quot;0&quot;,\r\n          &quot;skshotattempts&quot;: &quot;8&quot;,\r\n          &quot;skshotonnetpct&quot;: &quot;75.00&quot;,\r\n          &quot;skshotpct&quot;: &quot;50.00&quot;,\r\n          &quot;skshots&quot;: &quot;6&quot;,\r\n          &quot;sktakeaways&quot;: &quot;1&quot;,\r\n          &quot;toiseconds&quot;: &quot;3600&quot;,\r\n          &quot;playername&quot;: &quot;xxJONx&quot;\r\n        },\r\n        &quot;515447555&quot;: {\r\n          &quot;glbrksavepct&quot;: &quot;0.00&quot;,\r\n          &quot;glbrksaves&quot;: &quot;0&quot;,\r\n          &quot;glbrkshots&quot;: &quot;0&quot;,\r\n          &quot;gldsaves&quot;: &quot;0&quot;,\r\n          &quot;glga&quot;: &quot;0&quot;,\r\n          &quot;glgaa&quot;: &quot;0.00&quot;,\r\n          &quot;glpensavepct&quot;: &quot;0.00&quot;,\r\n          &quot;glpensaves&quot;: &quot;0&quot;,\r\n          &quot;glpenshots&quot;: &quot;0&quot;,\r\n          &quot;glpkclearzone&quot;: &quot;0&quot;,\r\n          &quot;glpokechecks&quot;: &quot;0&quot;,\r\n          &quot;glsavepct&quot;: &quot;0.00&quot;,\r\n          &quot;glsaves&quot;: &quot;0&quot;,\r\n          &quot;glshots&quot;: &quot;0&quot;,\r\n          &quot;glsoperiods&quot;: &quot;0&quot;,\r\n          &quot;opponentClubId&quot;: &quot;145078&quot;,\r\n          &quot;position&quot;: &quot;defenseMen&quot;,\r\n          &quot;posSorted&quot;: &quot;2&quot;,\r\n          &quot;ratingDefense&quot;: &quot;70.00&quot;,\r\n          &quot;ratingOffense&quot;: &quot;85.00&quot;,\r\n          &quot;ratingTeamplay&quot;: &quot;30.00&quot;,\r\n          &quot;skassists&quot;: &quot;1&quot;,\r\n          &quot;skbs&quot;: &quot;0&quot;,\r\n          &quot;skdeflections&quot;: &quot;0&quot;,\r\n          &quot;skfol&quot;: &quot;0&quot;,\r\n          &quot;skfopct&quot;: &quot;0.00&quot;,\r\n          &quot;skfow&quot;: &quot;0&quot;,\r\n          &quot;skgiveaways&quot;: &quot;11&quot;,\r\n          &quot;skgoals&quot;: &quot;1&quot;,\r\n          &quot;skgwg&quot;: &quot;0&quot;,\r\n          &quot;skhits&quot;: &quot;6&quot;,\r\n          &quot;skinterceptions&quot;: &quot;4&quot;,\r\n          &quot;skpassattempts&quot;: &quot;9&quot;,\r\n          &quot;skpasses&quot;: &quot;5&quot;,\r\n          &quot;skpasspct&quot;: &quot;55.56&quot;,\r\n          &quot;skpenaltiesdrawn&quot;: &quot;0&quot;,\r\n          &quot;skpim&quot;: &quot;6&quot;,\r\n          &quot;skpkclearzone&quot;: &quot;0&quot;,\r\n          &quot;skplusmin&quot;: &quot;5&quot;,\r\n          &quot;skpossession&quot;: &quot;212&quot;,\r\n          &quot;skppg&quot;: &quot;0&quot;,\r\n          &quot;sksaucerpasses&quot;: &quot;1&quot;,\r\n          &quot;skshg&quot;: &quot;0&quot;,\r\n          &quot;skshotattempts&quot;: &quot;2&quot;,\r\n          &quot;skshotonnetpct&quot;: &quot;50.00&quot;,\r\n          &quot;skshotpct&quot;: &quot;100.00&quot;,\r\n          &quot;skshots&quot;: &quot;1&quot;,\r\n          &quot;sktakeaways&quot;: &quot;2&quot;,\r\n          &quot;toiseconds&quot;: &quot;3404&quot;,\r\n          &quot;playername&quot;: &quot;vShotsy&quot;\r\n        },\r\n        &quot;800554172&quot;: {\r\n          &quot;glbrksavepct&quot;: &quot;0.00&quot;,\r\n          &quot;glbrksaves&quot;: &quot;0&quot;,\r\n          &quot;glbrkshots&quot;: &quot;0&quot;,\r\n          &quot;gldsaves&quot;: &quot;0&quot;,\r\n          &quot;glga&quot;: &quot;0&quot;,\r\n          &quot;glgaa&quot;: &quot;0.00&quot;,\r\n          &quot;glpensavepct&quot;: &quot;0.00&quot;,\r\n          &quot;glpensaves&quot;: &quot;0&quot;,\r\n          &quot;glpenshots&quot;: &quot;0&quot;,\r\n          &quot;glpkclearzone&quot;: &quot;0&quot;,\r\n          &quot;glpokechecks&quot;: &quot;0&quot;,\r\n          &quot;glsavepct&quot;: &quot;0.00&quot;,\r\n          &quot;glsaves&quot;: &quot;0&quot;,\r\n          &quot;glshots&quot;: &quot;0&quot;,\r\n          &quot;glsoperiods&quot;: &quot;0&quot;,\r\n          &quot;opponentClubId&quot;: &quot;145078&quot;,\r\n          &quot;position&quot;: &quot;defenseMen&quot;,\r\n          &quot;posSorted&quot;: &quot;1&quot;,\r\n          &quot;ratingDefense&quot;: &quot;90.00&quot;,\r\n          &quot;ratingOffense&quot;: &quot;95.00&quot;,\r\n          &quot;ratingTeamplay&quot;: &quot;70.00&quot;,\r\n          &quot;skassists&quot;: &quot;2&quot;,\r\n          &quot;skbs&quot;: &quot;1&quot;,\r\n          &quot;skdeflections&quot;: &quot;0&quot;,\r\n          &quot;skfol&quot;: &quot;0&quot;,\r\n          &quot;skfopct&quot;: &quot;0.00&quot;,\r\n          &quot;skfow&quot;: &quot;0&quot;,\r\n          &quot;skgiveaways&quot;: &quot;10&quot;,\r\n          &quot;skgoals&quot;: &quot;1&quot;,\r\n          &quot;skgwg&quot;: &quot;0&quot;,\r\n          &quot;skhits&quot;: &quot;6&quot;,\r\n          &quot;skinterceptions&quot;: &quot;4&quot;,\r\n          &quot;skpassattempts&quot;: &quot;26&quot;,\r\n          &quot;skpasses&quot;: &quot;20&quot;,\r\n          &quot;skpasspct&quot;: &quot;76.92&quot;,\r\n          &quot;skpenaltiesdrawn&quot;: &quot;0&quot;,\r\n          &quot;skpim&quot;: &quot;2&quot;,\r\n          &quot;skpkclearzone&quot;: &quot;3&quot;,\r\n          &quot;skplusmin&quot;: &quot;5&quot;,\r\n          &quot;skpossession&quot;: &quot;221&quot;,\r\n          &quot;skppg&quot;: &quot;0&quot;,\r\n          &quot;sksaucerpasses&quot;: &quot;2&quot;,\r\n          &quot;skshg&quot;: &quot;0&quot;,\r\n          &quot;skshotattempts&quot;: &quot;1&quot;,\r\n          &quot;skshotonnetpct&quot;: &quot;100.00&quot;,\r\n          &quot;skshotpct&quot;: &quot;100.00&quot;,\r\n          &quot;skshots&quot;: &quot;1&quot;,\r\n          &quot;sktakeaways&quot;: &quot;1&quot;,\r\n          &quot;toiseconds&quot;: &quot;3481&quot;,\r\n          &quot;playername&quot;: &quot;Martinez1225&quot;\r\n        },\r\n        &quot;858674479&quot;: {\r\n          &quot;glbrksavepct&quot;: &quot;0.00&quot;,\r\n          &quot;glbrksaves&quot;: &quot;0&quot;,\r\n          &quot;glbrkshots&quot;: &quot;1&quot;,\r\n          &quot;gldsaves&quot;: &quot;0&quot;,\r\n          &quot;glga&quot;: &quot;3&quot;,\r\n          &quot;glgaa&quot;: &quot;3.00&quot;,\r\n          &quot;glpensavepct&quot;: &quot;0.00&quot;,\r\n          &quot;glpensaves&quot;: &quot;0&quot;,\r\n          &quot;glpenshots&quot;: &quot;0&quot;,\r\n          &quot;glpkclearzone&quot;: &quot;0&quot;,\r\n          &quot;glpokechecks&quot;: &quot;0&quot;,\r\n          &quot;glsavepct&quot;: &quot;0.83&quot;,\r\n          &quot;glsaves&quot;: &quot;15&quot;,\r\n          &quot;glshots&quot;: &quot;18&quot;,\r\n          &quot;glsoperiods&quot;: &quot;0&quot;,\r\n          &quot;opponentClubId&quot;: &quot;145078&quot;,\r\n          &quot;position&quot;: &quot;goalie&quot;,\r\n          &quot;posSorted&quot;: &quot;0&quot;,\r\n          &quot;ratingDefense&quot;: &quot;75.00&quot;,\r\n          &quot;ratingOffense&quot;: &quot;75.00&quot;,\r\n          &quot;ratingTeamplay&quot;: &quot;60.00&quot;,\r\n          &quot;skassists&quot;: &quot;0&quot;,\r\n          &quot;skbs&quot;: &quot;0&quot;,\r\n          &quot;skdeflections&quot;: &quot;0&quot;,\r\n          &quot;skfol&quot;: &quot;0&quot;,\r\n          &quot;skfopct&quot;: &quot;0.00&quot;,\r\n          &quot;skfow&quot;: &quot;0&quot;,\r\n          &quot;skgiveaways&quot;: &quot;0&quot;,\r\n          &quot;skgoals&quot;: &quot;0&quot;,\r\n          &quot;skgwg&quot;: &quot;0&quot;,\r\n          &quot;skhits&quot;: &quot;0&quot;,\r\n          &quot;skinterceptions&quot;: &quot;0&quot;,\r\n          &quot;skpassattempts&quot;: &quot;0&quot;,\r\n          &quot;skpasses&quot;: &quot;0&quot;,\r\n          &quot;skpasspct&quot;: &quot;0.00&quot;,\r\n          &quot;skpenaltiesdrawn&quot;: &quot;0&quot;,\r\n          &quot;skpim&quot;: &quot;0&quot;,\r\n          &quot;skpkclearzone&quot;: &quot;0&quot;,\r\n          &quot;skplusmin&quot;: &quot;0&quot;,\r\n          &quot;skpossession&quot;: &quot;0&quot;,\r\n          &quot;skppg&quot;: &quot;0&quot;,\r\n          &quot;sksaucerpasses&quot;: &quot;0&quot;,\r\n          &quot;skshg&quot;: &quot;0&quot;,\r\n          &quot;skshotattempts&quot;: &quot;0&quot;,\r\n          &quot;skshotonnetpct&quot;: &quot;0.00&quot;,\r\n          &quot;skshotpct&quot;: &quot;0.00&quot;,\r\n          &quot;skshots&quot;: &quot;0&quot;,\r\n          &quot;sktakeaways&quot;: &quot;0&quot;,\r\n          &quot;toiseconds&quot;: &quot;3600&quot;,\r\n          &quot;playername&quot;: &quot;MacShrimp&quot;\r\n        },\r\n        &quot;1183100664&quot;: {\r\n          &quot;glbrksavepct&quot;: &quot;0.00&quot;,\r\n          &quot;glbrksaves&quot;: &quot;0&quot;,\r\n          &quot;glbrkshots&quot;: &quot;0&quot;,\r\n          &quot;gldsaves&quot;: &quot;0&quot;,\r\n          &quot;glga&quot;: &quot;0&quot;,\r\n          &quot;glgaa&quot;: &quot;0.00&quot;,\r\n          &quot;glpensavepct&quot;: &quot;0.00&quot;,\r\n          &quot;glpensaves&quot;: &quot;0&quot;,\r\n          &quot;glpenshots&quot;: &quot;0&quot;,\r\n          &quot;glpkclearzone&quot;: &quot;0&quot;,\r\n          &quot;glpokechecks&quot;: &quot;0&quot;,\r\n          &quot;glsavepct&quot;: &quot;0.00&quot;,\r\n          &quot;glsaves&quot;: &quot;0&quot;,\r\n          &quot;glshots&quot;: &quot;0&quot;,\r\n          &quot;glsoperiods&quot;: &quot;0&quot;,\r\n          &quot;opponentClubId&quot;: &quot;145078&quot;,\r\n          &quot;position&quot;: &quot;center&quot;,\r\n          &quot;posSorted&quot;: &quot;5&quot;,\r\n          &quot;ratingDefense&quot;: &quot;100.00&quot;,\r\n          &quot;ratingOffense&quot;: &quot;80.00&quot;,\r\n          &quot;ratingTeamplay&quot;: &quot;65.00&quot;,\r\n          &quot;skassists&quot;: &quot;2&quot;,\r\n          &quot;skbs&quot;: &quot;0&quot;,\r\n          &quot;skdeflections&quot;: &quot;0&quot;,\r\n          &quot;skfol&quot;: &quot;18&quot;,\r\n          &quot;skfopct&quot;: &quot;43.75&quot;,\r\n          &quot;skfow&quot;: &quot;14&quot;,\r\n          &quot;skgiveaways&quot;: &quot;1&quot;,\r\n          &quot;skgoals&quot;: &quot;0&quot;,\r\n          &quot;skgwg&quot;: &quot;0&quot;,\r\n          &quot;skhits&quot;: &quot;1&quot;,\r\n          &quot;skinterceptions&quot;: &quot;2&quot;,\r\n          &quot;skpassattempts&quot;: &quot;16&quot;,\r\n          &quot;skpasses&quot;: &quot;12&quot;,\r\n          &quot;skpasspct&quot;: &quot;75.00&quot;,\r\n          &quot;skpenaltiesdrawn&quot;: &quot;0&quot;,\r\n          &quot;skpim&quot;: &quot;0&quot;,\r\n          &quot;skpkclearzone&quot;: &quot;3&quot;,\r\n          &quot;skplusmin&quot;: &quot;5&quot;,\r\n          &quot;skpossession&quot;: &quot;103&quot;,\r\n          &quot;skppg&quot;: &quot;0&quot;,\r\n          &quot;sksaucerpasses&quot;: &quot;0&quot;,\r\n          &quot;skshg&quot;: &quot;0&quot;,\r\n          &quot;skshotattempts&quot;: &quot;1&quot;,\r\n          &quot;skshotonnetpct&quot;: &quot;200.00&quot;,\r\n          &quot;skshotpct&quot;: &quot;0.00&quot;,\r\n          &quot;skshots&quot;: &quot;2&quot;,\r\n          &quot;sktakeaways&quot;: &quot;2&quot;,\r\n          &quot;toiseconds&quot;: &quot;3600&quot;,\r\n          &quot;playername&quot;: &quot;Rakkarak&quot;\r\n        }\r\n      }\r\n    }\r\n  }\r\n]\r\n```",
                "title": "using jq to filter nested data in json"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1661756036,
                "creation_date": 1661756036,
                "answer_id": 73525082,
                "question_id": 73522843,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s another variation that you can provide regex patterns for the paths to select.\r\n\r\nPer segment matches\r\n```\r\n[\r\n\t[&quot;matchId&quot;],\r\n\t[&quot;timestamp&quot;],\r\n\t[&quot;clubs&quot;, &quot;.+&quot;, &quot;p.+&quot;],\r\n\t[&quot;clubs&quot;, &quot;.+&quot;, &quot;(shots|toa)&quot;],\r\n\t[&quot;clubs&quot;, &quot;.+&quot;, &quot;details&quot;, &quot;(name|clubId)&quot;],\r\n\t[&quot;players&quot;, &quot;.+&quot;, &quot;.+&quot;, &quot;gl.+&quot;],\r\n\t[&quot;players&quot;, &quot;.+&quot;, &quot;.+&quot;, &quot;(opponentClubId|position|posSorted)&quot;],\r\n\t[&quot;players&quot;, &quot;.+&quot;, &quot;.+&quot;, &quot;rating.+&quot;],\r\n\t[&quot;players&quot;, &quot;.+&quot;, &quot;.+&quot;, &quot;sk.+&quot;],\r\n\t[&quot;players&quot;, &quot;.+&quot;, &quot;.+&quot;, &quot;(toiseconds|playername)&quot;]\r\n] as $patterns\r\n|\r\ndef select_paths($patterns):\r\n\tdef is_matching_pattern($path):\r\n\t\t([$path, .] | transpose) as $pairs\r\n\t\t|\r\n\t\tall($pairs[]; . as [$path, $pattern] |\r\n\t\t\t$path | if $pattern then test(&quot;^(\\($pattern))$&quot;) else false end\r\n\t\t)\r\n\t\t;\r\n\tdef filter_paths: . as [$path] |\r\n\t\tselect(length == 1 or any($patterns[]; is_matching_pattern($path)))\r\n\t\t;\r\n\tfromstream(tostream | filter_paths)\r\n\t;\r\nmap(select_paths($patterns))\r\n```\r\n\r\nDotted path matches\r\n```\r\n[\r\n\t&quot;matchId&quot;,\r\n\t&quot;timestamp&quot;,\r\n\t&quot;clubs\\\\..+\\\\.p.+&quot;,\r\n\t&quot;clubs\\\\..+\\\\.(shots|toa)&quot;,\r\n\t&quot;clubs\\\\..+\\\\.details\\\\.(name|clubId)&quot;,\r\n\t&quot;players\\\\..+\\\\..+\\\\.gl.+&quot;,\r\n\t&quot;players\\\\..+\\\\..+\\\\.(opponentClubId|position|posSorted)&quot;,\r\n\t&quot;players\\\\..+\\\\..+\\\\.rating.+&quot;,\r\n\t&quot;players\\\\..+\\\\..+\\\\.sk.+&quot;,\r\n\t&quot;players\\\\..+\\\\..+\\\\.(toiseconds|playername)&quot;\r\n] as $patterns\r\n|\r\ndef select_paths($patterns):\r\n\tdef is_matching_pattern($path): &quot;^(\\(.))$&quot; as $pattern |\r\n\t\t$path | test($pattern)\r\n\t\t;\r\n\tdef filter_paths: . as [$path] |\r\n\t\tselect(length == 1 or any($patterns[]; is_matching_pattern($path | join(&quot;.&quot;))))\r\n\t\t;\r\n\tfromstream(tostream | filter_paths)\r\n\t;\r\nmap(select_paths($patterns))\r\n```",
                "title": "using jq to filter nested data in json"
            }
        ],
        "is_answered": false,
        "answer_count": 2,
        "score": -1,
        "last_activity_date": 1661756036,
        "creation_date": 1661727353,
        "question_id": 73522843,
        "body_markdown": "here is the original, it contains lots of information that i do not need for the purpose i am using it for.\r\n```\r\n[\r\n  {\r\n    &quot;matchId&quot;: &quot;2234705530498&quot;,\r\n    &quot;timestamp&quot;: 1661657182,\r\n    &quot;timeAgo&quot;: {\r\n      &quot;number&quot;: 17,\r\n      &quot;unit&quot;: &quot;hours&quot;\r\n    },\r\n    &quot;clubs&quot;: {\r\n      &quot;79718&quot;: {\r\n        &quot;clubDivision&quot;: &quot;4&quot;,\r\n        &quot;cNhlOnlineGameType&quot;: &quot;5&quot;,\r\n        &quot;garaw&quot;: &quot;3&quot;,\r\n        &quot;gfraw&quot;: &quot;6&quot;,\r\n        &quot;losses&quot;: &quot;0&quot;,\r\n        &quot;memberString&quot;: &quot;6 / 6&quot;,\r\n        &quot;opponentClubId&quot;: &quot;145078&quot;,\r\n        &quot;opponentScore&quot;: &quot;3&quot;,\r\n        &quot;opponentTeamArtAbbr&quot;: &quot;EASHL&quot;,\r\n        &quot;passa&quot;: &quot;79&quot;,\r\n        &quot;passc&quot;: &quot;58&quot;,\r\n        &quot;ppg&quot;: &quot;0&quot;,\r\n        &quot;ppo&quot;: &quot;0&quot;,\r\n        &quot;result&quot;: &quot;1&quot;,\r\n        &quot;score&quot;: &quot;6&quot;,\r\n        &quot;scoreString&quot;: &quot;6 - 3&quot;,\r\n        &quot;shots&quot;: &quot;15&quot;,\r\n        &quot;teamArtAbbr&quot;: &quot;DROP&quot;,\r\n        &quot;teamSide&quot;: &quot;1&quot;,\r\n        &quot;toa&quot;: &quot;252&quot;,\r\n        &quot;winnerByDnf&quot;: &quot;0&quot;,\r\n        &quot;winnerByGoalieDnf&quot;: &quot;0&quot;,\r\n        &quot;details&quot;: {\r\n          &quot;name&quot;: &quot;NZHL Memphis Make A Wish&quot;,\r\n          &quot;clubId&quot;: 79718,\r\n          &quot;regionId&quot;: 1,\r\n          &quot;teamId&quot;: 5108,\r\n          &quot;customKit&quot;: {\r\n            &quot;isCustomTeam&quot;: &quot;1&quot;,\r\n            &quot;crestAssetId&quot;: &quot;62&quot;,\r\n            &quot;useBaseAsset&quot;: &quot;1&quot;\r\n          }\r\n        },\r\n        &quot;goals&quot;: &quot;6&quot;,\r\n        &quot;goalsAgainst&quot;: &quot;3&quot;\r\n      },\r\n      &quot;145078&quot;: {\r\n        &quot;clubDivision&quot;: &quot;6&quot;,\r\n        &quot;cNhlOnlineGameType&quot;: &quot;5&quot;,\r\n        &quot;garaw&quot;: &quot;6&quot;,\r\n        &quot;gfraw&quot;: &quot;3&quot;,\r\n        &quot;losses&quot;: &quot;1&quot;,\r\n        &quot;memberString&quot;: &quot;6 / 6&quot;,\r\n        &quot;opponentClubId&quot;: &quot;79718&quot;,\r\n        &quot;opponentScore&quot;: &quot;6&quot;,\r\n        &quot;opponentTeamArtAbbr&quot;: &quot;DROP&quot;,\r\n        &quot;passa&quot;: &quot;101&quot;,\r\n        &quot;passc&quot;: &quot;79&quot;,\r\n        &quot;ppg&quot;: &quot;2&quot;,\r\n        &quot;ppo&quot;: &quot;5&quot;,\r\n        &quot;result&quot;: &quot;2&quot;,\r\n        &quot;score&quot;: &quot;3&quot;,\r\n        &quot;scoreString&quot;: &quot;3 - 6&quot;,\r\n        &quot;shots&quot;: &quot;18&quot;,\r\n        &quot;teamArtAbbr&quot;: &quot;EASHL&quot;,\r\n        &quot;teamSide&quot;: &quot;0&quot;,\r\n        &quot;toa&quot;: &quot;317&quot;,\r\n        &quot;winnerByDnf&quot;: &quot;0&quot;,\r\n        &quot;winnerByGoalieDnf&quot;: &quot;0&quot;,\r\n        &quot;details&quot;: {\r\n          &quot;name&quot;: &quot;NZHL LOCAL CRAFT BEER&quot;,\r\n          &quot;clubId&quot;: 145078,\r\n          &quot;regionId&quot;: 6,\r\n          &quot;teamId&quot;: 5102,\r\n          &quot;customKit&quot;: {\r\n            &quot;isCustomTeam&quot;: &quot;1&quot;,\r\n            &quot;crestAssetId&quot;: &quot;234&quot;,\r\n            &quot;useBaseAsset&quot;: &quot;1&quot;\r\n          }\r\n        },\r\n        &quot;goals&quot;: &quot;3&quot;,\r\n        &quot;goalsAgainst&quot;: &quot;6&quot;\r\n      }\r\n    },\r\n    &quot;players&quot;: {\r\n      &quot;145078&quot;: {\r\n        &quot;169580763&quot;: {\r\n          &quot;class&quot;: &quot;2&quot;,\r\n          &quot;glbrksavepct&quot;: &quot;0.00&quot;,\r\n          &quot;glbrksaves&quot;: &quot;0&quot;,\r\n          &quot;glbrkshots&quot;: &quot;0&quot;,\r\n          &quot;gldsaves&quot;: &quot;0&quot;,\r\n          &quot;glga&quot;: &quot;0&quot;,\r\n          &quot;glgaa&quot;: &quot;0.00&quot;,\r\n          &quot;glpensavepct&quot;: &quot;0.00&quot;,\r\n          &quot;glpensaves&quot;: &quot;0&quot;,\r\n          &quot;glpenshots&quot;: &quot;0&quot;,\r\n          &quot;glpkclearzone&quot;: &quot;0&quot;,\r\n          &quot;glpokechecks&quot;: &quot;0&quot;,\r\n          &quot;glsavepct&quot;: &quot;0.00&quot;,\r\n          &quot;glsaves&quot;: &quot;0&quot;,\r\n          &quot;glshots&quot;: &quot;0&quot;,\r\n          &quot;glsoperiods&quot;: &quot;0&quot;,\r\n          &quot;isGuest&quot;: &quot;1&quot;,\r\n          &quot;opponentClubId&quot;: &quot;79718&quot;,\r\n          &quot;opponentScore&quot;: &quot;6&quot;,\r\n          &quot;opponentTeamId&quot;: &quot;501&quot;,\r\n          &quot;player_dnf&quot;: &quot;0&quot;,\r\n          &quot;playerLevel&quot;: &quot;157&quot;,\r\n          &quot;pNhlOnlineGameType&quot;: &quot;5&quot;,\r\n          &quot;position&quot;: &quot;rightWing&quot;,\r\n          &quot;posSorted&quot;: &quot;3&quot;,\r\n          &quot;ratingDefense&quot;: &quot;55.00&quot;,\r\n          &quot;ratingOffense&quot;: &quot;85.00&quot;,\r\n          &quot;ratingTeamplay&quot;: &quot;70.00&quot;,\r\n          &quot;score&quot;: &quot;3&quot;,\r\n          &quot;skassists&quot;: &quot;0&quot;,\r\n          &quot;skbs&quot;: &quot;0&quot;,\r\n          &quot;skdeflections&quot;: &quot;0&quot;,\r\n          &quot;skfol&quot;: &quot;0&quot;,\r\n          &quot;skfopct&quot;: &quot;0.00&quot;,\r\n          &quot;skfow&quot;: &quot;0&quot;,\r\n          &quot;skgiveaways&quot;: &quot;4&quot;,\r\n          &quot;skgoals&quot;: &quot;2&quot;,\r\n          &quot;skgwg&quot;: &quot;0&quot;,\r\n          &quot;skhits&quot;: &quot;1&quot;,\r\n          &quot;skinterceptions&quot;: &quot;3&quot;,\r\n          &quot;skpassattempts&quot;: &quot;11&quot;,\r\n          &quot;skpasses&quot;: &quot;7&quot;,\r\n          &quot;skpasspct&quot;: &quot;63.64&quot;,\r\n          &quot;skpenaltiesdrawn&quot;: &quot;1&quot;,\r\n          &quot;skpim&quot;: &quot;0&quot;,\r\n          &quot;skpkclearzone&quot;: &quot;0&quot;,\r\n          &quot;skplusmin&quot;: &quot;-5&quot;,\r\n          &quot;skpossession&quot;: &quot;106&quot;,\r\n          &quot;skppg&quot;: &quot;1&quot;,\r\n          &quot;sksaucerpasses&quot;: &quot;0&quot;,\r\n          &quot;skshg&quot;: &quot;0&quot;,\r\n          &quot;skshotattempts&quot;: &quot;12&quot;,\r\n          &quot;skshotonnetpct&quot;: &quot;66.67&quot;,\r\n          &quot;skshotpct&quot;: &quot;25.00&quot;,\r\n          &quot;skshots&quot;: &quot;8&quot;,\r\n          &quot;sktakeaways&quot;: &quot;0&quot;,\r\n          &quot;teamId&quot;: &quot;500&quot;,\r\n          &quot;teamSide&quot;: &quot;0&quot;,\r\n          &quot;toi&quot;: &quot;60&quot;,\r\n          &quot;toiseconds&quot;: &quot;3600&quot;,\r\n          &quot;playername&quot;: &quot;Ababo&quot;\r\n        },\r\n        &quot;174908181&quot;: {\r\n          &quot;class&quot;: &quot;14&quot;,\r\n          &quot;glbrksavepct&quot;: &quot;0.00&quot;,\r\n          &quot;glbrksaves&quot;: &quot;0&quot;,\r\n          &quot;glbrkshots&quot;: &quot;0&quot;,\r\n          &quot;gldsaves&quot;: &quot;0&quot;,\r\n          &quot;glga&quot;: &quot;0&quot;,\r\n          &quot;glgaa&quot;: &quot;0.00&quot;,\r\n          &quot;glpensavepct&quot;: &quot;0.00&quot;,\r\n          &quot;glpensaves&quot;: &quot;0&quot;,\r\n          &quot;glpenshots&quot;: &quot;0&quot;,\r\n          &quot;glpkclearzone&quot;: &quot;0&quot;,\r\n          &quot;glpokechecks&quot;: &quot;0&quot;,\r\n          &quot;glsavepct&quot;: &quot;0.00&quot;,\r\n          &quot;glsaves&quot;: &quot;0&quot;,\r\n          &quot;glshots&quot;: &quot;0&quot;,\r\n          &quot;glsoperiods&quot;: &quot;0&quot;,\r\n          &quot;isGuest&quot;: &quot;1&quot;,\r\n          &quot;opponentClubId&quot;: &quot;79718&quot;,\r\n          &quot;opponentScore&quot;: &quot;6&quot;,\r\n          &quot;opponentTeamId&quot;: &quot;501&quot;,\r\n          &quot;player_dnf&quot;: &quot;0&quot;,\r\n          &quot;playerLevel&quot;: &quot;190&quot;,\r\n          &quot;pNhlOnlineGameType&quot;: &quot;5&quot;,\r\n          &quot;position&quot;: &quot;defenseMen&quot;,\r\n          &quot;posSorted&quot;: &quot;1&quot;,\r\n          &quot;ratingDefense&quot;: &quot;65.00&quot;,\r\n          &quot;ratingOffense&quot;: &quot;75.00&quot;,\r\n          &quot;ratingTeamplay&quot;: &quot;80.00&quot;,\r\n          &quot;score&quot;: &quot;3&quot;,\r\n          &quot;skassists&quot;: &quot;1&quot;,\r\n          &quot;skbs&quot;: &quot;0&quot;,\r\n          &quot;skdeflections&quot;: &quot;0&quot;,\r\n          &quot;skfol&quot;: &quot;0&quot;,\r\n          &quot;skfopct&quot;: &quot;0.00&quot;,\r\n          &quot;skfow&quot;: &quot;0&quot;,\r\n          &quot;skgiveaways&quot;: &quot;4&quot;,\r\n          &quot;skgoals&quot;: &quot;0&quot;,\r\n          &quot;skgwg&quot;: &quot;0&quot;,\r\n          &quot;skhits&quot;: &quot;5&quot;,\r\n          &quot;skinterceptions&quot;: &quot;6&quot;,\r\n          &quot;skpassattempts&quot;: &quot;32&quot;,\r\n          &quot;skpasses&quot;: &quot;28&quot;,\r\n          &quot;skpasspct&quot;: &quot;87.50&quot;,\r\n          &quot;skpenaltiesdrawn&quot;: &quot;0&quot;,\r\n          &quot;skpim&quot;: &quot;0&quot;,\r\n          &quot;skpkclearzone&quot;: &quot;0&quot;,\r\n          &quot;skplusmin&quot;: &quot;-5&quot;,\r\n          &quot;skpossession&quot;: &quot;259&quot;,\r\n          &quot;skppg&quot;: &quot;0&quot;,\r\n          &quot;sksaucerpasses&quot;: &quot;1&quot;,\r\n          &quot;skshg&quot;: &quot;0&quot;,\r\n          &quot;skshotattempts&quot;: &quot;5&quot;,\r\n          &quot;skshotonnetpct&quot;: &quot;20.00&quot;,\r\n          &quot;skshotpct&quot;: &quot;0.00&quot;,\r\n          &quot;skshots&quot;: &quot;1&quot;,\r\n          &quot;sktakeaways&quot;: &quot;3&quot;,\r\n          &quot;teamId&quot;: &quot;500&quot;,\r\n          &quot;teamSide&quot;: &quot;0&quot;,\r\n          &quot;toi&quot;: &quot;60&quot;,\r\n          &quot;toiseconds&quot;: &quot;3600&quot;,\r\n          &quot;playername&quot;: &quot;mikezaw4458&quot;\r\n        },\r\n        &quot;181235555&quot;: {\r\n          &quot;class&quot;: &quot;1&quot;,\r\n          &quot;glbrksavepct&quot;: &quot;0.00&quot;,\r\n          &quot;glbrksaves&quot;: &quot;0&quot;,\r\n          &quot;glbrkshots&quot;: &quot;0&quot;,\r\n          &quot;gldsaves&quot;: &quot;0&quot;,\r\n          &quot;glga&quot;: &quot;0&quot;,\r\n          &quot;glgaa&quot;: &quot;0.00&quot;,\r\n          &quot;glpensavepct&quot;: &quot;0.00&quot;,\r\n          &quot;glpensaves&quot;: &quot;0&quot;,\r\n          &quot;glpenshots&quot;: &quot;0&quot;,\r\n          &quot;glpkclearzone&quot;: &quot;0&quot;,\r\n          &quot;glpokechecks&quot;: &quot;0&quot;,\r\n          &quot;glsavepct&quot;: &quot;0.00&quot;,\r\n          &quot;glsaves&quot;: &quot;0&quot;,\r\n          &quot;glshots&quot;: &quot;0&quot;,\r\n          &quot;glsoperiods&quot;: &quot;0&quot;,\r\n          &quot;isGuest&quot;: &quot;1&quot;,\r\n          &quot;opponentClubId&quot;: &quot;79718&quot;,\r\n          &quot;opponentScore&quot;: &quot;6&quot;,\r\n          &quot;opponentTeamId&quot;: &quot;501&quot;,\r\n          &quot;player_dnf&quot;: &quot;0&quot;,\r\n          &quot;playerLevel&quot;: &quot;231&quot;,\r\n          &quot;pNhlOnlineGameType&quot;: &quot;5&quot;,\r\n          &quot;position&quot;: &quot;center&quot;,\r\n          &quot;posSorted&quot;: &quot;5&quot;,\r\n          &quot;ratingDefense&quot;: &quot;60.00&quot;,\r\n          &quot;ratingOffense&quot;: &quot;90.00&quot;,\r\n          &quot;ratingTeamplay&quot;: &quot;75.00&quot;,\r\n          &quot;score&quot;: &quot;3&quot;,\r\n          &quot;skassists&quot;: &quot;3&quot;,\r\n          &quot;skbs&quot;: &quot;0&quot;,\r\n          &quot;skdeflections&quot;: &quot;1&quot;,\r\n          &quot;skfol&quot;: &quot;14&quot;,\r\n          &quot;skfopct&quot;: &quot;56.25&quot;,\r\n          &quot;skfow&quot;: &quot;18&quot;,\r\n          &quot;skgiveaways&quot;: &quot;8&quot;,\r\n          &quot;skgoals&quot;: &quot;0&quot;,\r\n          &quot;skgwg&quot;: &quot;0&quot;,\r\n          &quot;skhits&quot;: &quot;1&quot;,\r\n          &quot;skinterceptions&quot;: &quot;4&quot;,\r\n          &quot;skpassattempts&quot;: &quot;20&quot;,\r\n          &quot;skpasses&quot;: &quot;14&quot;,\r\n          &quot;skpasspct&quot;: &quot;70.00&quot;,\r\n          &quot;skpenaltiesdrawn&quot;: &quot;2&quot;,\r\n          &quot;skpim&quot;: &quot;0&quot;,\r\n          &quot;skpkclearzone&quot;: &quot;0&quot;,\r\n          &quot;skplusmin&quot;: &quot;-5&quot;,\r\n          &quot;skpossession&quot;: &quot;202&quot;,\r\n          &quot;skppg&quot;: &quot;0&quot;,\r\n          &quot;sksaucerpasses&quot;: &quot;0&quot;,\r\n          &quot;skshg&quot;: &quot;0&quot;,\r\n          &quot;skshotattempts&quot;: &quot;0&quot;,\r\n          &quot;skshotonnetpct&quot;: &quot;0.00&quot;,\r\n          &quot;skshotpct&quot;: &quot;0.00&quot;,\r\n          &quot;skshots&quot;: &quot;1&quot;,\r\n          &quot;sktakeaways&quot;: &quot;2&quot;,\r\n          &quot;teamId&quot;: &quot;500&quot;,\r\n          &quot;teamSide&quot;: &quot;0&quot;,\r\n          &quot;toi&quot;: &quot;60&quot;,\r\n          &quot;toiseconds&quot;: &quot;3600&quot;,\r\n          &quot;playername&quot;: &quot;LedvinKa&quot;\r\n        },\r\n        &quot;1627813040&quot;: {\r\n          &quot;class&quot;: &quot;2&quot;,\r\n          &quot;glbrksavepct&quot;: &quot;0.00&quot;,\r\n          &quot;glbrksaves&quot;: &quot;0&quot;,\r\n          &quot;glbrkshots&quot;: &quot;0&quot;,\r\n          &quot;gldsaves&quot;: &quot;0&quot;,\r\n          &quot;glga&quot;: &quot;0&quot;,\r\n          &quot;glgaa&quot;: &quot;0.00&quot;,\r\n          &quot;glpensavepct&quot;: &quot;0.00&quot;,\r\n          &quot;glpensaves&quot;: &quot;0&quot;,\r\n          &quot;glpenshots&quot;: &quot;0&quot;,\r\n          &quot;glpkclearzone&quot;: &quot;0&quot;,\r\n          &quot;glpokechecks&quot;: &quot;0&quot;,\r\n          &quot;glsavepct&quot;: &quot;0.00&quot;,\r\n          &quot;glsaves&quot;: &quot;0&quot;,\r\n          &quot;glshots&quot;: &quot;0&quot;,\r\n          &quot;glsoperiods&quot;: &quot;0&quot;,\r\n          &quot;isGuest&quot;: &quot;1&quot;,\r\n          &quot;opponentClubId&quot;: &quot;79718&quot;,\r\n          &quot;opponentScore&quot;: &quot;6&quot;,\r\n          &quot;opponentTeamId&quot;: &quot;501&quot;,\r\n          &quot;player_dnf&quot;: &quot;0&quot;,\r\n          &quot;playerLevel&quot;: &quot;230&quot;,\r\n          &quot;pNhlOnlineGameType&quot;: &quot;5&quot;,\r\n          &quot;position&quot;: &quot;leftWing&quot;,\r\n          &quot;posSorted&quot;: &quot;4&quot;,\r\n          &quot;ratingDefense&quot;: &quot;60.00&quot;,\r\n          &quot;ratingOffense&quot;: &quot;85.00&quot;,\r\n          &quot;ratingTeamplay&quot;: &quot;70.00&quot;,\r\n          &quot;score&quot;: &quot;3&quot;,\r\n          &quot;skassists&quot;: &quot;1&quot;,\r\n          &quot;skbs&quot;: &quot;0&quot;,\r\n          &quot;skdeflections&quot;: &quot;0&quot;,\r\n          &quot;skfol&quot;: &quot;0&quot;,\r\n          &quot;skfopct&quot;: &quot;0.00&quot;,\r\n          &quot;skfow&quot;: &quot;0&quot;,\r\n          &quot;skgiveaways&quot;: &quot;12&quot;,\r\n          &quot;skgoals&quot;: &quot;1&quot;,\r\n          &quot;skgwg&quot;: &quot;0&quot;,\r\n          &quot;skhits&quot;: &quot;1&quot;,\r\n          &quot;skinterceptions&quot;: &quot;2&quot;,\r\n          &quot;skpassattempts&quot;: &quot;23&quot;,\r\n          &quot;skpasses&quot;: &quot;18&quot;,\r\n          &quot;skpasspct&quot;: &quot;78.26&quot;,\r\n          &quot;skpenaltiesdrawn&quot;: &quot;2&quot;,\r\n          &quot;skpim&quot;: &quot;0&quot;,\r\n          &quot;skpkclearzone&quot;: &quot;0&quot;,\r\n          &quot;skplusmin&quot;: &quot;-5&quot;,\r\n          &quot;skpossession&quot;: &quot;207&quot;,\r\n          &quot;skppg&quot;: &quot;1&quot;,\r\n          &quot;sksaucerpasses&quot;: &quot;0&quot;,\r\n          &quot;skshg&quot;: &quot;0&quot;,\r\n          &quot;skshotattempts&quot;: &quot;7&quot;,\r\n          &quot;skshotonnetpct&quot;: &quot;100.00&quot;,\r\n          &quot;skshotpct&quot;: &quot;14.29&quot;,\r\n          &quot;skshots&quot;: &quot;7&quot;,\r\n          &quot;sktakeaways&quot;: &quot;1&quot;,\r\n          &quot;teamId&quot;: &quot;500&quot;,\r\n          &quot;teamSide&quot;: &quot;0&quot;,\r\n          &quot;toi&quot;: &quot;60&quot;,\r\n          &quot;toiseconds&quot;: &quot;3600&quot;,\r\n          &quot;playername&quot;: &quot;Justn I87I&quot;\r\n        },\r\n        &quot;1785195119&quot;: {\r\n          &quot;class&quot;: &quot;15&quot;,\r\n          &quot;glbrksavepct&quot;: &quot;0.00&quot;,\r\n          &quot;glbrksaves&quot;: &quot;0&quot;,\r\n          &quot;glbrkshots&quot;: &quot;0&quot;,\r\n          &quot;gldsaves&quot;: &quot;0&quot;,\r\n          &quot;glga&quot;: &quot;0&quot;,\r\n          &quot;glgaa&quot;: &quot;0.00&quot;,\r\n          &quot;glpensavepct&quot;: &quot;0.00&quot;,\r\n          &quot;glpensaves&quot;: &quot;0&quot;,\r\n          &quot;glpenshots&quot;: &quot;0&quot;,\r\n          &quot;glpkclearzone&quot;: &quot;0&quot;,\r\n          &quot;glpokechecks&quot;: &quot;0&quot;,\r\n          &quot;glsavepct&quot;: &quot;0.00&quot;,\r\n          &quot;glsaves&quot;: &quot;0&quot;,\r\n          &quot;glshots&quot;: &quot;0&quot;,\r\n          &quot;glsoperiods&quot;: &quot;0&quot;,\r\n          &quot;isGuest&quot;: &quot;0&quot;,\r\n          &quot;opponentClubId&quot;: &quot;79718&quot;,\r\n          &quot;opponentScore&quot;: &quot;6&quot;,\r\n          &quot;opponentTeamId&quot;: &quot;501&quot;,\r\n          &quot;player_dnf&quot;: &quot;0&quot;,\r\n          &quot;playerLevel&quot;: &quot;117&quot;,\r\n          &quot;pNhlOnlineGameType&quot;: &quot;5&quot;,\r\n          &quot;position&quot;: &quot;defenseMen&quot;,\r\n          &quot;posSorted&quot;: &quot;2&quot;,\r\n          &quot;ratingDefense&quot;: &quot;35.00&quot;,\r\n          &quot;ratingOffense&quot;: &quot;60.00&quot;,\r\n          &quot;ratingTeamplay&quot;: &quot;60.00&quot;,\r\n          &quot;score&quot;: &quot;3&quot;,\r\n          &quot;skassists&quot;: &quot;0&quot;,\r\n          &quot;skbs&quot;: &quot;0&quot;,\r\n          &quot;skdeflections&quot;: &quot;0&quot;,\r\n          &quot;skfol&quot;: &quot;0&quot;,\r\n          &quot;skfopct&quot;: &quot;0.00&quot;,\r\n          &quot;skfow&quot;: &quot;0&quot;,\r\n          &quot;skgiveaways&quot;: &quot;2&quot;,\r\n          &quot;skgoals&quot;: &quot;0&quot;,\r\n          &quot;skgwg&quot;: &quot;0&quot;,\r\n          &quot;skhits&quot;: &quot;0&quot;,\r\n          &quot;skinterceptions&quot;: &quot;6&quot;,\r\n          &quot;skpassattempts&quot;: &quot;13&quot;,\r\n          &quot;skpasses&quot;: &quot;11&quot;,\r\n          &quot;skpasspct&quot;: &quot;84.62&quot;,\r\n          &quot;skpenaltiesdrawn&quot;: &quot;0&quot;,\r\n          &quot;skpim&quot;: &quot;0&quot;,\r\n          &quot;skpkclearzone&quot;: &quot;0&quot;,\r\n          &quot;skplusmin&quot;: &quot;-5&quot;,\r\n          &quot;skpossession&quot;: &quot;93&quot;,\r\n          &quot;skppg&quot;: &quot;0&quot;,\r\n          &quot;sksaucerpasses&quot;: &quot;0&quot;,\r\n          &quot;skshg&quot;: &quot;0&quot;,\r\n          &quot;skshotattempts&quot;: &quot;1&quot;,\r\n          &quot;skshotonnetpct&quot;: &quot;100.00&quot;,\r\n          &quot;skshotpct&quot;: &quot;0.00&quot;,\r\n          &quot;skshots&quot;: &quot;1&quot;,\r\n          &quot;sktakeaways&quot;: &quot;2&quot;,\r\n          &quot;teamId&quot;: &quot;500&quot;,\r\n          &quot;teamSide&quot;: &quot;0&quot;,\r\n          &quot;toi&quot;: &quot;60&quot;,\r\n          &quot;toiseconds&quot;: &quot;3600&quot;,\r\n          &quot;playername&quot;: &quot;bostonsniper4t4&quot;\r\n        },\r\n        &quot;1004176504213&quot;: {\r\n          &quot;class&quot;: &quot;21&quot;,\r\n          &quot;glbrksavepct&quot;: &quot;0.00&quot;,\r\n          &quot;glbrksaves&quot;: &quot;0&quot;,\r\n          &quot;glbrkshots&quot;: &quot;0&quot;,\r\n          &quot;gldsaves&quot;: &quot;1&quot;,\r\n          &quot;glga&quot;: &quot;6&quot;,\r\n          &quot;glgaa&quot;: &quot;6.00&quot;,\r\n          &quot;glpensavepct&quot;: &quot;0.00&quot;,\r\n          &quot;glpensaves&quot;: &quot;0&quot;,\r\n          &quot;glpenshots&quot;: &quot;0&quot;,\r\n          &quot;glpkclearzone&quot;: &quot;0&quot;,\r\n          &quot;glpokechecks&quot;: &quot;0&quot;,\r\n          &quot;glsavepct&quot;: &quot;0.60&quot;,\r\n          &quot;glsaves&quot;: &quot;9&quot;,\r\n          &quot;glshots&quot;: &quot;15&quot;,\r\n          &quot;glsoperiods&quot;: &quot;0&quot;,\r\n          &quot;isGuest&quot;: &quot;1&quot;,\r\n          &quot;opponentClubId&quot;: &quot;79718&quot;,\r\n          &quot;opponentScore&quot;: &quot;6&quot;,\r\n          &quot;opponentTeamId&quot;: &quot;501&quot;,\r\n          &quot;player_dnf&quot;: &quot;0&quot;,\r\n          &quot;playerLevel&quot;: &quot;156&quot;,\r\n          &quot;pNhlOnlineGameType&quot;: &quot;5&quot;,\r\n          &quot;position&quot;: &quot;goalie&quot;,\r\n          &quot;posSorted&quot;: &quot;0&quot;,\r\n          &quot;ratingDefense&quot;: &quot;70.00&quot;,\r\n          &quot;ratingOffense&quot;: &quot;30.00&quot;,\r\n          &quot;ratingTeamplay&quot;: &quot;45.00&quot;,\r\n          &quot;score&quot;: &quot;3&quot;,\r\n          &quot;skassists&quot;: &quot;0&quot;,\r\n          &quot;skbs&quot;: &quot;0&quot;,\r\n          &quot;skdeflections&quot;: &quot;0&quot;,\r\n          &quot;skfol&quot;: &quot;0&quot;,\r\n          &quot;skfopct&quot;: &quot;0.00&quot;,\r\n          &quot;skfow&quot;: &quot;0&quot;,\r\n          &quot;skgiveaways&quot;: &quot;0&quot;,\r\n          &quot;skgoals&quot;: &quot;0&quot;,\r\n          &quot;skgwg&quot;: &quot;0&quot;,\r\n          &quot;skhits&quot;: &quot;0&quot;,\r\n          &quot;skinterceptions&quot;: &quot;0&quot;,\r\n          &quot;skpassattempts&quot;: &quot;0&quot;,\r\n          &quot;skpasses&quot;: &quot;0&quot;,\r\n          &quot;skpasspct&quot;: &quot;0.00&quot;,\r\n          &quot;skpenaltiesdrawn&quot;: &quot;0&quot;,\r\n          &quot;skpim&quot;: &quot;0&quot;,\r\n          &quot;skpkclearzone&quot;: &quot;0&quot;,\r\n          &quot;skplusmin&quot;: &quot;0&quot;,\r\n          &quot;skpossession&quot;: &quot;0&quot;,\r\n          &quot;skppg&quot;: &quot;0&quot;,\r\n          &quot;sksaucerpasses&quot;: &quot;0&quot;,\r\n          &quot;skshg&quot;: &quot;0&quot;,\r\n          &quot;skshotattempts&quot;: &quot;0&quot;,\r\n          &quot;skshotonnetpct&quot;: &quot;0.00&quot;,\r\n          &quot;skshotpct&quot;: &quot;0.00&quot;,\r\n          &quot;skshots&quot;: &quot;0&quot;,\r\n          &quot;sktakeaways&quot;: &quot;0&quot;,\r\n          &quot;teamId&quot;: &quot;500&quot;,\r\n          &quot;teamSide&quot;: &quot;0&quot;,\r\n          &quot;toi&quot;: &quot;60&quot;,\r\n          &quot;toiseconds&quot;: &quot;3600&quot;,\r\n          &quot;playername&quot;: &quot;HABSFAN972651&quot;\r\n        }\r\n      },\r\n      &quot;79718&quot;: {\r\n        &quot;273323046&quot;: {\r\n          &quot;class&quot;: &quot;2&quot;,\r\n          &quot;glbrksavepct&quot;: &quot;0.00&quot;,\r\n          &quot;glbrksaves&quot;: &quot;0&quot;,\r\n          &quot;glbrkshots&quot;: &quot;0&quot;,\r\n          &quot;gldsaves&quot;: &quot;0&quot;,\r\n          &quot;glga&quot;: &quot;0&quot;,\r\n          &quot;glgaa&quot;: &quot;0.00&quot;,\r\n          &quot;glpensavepct&quot;: &quot;0.00&quot;,\r\n          &quot;glpensaves&quot;: &quot;0&quot;,\r\n          &quot;glpenshots&quot;: &quot;0&quot;,\r\n          &quot;glpkclearzone&quot;: &quot;0&quot;,\r\n          &quot;glpokechecks&quot;: &quot;0&quot;,\r\n          &quot;glsavepct&quot;: &quot;0.00&quot;,\r\n          &quot;glsaves&quot;: &quot;0&quot;,\r\n          &quot;glshots&quot;: &quot;0&quot;,\r\n          &quot;glsoperiods&quot;: &quot;0&quot;,\r\n          &quot;isGuest&quot;: &quot;1&quot;,\r\n          &quot;opponentClubId&quot;: &quot;145078&quot;,\r\n          &quot;opponentScore&quot;: &quot;3&quot;,\r\n          &quot;opponentTeamId&quot;: &quot;500&quot;,\r\n          &quot;player_dnf&quot;: &quot;0&quot;,\r\n          &quot;playerLevel&quot;: &quot;140&quot;,\r\n          &quot;pNhlOnlineGameType&quot;: &quot;5&quot;,\r\n          &quot;position&quot;: &quot;rightWing&quot;,\r\n          &quot;posSorted&quot;: &quot;3&quot;,\r\n          &quot;ratingDefense&quot;: &quot;95.00&quot;,\r\n          &quot;ratingOffense&quot;: &quot;100.00&quot;,\r\n          &quot;ratingTeamplay&quot;: &quot;30.00&quot;,\r\n          &quot;score&quot;: &quot;6&quot;,\r\n          &quot;skassists&quot;: &quot;3&quot;,\r\n          &quot;skbs&quot;: &quot;0&quot;,\r\n          &quot;skdeflections&quot;: &quot;0&quot;,\r\n          &quot;skfol&quot;: &quot;0&quot;,\r\n          &quot;skfopct&quot;: &quot;0.00&quot;,\r\n          &quot;skfow&quot;: &quot;0&quot;,\r\n          &quot;skgiveaways&quot;: &quot;2&quot;,\r\n          &quot;skgoals&quot;: &quot;1&quot;,\r\n          &quot;skgwg&quot;: &quot;0&quot;,\r\n          &quot;skhits&quot;: &quot;0&quot;,\r\n          &quot;skinterceptions&quot;: &quot;7&quot;,\r\n          &quot;skpassattempts&quot;: &quot;16&quot;,\r\n          &quot;skpasses&quot;: &quot;12&quot;,\r\n          &quot;skpasspct&quot;: &quot;75.00&quot;,\r\n          &quot;skpenaltiesdrawn&quot;: &quot;0&quot;,\r\n          &quot;skpim&quot;: &quot;2&quot;,\r\n          &quot;skpkclearzone&quot;: &quot;3&quot;,\r\n          &quot;skplusmin&quot;: &quot;5&quot;,\r\n          &quot;skpossession&quot;: &quot;241&quot;,\r\n          &quot;skppg&quot;: &quot;0&quot;,\r\n          &quot;sksaucerpasses&quot;: &quot;1&quot;,\r\n          &quot;skshg&quot;: &quot;0&quot;,\r\n          &quot;skshotattempts&quot;: &quot;3&quot;,\r\n          &quot;skshotonnetpct&quot;: &quot;100.00&quot;,\r\n          &quot;skshotpct&quot;: &quot;33.33&quot;,\r\n          &quot;skshots&quot;: &quot;3&quot;,\r\n          &quot;sktakeaways&quot;: &quot;6&quot;,\r\n          &quot;teamId&quot;: &quot;501&quot;,\r\n          &quot;teamSide&quot;: &quot;1&quot;,\r\n          &quot;toi&quot;: &quot;59&quot;,\r\n          &quot;toiseconds&quot;: &quot;3567&quot;,\r\n          &quot;playername&quot;: &quot;Gronk x L87L&quot;\r\n        },\r\n        &quot;288926878&quot;: {\r\n          &quot;class&quot;: &quot;2&quot;,\r\n          &quot;glbrksavepct&quot;: &quot;0.00&quot;,\r\n          &quot;glbrksaves&quot;: &quot;0&quot;,\r\n          &quot;glbrkshots&quot;: &quot;0&quot;,\r\n          &quot;gldsaves&quot;: &quot;0&quot;,\r\n          &quot;glga&quot;: &quot;0&quot;,\r\n          &quot;glgaa&quot;: &quot;0.00&quot;,\r\n          &quot;glpensavepct&quot;: &quot;0.00&quot;,\r\n          &quot;glpensaves&quot;: &quot;0&quot;,\r\n          &quot;glpenshots&quot;: &quot;0&quot;,\r\n          &quot;glpkclearzone&quot;: &quot;0&quot;,\r\n          &quot;glpokechecks&quot;: &quot;0&quot;,\r\n          &quot;glsavepct&quot;: &quot;0.00&quot;,\r\n          &quot;glsaves&quot;: &quot;0&quot;,\r\n          &quot;glshots&quot;: &quot;0&quot;,\r\n          &quot;glsoperiods&quot;: &quot;0&quot;,\r\n          &quot;isGuest&quot;: &quot;1&quot;,\r\n          &quot;opponentClubId&quot;: &quot;145078&quot;,\r\n          &quot;opponentScore&quot;: &quot;3&quot;,\r\n          &quot;opponentTeamId&quot;: &quot;500&quot;,\r\n          &quot;player_dnf&quot;: &quot;0&quot;,\r\n          &quot;playerLevel&quot;: &quot;107&quot;,\r\n          &quot;pNhlOnlineGameType&quot;: &quot;5&quot;,\r\n          &quot;position&quot;: &quot;leftWing&quot;,\r\n          &quot;posSorted&quot;: &quot;4&quot;,\r\n          &quot;ratingDefense&quot;: &quot;65.00&quot;,\r\n          &quot;ratingOffense&quot;: &quot;100.00&quot;,\r\n          &quot;ratingTeamplay&quot;: &quot;55.00&quot;,\r\n          &quot;score&quot;: &quot;6&quot;,\r\n          &quot;skassists&quot;: &quot;0&quot;,\r\n          &quot;skbs&quot;: &quot;2&quot;,\r\n          &quot;skdeflections&quot;: &quot;0&quot;,\r\n          &quot;skfol&quot;: &quot;0&quot;,\r\n          &quot;skfopct&quot;: &quot;0.00&quot;,\r\n          &quot;skfow&quot;: &quot;0&quot;,\r\n          &quot;skgiveaways&quot;: &quot;5&quot;,\r\n          &quot;skgoals&quot;: &quot;3&quot;,\r\n          &quot;skgwg&quot;: &quot;0&quot;,\r\n          &quot;skhits&quot;: &quot;1&quot;,\r\n          &quot;skinterceptions&quot;: &quot;1&quot;,\r\n          &quot;skpassattempts&quot;: &quot;11&quot;,\r\n          &quot;skpasses&quot;: &quot;8&quot;,\r\n          &quot;skpasspct&quot;: &quot;72.73&quot;,\r\n          &quot;skpenaltiesdrawn&quot;: &quot;0&quot;,\r\n          &quot;skpim&quot;: &quot;0&quot;,\r\n          &quot;skpkclearzone&quot;: &quot;0&quot;,\r\n          &quot;skplusmin&quot;: &quot;5&quot;,\r\n          &quot;skpossession&quot;: &quot;183&quot;,\r\n          &quot;skppg&quot;: &quot;0&quot;,\r\n          &quot;sksaucerpasses&quot;: &quot;0&quot;,\r\n          &quot;skshg&quot;: &quot;0&quot;,\r\n          &quot;skshotattempts&quot;: &quot;8&quot;,\r\n          &quot;skshotonnetpct&quot;: &quot;75.00&quot;,\r\n          &quot;skshotpct&quot;: &quot;50.00&quot;,\r\n          &quot;skshots&quot;: &quot;6&quot;,\r\n          &quot;sktakeaways&quot;: &quot;1&quot;,\r\n          &quot;teamId&quot;: &quot;501&quot;,\r\n          &quot;teamSide&quot;: &quot;1&quot;,\r\n          &quot;toi&quot;: &quot;60&quot;,\r\n          &quot;toiseconds&quot;: &quot;3600&quot;,\r\n          &quot;playername&quot;: &quot;xxJONx&quot;\r\n        },\r\n        &quot;515447555&quot;: {\r\n          &quot;class&quot;: &quot;15&quot;,\r\n          &quot;glbrksavepct&quot;: &quot;0.00&quot;,\r\n          &quot;glbrksaves&quot;: &quot;0&quot;,\r\n          &quot;glbrkshots&quot;: &quot;0&quot;,\r\n          &quot;gldsaves&quot;: &quot;0&quot;,\r\n          &quot;glga&quot;: &quot;0&quot;,\r\n          &quot;glgaa&quot;: &quot;0.00&quot;,\r\n          &quot;glpensavepct&quot;: &quot;0.00&quot;,\r\n          &quot;glpensaves&quot;: &quot;0&quot;,\r\n          &quot;glpenshots&quot;: &quot;0&quot;,\r\n          &quot;glpkclearzone&quot;: &quot;0&quot;,\r\n          &quot;glpokechecks&quot;: &quot;0&quot;,\r\n          &quot;glsavepct&quot;: &quot;0.00&quot;,\r\n          &quot;glsaves&quot;: &quot;0&quot;,\r\n          &quot;glshots&quot;: &quot;0&quot;,\r\n          &quot;glsoperiods&quot;: &quot;0&quot;,\r\n          &quot;isGuest&quot;: &quot;1&quot;,\r\n          &quot;opponentClubId&quot;: &quot;145078&quot;,\r\n          &quot;opponentScore&quot;: &quot;3&quot;,\r\n          &quot;opponentTeamId&quot;: &quot;500&quot;,\r\n          &quot;player_dnf&quot;: &quot;0&quot;,\r\n          &quot;playerLevel&quot;: &quot;125&quot;,\r\n          &quot;pNhlOnlineGameType&quot;: &quot;5&quot;,\r\n          &quot;position&quot;: &quot;defenseMen&quot;,\r\n          &quot;posSorted&quot;: &quot;2&quot;,\r\n          &quot;ratingDefense&quot;: &quot;70.00&quot;,\r\n          &quot;ratingOffense&quot;: &quot;85.00&quot;,\r\n          &quot;ratingTeamplay&quot;: &quot;30.00&quot;,\r\n          &quot;score&quot;: &quot;6&quot;,\r\n          &quot;skassists&quot;: &quot;1&quot;,\r\n          &quot;skbs&quot;: &quot;0&quot;,\r\n          &quot;skdeflections&quot;: &quot;0&quot;,\r\n          &quot;skfol&quot;: &quot;0&quot;,\r\n          &quot;skfopct&quot;: &quot;0.00&quot;,\r\n          &quot;skfow&quot;: &quot;0&quot;,\r\n          &quot;skgiveaways&quot;: &quot;11&quot;,\r\n          &quot;skgoals&quot;: &quot;1&quot;,\r\n          &quot;skgwg&quot;: &quot;0&quot;,\r\n          &quot;skhits&quot;: &quot;6&quot;,\r\n          &quot;skinterceptions&quot;: &quot;4&quot;,\r\n          &quot;skpassattempts&quot;: &quot;9&quot;,\r\n          &quot;skpasses&quot;: &quot;5&quot;,\r\n          &quot;skpasspct&quot;: &quot;55.56&quot;,\r\n          &quot;skpenaltiesdrawn&quot;: &quot;0&quot;,\r\n          &quot;skpim&quot;: &quot;6&quot;,\r\n          &quot;skpkclearzone&quot;: &quot;0&quot;,\r\n          &quot;skplusmin&quot;: &quot;5&quot;,\r\n          &quot;skpossession&quot;: &quot;212&quot;,\r\n          &quot;skppg&quot;: &quot;0&quot;,\r\n          &quot;sksaucerpasses&quot;: &quot;1&quot;,\r\n          &quot;skshg&quot;: &quot;0&quot;,\r\n          &quot;skshotattempts&quot;: &quot;2&quot;,\r\n          &quot;skshotonnetpct&quot;: &quot;50.00&quot;,\r\n          &quot;skshotpct&quot;: &quot;100.00&quot;,\r\n          &quot;skshots&quot;: &quot;1&quot;,\r\n          &quot;sktakeaways&quot;: &quot;2&quot;,\r\n          &quot;teamId&quot;: &quot;501&quot;,\r\n          &quot;teamSide&quot;: &quot;1&quot;,\r\n          &quot;toi&quot;: &quot;57&quot;,\r\n          &quot;toiseconds&quot;: &quot;3404&quot;,\r\n          &quot;playername&quot;: &quot;vShotsy&quot;\r\n        },\r\n        &quot;800554172&quot;: {\r\n          &quot;class&quot;: &quot;15&quot;,\r\n          &quot;glbrksavepct&quot;: &quot;0.00&quot;,\r\n          &quot;glbrksaves&quot;: &quot;0&quot;,\r\n          &quot;glbrkshots&quot;: &quot;0&quot;,\r\n          &quot;gldsaves&quot;: &quot;0&quot;,\r\n          &quot;glga&quot;: &quot;0&quot;,\r\n          &quot;glgaa&quot;: &quot;0.00&quot;,\r\n          &quot;glpensavepct&quot;: &quot;0.00&quot;,\r\n          &quot;glpensaves&quot;: &quot;0&quot;,\r\n          &quot;glpenshots&quot;: &quot;0&quot;,\r\n          &quot;glpkclearzone&quot;: &quot;0&quot;,\r\n          &quot;glpokechecks&quot;: &quot;0&quot;,\r\n          &quot;glsavepct&quot;: &quot;0.00&quot;,\r\n          &quot;glsaves&quot;: &quot;0&quot;,\r\n          &quot;glshots&quot;: &quot;0&quot;,\r\n          &quot;glsoperiods&quot;: &quot;0&quot;,\r\n          &quot;isGuest&quot;: &quot;1&quot;,\r\n          &quot;opponentClubId&quot;: &quot;145078&quot;,\r\n          &quot;opponentScore&quot;: &quot;3&quot;,\r\n          &quot;opponentTeamId&quot;: &quot;500&quot;,\r\n          &quot;player_dnf&quot;: &quot;0&quot;,\r\n          &quot;playerLevel&quot;: &quot;214&quot;,\r\n          &quot;pNhlOnlineGameType&quot;: &quot;5&quot;,\r\n          &quot;position&quot;: &quot;defenseMen&quot;,\r\n          &quot;posSorted&quot;: &quot;1&quot;,\r\n          &quot;ratingDefense&quot;: &quot;90.00&quot;,\r\n          &quot;ratingOffense&quot;: &quot;95.00&quot;,\r\n          &quot;ratingTeamplay&quot;: &quot;70.00&quot;,\r\n          &quot;score&quot;: &quot;6&quot;,\r\n          &quot;skassists&quot;: &quot;2&quot;,\r\n          &quot;skbs&quot;: &quot;1&quot;,\r\n          &quot;skdeflections&quot;: &quot;0&quot;,\r\n          &quot;skfol&quot;: &quot;0&quot;,\r\n          &quot;skfopct&quot;: &quot;0.00&quot;,\r\n          &quot;skfow&quot;: &quot;0&quot;,\r\n          &quot;skgiveaways&quot;: &quot;10&quot;,\r\n          &quot;skgoals&quot;: &quot;1&quot;,\r\n          &quot;skgwg&quot;: &quot;0&quot;,\r\n          &quot;skhits&quot;: &quot;6&quot;,\r\n          &quot;skinterceptions&quot;: &quot;4&quot;,\r\n          &quot;skpassattempts&quot;: &quot;26&quot;,\r\n          &quot;skpasses&quot;: &quot;20&quot;,\r\n          &quot;skpasspct&quot;: &quot;76.92&quot;,\r\n          &quot;skpenaltiesdrawn&quot;: &quot;0&quot;,\r\n          &quot;skpim&quot;: &quot;2&quot;,\r\n          &quot;skpkclearzone&quot;: &quot;3&quot;,\r\n          &quot;skplusmin&quot;: &quot;5&quot;,\r\n          &quot;skpossession&quot;: &quot;221&quot;,\r\n          &quot;skppg&quot;: &quot;0&quot;,\r\n          &quot;sksaucerpasses&quot;: &quot;2&quot;,\r\n          &quot;skshg&quot;: &quot;0&quot;,\r\n          &quot;skshotattempts&quot;: &quot;1&quot;,\r\n          &quot;skshotonnetpct&quot;: &quot;100.00&quot;,\r\n          &quot;skshotpct&quot;: &quot;100.00&quot;,\r\n          &quot;skshots&quot;: &quot;1&quot;,\r\n          &quot;sktakeaways&quot;: &quot;1&quot;,\r\n          &quot;teamId&quot;: &quot;501&quot;,\r\n          &quot;teamSide&quot;: &quot;1&quot;,\r\n          &quot;toi&quot;: &quot;58&quot;,\r\n          &quot;toiseconds&quot;: &quot;3481&quot;,\r\n          &quot;playername&quot;: &quot;Martinez1225&quot;\r\n        },\r\n        &quot;858674479&quot;: {\r\n          &quot;class&quot;: &quot;21&quot;,\r\n          &quot;glbrksavepct&quot;: &quot;0.00&quot;,\r\n          &quot;glbrksaves&quot;: &quot;0&quot;,\r\n          &quot;glbrkshots&quot;: &quot;1&quot;,\r\n          &quot;gldsaves&quot;: &quot;0&quot;,\r\n          &quot;glga&quot;: &quot;3&quot;,\r\n          &quot;glgaa&quot;: &quot;3.00&quot;,\r\n          &quot;glpensavepct&quot;: &quot;0.00&quot;,\r\n          &quot;glpensaves&quot;: &quot;0&quot;,\r\n          &quot;glpenshots&quot;: &quot;0&quot;,\r\n          &quot;glpkclearzone&quot;: &quot;0&quot;,\r\n          &quot;glpokechecks&quot;: &quot;0&quot;,\r\n          &quot;glsavepct&quot;: &quot;0.83&quot;,\r\n          &quot;glsaves&quot;: &quot;15&quot;,\r\n          &quot;glshots&quot;: &quot;18&quot;,\r\n          &quot;glsoperiods&quot;: &quot;0&quot;,\r\n          &quot;isGuest&quot;: &quot;0&quot;,\r\n          &quot;opponentClubId&quot;: &quot;145078&quot;,\r\n          &quot;opponentScore&quot;: &quot;3&quot;,\r\n          &quot;opponentTeamId&quot;: &quot;500&quot;,\r\n          &quot;player_dnf&quot;: &quot;0&quot;,\r\n          &quot;playerLevel&quot;: &quot;91&quot;,\r\n          &quot;pNhlOnlineGameType&quot;: &quot;5&quot;,\r\n          &quot;position&quot;: &quot;goalie&quot;,\r\n          &quot;posSorted&quot;: &quot;0&quot;,\r\n          &quot;ratingDefense&quot;: &quot;75.00&quot;,\r\n          &quot;ratingOffense&quot;: &quot;75.00&quot;,\r\n          &quot;ratingTeamplay&quot;: &quot;60.00&quot;,\r\n          &quot;score&quot;: &quot;6&quot;,\r\n          &quot;skassists&quot;: &quot;0&quot;,\r\n          &quot;skbs&quot;: &quot;0&quot;,\r\n          &quot;skdeflections&quot;: &quot;0&quot;,\r\n          &quot;skfol&quot;: &quot;0&quot;,\r\n          &quot;skfopct&quot;: &quot;0.00&quot;,\r\n          &quot;skfow&quot;: &quot;0&quot;,\r\n          &quot;skgiveaways&quot;: &quot;0&quot;,\r\n          &quot;skgoals&quot;: &quot;0&quot;,\r\n          &quot;skgwg&quot;: &quot;0&quot;,\r\n          &quot;skhits&quot;: &quot;0&quot;,\r\n          &quot;skinterceptions&quot;: &quot;0&quot;,\r\n          &quot;skpassattempts&quot;: &quot;0&quot;,\r\n          &quot;skpasses&quot;: &quot;0&quot;,\r\n          &quot;skpasspct&quot;: &quot;0.00&quot;,\r\n          &quot;skpenaltiesdrawn&quot;: &quot;0&quot;,\r\n          &quot;skpim&quot;: &quot;0&quot;,\r\n          &quot;skpkclearzone&quot;: &quot;0&quot;,\r\n          &quot;skplusmin&quot;: &quot;0&quot;,\r\n          &quot;skpossession&quot;: &quot;0&quot;,\r\n          &quot;skppg&quot;: &quot;0&quot;,\r\n          &quot;sksaucerpasses&quot;: &quot;0&quot;,\r\n          &quot;skshg&quot;: &quot;0&quot;,\r\n          &quot;skshotattempts&quot;: &quot;0&quot;,\r\n          &quot;skshotonnetpct&quot;: &quot;0.00&quot;,\r\n          &quot;skshotpct&quot;: &quot;0.00&quot;,\r\n          &quot;skshots&quot;: &quot;0&quot;,\r\n          &quot;sktakeaways&quot;: &quot;0&quot;,\r\n          &quot;teamId&quot;: &quot;501&quot;,\r\n          &quot;teamSide&quot;: &quot;1&quot;,\r\n          &quot;toi&quot;: &quot;60&quot;,\r\n          &quot;toiseconds&quot;: &quot;3600&quot;,\r\n          &quot;playername&quot;: &quot;MacShrimp&quot;\r\n        },\r\n        &quot;1183100664&quot;: {\r\n          &quot;class&quot;: &quot;1&quot;,\r\n          &quot;glbrksavepct&quot;: &quot;0.00&quot;,\r\n          &quot;glbrksaves&quot;: &quot;0&quot;,\r\n          &quot;glbrkshots&quot;: &quot;0&quot;,\r\n          &quot;gldsaves&quot;: &quot;0&quot;,\r\n          &quot;glga&quot;: &quot;0&quot;,\r\n          &quot;glgaa&quot;: &quot;0.00&quot;,\r\n          &quot;glpensavepct&quot;: &quot;0.00&quot;,\r\n          &quot;glpensaves&quot;: &quot;0&quot;,\r\n          &quot;glpenshots&quot;: &quot;0&quot;,\r\n          &quot;glpkclearzone&quot;: &quot;0&quot;,\r\n          &quot;glpokechecks&quot;: &quot;0&quot;,\r\n          &quot;glsavepct&quot;: &quot;0.00&quot;,\r\n          &quot;glsaves&quot;: &quot;0&quot;,\r\n          &quot;glshots&quot;: &quot;0&quot;,\r\n          &quot;glsoperiods&quot;: &quot;0&quot;,\r\n          &quot;isGuest&quot;: &quot;0&quot;,\r\n          &quot;opponentClubId&quot;: &quot;145078&quot;,\r\n          &quot;opponentScore&quot;: &quot;3&quot;,\r\n          &quot;opponentTeamId&quot;: &quot;500&quot;,\r\n          &quot;player_dnf&quot;: &quot;0&quot;,\r\n          &quot;playerLevel&quot;: &quot;135&quot;,\r\n          &quot;pNhlOnlineGameType&quot;: &quot;5&quot;,\r\n          &quot;position&quot;: &quot;center&quot;,\r\n          &quot;posSorted&quot;: &quot;5&quot;,\r\n          &quot;ratingDefense&quot;: &quot;100.00&quot;,\r\n          &quot;ratingOffense&quot;: &quot;80.00&quot;,\r\n          &quot;ratingTeamplay&quot;: &quot;65.00&quot;,\r\n          &quot;score&quot;: &quot;6&quot;,\r\n          &quot;skassists&quot;: &quot;2&quot;,\r\n          &quot;skbs&quot;: &quot;0&quot;,\r\n          &quot;skdeflections&quot;: &quot;0&quot;,\r\n          &quot;skfol&quot;: &quot;18&quot;,\r\n          &quot;skfopct&quot;: &quot;43.75&quot;,\r\n          &quot;skfow&quot;: &quot;14&quot;,\r\n          &quot;skgiveaways&quot;: &quot;1&quot;,\r\n          &quot;skgoals&quot;: &quot;0&quot;,\r\n          &quot;skgwg&quot;: &quot;0&quot;,\r\n          &quot;skhits&quot;: &quot;1&quot;,\r\n          &quot;skinterceptions&quot;: &quot;2&quot;,\r\n          &quot;skpassattempts&quot;: &quot;16&quot;,\r\n          &quot;skpasses&quot;: &quot;12&quot;,\r\n          &quot;skpasspct&quot;: &quot;75.00&quot;,\r\n          &quot;skpenaltiesdrawn&quot;: &quot;0&quot;,\r\n          &quot;skpim&quot;: &quot;0&quot;,\r\n          &quot;skpkclearzone&quot;: &quot;3&quot;,\r\n          &quot;skplusmin&quot;: &quot;5&quot;,\r\n          &quot;skpossession&quot;: &quot;103&quot;,\r\n          &quot;skppg&quot;: &quot;0&quot;,\r\n          &quot;sksaucerpasses&quot;: &quot;0&quot;,\r\n          &quot;skshg&quot;: &quot;0&quot;,\r\n          &quot;skshotattempts&quot;: &quot;1&quot;,\r\n          &quot;skshotonnetpct&quot;: &quot;200.00&quot;,\r\n          &quot;skshotpct&quot;: &quot;0.00&quot;,\r\n          &quot;skshots&quot;: &quot;2&quot;,\r\n          &quot;sktakeaways&quot;: &quot;2&quot;,\r\n          &quot;teamId&quot;: &quot;501&quot;,\r\n          &quot;teamSide&quot;: &quot;1&quot;,\r\n          &quot;toi&quot;: &quot;60&quot;,\r\n          &quot;toiseconds&quot;: &quot;3600&quot;,\r\n          &quot;playername&quot;: &quot;Rakkarak&quot;\r\n        }\r\n      }\r\n    }\r\n  }\r\n]\r\n```\r\n\r\nthis is what i would like the output to be, with some of the values being dynamic.\r\n```\r\n                    [\r\n                      {\r\n                        &quot;matchId&quot;: &quot;2234705530498&quot;,\r\n                        &quot;timestamp&quot;: 1661657182,\r\n                        &quot;clubs&quot;: {\r\n    this will be dynamic &quot;79718&quot;: {\r\n                            &quot;passa&quot;: &quot;79&quot;,\r\n                            &quot;passc&quot;: &quot;58&quot;,\r\n                            &quot;ppg&quot;: &quot;0&quot;,\r\n                            &quot;ppo&quot;: &quot;0&quot;,\r\n                            &quot;shots&quot;: &quot;15&quot;,\r\n                            &quot;toa&quot;: &quot;252&quot;,\r\n                            &quot;details&quot;: {\r\n                            &quot;name&quot;: &quot;NZHL Memphis Make A Wish&quot;,\r\n                            &quot;clubId&quot;: 79718,\r\n                            }\r\n                          },\r\n                        },\r\n                        &quot;players&quot;: {\r\n    this will be dynamic &quot;145078&quot;: {\r\n                            &quot;169580763&quot;: {\r\n                            &quot;glbrksavepct&quot;: &quot;0.00&quot;,\r\n                            &quot;glbrksaves&quot;: &quot;0&quot;,\r\n                            &quot;glbrkshots&quot;: &quot;0&quot;,\r\n                            &quot;gldsaves&quot;: &quot;0&quot;,\r\n                            &quot;glga&quot;: &quot;0&quot;,\r\n                            &quot;glgaa&quot;: &quot;0.00&quot;,\r\n                            &quot;glpensavepct&quot;: &quot;0.00&quot;,\r\n                            &quot;glpensaves&quot;: &quot;0&quot;,\r\n                            &quot;glpenshots&quot;: &quot;0&quot;,\r\n                            &quot;glpkclearzone&quot;: &quot;0&quot;,\r\n                            &quot;glpokechecks&quot;: &quot;0&quot;,\r\n                            &quot;glsavepct&quot;: &quot;0.00&quot;,\r\n                            &quot;glsaves&quot;: &quot;0&quot;,\r\n                            &quot;glshots&quot;: &quot;0&quot;,\r\n                            &quot;glsoperiods&quot;: &quot;0&quot;,\r\n                            &quot;opponentClubId&quot;: &quot;79718&quot;,\r\n                            &quot;position&quot;: &quot;rightWing&quot;,\r\n                            &quot;posSorted&quot;: &quot;3&quot;,\r\n                            &quot;ratingDefense&quot;: &quot;55.00&quot;,\r\n                            &quot;ratingOffense&quot;: &quot;85.00&quot;,\r\n                            &quot;ratingTeamplay&quot;: &quot;70.00&quot;,\r\n                            &quot;skassists&quot;: &quot;0&quot;,\r\n                            &quot;skbs&quot;: &quot;0&quot;,\r\n                            &quot;skdeflections&quot;: &quot;0&quot;,\r\n                            &quot;skfol&quot;: &quot;0&quot;,\r\n                            &quot;skfopct&quot;: &quot;0.00&quot;,\r\n                            &quot;skfow&quot;: &quot;0&quot;,\r\n                            &quot;skgiveaways&quot;: &quot;4&quot;,\r\n                            &quot;skgoals&quot;: &quot;2&quot;,\r\n                            &quot;skgwg&quot;: &quot;0&quot;,\r\n                            &quot;skhits&quot;: &quot;1&quot;,\r\n                            &quot;skinterceptions&quot;: &quot;3&quot;,\r\n                            &quot;skpassattempts&quot;: &quot;11&quot;,\r\n                            &quot;skpasses&quot;: &quot;7&quot;,\r\n                            &quot;skpasspct&quot;: &quot;63.64&quot;,\r\n                            &quot;skpenaltiesdrawn&quot;: &quot;1&quot;,\r\n                            &quot;skpim&quot;: &quot;0&quot;,\r\n                            &quot;skpkclearzone&quot;: &quot;0&quot;,\r\n                            &quot;skplusmin&quot;: &quot;-5&quot;,\r\n                            &quot;skpossession&quot;: &quot;106&quot;,\r\n                            &quot;skppg&quot;: &quot;1&quot;,\r\n                            &quot;sksaucerpasses&quot;: &quot;0&quot;,\r\n                            &quot;skshg&quot;: &quot;0&quot;,\r\n                            &quot;skshotattempts&quot;: &quot;12&quot;,\r\n                            &quot;skshotonnetpct&quot;: &quot;66.67&quot;,\r\n                            &quot;skshotpct&quot;: &quot;25.00&quot;,\r\n                            &quot;skshots&quot;: &quot;8&quot;,\r\n                            &quot;sktakeaways&quot;: &quot;0&quot;,\r\n                            &quot;toiseconds&quot;: &quot;3600&quot;,\r\n                            &quot;playername&quot;: &quot;Ababo&quot;\r\n                            }\r\n                          }\r\n                        }\r\n                      }\r\n                    ]\r\n```\r\nI have been trying multiple configurations with map, select, flatten, with_entries, and many others with no luck. would appreciate any help to point me in the right direction.",
        "link": "https://stackoverflow.com/questions/73522843/using-jq-to-filter-nested-data-in-json",
        "title": "using jq to filter nested data in json"
    },
    {
        "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": 1661786088,
                "post_id": 73523980,
                "comment_id": 129848435,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1661760741,
                "creation_date": 1661760741,
                "answer_id": 73525878,
                "question_id": 73523980,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Neither the input sample nor your desired output is valid JSON. Arrays need surrounding brackets `[..., ...]`, and objects need surrounding curly braces `{&quot;...&quot;: ..., &quot;...&quot;: ...}`.\r\n\r\nAssuming your input and output documents are supposed to be an array and and an object, respectively, and their difference in the values of `.client` and `.instance_id` are just a mistake while composing this question, it looks like all you need is a conversion to and from an array of &quot;entries&quot; using `to_entries` and `from_entries`, and a `map` in between to convert the keys to strings. As this pattern is so common, a special builtin `with_entries` does the first and last conversion and the mapping at once: `with_entries`. The middle conversion can be achieved with `tostring` or `@text`, or even string interpolation `&quot;\\(...)&quot;`:\r\n\r\n~~~json\r\n[\r\n  {\r\n    &quot;client&quot;: &quot;i-0816dfac36b036002&quot;,\r\n    &quot;instance_id&quot;: &quot;i-0816dfac36b036002&quot;,\r\n    &quot;fstype&quot;: &quot;ext4&quot;,\r\n    &quot;device&quot;: &quot;nvme0n1p1&quot;\r\n  },\r\n  {\r\n    &quot;client&quot;: &quot;i-09ae6f92cda7fca83&quot;,\r\n    &quot;instance_id&quot;: &quot;i-09ae6f92cda7fca83&quot;,\r\n    &quot;fstype&quot;: &quot;ext4&quot;,\r\n    &quot;device&quot;: &quot;nvme0n1p1&quot;\r\n  }\r\n]\r\n~~~\r\n~~~sh\r\njq &#39;with_entries(.key |= tostring)&#39; \r\n~~~\r\n~~~json\r\n{\r\n  &quot;0&quot;: {\r\n    &quot;client&quot;: &quot;i-0816dfac36b036002&quot;,\r\n    &quot;instance_id&quot;: &quot;i-0816dfac36b036002&quot;,\r\n    &quot;fstype&quot;: &quot;ext4&quot;,\r\n    &quot;device&quot;: &quot;nvme0n1p1&quot;\r\n  },\r\n  &quot;1&quot;: {\r\n    &quot;client&quot;: &quot;i-09ae6f92cda7fca83&quot;,\r\n    &quot;instance_id&quot;: &quot;i-09ae6f92cda7fca83&quot;,\r\n    &quot;fstype&quot;: &quot;ext4&quot;,\r\n    &quot;device&quot;: &quot;nvme0n1p1&quot;\r\n  }\r\n}\r\n~~~\r\n[Demo](https://jqplay.org/s/UnAyEcPBHdt)\r\n\r\nIf you want some (numeric) pre-processing of the key numbers, do it inside the mapping and before the string conversion, e.g.\r\n~~~sh\r\njq &#39;with_entries(.key |= (. + 1 | tostring))&#39;\r\n~~~\r\n~~~json\r\n{\r\n  &quot;1&quot;: {\r\n    &quot;client&quot;: &quot;i-0816dfac36b036002&quot;,\r\n    &quot;instance_id&quot;: &quot;i-0816dfac36b036002&quot;,\r\n    &quot;fstype&quot;: &quot;ext4&quot;,\r\n    &quot;device&quot;: &quot;nvme0n1p1&quot;\r\n  },\r\n  &quot;2&quot;: {\r\n    &quot;client&quot;: &quot;i-09ae6f92cda7fca83&quot;,\r\n    &quot;instance_id&quot;: &quot;i-09ae6f92cda7fca83&quot;,\r\n    &quot;fstype&quot;: &quot;ext4&quot;,\r\n    &quot;device&quot;: &quot;nvme0n1p1&quot;\r\n  }\r\n}\r\n~~~\r\n[Demo](https://jqplay.org/s/1mv6Xi9G-Xi)",
                "title": "JSON: Add a unique key iterator for every json array object"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1661760741,
        "creation_date": 1661745411,
        "last_edit_date": 1661757775,
        "question_id": 73523980,
        "body_markdown": "Im trying to achieve the following transformation for a big json file. How do I do it using jq or any command line tools. \r\n\r\nInput\r\n```\r\n    {\r\n        &quot;client&quot;: &quot;i-0816dfac36b036002&quot;,\r\n        &quot;instance_id&quot;: &quot;i-0816dfac36b036002&quot;,\r\n        &quot;fstype&quot;: &quot;ext4&quot;,\r\n        &quot;device&quot;: &quot;nvme0n1p1&quot;\r\n    },\r\n    {\r\n        &quot;client&quot;: &quot;i-09ae6f92cda7fca83&quot;,\r\n        &quot;instance_id&quot;: &quot;i-09ae6f92cda7fca83&quot;,\r\n        &quot;fstype&quot;: &quot;ext4&quot;,\r\n        &quot;device&quot;: &quot;nvme0n1p1&quot;\r\n    }\r\n```\r\n\r\nOutput\r\n```\r\n&quot;1&quot;: {\r\n      &quot;client&quot;: &quot;i-00112fc0b535a9d2e&quot;,\r\n      &quot;instance_id&quot;: &quot;i-00112fc0b535a9d2e&quot;,\r\n      &quot;fstype&quot;: &quot;ext4&quot;,\r\n      &quot;device&quot;: &quot;nvme0n1p1&quot;\r\n   },\r\n&quot;2&quot;: {\r\n      &quot;client&quot;: &quot;i-0876600d6d3d72477&quot;,\r\n      &quot;instance_id&quot;: &quot;i-0876600d6d3d72477&quot;,\r\n      &quot;fstype&quot;: &quot;ext4&quot;,\r\n      &quot;device&quot;: &quot;nvme0n1p1&quot;\r\n   }\r\n```",
        "link": "https://stackoverflow.com/questions/73523980/json-add-a-unique-key-iterator-for-every-json-array-object",
        "title": "JSON: Add a unique key iterator for every json array object"
    },
    {
        "tags": [
            "if-statement",
            "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": 1661768710,
                "post_id": 73527302,
                "comment_id": 129842157,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 299613,
                    "reputation": 7252,
                    "user_id": 606294,
                    "user_type": "registered",
                    "accept_rate": 78,
                    "profile_image": "https://i.sstatic.net/po1YC.jpg?s=256",
                    "display_name": "Mad Dog Tannen",
                    "link": "https://stackoverflow.com/users/606294/mad-dog-tannen"
                },
                "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": 1661768846,
                "post_id": 73527302,
                "comment_id": 129842205,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1661771357,
                "last_edit_date": 1661771357,
                "creation_date": 1661769134,
                "answer_id": 73527484,
                "question_id": 73527302,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The idea is right, but you shouldn&#39;t be using `select` for this. The way select works is by evaluating the boolean expression provided inside `(..)` and returning the object, _if_ the expression evaluates to true and skip the object from being considered/printed on false.\r\n\r\nOn your code, for the object that evaluates to false, select is evaluated as `select(false)` which as explained above returns nothing - this is not evaluated to boolean false condition. i.e. the return value of select is _not_ a boolean value. \r\n\r\nTo use explicit boolean conditions, drop the select from expression and to summarise the result to a single value do something like below\r\n\r\n```none\r\nif ( [ .[] | .displayName == &quot;display&quot; ] | any ) then &quot;yes&quot; else &quot;no&quot; end\r\n```\r\n\r\n[Demo][1] on jqplay\r\n\r\nThe way this works, is `any` can evaluate an array of boolean values and produces true as output if any of the elements of the array are true. We collect the match condition results to the array and apply `any` on it. i.e. `[true, false]` evaluates to `true`, thereby printing `yes` _only_ once\r\n\r\n\r\n  [1]: https://jqplay.org/s/1vL0wvjURev",
                "title": "Print one result after combining multiple expression results using jq"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1661789811,
                "creation_date": 1661789811,
                "answer_id": 73531706,
                "question_id": 73527302,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "A concise solution is possible with `select`:\r\n\r\n    select( any(.displayName==&quot;display&quot;) ) | &quot;yes&quot; // &quot;no&quot;",
                "title": "Print one result after combining multiple expression results using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1661789811,
        "creation_date": 1661768211,
        "last_edit_date": 1661771683,
        "question_id": 73527302,
        "body_markdown": "I want to have the output of either true or false.\r\nI have this syntax\r\n\r\n```\r\n.[] | (if (select(.displayName==&quot;display&quot;)) then &quot;yes&quot; else &quot;no&quot; end)\r\n```\r\n\r\nThis is the json source\r\n\r\n```json\r\n[{&quot;displayName&quot;:&quot;display&quot;,&quot;message&quot;:&quot;bla bla&quot;}, {&quot;displayName&quot;:&quot;test&quot;,&quot;message&quot;:&quot;bla bla&quot;}]\r\n```\r\nI only need to query against the array and if the value im looking for exists in one of them I need the output to be &quot;yes&quot;, and if it doesnt a &quot;no&quot;. ***So a single output value is what I am looking for.***\r\n\r\nThis evaluates to `&quot;yes&quot;`, however, if the value display is not present in the json, it does not output `&quot;no&quot;`, its just empty. Can anyone tell me why?\r\n\r\n\r\n----------\r\n\r\n\r\nHere is a snippet to try: https://jqplay.org/s/WKcZh91hk8L",
        "link": "https://stackoverflow.com/questions/73527302/print-one-result-after-combining-multiple-expression-results-using-jq",
        "title": "Print one result after combining multiple expression results using jq"
    },
    {
        "tags": [
            "json",
            "bigdata",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1661777986,
                "last_edit_date": 1661777986,
                "creation_date": 1661776278,
                "answer_id": 73528846,
                "question_id": 73527768,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If the &quot;very large file&quot; fits into your memory, just decompose the array `.[]`, and create your objects as needed using iterations `{a, b: .b[]}`:\r\n~~~sh\r\njq -c &#39;.[] | {a, b: .b[]}&#39;\r\n~~~\r\n~~~json\r\n{&quot;a&quot;:4,&quot;b&quot;:1}\r\n{&quot;a&quot;:4,&quot;b&quot;:2}\r\n{&quot;a&quot;:4,&quot;b&quot;:3}\r\n{&quot;a&quot;:6,&quot;b&quot;:7}\r\n{&quot;a&quot;:6,&quot;b&quot;:8}\r\n{&quot;a&quot;:6,&quot;b&quot;:9}\r\n~~~\r\n[Demo](https://jqplay.org/s/bQ_EvDqF9tt)\r\n\r\n---\r\nIf not, but an array item alone would, use the `--stream` flag to read the file in parts, only consider the items level using `truncate_stream` with level `1`, re-compose the array items using `fromstream`, and create the final objects as above:\r\n~~~sh\r\njq --stream -cn &#39;fromstream(1 | truncate_stream(inputs)) | {a, b: .b[]}&#39;\r\n~~~\r\n~~~json\r\n{&quot;a&quot;:4,&quot;b&quot;:1}\r\n{&quot;a&quot;:4,&quot;b&quot;:2}\r\n{&quot;a&quot;:4,&quot;b&quot;:3}\r\n{&quot;a&quot;:6,&quot;b&quot;:7}\r\n{&quot;a&quot;:6,&quot;b&quot;:8}\r\n{&quot;a&quot;:6,&quot;b&quot;:9}\r\n~~~",
                "title": "How to explode/unwrap all documents using jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1661784555,
        "creation_date": 1661770759,
        "last_edit_date": 1661784555,
        "question_id": 73527768,
        "body_markdown": "I have a very large file that looks like this:\r\n\r\n    [\r\n      {a: 4, b: [1,2,3]},\r\n      {a: 6, b: [7,8,9]},\r\n    ]\r\n\r\nand I would like to transform it to\r\n\r\n    {a: 4, b: 1},\r\n    {a: 4, b: 2},\r\n    {a: 4, b: 3},\r\n    {a: 6, b: 7},\r\n    {a: 6, b: 8},\r\n    {a: 6, b: 9}\r\n\r\nusing [jq][1]. The filter `.[] | {a: .a, b: .b[]}` [would work][2] for a smaller set of input. Given the size of the file, I want to use `--streaming`. Anyone who could give a pointer on how to use streaming to solve this problem?\r\n\r\n  [1]: https://stedolan.github.io/jq/\r\n  [2]: https://jqplay.org/s/upWg1D6Vowx",
        "link": "https://stackoverflow.com/questions/73527768/how-to-explode-unwrap-all-documents-using-jq",
        "title": "How to explode/unwrap all documents using jq?"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1661790215,
                "post_id": 73531765,
                "comment_id": 129849876,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "reply_to_user": {
                    "account_id": 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": 1661790262,
                "post_id": 73531765,
                "comment_id": 129849901,
                "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": 1661790337,
                "post_id": 73531765,
                "comment_id": 129849931,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "reply_to_user": {
                    "account_id": 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": 1661790358,
                "post_id": 73531765,
                "comment_id": 129849937,
                "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": 1661790599,
                "post_id": 73531765,
                "comment_id": 129850035,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 19822133,
                    "reputation": 396,
                    "user_id": 14962409,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/17a5186099467688abed8d788014f255?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "inquisitivemongoose",
                    "link": "https://stackoverflow.com/users/14962409/inquisitivemongoose"
                },
                "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": 1661790656,
                "post_id": 73531765,
                "comment_id": 129850061,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "is_answered": false,
        "answer_count": 0,
        "score": 0,
        "last_activity_date": 1661790111,
        "creation_date": 1661790111,
        "question_id": 73531765,
        "body_markdown": "I am trying to add a field to the `data` variable. Initially,  it is \r\n```\r\n{ &quot;objects&quot;: [] }\r\n```\r\nI want to add another field called `objects_count` such that \r\n```\r\n{ &quot;objects&quot;: [], &quot;objects_count&quot;: 1 }\r\n```\r\n\r\nHere is what I have so far:\r\n```\r\necho $data\r\n    \r\ndata=$( $data | jq --argjson oc &quot;$objects_count&quot; &#39;. + {objects_count: $oc}&#39; )\r\n\r\necho $data\r\n```\r\nAnd its output:\r\n```\r\n{ &quot;objects&quot;: [] }\r\n\r\n./scripts.sh: line 42: {: command not found\r\n\r\n{ &quot;objects_count&quot;: 1 }\r\n```\r\nWhy is it not appending the field, and creating a new object instead?",
        "link": "https://stackoverflow.com/questions/73531765/add-a-field-to-an-existing-json-object-with-jq",
        "title": "Add a field to an existing JSON object with JQ"
    },
    {
        "tags": [
            "unix",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 7195850,
                    "reputation": 4762,
                    "user_id": 5494721,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/WHK5j.png?s=256",
                    "display_name": "OznOg",
                    "link": "https://stackoverflow.com/users/5494721/oznog"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1661791297,
                "post_id": 73531965,
                "comment_id": 129850287,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 4884728,
                    "reputation": 19,
                    "user_id": 3937509,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/a88bdabdfc2d90db12f753405ee2d9c2?s=256&d=identicon&r=PG",
                    "display_name": "habjo",
                    "link": "https://stackoverflow.com/users/3937509/habjo"
                },
                "reply_to_user": {
                    "account_id": 7195850,
                    "reputation": 4762,
                    "user_id": 5494721,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/WHK5j.png?s=256",
                    "display_name": "OznOg",
                    "link": "https://stackoverflow.com/users/5494721/oznog"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1661791514,
                "post_id": 73531965,
                "comment_id": 129850346,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1661792187,
                "creation_date": 1661792187,
                "answer_id": 73532171,
                "question_id": 73531965,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The generator provided to `any` already descends to `.topics[]` from where you cannot back-reference two levels higher. Use the `select` statement to filter beforehand (also note that booleans are not strings):\r\n~~~sh\r\njq &#39;map(select(.archived == false and any(.topics[]; . == &quot;stackoverflow&quot;)))&#39;\r\n~~~\r\n\r\n---\r\nYou should also be able to combine both calls to `jq` into one:\r\n~~~sh\r\njq -r &#39;.[] | select(.archived == false and any(.topics[]; . == &quot;stackoverflow&quot;)).name&#39;\r\n~~~\r\n\r\n",
                "title": "jq: how to check two conditions in the any filter?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1661792257,
        "creation_date": 1661791161,
        "last_edit_date": 1661792257,
        "question_id": 73531965,
        "body_markdown": "I have this line `jq &#39;map(select( any(.topics[]; . == &quot;stackoverflow&quot; )))&#39;`\r\n\r\nNow I want to modify it (I didn&#39;t write the original) to add another condition to the any function.\r\n\r\nSomething like this `jq &#39;map(select( any(.topics[]; . == &quot;stackoverflow&quot; and .archived == &quot;false&quot; )))&#39;`\r\n\r\nBut it gives me “Cannot index string with string “archived”&quot;.\r\n\r\nThe archive field is on the same level as the topics array (it&#39;s repo information from the github API).\r\n\r\nIt is part of a longer command, FYI:\r\n\r\n    repositoryNames=$(curl \\\r\n          -H &quot;Authorization: token $GITHUB_TOKEN&quot; \\\r\n          -H &quot;Accept: application/vnd.github.v3+json&quot; \\\r\n          &quot;https://api.github.com/orgs/organization/repos?per_page=100&amp;page=$i&quot; | \\\r\n        jq &#39;map(select(any(.topics[]; . == &quot;stackoverflow&quot;)))&#39; | \\\r\n        jq -r &#39;.[].name&#39;)",
        "link": "https://stackoverflow.com/questions/73531965/jq-how-to-check-two-conditions-in-the-any-filter",
        "title": "jq: how to check two conditions in the any filter?"
    },
    {
        "tags": [
            "arrays",
            "json",
            "jq",
            "flatten"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1661806239,
                "last_edit_date": 1661806239,
                "creation_date": 1661806103,
                "answer_id": 73534504,
                "question_id": 73534446,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Use `with_entries`, changing each value to the first element of itself:\r\n\r\n    jq &#39;with_entries(.value |= .[0])&#39; file.json",
                "title": "Convert json single-item arrays to objects using bash/jq"
            },
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1661807406,
                "creation_date": 1661807406,
                "answer_id": 73534683,
                "question_id": 73534446,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Short and sweet:\r\n\r\n     map_values(first)",
                "title": "Convert json single-item arrays to objects using bash/jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1661807406,
        "creation_date": 1661805717,
        "last_edit_date": 1661806265,
        "question_id": 73534446,
        "body_markdown": "Given the example JSON below:\r\n\r\n```\r\n{\r\n  &quot;account_number&quot;: [\r\n    &quot;123456&quot;\r\n  ],\r\n  &quot;account_name&quot;: [\r\n    &quot;name&quot;\r\n  ],\r\n  &quot;account_id&quot;: [\r\n    654321\r\n  ],\r\n  &quot;username&quot;: [\r\n    &quot;demo&quot;\r\n  ]\r\n}\r\n```\r\n\r\nI&#39;d like to get:\r\n\r\n```\r\n{\r\n  &quot;account_number&quot;: &quot;123456&quot;,\r\n  &quot;account_name&quot;: &quot;name&quot;,\r\n  &quot;account_id&quot;: 654321,\r\n  &quot;username&quot;: &quot;demo&quot;\r\n}\r\n```\r\n\r\nCurrently, I&#39;m brute forcing it with `| sed &#39;s/\\[//g&#39; | sed &#39;s/\\]//g&#39; | jq &#39;.&#39;` ... but of course, that&#39;s ugly and causes issues if any of the values contain `[` or `]`.\r\n\r\nI&#39;ve been unsuccessful with `jq`&#39;s `flatten` and other loops and mapping techniques like `| jq -s &#39;{Item:.[]} | .Item |add&#39;` to try and flatten the single-item arrays. Ideally, it would work where it would flatten arrays `[...]` to flat elements/objects `{...}`. Either way something better than replacing all occurrences of square brackets.",
        "link": "https://stackoverflow.com/questions/73534446/convert-json-single-item-arrays-to-objects-using-bash-jq",
        "title": "Convert json single-item arrays to objects using bash/jq"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1661872564,
                "last_edit_date": 1661872564,
                "creation_date": 1661835102,
                "answer_id": 73537288,
                "question_id": 73537190,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "One way:\r\n\r\n```\r\njq &#39;.data.all\r\n| .live.online as $online\r\n| {members}\r\n| .members |= map( select(.id | IN($online[]) // null) )\r\n&#39; data.json\r\n```\r\n",
                "title": "How to select items in JQ based on values in array"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1663579133,
                "last_edit_date": 1663579133,
                "creation_date": 1663577814,
                "answer_id": 73770880,
                "question_id": 73537190,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s a solution that should be fairly easy to understand:\r\n\r\n```\r\n.data.all\r\n| .live.online as $online\r\n| { members: .members | map(select([.id] | inside($online))) }\r\n```\r\n\r\nOutput:\r\n\r\n```\r\n{\r\n  &quot;members&quot;: [\r\n    {\r\n      &quot;id&quot;: 10,\r\n      &quot;name&quot;: &quot;First&quot;\r\n    },\r\n    {\r\n      &quot;id&quot;: 14,\r\n      &quot;name&quot;: &quot;Third&quot;\r\n    }\r\n  ]\r\n}\r\n```\r\n\r\nAnd if you need more flexibility how your ids are matched:\r\n\r\n```\r\n.data.all\r\n| .live.online as $online\r\n| { members: .members | map(select(.id as $id | $online | any(. == $id))) }\r\n```",
                "title": "How to select items in JQ based on values in array"
            }
        ],
        "is_answered": false,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1663579133,
        "creation_date": 1661834047,
        "question_id": 73537190,
        "body_markdown": "I have a json file with data like this:\r\n```\r\n{ \r\n  &quot;data&quot;: {\r\n    &quot;all&quot;: {\r\n      &quot;members&quot;: [\r\n        {\r\n          &quot;id&quot;: 10,\r\n          &quot;name&quot;: &quot;First&quot;\r\n        },\r\n        {\r\n          &quot;id&quot;: 12,\r\n          &quot;name&quot;: &quot;Second&quot;\r\n        },\r\n        {\r\n          &quot;id&quot;: 14,\r\n          &quot;name&quot;: &quot;Third&quot;\r\n        }\r\n      ],\r\n      &quot;live&quot;: {\r\n        &quot;online&quot;: [\r\n          10,\r\n          14\r\n        ]\r\n      }\r\n    }\r\n  }\r\n}\r\n```\r\nHow can I use jq to select and show only the JSON values in `data.all.members` that have their `id` in `data.all.live.online` array?\r\n\r\nSo the output would be something like:\r\n```\r\n{\r\n&quot;members&quot;: [\r\n        {\r\n          &quot;id&quot;: 10,\r\n          &quot;name&quot;: &quot;First&quot;\r\n        },\r\n        {\r\n          &quot;id&quot;: 14,\r\n          &quot;name&quot;: &quot;Third&quot;\r\n        }\r\n      ]\r\n}\r\n```",
        "link": "https://stackoverflow.com/questions/73537190/how-to-select-items-in-jq-based-on-values-in-array",
        "title": "How to select items in JQ based on values in array"
    },
    {
        "tags": [
            "json",
            "bash",
            "select",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 32384,
                    "reputation": 127026,
                    "user_id": 89817,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/df253c3b6533949ea94f31f328f3e769?s=256&d=identicon&r=PG",
                    "display_name": "Gordon Davisson",
                    "link": "https://stackoverflow.com/users/89817/gordon-davisson"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1661836348,
                "post_id": 73537210,
                "comment_id": 129859310,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2186012,
                    "reputation": 22650,
                    "user_id": 1934428,
                    "user_type": "registered",
                    "accept_rate": 86,
                    "profile_image": "https://www.gravatar.com/avatar/072774c5d4204a1c2385560e6114a887?s=256&d=identicon&r=PG",
                    "display_name": "user1934428",
                    "link": "https://stackoverflow.com/users/1934428/user1934428"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1661844313,
                "post_id": 73537210,
                "comment_id": 129861304,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 8,
                "is_accepted": true,
                "score": 8,
                "last_activity_date": 1661835407,
                "creation_date": 1661835407,
                "answer_id": 73537317,
                "question_id": 73537210,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "There is no need to use a shell loop.\r\n\r\nWith your test.json,\r\n```\r\njq &#39; # get the name of the agent if the result was &quot;succeeded&quot;.\r\n  .value[]\r\n  | select(.result == &quot;succeeded&quot;)\r\n  | .agent.name\r\n&#39; test.json\r\n\r\n```\r\nproduces:\r\n```\r\n&quot;John&quot;\r\n```\r\n",
                "title": "bash use jq to get value if condition meets"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1661840901,
        "creation_date": 1661834253,
        "last_edit_date": 1661840901,
        "question_id": 73537210,
        "body_markdown": "I am trying to get certain value in the json with some for each and if condition.\r\n\r\ncode looks like the following \r\n\r\n    for i in &quot;$(jq -r &#39;.value[]&#39; test.json)&quot;; do\r\n        result=$(echo $i | jq -r .result)\r\n        if [ &quot;$result&quot; == &quot;succeeded&quot; ]\r\n        then\r\n          name=$(echo $i | jq -r .agent.name)\r\n          echo &quot;$name&quot;\r\n        fi\r\n    done\r\n\r\njson file - test.json\r\n\r\n    {\r\n       &quot;count&quot;:3,\r\n       &quot;value&quot;:[\r\n          {\r\n             &quot;location&quot;:&quot;CA&quot;,\r\n             &quot;result&quot;:&quot;failed&quot;,\r\n             &quot;agent&quot;:{\r\n                &quot;id&quot;:97833,\r\n                &quot;name&quot;:&quot;Brad&quot;\r\n             },\r\n             &quot;priority&quot;:0\r\n          },\r\n          {\r\n             &quot;location&quot;:&quot;TX&quot;,\r\n             &quot;result&quot;:&quot;failed&quot;,\r\n             &quot;agent&quot;:{i\r\n                &quot;id&quot;:15232,\r\n                &quot;name&quot;:&quot;Tom&quot;\r\n             },\r\n             &quot;priority&quot;:0\r\n          },\r\n          {\r\n             &quot;location&quot;:&quot;CO&quot;,\r\n             &quot;result&quot;:&quot;succeeded&quot;,\r\n             &quot;agent&quot;:{\r\n                &quot;id&quot;:13412,\r\n                &quot;name&quot;:&quot;John&quot;\r\n             },\r\n             &quot;priority&quot;:0\r\n          }\r\n       ]\r\n    }\r\n\r\nI am trying to loop through the json file using jq to get the name of the agent if the result was &quot;succeeded&quot;. but the result i get from result=$(echo $i | jq -r .result) seems like it&#39;s returning string array @(&quot;failed&quot;,&quot;failed&quot;,&quot;succeeded&quot;).\r\n\r\n\r\n========================update==============================\r\n\r\n    jq &#39; # get the name of the agent if the result was &quot;succeeded&quot;.\r\n      .value[]\r\n      | select(.result == &quot;succeeded&quot;)\r\n      | var1=.agent.name\r\n      | echo $var1\r\n    &#39; test.json\r\n\r\nif I want to save the .agent.name into a variable and use it with a different command, what do I have to do?",
        "link": "https://stackoverflow.com/questions/73537210/bash-use-jq-to-get-value-if-condition-meets",
        "title": "bash use jq to get value if condition meets"
    },
    {
        "tags": [
            "aws-cloudformation",
            "jq",
            "yq"
        ],
        "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": 1661852668,
                "post_id": 73539877,
                "comment_id": 129864464,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 192652,
                    "reputation": 1559,
                    "user_id": 433922,
                    "user_type": "registered",
                    "accept_rate": 53,
                    "profile_image": "https://www.gravatar.com/avatar/77971018b92849e461b86d4ca7442ded?s=256&d=identicon&r=PG",
                    "display_name": "Chip",
                    "link": "https://stackoverflow.com/users/433922/chip"
                },
                "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": 1661892046,
                "post_id": 73539877,
                "comment_id": 129879069,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1661851212,
                "creation_date": 1661851212,
                "answer_id": 73539997,
                "question_id": 73539877,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Use the tag operator \r\n\r\nadd_policy.yq:\r\n\r\n    ( .Resources[] |= \r\n        select(.Properties.AssumeRolePolicyDocument.Statement[].Principal.Service.[] == &quot;ecs-tasks.amazonaws.com&quot; or .Properties.AssumeRolePolicyDocument.Statement[].Principal.Service.[] == &quot;lambda.amazonaws.com&quot;)\r\n        .Properties.ManagedPolicyArns += {&quot;Fn::ImportValue&quot;: &quot;${AuthAuditBucketStackName}-logging-policy-arn&quot; | . tag = &quot;!Sub&quot; }\r\n    )\r\n\r\nresults in:\r\n\r\n    - Fn::ImportValue: !Sub &quot;${MyPrefix}-my-policy-arn&quot;\r\n    - Fn::ImportValue: !Sub ${MyPrefix}-my-new-policy-arn\r\n\r\n\r\nNow I&#39;m not sure why the string value isn&#39;t quoted.",
                "title": "How can I set a cloudformation field with function shorthand (ie. !Sub) using yq?"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1661851236,
        "creation_date": 1661850679,
        "last_edit_date": 1661851236,
        "question_id": 73539877,
        "body_markdown": "I need to add a managed policy to a large number of lambda and ecs task roles across many cloudformation yaml files. Some of them already have this array field with items in it while some do not. I need to add an item to the ManagedPolicyArns array field where that item contains cloudformation shorthand such as !Sub. I&#39;m using yq, which is a fantastic tool, but I can&#39;t figure out handling this shorthand using the docs.\r\n\r\ncloudformation.yaml:\r\n\r\n    AWSTemplateFormatVersion: &quot;2010-09-09&quot;\r\n    Parameters:\r\n      MyPrefix:\r\n        Description: MyPrefix\r\n        Type: String\r\n    Resources:\r\n      MyRole:\r\n        Type: AWS::IAM::Role\r\n        Properties:\r\n          ManagedPolicyArns:\r\n            - Fn::ImportValue: !Sub &quot;${MyPrefix}-my-policy-arn&quot;\r\n          AssumeRolePolicyDocument:\r\n            Version: &#39;2012-10-17&#39;\r\n            Statement:\r\n              - Effect: Allow\r\n                Principal:\r\n                  Service:\r\n                    - ecs-tasks.amazonaws.com\r\n                    - lambda.amazonaws.com\r\n                Action:\r\n                  - sts:AssumeRole\r\n                  - sts:TagSession\r\n          Path: /\r\n\r\nExpected output .yaml:\r\n\r\n    AWSTemplateFormatVersion: &quot;2010-09-09&quot;\r\n    Parameters:\r\n      MyPrefix:\r\n        Description: MyPrefix\r\n        Type: String\r\n    Resources:\r\n      MyRole:\r\n        Type: AWS::IAM::Role\r\n        Properties:\r\n          ManagedPolicyArns:\r\n            - Fn::ImportValue: !Sub &quot;${MyPrefix}-my-policy-arn&quot;\r\n            - Fn::ImportValue: !Sub &quot;${MyPrefix}-my-new-policy-arn&quot;\r\n          AssumeRolePolicyDocument:\r\n            Version: &#39;2012-10-17&#39;\r\n            Statement:\r\n              - Effect: Allow\r\n                Principal:\r\n                  Service:\r\n                    - ecs-tasks.amazonaws.com\r\n                    - lambda.amazonaws.com\r\n                Action:\r\n                  - sts:AssumeRole\r\n                  - sts:TagSession\r\n          Path: /\r\n\r\nMy failed attempt:\r\n\r\nadd_policy.yq:\r\n\r\n    ( .Resources[] |= \r\n        select(.Properties.AssumeRolePolicyDocument.Statement[].Principal.Service.[] == &quot;ecs-tasks.amazonaws.com&quot; or .Properties.AssumeRolePolicyDocument.Statement[].Principal.Service.[] == &quot;lambda.amazonaws.com&quot;)\r\n        .Properties.ManagedPolicyArns += {&quot;Fn::ImportValue&quot;: {&quot;!Sub&quot;: &quot;${MyPrefix}-my-new-policy-arn&quot;} }\r\n    )\r\n\r\ncommand:\r\n\r\n    yq --from-file add_policy.yq cloudformation.yaml \r\n\r\nwhich outputs:\r\n\r\n    AWSTemplateFormatVersion: &quot;2010-09-09&quot;\r\n    Parameters:\r\n      MyPrefix:\r\n        Description: MyPrefix\r\n        Type: String\r\n    Resources:\r\n      MyRole:\r\n        Type: AWS::IAM::Role\r\n        Properties:\r\n          ManagedPolicyArns:\r\n            - Fn::ImportValue: !Sub &quot;${MyPrefix}-my-policy-arn&quot;\r\n            - Fn::ImportValue:\r\n                &#39;!Sub&#39;: ${MyPrefix}-my-new-policy-arn\r\n          AssumeRolePolicyDocument:\r\n            Version: &#39;2012-10-17&#39;\r\n            Statement:\r\n              - Effect: Allow\r\n                Principal:\r\n                  Service:\r\n                    - ecs-tasks.amazonaws.com\r\n                    - lambda.amazonaws.com\r\n                Action:\r\n                  - sts:AssumeRole\r\n                  - sts:TagSession\r\n          Path: /\r\n\r\n\r\nHow do I get\r\n\r\n            - Fn::ImportValue: !Sub &quot;${MyPrefix}-my-policy-arn&quot;\r\n            - Fn::ImportValue: !Sub &quot;${MyPrefix}-my-new-policy-arn&quot;\r\n\r\ninstead of\r\n\r\n            - Fn::ImportValue: !Sub &quot;${MyPrefix}-my-policy-arn&quot;\r\n            - Fn::ImportValue:\r\n                &#39;!Sub&#39;: ${MyPrefix}-my-new-policy-arn\r\n\r\n?",
        "link": "https://stackoverflow.com/questions/73539877/how-can-i-set-a-cloudformation-field-with-function-shorthand-ie-sub-using-yq",
        "title": "How can I set a cloudformation field with function shorthand (ie. !Sub) using yq?"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1661867640,
                "creation_date": 1661867640,
                "answer_id": 73543639,
                "question_id": 73541010,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "With some assumptions made for the edge cases, this should meet your requirements:\r\n~~~sh\r\nmap(select(has(&quot;baseBranch&quot;) and .config != {}) | {\r\n  repository,\r\n  numberOfUpdates: 0,\r\n  gradleUpdates: .config.gradle,\r\n  gradleWrapperUpdates: .config.&quot;gradle-wrapper&quot;\r\n} | (.gradleUpdates, .gradleWrapperUpdates) |= map(\r\n  .packageFile as $fileName | .deps[] | .updates[] as $update | {\r\n    $fileName,\r\n    package: (.packageName // .depName),\r\n    currentVersion,\r\n    newVersion: $update.newValue\r\n  })\r\n  | .numberOfUpdates += ([.gradleUpdates, .gradleWrapperUpdates | length] | add)\r\n)\r\n~~~\r\n~~~json\r\n[\r\n  {\r\n    &quot;repository&quot;: &quot;myRepositoryName&quot;,\r\n    &quot;numberOfUpdates&quot;: 5,\r\n    &quot;gradleUpdates&quot;: [\r\n      {\r\n        &quot;fileName&quot;: &quot;dependencies.gradle&quot;,\r\n        &quot;package&quot;: &quot;packageName.api:feature-flags&quot;,\r\n        &quot;currentVersion&quot;: &quot;0.20.0&quot;,\r\n        &quot;newVersion&quot;: &quot;0.21.0&quot;\r\n      },\r\n      {\r\n        &quot;fileName&quot;: &quot;dependencies.gradle&quot;,\r\n        &quot;package&quot;: &quot;io.rest-assured:xml-path&quot;,\r\n        &quot;currentVersion&quot;: &quot;4.5.1&quot;,\r\n        &quot;newVersion&quot;: &quot;5.1.1&quot;\r\n      },\r\n      {\r\n        &quot;fileName&quot;: &quot;build.gradle&quot;,\r\n        &quot;package&quot;: &quot;com.diffplug.spotless:com.diffplug.spotless.gradle.plugin&quot;,\r\n        &quot;currentVersion&quot;: &quot;6.9.0&quot;,\r\n        &quot;newVersion&quot;: &quot;6.10.0&quot;\r\n      },\r\n      {\r\n        &quot;fileName&quot;: &quot;build.gradle&quot;,\r\n        &quot;package&quot;: &quot;org.springframework.boot:org.springframework.boot.gradle.plugin&quot;,\r\n        &quot;currentVersion&quot;: &quot;2.7.2&quot;,\r\n        &quot;newVersion&quot;: &quot;2.7.3&quot;\r\n      }\r\n    ],\r\n    &quot;gradleWrapperUpdates&quot;: [\r\n      {\r\n        &quot;fileName&quot;: &quot;gradle/wrapper/gradle-wrapper.properties&quot;,\r\n        &quot;package&quot;: &quot;gradle&quot;,\r\n        &quot;currentVersion&quot;: &quot;7.5&quot;,\r\n        &quot;newVersion&quot;: &quot;7.5.1&quot;\r\n      }\r\n    ]\r\n  }\r\n]\r\n~~~\r\n[Demo](https://jqplay.org/s/WjO3PRCKTm6)",
                "title": "How to parse JSON objects that depend on array contents for their attributes with JQ?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1661867640,
        "creation_date": 1661855748,
        "last_edit_date": 1661864023,
        "question_id": 73541010,
        "body_markdown": "I have this complex array of JSON objects that have attributes that are arrays which may or may not be populated. \r\n\r\nI am looking for a way using `jq` to filter out the array elements that do not have any items in their `updates` attribute, but this is buried deep down the object tree.\r\n\r\nIs there a way to produce the sample output from the input JSON array under it?\r\n\r\nWhat I am trying to find is:\r\n\r\nSelect all top level objects from the array that have a `baseBranch` attribute and a non-empty `config` attribute and filter out the results to show me only the elements within the (`gradle` and `gradle-wrapper`) attributes within the `config` that have a non-empty `deps` array attribute. The result is a `deps` element that have a non-empty `updates` array in it.\r\n\r\nThanks in advance to anyone who can take this challenge!\r\n\r\nEdit:\r\n* Yes I have tried solving it on my own. I have been through the documentation and so far this is the expression I have: `.[] | . as $parent | select(.baseBranch != null and .config != null) | .config | [.gradle[] .deps[]]`\r\n* This will filter out all the top level elements and get me to the dependency array, but I cannot figure out how to filter out the `deps` array and group them by the attribute where they are located.\r\n\r\nEdit 2:\r\n\r\nThe query bellow is returning most of the information I want. But I&#39;d like to figure out how to group the `updates` by the `repository` and `file` values.\r\n\r\n```\r\njq &#39;.[] \r\n    | . as $parent \r\n    | select(.baseBranch != null and .config != null) \r\n    | .config.gradle[]?.deps[]? as $deps\r\n    | [\r\n        {\r\n            repository: $parent.repository,\r\n            file:$deps.managerData.packageFile, \r\n            depName:$deps.depName,\r\n            currentVersion:$deps.currentValue,\r\n            newVersion:$deps.updates[]?.newVersion\r\n        }\r\n    ]\r\n&#39;\r\n```\r\n\r\n```json\r\n/* Desired sample output */\r\n[\r\n    { \r\n        &quot;repository&quot;: &quot;repositoryName&quot;,\r\n        &quot;numberOfUpdates&quot;: 5, \r\n        &quot;gradleUpdates&quot;: [\r\n            {\r\n                &quot;fileName&quot;: &quot;dependencies.gradle&quot;,\r\n                &quot;package&quot;: &quot;packageName.api:feature-flags&quot;, /* if packageName then display the depName */\r\n                &quot;currentVersion&quot;: &quot;0.20.0&quot;,\r\n                &quot;newVersion&quot;: &quot;0.21.0&quot;\r\n            },\r\n            {\r\n                &quot;fileName&quot;: &quot;dependencies.gradle&quot;,\r\n                &quot;package&quot;: &quot;io.rest-assured:xml-path&quot;, /* if packageName then display the depName */\r\n                &quot;currentVersion&quot;: &quot;4.5.1&quot;,\r\n                &quot;newVersion&quot;: &quot;5.1.1&quot;\r\n            },\r\n            {\r\n                &quot;fileName&quot;: &quot;build.gradle&quot;,\r\n                &quot;package&quot;: &quot;com.diffplug.spotless:com.diffplug.spotless.gradle.plugin&quot;, /* if packageName then display the depName */\r\n                &quot;currentVersion&quot;: &quot;6.9.0&quot;,\r\n                &quot;newVersion&quot;: &quot;6.10.0&quot;\r\n            },\r\n            {\r\n                &quot;fileName&quot;: &quot;build.gradle&quot;,\r\n                &quot;package&quot;: &quot;org.springframework.boot:org.springframework.boot.gradle.plugin&quot;, /* if packageName then display the depName */\r\n                &quot;currentVersion&quot;: &quot;2.7.2&quot;,\r\n                &quot;newVersion&quot;: &quot;2.7.3&quot;\r\n            }\r\n        ],\r\n        &quot;gradleWrapperUpdates&quot;: [\r\n            {\r\n                &quot;fileName&quot;: &quot;gradle/wrapper/gradle-wrapper.properties&quot;,\r\n                &quot;currentVersion&quot;: &quot;7.5&quot;,\r\n                &quot;newVersion&quot;: &quot;7.5.1&quot;\r\n            }\r\n        ]\r\n    }\r\n]\r\n\r\n\r\n/* This is the input */\r\n[\r\n    {\r\n        &quot;randomKey&quot;: &quot;this is not what I am looking for&quot;,\r\n        &quot;otherFields&quot;: &quot;other object that does not match the query&quot;\r\n    },\r\n    {\r\n        &quot;repository&quot;: &quot;myRepositoryName&quot;,\r\n        &quot;baseBranch&quot;: &quot;master&quot;,\r\n        &quot;config&quot;: {\r\n            &quot;gradle&quot;: [\r\n                {\r\n                    &quot;packageFile&quot;: &quot;gradle.properties&quot;,\r\n                    &quot;datasource&quot;: &quot;maven&quot;,\r\n                    &quot;deps&quot;: []\r\n                },\r\n                {\r\n                    &quot;packageFile&quot;: &quot;dependencies.gradle&quot;,\r\n                    &quot;datasource&quot;: &quot;maven&quot;,\r\n                    &quot;deps&quot;: [\r\n                        {\r\n                            &quot;depName&quot;: &quot;packageName:dependencyName&quot;,\r\n                            &quot;currentValue&quot;: &quot;0.8.0&quot;,\r\n                            &quot;managerData&quot;: {\r\n                                &quot;fileReplacePosition&quot;: 611,\r\n                                &quot;packageFile&quot;: &quot;dependencies.gradle&quot;\r\n                            },\r\n                            &quot;fileReplacePosition&quot;: 611,\r\n                            &quot;registryUrls&quot;: [\r\n                                &quot;https://mavenCentral/repository/release&quot;,\r\n                                &quot;https://mavenCentral/repository/maven-mirror&quot;,\r\n                                &quot;https://mavenCentral/repository/gradle-plugins&quot;\r\n                            ],\r\n                            &quot;depType&quot;: &quot;dependencies&quot;,\r\n                            &quot;depIndex&quot;: 0,\r\n                            &quot;updates&quot;: [],\r\n                            &quot;warnings&quot;: [],\r\n                            &quot;versioning&quot;: &quot;gradle&quot;,\r\n                            &quot;currentVersion&quot;: &quot;0.8.0&quot;,\r\n                            &quot;fixedVersion&quot;: &quot;0.8.0&quot;\r\n                        },\r\n                        {\r\n                            &quot;depName&quot;: &quot;packageName.api:feature-flags&quot;,\r\n                            &quot;currentValue&quot;: &quot;0.20.0&quot;,\r\n                            &quot;managerData&quot;: {\r\n                                &quot;fileReplacePosition&quot;: 1118,\r\n                                &quot;packageFile&quot;: &quot;dependencies.gradle&quot;\r\n                            },\r\n                            &quot;fileReplacePosition&quot;: 1118,\r\n                            &quot;registryUrls&quot;: [\r\n                                &quot;https://mavenCentral/repository/release&quot;,\r\n                                &quot;https://mavenCentral/repository/maven-mirror&quot;,\r\n                                &quot;https://mavenCentral/repository/gradle-plugins&quot;\r\n                            ],\r\n                            &quot;depType&quot;: &quot;dependencies&quot;,\r\n                            &quot;depIndex&quot;: 8,\r\n                            &quot;updates&quot;: [\r\n                                {\r\n                                    &quot;bucket&quot;: &quot;non-major&quot;,\r\n                                    &quot;newVersion&quot;: &quot;0.21.0&quot;,\r\n                                    &quot;newValue&quot;: &quot;0.21.0&quot;,\r\n                                    &quot;releaseTimestamp&quot;: &quot;2022-08-25T04:57:50.000Z&quot;,\r\n                                    &quot;newMajor&quot;: 0,\r\n                                    &quot;newMinor&quot;: 21,\r\n                                    &quot;updateType&quot;: &quot;minor&quot;,\r\n                                    &quot;branchName&quot;: &quot;renovate/all-minor-patch&quot;\r\n                                }\r\n                            ],\r\n                            &quot;warnings&quot;: [],\r\n                            &quot;versioning&quot;: &quot;gradle&quot;,\r\n                            &quot;currentVersion&quot;: &quot;0.20.0&quot;,\r\n                            &quot;isSingleVersion&quot;: true,\r\n                            &quot;fixedVersion&quot;: &quot;0.20.0&quot;\r\n                        },\r\n                        {\r\n                            &quot;depName&quot;: &quot;io.rest-assured:xml-path&quot;,\r\n                            &quot;currentValue&quot;: &quot;4.5.1&quot;,\r\n                            &quot;managerData&quot;: {\r\n                                &quot;fileReplacePosition&quot;: 3307,\r\n                                &quot;packageFile&quot;: &quot;dependencies.gradle&quot;\r\n                            },\r\n                            &quot;fileReplacePosition&quot;: 3307,\r\n                            &quot;registryUrls&quot;: [\r\n                                &quot;https://mavenCentral/repository/release&quot;,\r\n                                &quot;https://mavenCentral/repository/maven-mirror&quot;,\r\n                                &quot;https://mavenCentral/repository/gradle-plugins&quot;\r\n                            ],\r\n                            &quot;depType&quot;: &quot;dependencies&quot;,\r\n                            &quot;depIndex&quot;: 39,\r\n                            &quot;updates&quot;: [\r\n                                {\r\n                                    &quot;bucket&quot;: &quot;major&quot;,\r\n                                    &quot;newVersion&quot;: &quot;5.1.1&quot;,\r\n                                    &quot;newValue&quot;: &quot;5.1.1&quot;,\r\n                                    &quot;releaseTimestamp&quot;: &quot;2022-06-10T06:46:14.000Z&quot;,\r\n                                    &quot;newMajor&quot;: 5,\r\n                                    &quot;newMinor&quot;: 1,\r\n                                    &quot;updateType&quot;: &quot;major&quot;,\r\n                                    &quot;branchName&quot;: &quot;renovate/io.rest-assured-xml-path-5.x&quot;\r\n                                }\r\n                            ],\r\n                            &quot;warnings&quot;: [],\r\n                            &quot;versioning&quot;: &quot;gradle&quot;,\r\n                            &quot;sourceUrl&quot;: &quot;http://svn.sonatype.org/spice/tags/oss-parent-5&quot;,\r\n                            &quot;homepage&quot;: &quot;https://rest-assured.io/&quot;,\r\n                            &quot;currentVersion&quot;: &quot;4.5.1&quot;,\r\n                            &quot;isSingleVersion&quot;: true,\r\n                            &quot;fixedVersion&quot;: &quot;4.5.1&quot;\r\n                        },\r\n                        {\r\n                            &quot;depName&quot;: &quot;io.rest-assured:json-schema-validator&quot;,\r\n                            &quot;currentValue&quot;: &quot;5.1.1&quot;,\r\n                            &quot;managerData&quot;: {\r\n                                &quot;fileReplacePosition&quot;: 3376,\r\n                                &quot;packageFile&quot;: &quot;dependencies.gradle&quot;\r\n                            },\r\n                            &quot;fileReplacePosition&quot;: 3376,\r\n                            &quot;registryUrls&quot;: [\r\n                                &quot;https://mavenCentral/repository/release&quot;,\r\n                                &quot;https://mavenCentral/repository/maven-mirror&quot;,\r\n                                &quot;https://mavenCentral/repository/gradle-plugins&quot;\r\n                            ],\r\n                            &quot;depType&quot;: &quot;dependencies&quot;,\r\n                            &quot;depIndex&quot;: 40,\r\n                            &quot;updates&quot;: [],\r\n                            &quot;warnings&quot;: [],\r\n                            &quot;versioning&quot;: &quot;gradle&quot;,\r\n                            &quot;sourceUrl&quot;: &quot;http://svn.sonatype.org/spice/tags/oss-parent-5&quot;,\r\n                            &quot;homepage&quot;: &quot;http://maven.apache.org&quot;,\r\n                            &quot;currentVersion&quot;: &quot;5.1.1&quot;,\r\n                            &quot;fixedVersion&quot;: &quot;5.1.1&quot;\r\n                        }\r\n                    ]\r\n                },\r\n                {\r\n                    &quot;packageFile&quot;: &quot;settings.gradle&quot;,\r\n                    &quot;datasource&quot;: &quot;maven&quot;,\r\n                    &quot;deps&quot;: []\r\n                },\r\n                {\r\n                    &quot;packageFile&quot;: &quot;build.gradle&quot;,\r\n                    &quot;datasource&quot;: &quot;maven&quot;,\r\n                    &quot;deps&quot;: [\r\n                        {\r\n                            &quot;depType&quot;: &quot;plugin&quot;,\r\n                            &quot;depName&quot;: &quot;com.diffplug.spotless&quot;,\r\n                            &quot;packageName&quot;: &quot;com.diffplug.spotless:com.diffplug.spotless.gradle.plugin&quot;,\r\n                            &quot;registryUrls&quot;: [\r\n                                &quot;https://mavenCentral/repository/release&quot;,\r\n                                &quot;https://mavenCentral/repository/maven-mirror&quot;,\r\n                                &quot;https://mavenCentral/repository/gradle-plugins&quot;,\r\n                                &quot;https://plugins.gradle.org/m2/&quot;\r\n                            ],\r\n                            &quot;commitMessageTopic&quot;: &quot;plugin com.diffplug.spotless&quot;,\r\n                            &quot;currentValue&quot;: &quot;6.9.0&quot;,\r\n                            &quot;managerData&quot;: {\r\n                                &quot;fileReplacePosition&quot;: 50,\r\n                                &quot;packageFile&quot;: &quot;build.gradle&quot;\r\n                            },\r\n                            &quot;fileReplacePosition&quot;: 50,\r\n                            &quot;depIndex&quot;: 0,\r\n                            &quot;updates&quot;: [\r\n                                {\r\n                                    &quot;bucket&quot;: &quot;non-major&quot;,\r\n                                    &quot;newVersion&quot;: &quot;6.10.0&quot;,\r\n                                    &quot;newValue&quot;: &quot;6.10.0&quot;,\r\n                                    &quot;releaseTimestamp&quot;: &quot;2022-08-24T14:40:44.000Z&quot;,\r\n                                    &quot;newMajor&quot;: 6,\r\n                                    &quot;newMinor&quot;: 10,\r\n                                    &quot;updateType&quot;: &quot;minor&quot;,\r\n                                    &quot;branchName&quot;: &quot;renovate/all-minor-patch&quot;\r\n                                }\r\n                            ],\r\n                            &quot;warnings&quot;: [],\r\n                            &quot;versioning&quot;: &quot;gradle&quot;,\r\n                            &quot;currentVersion&quot;: &quot;6.9.0&quot;,\r\n                            &quot;isSingleVersion&quot;: true,\r\n                            &quot;fixedVersion&quot;: &quot;6.9.0&quot;\r\n                        },\r\n                        {\r\n                            &quot;depType&quot;: &quot;plugin&quot;,\r\n                            &quot;depName&quot;: &quot;docker-publish-convention&quot;,\r\n                            &quot;packageName&quot;: &quot;docker-publish-convention:docker-publish-convention.gradle.plugin&quot;,\r\n                            &quot;registryUrls&quot;: [\r\n                                &quot;https://mavenCentral/repository/release&quot;,\r\n                                &quot;https://mavenCentral/repository/maven-mirror&quot;,\r\n                                &quot;https://mavenCentral/repository/gradle-plugins&quot;,\r\n                                &quot;https://plugins.gradle.org/m2/&quot;\r\n                            ],\r\n                            &quot;commitMessageTopic&quot;: &quot;plugin docker-publish-convention&quot;,\r\n                            &quot;currentValue&quot;: &quot;latest.release&quot;,\r\n                            &quot;managerData&quot;: {\r\n                                &quot;fileReplacePosition&quot;: 158,\r\n                                &quot;packageFile&quot;: &quot;build.gradle&quot;\r\n                            },\r\n                            &quot;fileReplacePosition&quot;: 158,\r\n                            &quot;depIndex&quot;: 2,\r\n                            &quot;updates&quot;: [],\r\n                            &quot;warnings&quot;: [],\r\n                            &quot;versioning&quot;: &quot;gradle&quot;,\r\n                            &quot;skipReason&quot;: &quot;invalid-value&quot;\r\n                        },\r\n                        {\r\n                            &quot;depType&quot;: &quot;plugin&quot;,\r\n                            &quot;depName&quot;: &quot;org.springframework.boot&quot;,\r\n                            &quot;packageName&quot;: &quot;org.springframework.boot:org.springframework.boot.gradle.plugin&quot;,\r\n                            &quot;registryUrls&quot;: [\r\n                                &quot;https://mavenCentral/repository/release&quot;,\r\n                                &quot;https://mavenCentral/repository/maven-mirror&quot;,\r\n                                &quot;https://mavenCentral/repository/gradle-plugins&quot;,\r\n                                &quot;https://plugins.gradle.org/m2/&quot;\r\n                            ],\r\n                            &quot;commitMessageTopic&quot;: &quot;plugin org.springframework.boot&quot;,\r\n                            &quot;currentValue&quot;: &quot;2.7.2&quot;,\r\n                            &quot;managerData&quot;: {\r\n                                &quot;fileReplacePosition&quot;: 217,\r\n                                &quot;packageFile&quot;: &quot;build.gradle&quot;\r\n                            },\r\n                            &quot;fileReplacePosition&quot;: 217,\r\n                            &quot;depIndex&quot;: 3,\r\n                            &quot;updates&quot;: [\r\n                                {\r\n                                    &quot;bucket&quot;: &quot;non-major&quot;,\r\n                                    &quot;newVersion&quot;: &quot;2.7.3&quot;,\r\n                                    &quot;newValue&quot;: &quot;2.7.3&quot;,\r\n                                    &quot;releaseTimestamp&quot;: &quot;2022-08-18T06:30:12.000Z&quot;,\r\n                                    &quot;newMajor&quot;: 2,\r\n                                    &quot;newMinor&quot;: 7,\r\n                                    &quot;updateType&quot;: &quot;patch&quot;,\r\n                                    &quot;branchName&quot;: &quot;renovate/all-minor-patch&quot;\r\n                                }\r\n                            ],\r\n                            &quot;warnings&quot;: [],\r\n                            &quot;versioning&quot;: &quot;gradle&quot;,\r\n                            &quot;sourceUrl&quot;: &quot;https://github.com/spring-projects/spring-boot&quot;,\r\n                            &quot;homepage&quot;: &quot;https://spring.io/projects/spring-boot&quot;,\r\n                            &quot;currentVersion&quot;: &quot;2.7.2&quot;,\r\n                            &quot;isSingleVersion&quot;: true,\r\n                            &quot;fixedVersion&quot;: &quot;2.7.2&quot;\r\n                        }\r\n                    ]\r\n                }\r\n            ],\r\n            &quot;gradle-wrapper&quot;: [\r\n                {\r\n                    &quot;packageFile&quot;: &quot;gradle/wrapper/gradle-wrapper.properties&quot;,\r\n                    &quot;deps&quot;: [\r\n                        {\r\n                            &quot;depName&quot;: &quot;gradle&quot;,\r\n                            &quot;currentValue&quot;: &quot;7.5&quot;,\r\n                            &quot;replaceString&quot;: &quot;https\\\\://mavenCentral/repository/gradle-dist/gradle-7.5-bin.zip&quot;,\r\n                            &quot;datasource&quot;: &quot;gradle-version&quot;,\r\n                            &quot;versioning&quot;: &quot;gradle&quot;,\r\n                            &quot;depIndex&quot;: 0,\r\n                            &quot;updates&quot;: [\r\n                                {\r\n                                    &quot;bucket&quot;: &quot;non-major&quot;,\r\n                                    &quot;newVersion&quot;: &quot;7.5.1&quot;,\r\n                                    &quot;newValue&quot;: &quot;7.5.1&quot;,\r\n                                    &quot;releaseTimestamp&quot;: &quot;2022-08-05T21:17:56.000Z&quot;,\r\n                                    &quot;newMajor&quot;: 7,\r\n                                    &quot;newMinor&quot;: 5,\r\n                                    &quot;updateType&quot;: &quot;patch&quot;,\r\n                                    &quot;branchName&quot;: &quot;renovate/all-minor-patch&quot;\r\n                                }\r\n                            ],\r\n                            &quot;warnings&quot;: [],\r\n                            &quot;sourceUrl&quot;: &quot;https://github.com/gradle/gradle&quot;,\r\n                            &quot;homepage&quot;: &quot;https://gradle.org&quot;,\r\n                            &quot;currentVersion&quot;: &quot;7.5&quot;,\r\n                            &quot;isSingleVersion&quot;: true,\r\n                            &quot;fixedVersion&quot;: &quot;7.5&quot;\r\n                        }\r\n                    ]\r\n                }\r\n            ]\r\n        }\r\n    }\r\n]\r\n\r\n```",
        "link": "https://stackoverflow.com/questions/73541010/how-to-parse-json-objects-that-depend-on-array-contents-for-their-attributes-wit",
        "title": "How to parse JSON objects that depend on array contents for their attributes with JQ?"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1661859329,
                "creation_date": 1661859329,
                "answer_id": 73541791,
                "question_id": 73541709,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can use the [alternative operator `//`][1]:\r\n\r\n```\r\n.data.sub1[] | .sub2.steps[].task[].active // &quot;error&quot;\r\n```\r\n\r\nSee [playground][2].\r\n\r\n\r\n  [1]: https://stedolan.github.io/jq/manual/#Alternativeoperator://\r\n  [2]: https://jqplay.org/s/1GQqTF1X2At",
                "title": "How do i use try catch in multiple sets of arrays in jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1661859329,
        "creation_date": 1661858889,
        "question_id": 73541709,
        "body_markdown": "json example:\r\n```\r\n{\r\n  &quot;data&quot;: {\r\n    &quot;sub1&quot;: [\r\n      {\r\n        &quot;sub2&quot;: {\r\n          &quot;sub3&quot;: 32,\r\n          &quot;steps&quot;: []\r\n        }\r\n      },\r\n      {\r\n        &quot;sub2&quot;: {\r\n          &quot;sub3&quot;: 21,\r\n          &quot;steps&quot;: [\r\n            {\r\n              &quot;task&quot;: [\r\n                {\r\n                  &quot;active&quot;: 223,\r\n                  &quot;activel&quot;: 21\r\n                }\r\n              ]\r\n            }\r\n          ]\r\n        }\r\n      },\r\n      {\r\n        &quot;sub2&quot;: {\r\n          &quot;sub3&quot;: 234,\r\n          &quot;steps&quot;: [\r\n            {\r\n              &quot;task&quot;: [\r\n                {\r\n                  &quot;active&quot;: 23,\r\n                  &quot;activel&quot;: 2\r\n                }\r\n              ]\r\n            }\r\n          ]\r\n        }\r\n      },\r\n      {\r\n        &quot;sub2&quot;: {\r\n          &quot;sub3&quot;: 32,\r\n          &quot;steps&quot;: [\r\n            {\r\n              &quot;task&quot;: []\r\n            }\r\n          ]\r\n        }\r\n      }\r\n    ]\r\n  }\r\n}\r\n```\r\nwhat i have tried: \r\n```\r\n.data.sub1[]| [try(.sub2.steps[].task[].active) catch &quot;error&quot;]\r\n```\r\nin jqplay : https://jqplay.org/s/U2mWmdkhsm5\r\n\r\nthis is the closest i have gotten, but what i need is for it to write error for each part of the array where active doesnt exist.\r\nlike this: \r\n``` \r\n&quot;error&quot;\r\n223\r\n23\r\n&quot;error&quot;\r\n\r\n``` \r\nthis seems like a simple question, but i just cant figure out how to get this to work, so thanks in advance for any answers.",
        "link": "https://stackoverflow.com/questions/73541709/how-do-i-use-try-catch-in-multiple-sets-of-arrays-in-jq",
        "title": "How do i use try catch in multiple sets of arrays in jq?"
    },
    {
        "tags": [
            "python",
            "csv",
            "command-line",
            "jq",
            "json2csv"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 4879,
                    "reputation": 248190,
                    "user_id": 7552,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/b60298053f87465641c1b1192338c8cd?s=256&d=identicon&r=PG",
                    "display_name": "glenn jackman",
                    "link": "https://stackoverflow.com/users/7552/glenn-jackman"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1661901068,
                "post_id": 73547586,
                "comment_id": 129880922,
                "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": 1661902496,
                "post_id": 73547586,
                "comment_id": 129881154,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 21612412,
                    "reputation": 5,
                    "user_id": 15938726,
                    "user_type": "registered",
                    "profile_image": "https://lh3.googleusercontent.com/a/AATXAJwCZUcrnLB_dNAGF0g1jcn-I8geaR5PQ6HShbuW=k-s256",
                    "display_name": "Joseph",
                    "link": "https://stackoverflow.com/users/15938726/joseph"
                },
                "reply_to_user": {
                    "account_id": 4879,
                    "reputation": 248190,
                    "user_id": 7552,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/b60298053f87465641c1b1192338c8cd?s=256&d=identicon&r=PG",
                    "display_name": "glenn jackman",
                    "link": "https://stackoverflow.com/users/7552/glenn-jackman"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1661921941,
                "post_id": 73547586,
                "comment_id": 129883726,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 21612412,
                    "reputation": 5,
                    "user_id": 15938726,
                    "user_type": "registered",
                    "profile_image": "https://lh3.googleusercontent.com/a/AATXAJwCZUcrnLB_dNAGF0g1jcn-I8geaR5PQ6HShbuW=k-s256",
                    "display_name": "Joseph",
                    "link": "https://stackoverflow.com/users/15938726/joseph"
                },
                "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": 1661922070,
                "post_id": 73547586,
                "comment_id": 129883751,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1661979210,
                "last_edit_date": 1661979210,
                "creation_date": 1661947927,
                "answer_id": 73555732,
                "question_id": 73547586,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I&#39;m working hard to really grok jq, so here you go: with no explanation:\r\n```jq\r\njq -r &#39;\r\n    .[]\r\n    | [.matchId, .timestamp] as [$matchId, $timestamp]\r\n    | (.players | [to_entries[] | .key as $id1 | .value | to_entries[] | [$id1, .key, .value.position, .value.toiseconds, .value.playername]]) as $players\r\n    | (.clubs | [to_entries[] | [.key, .value.toa, .value.details.name, .value.details.clubId]]) as $clubs\r\n    | range([$players, $clubs] | map(length) | max)\r\n    | [$matchId, $timestamp] + ($clubs[.] // [&quot;&quot;,&quot;&quot;,&quot;&quot;,&quot;&quot;]) + ($players[.] // [&quot;&quot;,&quot;&quot;,&quot;&quot;,&quot;&quot;,&quot;&quot;])\r\n    | @csv\r\n&#39; file.json\r\n```\r\n```\r\n&quot;2068447050405&quot;,1658361314,&quot;39335&quot;,&quot;486&quot;,&quot;Team one&quot;,39335,&quot;39335&quot;,&quot;189908959&quot;,&quot;defenseMen&quot;,&quot;3600&quot;,&quot;player one&quot;\r\n&quot;2068447050405&quot;,1658361314,&quot;111655&quot;,&quot;229&quot;,&quot;Team two&quot;,111655,&quot;39335&quot;,&quot;828715674&quot;,&quot;rightWing&quot;,&quot;3600&quot;,&quot;player two&quot;\r\n&quot;2068447050405&quot;,1658361314,&quot;&quot;,&quot;&quot;,&quot;&quot;,&quot;&quot;,&quot;111655&quot;,&quot;515447555&quot;,&quot;defenseMen&quot;,&quot;3600&quot;,&quot;player three&quot;\r\n&quot;2068447050405&quot;,1658361314,&quot;&quot;,&quot;&quot;,&quot;&quot;,&quot;&quot;,&quot;111655&quot;,&quot;806370074&quot;,&quot;center&quot;,&quot;3600&quot;,&quot;player four&quot;\r\n```\r\n\r\n---\r\nThe default value arrays of empty strings needs to be the same size as the amount of &quot;real&quot; data you&#39;re grabbing.\r\n\r\nSince this is a PITA to keep aligned, an update:\r\n```\r\njq -r &#39;\r\n    def empty_strings: reduce range(length) as $i ([]; . + [&quot;&quot;]);\r\n\r\n    .[]\r\n    | [.matchId, .timestamp] as [$matchId, $timestamp]\r\n    | (.players | [to_entries[] | .key as $id1 | .value | to_entries[] | [$id1, .key, .value.position, .value.toiseconds, .value.playername]]) as $players\r\n    | (.clubs | [to_entries[] | [.key, .value.toa, .value.details.name, .value.details.clubId]]) as $clubs\r\n    | range([$players, $clubs] | map(length) | max)\r\n    | [$matchId, $timestamp]\r\n      + ($clubs[.]   // ($clubs[0] | empty_strings))\r\n      + ($players[.] // ($players[0] | empty_strings))\r\n    | @csv\r\n&#39; file.json\r\n```",
                "title": "Converting Json to CSV using command line(JQ,json2csv, Python, other)"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1661979210,
        "creation_date": 1661887773,
        "last_edit_date": 1661972913,
        "question_id": 73547586,
        "body_markdown": "I am wanting to write a script to\r\n   1) fetch information then returning Json file\r\n   2) filter Json file\r\n   3) then converting that Json to CSV.\r\n\r\nI have figured out steps 1 and 2, but am stuck on steps 3. Currently I have to use an online Json to CSV converter to get the desired output.\r\n\r\nThe Online Json to CSV tool uses python for users to connect to it&#39;s API to use the conversation tool. Possibly means that the tool itself is a python module.\r\n\r\n**Json file to convert**\r\n```\r\n[{\r\n  &quot;matchId&quot;:&quot;2068447050405&quot;,\r\n  &quot;timestamp&quot;:1658361314,\r\n  &quot;clubs&quot;: {\r\n    &quot;39335&quot;: {\r\n      &quot;toa&quot;:&quot;486&quot;,\r\n      &quot;details&quot;: {\r\n        &quot;name&quot;:&quot;Team one&quot;,\r\n        &quot;clubId&quot;:39335\r\n      }},\r\n    &quot;111655&quot;: {\r\n      &quot;toa&quot;:&quot;229&quot;,\r\n      &quot;details&quot;: {\r\n        &quot;name&quot;:&quot;Team two&quot;,\r\n        &quot;clubId&quot;:111655\r\n      }}},\r\n  &quot;players&quot;: {\r\n    &quot;39335&quot;: {\r\n      &quot;189908959&quot;: {\r\n        &quot;position&quot;:&quot;defenseMen&quot;,\r\n        &quot;toiseconds&quot;:&quot;3600&quot;,\r\n        &quot;playername&quot;:&quot;player one&quot;\r\n      },\r\n      &quot;828715674&quot;: {\r\n        &quot;position&quot;:&quot;rightWing&quot;,\r\n        &quot;toiseconds&quot;:&quot;3600&quot;,\r\n        &quot;playername&quot;:&quot;player two&quot;\r\n      }},\r\n    &quot;111655&quot;: {\r\n      &quot;515447555&quot;: {\r\n        &quot;position&quot;:&quot;defenseMen&quot;,\r\n        &quot;toiseconds&quot;:&quot;3600&quot;,\r\n        &quot;playername&quot;:&quot;player three&quot;\r\n      },\r\n      &quot;806370074&quot;: {\r\n        &quot;position&quot;:&quot;center&quot;,\r\n        &quot;toiseconds&quot;:&quot;3600&quot;,\r\n        &quot;playername&quot;:&quot;player four&quot;\r\n      }}}}]\r\n```\r\n\r\n**Desired output csv code**\r\n```\r\n&quot;matchId&quot;,&quot;timestamp&quot;,&quot;clubs__|&quot;,&quot;clubs__|__toa&quot;,&quot;clubs__|__details__name&quot;,&quot;clubs__|__details__clubId&quot;,&quot;players__|&quot;,&quot;players__||&quot;,&quot;players__||__position&quot;,&quot;players__||__toiseconds&quot;,&quot;players__||__playername&quot;\r\n&quot;2068447050405&quot;,&quot;1658361314&quot;,&quot;39335&quot;,&quot;486&quot;,&quot;Team one&quot;,&quot;39335&quot;,&quot;39335&quot;,&quot;189908959&quot;,&quot;defenseMen&quot;,&quot;3600&quot;,&quot;player one&quot;\r\n&quot;2068447050405&quot;,&quot;1658361314&quot;,&quot;111655&quot;,&quot;229&quot;,&quot;Team two&quot;,&quot;111655&quot;,&quot;39335&quot;,&quot;828715674&quot;,&quot;rightWing&quot;,&quot;3600&quot;,&quot;player two&quot;\r\n&quot;2068447050405&quot;,&quot;1658361314&quot;,&quot;&quot;,&quot;&quot;,&quot;&quot;,&quot;&quot;,&quot;111655&quot;,&quot;515447555&quot;,&quot;defenseMen&quot;,&quot;3600&quot;,&quot;player three&quot;\r\n&quot;2068447050405&quot;,&quot;1658361314&quot;,&quot;&quot;,&quot;&quot;,&quot;&quot;,&quot;&quot;,&quot;111655&quot;,&quot;806370074&quot;,&quot;center&quot;,&quot;3600&quot;,&quot;player four&quot;\r\n```\r\n**How it looks in a spreadsheet**\r\n[Sheet example][1]\r\n\r\n\r\nSome believe the filter is having an effect on how the csv out put is formatted, here is a link to the full json file and csv output of that file. Code is to long to post on this page.\r\n\r\n**Original JSON before filter**\r\n[Original JSON][2]\r\n\r\n**CSV output of original JSON file**\r\n[CSV output][3]\r\n\r\n*Edit*\r\nI should have mentioned this, The &quot;Jason file to convert is only a small sample of the actual Json I wish to convert. I assumed I would be able to simple add to the code used to answer, I was wrong.\r\nThe Json I intend to use has 9 total columns for clubs and 52 columns for Players.\r\n\r\n  [1]: https://i.sstatic.net/DQEKa.png\r\n  [3]: https://gist.githubusercontent.com/dohman89/f7f1b32dbbe78fbff0afe221d00ef6e4/raw/423939c50d4ab91bc27a4304320f676270d8562f/csv%2520example\r\n  [2]: https://gist.githubusercontent.com/dohman89/f7f1b32dbbe78fbff0afe221d00ef6e4/raw/02cf7971568a95ee1180e66ed133493b24d49459/gistfile1.txt",
        "link": "https://stackoverflow.com/questions/73547586/converting-json-to-csv-using-command-linejq-json2csv-python-other",
        "title": "Converting Json to CSV using command line(JQ,json2csv, Python, other)"
    },
    {
        "tags": [
            "json",
            "bash",
            "command-line-interface",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1661898042,
                "creation_date": 1661898042,
                "answer_id": 73548997,
                "question_id": 73548916,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Just pipe the filters together within a single `jq` command:\r\n\r\n    jq -c &#39;.[] | select(. property==&quot;undesired&quot;) | del(.property)&#39; file.json",
                "title": "Is there a way to filter a JSON list with jq and remove an attribute from the filtered results with a single command?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1661898042,
        "creation_date": 1661897242,
        "question_id": 73548916,
        "body_markdown": "Figured this line works, but uses jq twice:\r\n\r\n```bash\r\ncat file.json | jq -c &#39;.[] | select(.property==&quot;undesired&quot;)&#39; | jq -c &#39;del(.property)&#39;\r\n```\r\n\r\nIs there a way to invoke jq just once? ",
        "link": "https://stackoverflow.com/questions/73548916/is-there-a-way-to-filter-a-json-list-with-jq-and-remove-an-attribute-from-the-fi",
        "title": "Is there a way to filter a JSON list with jq and remove an attribute from the filtered results with a single command?"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1661926744,
                "creation_date": 1661926744,
                "answer_id": 73551600,
                "question_id": 73551461,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I was able to fix this by:\r\n\r\n```\r\n$ jq &#39;(.data[]|select(.id==100)).content|=&quot;watermelon&quot;&#39; test.json \r\n{\r\n  &quot;data&quot;: [\r\n    {\r\n      &quot;id&quot;: 0,\r\n      &quot;content&quot;: &quot;apple&quot;\r\n    },\r\n    {\r\n      &quot;id&quot;: 100,\r\n      &quot;content&quot;: &quot;watermelon&quot;\r\n    }\r\n  ]\r\n}\r\n```",
                "title": "How to output the whole json after making change by jq"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1661948853,
                "creation_date": 1661948853,
                "answer_id": 73555911,
                "question_id": 73551461,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "A less elegant attempt\r\n```sh\r\njq &#39;.data |= map(.content = if .id == 100 then &quot;watermelons&quot; else .content end)&#39; file.json\r\n```",
                "title": "How to output the whole json after making change by jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1661948853,
        "creation_date": 1661925613,
        "question_id": 73551461,
        "body_markdown": "I have json file test.json:\r\n\r\n```\r\n{\r\n  &quot;data&quot;: [\r\n    {\r\n      &quot;id&quot;: 0,\r\n      &quot;content&quot;: &quot;apple&quot;\r\n    },\r\n    {\r\n      &quot;id&quot;: 100,\r\n      &quot;content&quot;: &quot;pears&quot;\r\n    }\r\n  ]\r\n}\r\n```\r\n\r\nI want to change &quot;content&quot; of &quot;id&quot;==100 to &quot;watermelon&quot; then output the whole of test.json.\r\n\r\nBut when I do:\r\n\r\n```\r\n$ jq &#39;.data[]|select(.id==100)|.content|=&quot;watermelon&quot;&#39; test.json\r\n{\r\n  &quot;id&quot;: 100,\r\n  &quot;content&quot;: &quot;watermelon&quot;\r\n}\r\n```\r\n\r\nI don&#39;t get the output of the changed whole test.json but just the portion of it.\r\n\r\nHow do I make the aforementioned change to test.json and output the whole of test.json?",
        "link": "https://stackoverflow.com/questions/73551461/how-to-output-the-whole-json-after-making-change-by-jq",
        "title": "How to output the whole json after making change by jq"
    },
    {
        "tags": [
            "aws-cloudformation",
            "jq",
            "yq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 192652,
                    "reputation": 1559,
                    "user_id": 433922,
                    "user_type": "registered",
                    "accept_rate": 53,
                    "profile_image": "https://www.gravatar.com/avatar/77971018b92849e461b86d4ca7442ded?s=256&d=identicon&r=PG",
                    "display_name": "Chip",
                    "link": "https://stackoverflow.com/users/433922/chip"
                },
                "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": 1661966918,
                "post_id": 73551977,
                "comment_id": 129899429,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1661993638,
                "creation_date": 1661993638,
                "answer_id": 73563280,
                "question_id": 73551977,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Thanks to the question &quot;https://stackoverflow.com/questions/42097410/how-to-check-for-presence-of-key-in-jq-before-iterating-over-the-values&quot; and also trying out some various queries to see what output .Resources.Properties.ManagedPolicyArns[] is returning (ie. nulls), I figured it out.\r\n\r\nThere&#39;s a list of null values that it is iterating and that causes the expression to just break and not evaluate. I need to instead return true for items that are null or not matching, then all will be handled and the expression evaluated fully to true or false.\r\n\r\n`add_policy.yq`:\r\n\r\n    ( .Resources[] |= \r\n        select(\r\n            (.Properties.AssumeRolePolicyDocument.Statement[].Principal.Service.[] == &quot;ecs-tasks.amazonaws.com&quot; \r\n                or .Properties.AssumeRolePolicyDocument.Statement[].Principal.Service.[] == &quot;lambda.amazonaws.com&quot;)\r\n            and (\r\n                .Properties.ManagedPolicyArns[] == null\r\n                or ( .Properties.ManagedPolicyArns[].&quot;Fn::ImportValue&quot; == &quot;${MyPrefix}-my-policy-arn&quot; | not )\r\n            )\r\n        )\r\n        .Properties.ManagedPolicyArns += {&quot;Fn::ImportValue&quot;: &quot;${MyPrefix}-my-policy-arn&quot; | . tag = &quot;!Sub&quot; }\r\n    )",
                "title": "How to yq select contains on a field with an object with a value of tags and special characters?"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1661993638,
        "creation_date": 1661929100,
        "last_edit_date": 1661966886,
        "question_id": 73551977,
        "body_markdown": "I need to add ManagedPolicyArns to many IAM roles in many cloudformation.yaml files. Some already have this policy added so I need to select, in order to add, only those that do not. I&#39;m using yq (https://github.com/mikefarah/yq/) version 4.27.3, which is fantastic.\r\n\r\nCommand:\r\n\r\n    yq --from-file add_policy.yq cloudformation.yaml\r\n\r\n`cloudformation.yaml`:\r\n\r\n    AWSTemplateFormatVersion: &quot;2010-09-09&quot;\r\n    Parameters:\r\n      MyPrefix:\r\n        Description: MyPrefix\r\n        Type: String\r\n    Resources:\r\n      MyRole:\r\n        Type: AWS::IAM::Role\r\n        Properties:\r\n          ManagedPolicyArns:\r\n            - Fn::ImportValue: !Sub &quot;${MyPrefix}-my-policy-arn&quot;\r\n          AssumeRolePolicyDocument:\r\n            Version: &#39;2012-10-17&#39;\r\n            Statement:\r\n              - Effect: Allow\r\n                Principal:\r\n                  Service:\r\n                    - ecs-tasks.amazonaws.com\r\n                    - lambda.amazonaws.com\r\n                Action:\r\n                  - sts:AssumeRole\r\n                  - sts:TagSession\r\n          Path: /\r\n\r\n\r\nPartially working in that it always adds the policy creating duplicates, `add_policy.yq`:\r\n\r\n    ( .Resources[] |= \r\n        select(\r\n            (.Properties.AssumeRolePolicyDocument.Statement[].Principal.Service.[] == &quot;ecs-tasks.amazonaws.com&quot; \r\n                or .Properties.AssumeRolePolicyDocument.Statement[].Principal.Service.[] == &quot;lambda.amazonaws.com&quot;)\r\n            and (.Properties.ManagedPolicyArns | contains([{&quot;Fn::ImportValue&quot;: &quot;${MyPrefix}-my-policy-arn&quot;}]) | not ) )\r\n        .Properties.ManagedPolicyArns += {&quot;Fn::ImportValue&quot;: &quot;${MyPrefix}-my-policy-arn&quot; | . tag = &quot;!Sub&quot; }\r\n    )\r\n\r\nDoes does not add the policy at all and fails silently, `add_policy.yq`\r\n\r\n    ( .Resources[] |= \r\n        select(\r\n            (.Properties.AssumeRolePolicyDocument.Statement[].Principal.Service.[] == &quot;ecs-tasks.amazonaws.com&quot; \r\n                or .Properties.AssumeRolePolicyDocument.Statement[].Principal.Service.[] == &quot;lambda.amazonaws.com&quot;)\r\n            and (.Properties.ManagedPolicyArns[].&quot;Fn::ImportValue&quot; | contains(&quot;${MyPrefix}-my-policy-arn&quot; | . tag = &quot;!Sub&quot;) | not) )\r\n        .Properties.ManagedPolicyArns += {&quot;Fn::ImportValue&quot;: &quot;${MyPrefix}-my-policy-arn&quot; | . tag = &quot;!Sub&quot; }\r\n    )\r\n\r\nI&#39;m failing to see from the simpler examples in the docs, How do I keep `ManagedPolicyArns` unique and not add the new entry to it if it already exists?",
        "link": "https://stackoverflow.com/questions/73551977/how-to-yq-select-contains-on-a-field-with-an-object-with-a-value-of-tags-and-spe",
        "title": "How to yq select contains on a field with an object with a value of tags and special characters?"
    },
    {
        "tags": [
            "arrays",
            "json",
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 6313442,
                    "reputation": 45115,
                    "user_id": 5625547,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/oqCND.jpg?s=256",
                    "display_name": "0stone0",
                    "link": "https://stackoverflow.com/users/5625547/0stone0"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1661939396,
                "post_id": 73553724,
                "comment_id": 129889180,
                "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": 1661939954,
                "post_id": 73553724,
                "comment_id": 129889388,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 26138911,
                    "reputation": 1,
                    "user_id": 19828571,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/79d1e22594957afd4ae17f37b3da545d?s=256&d=identicon&r=PG",
                    "display_name": "def0to",
                    "link": "https://stackoverflow.com/users/19828571/def0to"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1661941297,
                "post_id": 73553724,
                "comment_id": 129889891,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 468289,
                    "reputation": 190915,
                    "user_id": 874188,
                    "user_type": "registered",
                    "accept_rate": 62,
                    "profile_image": "https://www.gravatar.com/avatar/091f411d57db5be8298e057a32e5ad72?s=256&d=identicon&r=PG",
                    "display_name": "tripleee",
                    "link": "https://stackoverflow.com/users/874188/tripleee"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1661945414,
                "post_id": 73553724,
                "comment_id": 129891253,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 26138911,
                    "reputation": 1,
                    "user_id": 19828571,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/79d1e22594957afd4ae17f37b3da545d?s=256&d=identicon&r=PG",
                    "display_name": "def0to",
                    "link": "https://stackoverflow.com/users/19828571/def0to"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1662025530,
                "post_id": 73553724,
                "comment_id": 129912759,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 39208,
                    "reputation": 267964,
                    "user_id": 112968,
                    "user_type": "registered",
                    "accept_rate": 68,
                    "profile_image": "https://i.sstatic.net/zHTaT.png?s=256",
                    "display_name": "knittl",
                    "link": "https://stackoverflow.com/users/112968/knittl"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1663577181,
                "post_id": 73553724,
                "comment_id": 130264133,
                "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": 1663578775,
                "post_id": 73553724,
                "comment_id": 130264634,
                "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": 1664728994,
                "post_id": 73553724,
                "comment_id": 130533637,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1661950791,
                "creation_date": 1661950791,
                "answer_id": 73556288,
                "question_id": 73553724,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "After fixing your input JSON, I think you can get the desired output by using the following JQ filter:\r\n```none\r\nif (.result | type) == &quot;array&quot; then . else (.result |= [.]) end \\\r\n    | .result[].software | [ .name, (.platform // [ &quot;Empty&quot; ] | join(&quot;,&quot;)) ]\r\n```\r\n\r\nWhere\r\n\r\n* `if (.result | type) == &quot;array&quot; then . else (.result |= [.]) end`  \r\n    Wraps `.result` in an array if `type` isn&#39;t array\r\n\r\n* `.result[].software`  \r\n    Loops though the `software` in each `.result` obj\r\n\r\n* `[ .name, (.platform // [ &quot;Empty&quot; ] | join(&quot;,&quot;)) ]`  \r\n    Create an array with `.name` and `.platform` (which is replaced by `[ &quot;Empty&quot; ]` when it doesn&#39;t exist. Then it&#39;s `join()`&#39;d to a string\r\n\r\n\r\n----------\r\n\r\n\r\nOutcome:\r\n\r\n```json\r\n[\r\n  &quot;Bluetooth Mesh SDK&quot;,\r\n  &quot;Linux,Android&quot;\r\n]\r\n```\r\n[Online demo](https://jqplay.org/s/pYhInDK_Vez)\r\n\r\nOr\r\n```json\r\n[\r\n  &quot;Bluetooth Mesh SDK&quot;,\r\n  &quot;Empty\r\n]\r\n```\r\n[Online demo](https://jqplay.org/s/2VX_gABa-vv)\r\n",
                "title": "JQ if else then NULL Return"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": -3,
        "last_activity_date": 1661955943,
        "creation_date": 1661937967,
        "last_edit_date": 1661955943,
        "question_id": 73553724,
        "body_markdown": "I&#39;m trying to filter and output from JSON with `jq`.\r\n\r\nThe API will sometime return an object and sometime an array, I want to catch the result using an `if` statement and return empty string when the object/array is not available.\r\n```    \r\n{\r\n    &quot;result&quot;: \r\n        {\r\n            &quot;entry&quot;: {\r\n                &quot;id&quot;: &quot;207579&quot;,\r\n                &quot;title&quot;: &quot;Realtek Bluetooth Mesh SDK on Linux\\/Android Segmented Packet reference buffer overflow&quot;,\r\n                &quot;summary&quot;: &quot;A vulnerability, which was classified as critical, was found in Realtek Bluetooth Mesh SDK on Linux\\/Android (the affected version unknown). This affects an unknown functionality of the component Segmented Packet Handler. There is no information about possible countermeasures known. It may be suggested to replace the affected object with an alternative product.&quot;,\r\n                &quot;details&quot;: {\r\n                    &quot;affected&quot;: &quot;A vulnerability, which was classified as critical, was found in Realtek Bluetooth Mesh SDK on Linux\\/Android (the affected version unknown).&quot;,\r\n                    &quot;vulnerability&quot;: &quot;The manipulation of the argument reference with an unknown input leads to a unknown weakness. CWE is classifying the issue as CWE-120. The program copies an input buffer to an output buffer without verifying that the size of the input buffer is less than the size of the output buffer, leading to a buffer overflow.&quot;,\r\n                    &quot;impact&quot;: &quot;This is going to have an impact on confidentiality, integrity, and availability.&quot;,\r\n                    &quot;countermeasure&quot;: &quot;There is no information about possible countermeasures known. It may be suggested to replace the affected object with an alternative product.&quot;\r\n                },\r\n                &quot;timestamp&quot;: {\r\n                    &quot;create&quot;: &quot;1661860801&quot;,\r\n                    &quot;change&quot;: &quot;1661861110&quot;\r\n                },\r\n                &quot;changelog&quot;: [\r\n                    &quot;software_argument&quot;\r\n                ]\r\n            },\r\n            &quot;software&quot;: {\r\n                &quot;vendor&quot;: &quot;Realtek&quot;,\r\n                &quot;name&quot;: &quot;Bluetooth Mesh SDK&quot;,\r\n                &quot;platform&quot;: [\r\n                    &quot;Linux&quot;,\r\n                    &quot;Android&quot;\r\n                ],\r\n                &quot;component&quot;: &quot;Segmented Packet Handler&quot;,\r\n                &quot;argument&quot;: &quot;reference&quot;,\r\n                &quot;cpe&quot;: [\r\n                    &quot;cpe:\\/a:realtek:bluetooth_mesh_sdk&quot;\r\n                ],\r\n                &quot;cpe23&quot;: [\r\n                    &quot;cpe:2.3:a:realtek:bluetooth_mesh_sdk:*:*:*:*:*:*:*:*&quot;\r\n                ]\r\n            }\r\n        }\r\n    \r\n}\r\n```\r\n\r\nWould also like to  to use the statement globally for the whole array output so I can parse it to .csv and escape the null, since sofware name , can also contain an array or an object. Having a global `if` statement with simplify the syntax  result and suppress the error with `?`\r\n\r\nThe error i received from `bash`\r\n\r\n```\r\njq  -r &#39;.result []   |  [ &quot;https://vuldb.com/?id.&quot; + .entry.id ,.software.vendor // &quot;empty&quot;,(.software.name | if type!=&quot;array&quot; then [.] | join (&quot;,&quot;)  else . //&quot;empty&quot; end  )?,.software.type //  &quot;empty&quot;,(.software.platform | if type!=&quot;array&quot; then []  else . | join (&quot;,&quot;) //&quot;empty&quot; end )?] | @csv&#39; &gt; tst.csv\r\n  % Total    % Received % Xferd  Average Speed   Time    Time     Time  Current\r\n                                 Dload  Upload   Total   Spent    Left  Speed\r\n100  7452    0  7393  100    59   4892     39  0:00:01  0:00:01 --:--:--  4935\r\njq: error (at &lt;stdin&gt;:182): Cannot iterate over null (null)\r\n```\r\n\r\nWhat I have tried is the following code which i tried to demo https://jqplay.org/ which is incorrect syntax \r\n```\r\n.result [] |( if .[] == null  then // &quot;empty&quot; else . end \r\n| ,software.name // &quot;empty&quot; ,.software.platform |if type!=&quot;array&quot; then [.]  // &quot;empty&quot; else . | join (&quot;,&quot;)  end)\r\n```\r\n\r\nCurrent output \r\n\r\n```\r\n[\r\n  [\r\n    &quot;Bluetooth Mesh SDK&quot;\r\n  ],\r\n  &quot;Linux,Android&quot;\r\n]\r\n```\r\nDesired outcome \r\n\r\n```\r\n[\r\n  \r\n  &quot;Bluetooth Mesh SDK&quot;,\r\n  &quot;empty&quot;\r\n]\r\n```\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/73553724/jq-if-else-then-null-return",
        "title": "JQ if else then NULL Return"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 6,
                "is_accepted": true,
                "score": 6,
                "last_activity_date": 1662024260,
                "last_edit_date": 1662024260,
                "creation_date": 1662023908,
                "answer_id": 73566973,
                "question_id": 73566899,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Yes, it&#39;s pretty straightforward actually.\r\n```\r\n.compatibility | to_entries[] | select(.value | index(&quot;8.1.0&quot;)) .key\r\n```\r\n&lt;sup&gt;[Online demo](https://jqplay.org/s/dqwW6fvSLC3)&lt;/sup&gt;\r\n\r\nIn case it&#39;s unclear, the version string doesn&#39;t have to be hardcoded; it may come from outside the program too: \r\n``` sh\r\njq --arg version 8.1.0 &#39;.compatibility | to_entries[] | select(.value | index($version)) .key&#39;\r\n```",
                "title": "jq find a key name in multi-map structured JSON"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1662098728,
                "creation_date": 1662098728,
                "answer_id": 73578398,
                "question_id": 73566899,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If you need to query the same data set several times, it might be worth creating an index object, store it in a variable, and perform the lookup from there:\r\n~~~sh\r\n(.compatibility | with_entries({value: .key, key: .value[]})) as $lookup\r\n\r\n# various ways to lookup multiple versions\r\n| $lookup[&quot;8.0.1&quot;, &quot;7.11.2&quot;], $lookup[&quot;7.16.1&quot;]\r\n~~~\r\n~~~json\r\n&quot;v7.15.x&quot;\r\n&quot;v7.11.x&quot;\r\n&quot;v7.15.x&quot;\r\n~~~\r\n[Demo](https://jqplay.org/s/TE7RiAmbdo6)",
                "title": "jq find a key name in multi-map structured JSON"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": -1,
        "last_activity_date": 1662098728,
        "creation_date": 1662023574,
        "last_edit_date": 1662023720,
        "question_id": 73566899,
        "body_markdown": "I have this JSON object that maps the compatibility of patch sets to specific software versions.\r\n\r\n\r\n```json\r\n{\r\n   &quot;compatibility&quot;:{\r\n      &quot;v7.11.x&quot;:[\r\n         &quot;7.12.1&quot;,\r\n         &quot;7.12.0&quot;,\r\n         &quot;7.11.2&quot;,\r\n         &quot;7.11.1&quot;,\r\n         &quot;7.11.0&quot;\r\n      ],\r\n      &quot;v7.13.x&quot;:[\r\n         &quot;7.14.2&quot;,\r\n         &quot;7.14.1&quot;,\r\n         &quot;7.14.0&quot;,\r\n         &quot;7.13.1&quot;,\r\n         &quot;7.13.0&quot;\r\n      ],\r\n      &quot;v7.15.x&quot;:[\r\n         &quot;8.1.0&quot;,\r\n         &quot;8.0.1&quot;,\r\n         &quot;8.0.0&quot;,\r\n         &quot;7.17.1&quot;,\r\n         &quot;7.17.0&quot;,\r\n         &quot;7.16.1&quot;,\r\n         &quot;7.16.0&quot;,\r\n         &quot;7.15.1&quot;,\r\n         &quot;7.15.0&quot;\r\n      ]\r\n   }\r\n}\r\n```\r\n\r\nWould it be possible for `jq` to return the patch set name (e.g. &quot;v7.15.x&quot;) when given \r\n the specific version (e.g. &quot;8.1.0&quot;)?",
        "link": "https://stackoverflow.com/questions/73566899/jq-find-a-key-name-in-multi-map-structured-json",
        "title": "jq find a key name in multi-map structured JSON"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1662120327,
                "last_edit_date": 1662120327,
                "creation_date": 1662119382,
                "answer_id": 73582115,
                "question_id": 73581846,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Assuming the first element is always the mother, this should work just fine:\r\n```\r\n.data[].assets.array |= (.[1].properties.parent = .[0].id)\r\n```\r\n&lt;sup&gt;[Online demo](https://jqplay.org/s/IzBYbkWSDjb)&lt;/sup&gt;\r\n\r\nOtherwise sort them by `labels.text` first so that they are always at certain indices.\r\n```\r\n.data[].assets.array |= (sort_by(.labels.text) | .[0].properties.parent = .[1].id)\r\n```",
                "title": "Copying fields between array elements in JQ"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1662121300,
                "creation_date": 1662121300,
                "answer_id": 73582507,
                "question_id": 73581846,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "```\r\njq &#39;.data |= map(.assets.array | .[1].properties.parent = .[0].id)&#39; test.json\r\n```",
                "title": "Copying fields between array elements in JQ"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1662121300,
        "creation_date": 1662117953,
        "last_edit_date": 1662119415,
        "question_id": 73581846,
        "body_markdown": "I&#39;m relatively new to JQ and this might be a simple question.\r\n\r\nI have a big, pretty nested JSON file with thousands of *assets*. Each asset always contains one array with two objects (one mother and one child).\r\n\r\n```\r\n{\r\n  &quot;data&quot;: [\r\n    {\r\n      &quot;assets&quot;: {\r\n        &quot;array&quot;: [\r\n          {\r\n            &quot;id&quot;: &quot;7978918&quot;,\r\n            &quot;labels&quot;: {\r\n              &quot;text&quot;: &quot;mother&quot;,\r\n              &quot;value&quot;: true\r\n            },\r\n            &quot;properties&quot;: {\r\n              &quot;context_ids&quot;: [],\r\n              &quot;parent&quot;: null\r\n            }\r\n          },\r\n          {\r\n            &quot;id&quot;: &quot;caa17b2a-4582-4d13-b891-2607e4ba33c6&quot;,\r\n            &quot;labels&quot;: {\r\n              &quot;text&quot;: &quot;child&quot;,\r\n              &quot;value&quot;: true\r\n            },\r\n            &quot;properties&quot;: {\r\n              &quot;context_ids&quot;: [],\r\n              &quot;parent&quot;: null\r\n            }\r\n          }\r\n        ]\r\n      }\r\n    }\r\n  ]\r\n}\r\n```\r\n\r\nWhat I want to do is copying the id from the mother object into the parent field of the child object.\r\n\r\n```\r\n{\r\n  &quot;data&quot;: [\r\n    {\r\n      &quot;assets&quot;: {\r\n        &quot;array&quot;: [\r\n          {\r\n            &quot;id&quot;: &quot;7978918&quot;,\r\n            &quot;labels&quot;: {\r\n              &quot;text&quot;: &quot;mother&quot;,\r\n              &quot;value&quot;: true\r\n            },\r\n            &quot;properties&quot;: {\r\n              &quot;context_ids&quot;: [],\r\n              &quot;parent&quot;: null\r\n            }\r\n          },\r\n          {\r\n            &quot;id&quot;: &quot;caa17b2a-4582-4d13-b891-2607e4ba33c6&quot;,\r\n            &quot;labels&quot;: {\r\n              &quot;text&quot;: &quot;child&quot;,\r\n              &quot;value&quot;: true\r\n            },\r\n            &quot;properties&quot;: {\r\n              &quot;context_ids&quot;: [],\r\n              &quot;parent&quot;: &quot;7978918&quot;\r\n            }\r\n          }\r\n        ]\r\n      }\r\n    }\r\n  ]\r\n}\r\n```\r\n\r\nSo far I got\r\n\r\n``` sh\r\ncat test.json | jq &#39;.data[].assets.array[]|=(.properties.parent=.id|select(.labels.text==&quot;mother&quot;))&#39; |less\r\n```\r\n\r\nbut this, of course, only copies the mother `id` into the mother object&#39;s `parent` field and deletes the child object entirely. \r\n\r\nI also tried\r\n\r\n``` sh\r\ncat test.json | jq &#39;.data[].assets.array[].properties += {&quot;parent&quot;: .data[].assets.array[0].id} |less\r\n```\r\n\r\nOn first sight this looked to be correct but seemingly has created a strange loop which never stops and creates a bigger and bigger JSON.",
        "link": "https://stackoverflow.com/questions/73581846/copying-fields-between-array-elements-in-jq",
        "title": "Copying fields between array elements in JQ"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 6190276,
                    "reputation": 3,
                    "user_id": 6807871,
                    "user_type": "registered",
                    "profile_image": "https://lh5.googleusercontent.com/-TmujoirxWKk/AAAAAAAAAAI/AAAAAAAAD2k/h6j6i78u1FE/s256-rj/photo.jpg",
                    "display_name": "Antti Lagus",
                    "link": "https://stackoverflow.com/users/6807871/antti-lagus"
                },
                "reply_to_user": {
                    "account_id": 9629731,
                    "reputation": 51350,
                    "user_id": 10248678,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d8f818402f22d485b135a3b685ef908e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "oguz ismail",
                    "link": "https://stackoverflow.com/users/10248678/oguz-ismail"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1662122856,
                "post_id": 73582719,
                "comment_id": 129939159,
                "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": 2,
                "creation_date": 1662123092,
                "post_id": 73582719,
                "comment_id": 129939254,
                "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": 1662123233,
                "post_id": 73582719,
                "comment_id": 129939307,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1274901,
                    "reputation": 5406,
                    "user_id": 1230360,
                    "user_type": "registered",
                    "accept_rate": 75,
                    "profile_image": "https://www.gravatar.com/avatar/353f6b7e232b23141659afa77911c77d?s=256&d=identicon&r=PG",
                    "display_name": "Ketan Bhavsar",
                    "link": "https://stackoverflow.com/users/1230360/ketan-bhavsar"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1662124031,
                "post_id": 73582719,
                "comment_id": 129939624,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1662123640,
                "last_edit_date": 1662123640,
                "creation_date": 1662123148,
                "answer_id": 73582876,
                "question_id": 73582719,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s one way with a valid output JSON as array of objects:\r\n~~~sh\r\njq &#39;map(\r\n  .results[] as $r | select($r.comments | test(&quot;whatamImissing&quot;))\r\n  | {bar} + ($r | {name, comments})\r\n)&#39;\r\n~~~\r\n~~~json\r\n[\r\n  {\r\n    &quot;bar&quot;: &quot;thisIsneeded&quot;,\r\n    &quot;name&quot;: &quot;foo&quot;,\r\n    &quot;comments&quot;: &quot;whatamImissing&quot;\r\n  }\r\n]\r\n~~~\r\n[Demo](https://jqplay.org/s/aYdE4WG-6q9)\r\n\r\n---\r\nHere&#39;s another way with a nested array\r\n~~~sh\r\njq &#39;map(\r\n  .results |= map(select(.comments | test(&quot;whatamImissing&quot;))\r\n  | {name, comments}) | {bar, results}\r\n)&#39;\r\n~~~\r\n~~~json\r\n[\r\n  {\r\n    &quot;bar&quot;: &quot;thisIsneeded&quot;,\r\n    &quot;results&quot;: [\r\n      {\r\n        &quot;name&quot;: &quot;foo&quot;,\r\n        &quot;comments&quot;: &quot;whatamImissing&quot;\r\n      }\r\n    ]\r\n  }\r\n]\r\n~~~\r\n[Demo](https://jqplay.org/s/KaYDQV5XTZP)",
                "title": "How do I get wanted data structure with jq"
            },
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1662131373,
                "creation_date": 1662131373,
                "answer_id": 73584682,
                "question_id": 73582719,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Another take:\r\n```sh\r\njq &#39;\r\n    map({\r\n        bar,\r\n        result: (\r\n            .results[]\r\n            | select(.comments | contains(&quot;whatamI&quot;))\r\n            | {name, comments}\r\n        )\r\n    })\r\n&#39;\r\n```\r\n```json\r\n[\r\n  {\r\n    &quot;bar&quot;: &quot;thisIsneeded&quot;,\r\n    &quot;result&quot;: {\r\n      &quot;name&quot;: &quot;foo&quot;,\r\n      &quot;comments&quot;: &quot;whatamImissing&quot;\r\n    }\r\n  }\r\n]\r\n```\r\n",
                "title": "How do I get wanted data structure with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1662131373,
        "creation_date": 1662122429,
        "last_edit_date": 1662122963,
        "question_id": 73582719,
        "body_markdown": "I have lots of data from where I try to extract details when value contains certain string (here &quot;whatamImissing&quot;).\r\n```\r\n[\r\n {\r\n  &quot;http_method&quot;: &quot;GET&quot;,\r\n  &quot;revision&quot;: &quot;2226.1.0.17580034458892190058.1564516060&quot;,\r\n  &quot;results&quot;: [\r\n    {\r\n      &quot;origin&quot;: 80,\r\n      &quot;name&quot;: &quot;foo&quot;,     \r\n      &quot;comments&quot;: &quot;whatamImissing&quot;,\r\n      &quot;emptydata&quot;: &quot;&quot;\r\n    }\r\n  ],\r\n  &quot;bar&quot;: &quot;thisIsneeded&quot;,\r\n  &quot;meta&quot;: &quot;metainfo&quot;\r\n }\r\n]\r\n```\r\nso far the nearest I&#39;ve managed is with this:\r\n```\r\njq &#39;.[] | [.bar, (.results[] | select(.comments | test(&quot;whatamImissing&quot;))|{name: .name, comments: .comments})]&#39;\r\n```\r\nwhich returns\r\n```\r\n[\r\n  &quot;thisIsneeded&quot;,\r\n  {\r\n    &quot;name&quot;: &quot;foo&quot;,\r\n    &quot;comments&quot;: &quot;whatamImissing&quot;\r\n  }\r\n]\r\n```\r\nWhat I want is \r\n```\r\n{\r\n  &quot;bar&quot;: &quot;thisIsneeded&quot;,\r\n  {\r\n    &quot;name&quot;: &quot;foo&quot;,\r\n    &quot;comments&quot;: &quot;whatamImissing&quot;\r\n  }\r\n}",
        "link": "https://stackoverflow.com/questions/73582719/how-do-i-get-wanted-data-structure-with-jq",
        "title": "How do I get wanted data structure with jq"
    },
    {
        "tags": [
            "json",
            "bash",
            "shell",
            "filter",
            "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": 1662140977,
                "post_id": 73586326,
                "comment_id": 129945547,
                "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": 1662141075,
                "post_id": 73586326,
                "comment_id": 129945578,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "is_answered": false,
        "answer_count": 0,
        "score": 0,
        "last_activity_date": 1662370921,
        "creation_date": 1662140913,
        "last_edit_date": 1662370921,
        "question_id": 73586326,
        "body_markdown": "I am writing a shell script that will read from a text file line by line some item names stored in the $entry variable within a while loop. With a curl command, I retrieve a json which is given as sample json response. I need to be able to compare the input text value which is saved in $entry to all the values within the item_name array and return true/false depending on if the $entry value is present using jq library. I am able to retrieve the item names values using the jq command written below, but I am not familiar how to compare with the input string. when I use &quot;select&quot; command to compare, I get syntax error. I am quite new to jq and not proficient with using filters/select statement for comparison, any pointers on how to resolve it?\r\n\r\nbash variable\r\n\r\n    $entry = &quot;some value from a text file&quot;\r\n\r\nsample json response\r\n\r\n    &quot;response&quot;: {\r\n        &quot;numFound&quot;: 2,\r\n        &quot;docs&quot;: [{\r\n                &quot;country&quot;: &quot;USA&quot;,\r\n                &quot;item_name&quot;: [\r\n                    &quot;parachutes&quot;,\r\n                    &quot;air balloon&quot;\r\n                ]\r\n            },\r\n            {\r\n                &quot;country&quot;: &quot;Brazil&quot;,\r\n                &quot;item_name&quot;: [\r\n                    &quot;gliders&quot;,\r\n                    &quot;aircraft carriers&quot;\r\n                ]\r\n            }\r\n        ]\r\n    }\r\n\r\njq command\r\n\r\n    echo &quot;$RESPONSE&quot; | jq &#39;.&#39; | jq &#39;.[&quot;response&quot;][&quot;docs&quot;]&#39; | jq &#39;.[].item_name&#39; | jq - r &#39;.[]&#39;\r\n\r\n\r\nUpdate:\r\n\r\nThe jq command that works as expected is\r\n\r\n    echo $RESPONSE | jq -e &#39;.&#39; | jq -r &#39;.[&quot;response&quot;][&quot;docs&quot;] | .[].item_name &#39; | jq -s &#39;add&#39; | jq &#39;any(. == &quot;&#39;&quot;$entry&quot;&#39;&quot;) | if . == true then &quot;Exact match&quot; else &quot;No Exact match&quot; end&#39;\r\n",
        "link": "https://stackoverflow.com/questions/73586326/jq-library-compare-string-from-an-array-to-a-bash-variablenot-static-value",
        "title": "jq library: compare string from an array to a bash variable(not static value)"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1662233660,
                "last_edit_date": 1662233660,
                "creation_date": 1662202950,
                "answer_id": 73591715,
                "question_id": 73591710,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Use \r\n\r\n```sh\r\njq &#39;{names: [.[] | {name: .name}]}&#39;\r\n```\r\n\r\nAlternatively, we use a few shortcuts produces the shorten the above.\r\n\r\n```sh\r\njq &#39;{names: map({name})}&#39;\r\n```\r\n",
                "title": "How can I name the output array in jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1662233660,
        "creation_date": 1662202918,
        "question_id": 73591710,
        "body_markdown": "Here&#39;s my JSON input\r\n\r\n```json\r\n[\r\n  {\r\n    &quot;name&quot;: &quot;A&quot;,\r\n    &quot;age&quot;: 1\r\n  },\r\n  {\r\n    &quot;name&quot;: &quot;B&quot;,\r\n    &quot;age&quot;: 2\r\n  },\r\n  {\r\n    &quot;name&quot;: &quot;C&quot;,\r\n    &quot;age&quot;: 3\r\n  }\r\n]\r\n```\r\n\r\nI want filer out only the `name` fields and create an array named `names` \r\n\r\n```json\r\n{\r\n  &quot;names&quot;: [\r\n    {\r\n      &quot;name&quot;: &quot;A&quot;\r\n    },\r\n    {\r\n      &quot;name&quot;: &quot;B&quot;\r\n    },\r\n    {\r\n      &quot;name&quot;: &quot;C&quot;\r\n    }\r\n  ]\r\n}\r\n```\r\n\r\n",
        "link": "https://stackoverflow.com/questions/73591710/how-can-i-name-the-output-array-in-jq",
        "title": "How can I name the output array in jq?"
    },
    {
        "tags": [
            "json",
            "key",
            "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": 1662260737,
                "post_id": 73596490,
                "comment_id": 129963707,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1662261311,
                "last_edit_date": 1662261311,
                "creation_date": 1662259850,
                "answer_id": 73596503,
                "question_id": 73596490,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The `.foo` syntax cannot be used if the key name has anything but alphanumeric characters or the underscore, or if the first character of the key name is numeric.  \r\n\r\nAssuming you are using a recent version of jq,\r\nyou can always use the form: `.&quot;foo&quot;`, which is actually an abbreviation of the basic form, `.[&quot;foo&quot;]`.\r\n\r\nSo assuming you&#39;re using a sufficiently recent version of jq, your query could begin with:\r\n\r\n    .dataSets[0].series.&quot;0:0:0:0:0&quot;\r\n\r\n---\r\n\r\nIf you are presenting the jq query on a command line, then you may have to escape the double-quotes appropriately, e.g. in a bash shell, by enclosing the jq query in single-quotes.\r\n",
                "title": "Cannot get jq to query json object"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1662261311,
        "creation_date": 1662259516,
        "last_edit_date": 1662259886,
        "question_id": 73596490,
        "body_markdown": "I have a JSON file that I am trying to query with jq. I am unable to retrieve the observations. I am trying to retieve each of the &quot;observations using the following command and not able to get to the result:\r\n\r\n    cat sample3.json | jq .dataSets[0].series.0:0:0:0:0.observations.0[0]\r\n\r\nI am able to retieve up to the series using:\r\n\r\n    cat sample3.json | jq .dataSets[0].series\r\n\r\nBut once I try to drill down further I am getting a compile error:\r\n\r\n    $ cat sample3.json | jq .dataSets[0].series.0:0:0:0:0\r\n    jq: error: syntax error, unexpected LITERAL, expecting end of file (Unix shell quoting issues?) at &lt;top-level&gt;, line 1:\r\n    .dataSets[0].series.0:0:0:0:0                   \r\n    jq: 1 compile error\r\n\r\nI am not sure what I am doing wrong here....\r\n\r\nThe input file is:\r\n\r\n    {\r\n        &quot;header&quot;: {\r\n            &quot;id&quot;: &quot;b8be2cd5-33bf-4687-9e81-eb032f6f8a71&quot;,\r\n            &quot;test&quot;: false,\r\n            &quot;prepared&quot;: &quot;2022-09-01T13:30:57.013+02:00&quot;,\r\n            &quot;sender&quot;: {\r\n                &quot;id&quot;: &quot;ECB&quot;\r\n            }\r\n        },\r\n        &quot;dataSets&quot;: [\r\n            {\r\n                &quot;action&quot;: &quot;Replace&quot;,\r\n                &quot;validFrom&quot;: &quot;2022-09-01T13:30:57.013+02:00&quot;,\r\n                &quot;series&quot;: {\r\n                    &quot;0:0:0:0:0&quot;: {\r\n                        &quot;attributes&quot;: [\r\n                            0,\r\n                            null,\r\n                            0,\r\n                            null,\r\n                            null,\r\n                            null,\r\n                            null,\r\n                            null,\r\n                            null,\r\n                            null,\r\n                            null,\r\n                            null,\r\n                            0,\r\n                            null,\r\n                            0,\r\n                            null,\r\n                            0,\r\n                            0,\r\n                            0,\r\n                            0\r\n                        ],\r\n                        &quot;observations&quot;: {\r\n                            &quot;0&quot;: [\r\n                                1.4529,\r\n                                0,\r\n                                0,\r\n                                null,\r\n                                null\r\n                            ],\r\n                            &quot;1&quot;: [\r\n                                1.4472,\r\n                                0,\r\n                                0,\r\n                                null,\r\n                                null\r\n                            ],\r\n                            &quot;2&quot;: [\r\n                                1.4591,\r\n                                0,\r\n                                0,\r\n                                null,\r\n                                null\r\n                            ]\r\n                        }\r\n                    }\r\n                }\r\n            }\r\n        ],\r\n        &quot;structure&quot;: {\r\n            &quot;links&quot;: [\r\n                {\r\n                    &quot;title&quot;: &quot;Exchange Rates&quot;,\r\n                    &quot;rel&quot;: &quot;dataflow&quot;,\r\n                    &quot;href&quot;: &quot;https://sdw-wsrest.ecb.europa.eu:443/service/dataflow/ECB/EXR/1.0&quot;\r\n                }\r\n            ],\r\n            &quot;name&quot;: &quot;Exchange Rates&quot;,\r\n            &quot;dimensions&quot;: {\r\n                &quot;series&quot;: [\r\n                    {\r\n                        &quot;id&quot;: &quot;FREQ&quot;,\r\n                        &quot;name&quot;: &quot;Frequency&quot;,\r\n                        &quot;values&quot;: [\r\n                            {\r\n                                &quot;id&quot;: &quot;D&quot;,\r\n                                &quot;name&quot;: &quot;Daily&quot;\r\n                            }\r\n                        ]\r\n                    },\r\n                    {\r\n                        &quot;id&quot;: &quot;CURRENCY&quot;,\r\n                        &quot;name&quot;: &quot;Currency&quot;,\r\n                        &quot;values&quot;: [\r\n                            {\r\n                                &quot;id&quot;: &quot;AUD&quot;,\r\n                                &quot;name&quot;: &quot;Australian dollar&quot;\r\n                            }\r\n                        ]\r\n                    },\r\n                    {\r\n                        &quot;id&quot;: &quot;CURRENCY_DENOM&quot;,\r\n                        &quot;name&quot;: &quot;Currency denominator&quot;,\r\n                        &quot;values&quot;: [\r\n                            {\r\n                                &quot;id&quot;: &quot;EUR&quot;,\r\n                                &quot;name&quot;: &quot;Euro&quot;\r\n                            }\r\n                        ]\r\n                    },\r\n                    {\r\n                        &quot;id&quot;: &quot;EXR_TYPE&quot;,\r\n                        &quot;name&quot;: &quot;Exchange rate type&quot;,\r\n                        &quot;values&quot;: [\r\n                            {\r\n                                &quot;id&quot;: &quot;SP00&quot;,\r\n                                &quot;name&quot;: &quot;Spot&quot;\r\n                            }\r\n                        ]\r\n                    },\r\n                    {\r\n                        &quot;id&quot;: &quot;EXR_SUFFIX&quot;,\r\n                        &quot;name&quot;: &quot;Series variation - EXR context&quot;,\r\n                        &quot;values&quot;: [\r\n                            {\r\n                                &quot;id&quot;: &quot;A&quot;,\r\n                                &quot;name&quot;: &quot;Average&quot;\r\n                            }\r\n                        ]\r\n                    }\r\n                ],\r\n                &quot;observation&quot;: [\r\n                    {\r\n                        &quot;id&quot;: &quot;TIME_PERIOD&quot;,\r\n                        &quot;name&quot;: &quot;Time period or range&quot;,\r\n                        &quot;role&quot;: &quot;time&quot;,\r\n                        &quot;values&quot;: [\r\n                            {\r\n                                &quot;id&quot;: &quot;2022-08-29&quot;,\r\n                                &quot;name&quot;: &quot;2022-08-29&quot;,\r\n                                &quot;start&quot;: &quot;2022-08-29T00:00:00.000+02:00&quot;,\r\n                                &quot;end&quot;: &quot;2022-08-29T23:59:59.999+02:00&quot;\r\n                            },\r\n                            {\r\n                                &quot;id&quot;: &quot;2022-08-30&quot;,\r\n                                &quot;name&quot;: &quot;2022-08-30&quot;,\r\n                                &quot;start&quot;: &quot;2022-08-30T00:00:00.000+02:00&quot;,\r\n                                &quot;end&quot;: &quot;2022-08-30T23:59:59.999+02:00&quot;\r\n                            },\r\n                            {\r\n                                &quot;id&quot;: &quot;2022-08-31&quot;,\r\n                                &quot;name&quot;: &quot;2022-08-31&quot;,\r\n                                &quot;start&quot;: &quot;2022-08-31T00:00:00.000+02:00&quot;,\r\n                                &quot;end&quot;: &quot;2022-08-31T23:59:59.999+02:00&quot;\r\n                            }\r\n                        ]\r\n                    }\r\n                ]\r\n            },\r\n            &quot;attributes&quot;: {\r\n                &quot;series&quot;: [\r\n                    {\r\n                        &quot;id&quot;: &quot;TIME_FORMAT&quot;,\r\n                        &quot;name&quot;: &quot;Time format code&quot;,\r\n                        &quot;values&quot;: [\r\n                            {\r\n                                &quot;name&quot;: &quot;P1D&quot;\r\n                            }\r\n                        ]\r\n                    },\r\n                    {\r\n                        &quot;id&quot;: &quot;BREAKS&quot;,\r\n                        &quot;name&quot;: &quot;Breaks&quot;,\r\n                        &quot;values&quot;: []\r\n                    },\r\n                    {\r\n                        &quot;id&quot;: &quot;COLLECTION&quot;,\r\n                        &quot;name&quot;: &quot;Collection indicator&quot;,\r\n                        &quot;values&quot;: [\r\n                            {\r\n                                &quot;id&quot;: &quot;A&quot;,\r\n                                &quot;name&quot;: &quot;Average of observations through period&quot;\r\n                            }\r\n                        ]\r\n                    },\r\n                    {\r\n                        &quot;id&quot;: &quot;COMPILING_ORG&quot;,\r\n                        &quot;name&quot;: &quot;Compiling organisation&quot;,\r\n                        &quot;values&quot;: []\r\n                    },\r\n                    {\r\n                        &quot;id&quot;: &quot;DISS_ORG&quot;,\r\n                        &quot;name&quot;: &quot;Data dissemination organisation&quot;,\r\n                        &quot;values&quot;: []\r\n                    },\r\n                    {\r\n                        &quot;id&quot;: &quot;DOM_SER_IDS&quot;,\r\n                        &quot;name&quot;: &quot;Domestic series ids&quot;,\r\n                        &quot;values&quot;: []\r\n                    },\r\n                    {\r\n                        &quot;id&quot;: &quot;PUBL_ECB&quot;,\r\n                        &quot;name&quot;: &quot;Source publication (ECB only)&quot;,\r\n                        &quot;values&quot;: []\r\n                    },\r\n                    {\r\n                        &quot;id&quot;: &quot;PUBL_MU&quot;,\r\n                        &quot;name&quot;: &quot;Source publication (Euro area only)&quot;,\r\n                        &quot;values&quot;: []\r\n                    },\r\n                    {\r\n                        &quot;id&quot;: &quot;PUBL_PUBLIC&quot;,\r\n                        &quot;name&quot;: &quot;Source publication (public)&quot;,\r\n                        &quot;values&quot;: []\r\n                    },\r\n                    {\r\n                        &quot;id&quot;: &quot;UNIT_INDEX_BASE&quot;,\r\n                        &quot;name&quot;: &quot;Unit index base&quot;,\r\n                        &quot;values&quot;: []\r\n                    },\r\n                    {\r\n                        &quot;id&quot;: &quot;COMPILATION&quot;,\r\n                        &quot;name&quot;: &quot;Compilation&quot;,\r\n                        &quot;values&quot;: []\r\n                    },\r\n                    {\r\n                        &quot;id&quot;: &quot;COVERAGE&quot;,\r\n                        &quot;name&quot;: &quot;Coverage&quot;,\r\n                        &quot;values&quot;: []\r\n                    },\r\n                    {\r\n                        &quot;id&quot;: &quot;DECIMALS&quot;,\r\n                        &quot;name&quot;: &quot;Decimals&quot;,\r\n                        &quot;values&quot;: [\r\n                            {\r\n                                &quot;id&quot;: &quot;4&quot;,\r\n                                &quot;name&quot;: &quot;Four&quot;\r\n                            }\r\n                        ]\r\n                    },\r\n                    {\r\n                        &quot;id&quot;: &quot;NAT_TITLE&quot;,\r\n                        &quot;name&quot;: &quot;National language title&quot;,\r\n                        &quot;values&quot;: []\r\n                    },\r\n                    {\r\n                        &quot;id&quot;: &quot;SOURCE_AGENCY&quot;,\r\n                        &quot;name&quot;: &quot;Source agency&quot;,\r\n                        &quot;values&quot;: [\r\n                            {\r\n                                &quot;id&quot;: &quot;4F0&quot;,\r\n                                &quot;name&quot;: &quot;European Central Bank (ECB)&quot;\r\n                            }\r\n                        ]\r\n                    },\r\n                    {\r\n                        &quot;id&quot;: &quot;SOURCE_PUB&quot;,\r\n                        &quot;name&quot;: &quot;Publication source&quot;,\r\n                        &quot;values&quot;: []\r\n                    },\r\n                    {\r\n                        &quot;id&quot;: &quot;TITLE&quot;,\r\n                        &quot;name&quot;: &quot;Title&quot;,\r\n                        &quot;values&quot;: [\r\n                            {\r\n                                &quot;name&quot;: &quot;Australian dollar/Euro&quot;\r\n                            }\r\n                        ]\r\n                    },\r\n                    {\r\n                        &quot;id&quot;: &quot;TITLE_COMPL&quot;,\r\n                        &quot;name&quot;: &quot;Title complement&quot;,\r\n                        &quot;values&quot;: [\r\n                            {\r\n                                &quot;name&quot;: &quot;ECB reference exchange rate, Australian dollar/Euro, 2:15 pm (C.E.T.)&quot;\r\n                            }\r\n                        ]\r\n                    },\r\n                    {\r\n                        &quot;id&quot;: &quot;UNIT&quot;,\r\n                        &quot;name&quot;: &quot;Unit&quot;,\r\n                        &quot;values&quot;: [\r\n                            {\r\n                                &quot;id&quot;: &quot;AUD&quot;,\r\n                                &quot;name&quot;: &quot;Australian dollar&quot;\r\n                            }\r\n                        ]\r\n                    },\r\n                    {\r\n                        &quot;id&quot;: &quot;UNIT_MULT&quot;,\r\n                        &quot;name&quot;: &quot;Unit multiplier&quot;,\r\n                        &quot;values&quot;: [\r\n                            {\r\n                                &quot;id&quot;: &quot;0&quot;,\r\n                                &quot;name&quot;: &quot;Units&quot;\r\n                            }\r\n                        ]\r\n                    }\r\n                ],\r\n                &quot;observation&quot;: [\r\n                    {\r\n                        &quot;id&quot;: &quot;OBS_STATUS&quot;,\r\n                        &quot;name&quot;: &quot;Observation status&quot;,\r\n                        &quot;values&quot;: [\r\n                            {\r\n                                &quot;id&quot;: &quot;A&quot;,\r\n                                &quot;name&quot;: &quot;Normal value&quot;\r\n                            }\r\n                        ]\r\n                    },\r\n                    {\r\n                        &quot;id&quot;: &quot;OBS_CONF&quot;,\r\n                        &quot;name&quot;: &quot;Observation confidentiality&quot;,\r\n                        &quot;values&quot;: [\r\n                            {\r\n                                &quot;id&quot;: &quot;F&quot;,\r\n                                &quot;name&quot;: &quot;Free&quot;\r\n                            }\r\n                        ]\r\n                    },\r\n                    {\r\n                        &quot;id&quot;: &quot;OBS_PRE_BREAK&quot;,\r\n                        &quot;name&quot;: &quot;Pre-break observation value&quot;,\r\n                        &quot;values&quot;: []\r\n                    },\r\n                    {\r\n                        &quot;id&quot;: &quot;OBS_COM&quot;,\r\n                        &quot;name&quot;: &quot;Observation comment&quot;,\r\n                        &quot;values&quot;: []\r\n                    }\r\n                ]\r\n            }\r\n        }\r\n    }\r\n\r\n",
        "link": "https://stackoverflow.com/questions/73596490/cannot-get-jq-to-query-json-object",
        "title": "Cannot get jq to query json object"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1662298374,
                "last_edit_date": 1662298374,
                "creation_date": 1662298060,
                "answer_id": 73599789,
                "question_id": 73599316,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You were really close.\r\n```\r\n.objects[] |= {uid, name, type, members: .members | map({uid, name, type, &quot;ipv4-address&quot;})}\r\n```\r\n&lt;sup&gt;[Online demo](https://jqplay.org/s/LNgheWr511O)&lt;/sup&gt;",
                "title": "jq transform outer and inner array"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1662298374,
        "creation_date": 1662293788,
        "question_id": 73599316,
        "body_markdown": "This seems like it should be easy. I have a json file, and all I want is less of it - the structure stays the same. I am missing some ah-ha moment. What I am trying to do is get the some of the main array details and for each member, some of the inner details.\r\n\r\nSo for this:\r\n\r\n```\r\n{\r\n  &quot;objects&quot; : [ {\r\n    &quot;uid&quot; : &quot;fc5d20ad-03d5-4684-8836-feae73d1fe&quot;,\r\n    &quot;name&quot; : &quot;group1&quot;,\r\n    &quot;type&quot; : &quot;group&quot;,\r\n    &quot;members&quot; : [ {\r\n      &quot;uid&quot; : &quot;7846f4d6-72e0-4cd8-8795-1f5bc2f124&quot;,\r\n      &quot;name&quot; : &quot;member1&quot;,\r\n      &quot;type&quot; : &quot;host&quot;,\r\n      &quot;ipv4-address&quot; : &quot;17.19.49.10&quot;,\r\n      &quot;comments&quot; : &quot;&quot;,\r\n      &quot;color&quot; : &quot;black&quot;,\r\n      &quot;icon&quot; : &quot;Objects/host&quot;,\r\n      &quot;tags&quot; : [ ],\r\n      &quot;meta-info&quot; : {\r\n        &quot;lock&quot; : &quot;unlocked&quot;,\r\n        &quot;validation-state&quot; : &quot;ok&quot;,\r\n        &quot;last-modify-time&quot; : {\r\n          &quot;posix&quot; : 1626407214607,\r\n          &quot;iso-8601&quot; : &quot;2021-07-16T13:46+1000&quot;\r\n        },\r\n        &quot;last-modifier&quot; : &quot;&quot;,\r\n        &quot;creation-time&quot; : {\r\n          &quot;posix&quot; : 1625632725273,\r\n          &quot;iso-8601&quot; : &quot;2021-07-07T14:38+1000&quot;\r\n        },\r\n        &quot;creator&quot; : &quot;user&quot;\r\n      },\r\n      &quot;read-only&quot; : false\r\n    }, {\r\n      &quot;uid&quot; : &quot;a5b12fed-e32e-4151-8310-4848f16bef&quot;,\r\n      &quot;name&quot; : &quot;member2&quot;,\r\n      &quot;type&quot; : &quot;host&quot;,\r\n      &quot;domain&quot; : {\r\n        &quot;uid&quot; : &quot;41e821a0-3720-11e3-aa6e-00200c9fde&quot;,\r\n        &quot;name&quot; : &quot;SMC &quot;,\r\n        &quot;domain-type&quot; : &quot;domain&quot;\r\n      },\r\n      &quot;ipv4-address&quot; : &quot;12.19.50.10&quot;,\r\n      &quot;interfaces&quot; : [ ],\r\n      &quot;nat-settings&quot; : {\r\n        &quot;auto-rule&quot; : false\r\n      },\r\n      &quot;comments&quot; : &quot;&quot;,\r\n      &quot;color&quot; : &quot;black&quot;,\r\n      &quot;icon&quot; : &quot;Objects/host&quot;,\r\n      &quot;tags&quot; : [ ],\r\n      &quot;meta-info&quot; : {\r\n        &quot;lock&quot; : &quot;unlocked&quot;,\r\n        &quot;validation-state&quot; : &quot;ok&quot;,\r\n        &quot;last-modify-time&quot; : {\r\n          &quot;posix&quot; : 1626407292367,\r\n          &quot;iso-8601&quot; : &quot;2021-07-16T13:48+1000&quot;\r\n        },\r\n        &quot;last-modifier&quot; : &quot;user&quot;,\r\n        &quot;creation-time&quot; : {\r\n          &quot;posix&quot; : 1625632759552,\r\n          &quot;iso-8601&quot; : &quot;2021-07-07T14:39+1000&quot;\r\n        },\r\n        &quot;creator&quot; : &quot;user&quot;\r\n      },\r\n      &quot;read-only&quot; : false\r\n    } ],\r\n    &quot;comments&quot; : &quot;&quot;,\r\n    &quot;color&quot; : &quot;black&quot;,\r\n    &quot;icon&quot; : &quot;General/group&quot;,\r\n    &quot;tags&quot; : [ ],\r\n    &quot;meta-info&quot; : {\r\n      &quot;lock&quot; : &quot;unlocked&quot;,\r\n      &quot;validation-state&quot; : &quot;ok&quot;,\r\n      &quot;last-modify-time&quot; : {\r\n        &quot;posix&quot; : 1626407413393,\r\n        &quot;iso-8601&quot; : &quot;2021-07-16T13:50+1000&quot;\r\n      },\r\n      &quot;last-modifier&quot; : &quot;user&quot;,\r\n      &quot;creation-time&quot; : {\r\n        &quot;posix&quot; : 1625633894300,\r\n        &quot;iso-8601&quot; : &quot;2021-07-07T14:58+1000&quot;\r\n      },\r\n      &quot;creator&quot; : &quot;user&quot;\r\n    },\r\n    &quot;read-only&quot; : false\r\n  }, {\r\n    &quot;uid&quot; : &quot;e8d4f757-98e8-4aae-bc31-772066d&quot;,\r\n    &quot;name&quot; : &quot;group2&quot;,\r\n    &quot;type&quot; : &quot;group&quot;,\r\n    &quot;domain&quot; : {\r\n      &quot;uid&quot; : &quot;41e821a0-3720-11e3-aa6e-0800c9fde&quot;,\r\n      &quot;name&quot; : &quot;SMC &quot;,\r\n      &quot;domain-type&quot; : &quot;domain&quot;\r\n    },\r\n    &quot;members&quot; : [ {\r\n      &quot;uid&quot; : &quot;84e89b9c-dbe7-441e-9859-2d0eef&quot;,\r\n      &quot;name&quot; : &quot;member1&quot;,\r\n      &quot;type&quot; : &quot;host&quot;,\r\n      &quot;domain&quot; : {\r\n        &quot;uid&quot; : &quot;41e821a0-3720-11e3-aa6e-08fde&quot;,\r\n        &quot;name&quot; : &quot;SMC &quot;,\r\n        &quot;domain-type&quot; : &quot;domain&quot;\r\n      },\r\n      &quot;ipv4-address&quot; : &quot;82.19.76.10&quot;,\r\n      &quot;interfaces&quot; : [ ],\r\n      &quot;nat-settings&quot; : {\r\n        &quot;auto-rule&quot; : false\r\n      },\r\n      &quot;comments&quot; : &quot;&quot;,\r\n      &quot;color&quot; : &quot;black&quot;,\r\n      &quot;icon&quot; : &quot;Objects/host&quot;,\r\n      &quot;tags&quot; : [ ],\r\n      &quot;meta-info&quot; : {\r\n        &quot;lock&quot; : &quot;unlocked&quot;,\r\n        &quot;validation-state&quot; : &quot;ok&quot;,\r\n        &quot;last-modify-time&quot; : {\r\n          &quot;posix&quot; : 1626398340102,\r\n          &quot;iso-8601&quot; : &quot;2021-07-16T11:19+1000&quot;\r\n        },\r\n        &quot;last-modifier&quot; : &quot;user&quot;,\r\n        &quot;creation-time&quot; : {\r\n          &quot;posix&quot; : 1625632518542,\r\n          &quot;iso-8601&quot; : &quot;2021-07-07T14:35+1000&quot;\r\n        },\r\n        &quot;creator&quot; : &quot;user&quot;\r\n      },\r\n      &quot;read-only&quot; : false\r\n    }, {\r\n      &quot;uid&quot; : &quot;116f3792-8baa-4e56-888bcbd8194&quot;,\r\n      &quot;name&quot; : &quot;member2&quot;,\r\n      &quot;type&quot; : &quot;host&quot;,\r\n      &quot;domain&quot; : {\r\n        &quot;uid&quot; : &quot;41e821a0-3720-e3-aa6e-0c9fde&quot;,\r\n        &quot;name&quot; : &quot;member3&quot;,\r\n        &quot;domain-type&quot; : &quot;domain&quot;\r\n      },\r\n      &quot;ipv4-address&quot; : &quot;84.12.48.10&quot;,\r\n      &quot;interfaces&quot; : [ ],\r\n      &quot;nat-settings&quot; : {\r\n        &quot;auto-rule&quot; : false\r\n      },\r\n      &quot;comments&quot; : &quot;&quot;,\r\n      &quot;color&quot; : &quot;black&quot;,\r\n      &quot;icon&quot; : &quot;Objects/host&quot;,\r\n      &quot;tags&quot; : [ ],\r\n      &quot;meta-info&quot; : {\r\n        &quot;lock&quot; : &quot;unlocked&quot;,\r\n        &quot;validation-state&quot; : &quot;ok&quot;,\r\n        &quot;last-modify-time&quot; : {\r\n          &quot;posix&quot; : 1626398367303,\r\n          &quot;iso-8601&quot; : &quot;2021-07-16T11:19+1000&quot;\r\n        },\r\n        &quot;last-modifier&quot; : &quot;user&quot;,\r\n        &quot;creation-time&quot; : {\r\n          &quot;posix&quot; : 1625632577299,\r\n          &quot;iso-8601&quot; : &quot;2021-07-07T14:36+1000&quot;\r\n        },\r\n        &quot;creator&quot; : &quot;user&quot;\r\n      },\r\n      &quot;read-only&quot; : false\r\n    } ],\r\n    &quot;comments&quot; : &quot;&quot;,\r\n    &quot;color&quot; : &quot;black&quot;,\r\n    &quot;icon&quot; : &quot;General/group&quot;,\r\n    &quot;tags&quot; : [ ],\r\n    &quot;meta-info&quot; : {\r\n      &quot;lock&quot; : &quot;unlocked&quot;,\r\n      &quot;validation-state&quot; : &quot;ok&quot;,\r\n      &quot;last-modify-time&quot; : {\r\n        &quot;posix&quot; : 1626398715255,\r\n        &quot;iso-8601&quot; : &quot;2021-07-16T11:25+1000&quot;\r\n      },\r\n      &quot;last-modifier&quot; : &quot;user&quot;,\r\n      &quot;creation-time&quot; : {\r\n        &quot;posix&quot; : 1625632984944,\r\n        &quot;iso-8601&quot; : &quot;2021-07-07T14:43+1000&quot;\r\n      },\r\n      &quot;creator&quot; : &quot;user&quot;\r\n    },\r\n    &quot;read-only&quot; : false\r\n  } ]\r\n}\r\n```\r\n\r\nI want to end up with this:\r\n\r\n```\r\n{\r\n  [ {\r\n    &quot;uid&quot; : &quot;fc5d20ad-03d5-4684-8836-feae73d1fe&quot;,\r\n    &quot;name&quot; : &quot;group1&quot;,\r\n    &quot;type&quot; : &quot;group&quot;,\r\n    &quot;members&quot; : [ {\r\n      &quot;uid&quot; : &quot;7846f4d6-72e0-4cd8-8795-1f5bc2f124&quot;,\r\n      &quot;name&quot; : &quot;member1&quot;,\r\n      &quot;type&quot; : &quot;host&quot;,\r\n      &quot;ipv4-address&quot; : &quot;17.19.49.10&quot;,\r\n    }, {\r\n      &quot;uid&quot; : &quot;a5b12fed-e32e-4151-8310-4848f16bef&quot;,\r\n      &quot;name&quot; : &quot;member2&quot;,\r\n      &quot;type&quot; : &quot;host&quot;,\r\n      &quot;ipv4-address&quot; : &quot;12.19.50.10&quot;,\r\n    } ],\r\n   \r\n  }, {\r\n    &quot;uid&quot; : &quot;e8d4f757-98e8-4aae-bc31-772066d&quot;,\r\n    &quot;name&quot; : &quot;group2&quot;,\r\n    &quot;type&quot; : &quot;group&quot;,\r\n    &quot;members&quot; : [ {\r\n      &quot;uid&quot; : &quot;84e89b9c-dbe7-441e-9859-2d0eef&quot;,\r\n      &quot;name&quot; : &quot;member1&quot;,\r\n      &quot;type&quot; : &quot;host&quot;,\r\n      &quot;ipv4-address&quot; : &quot;82.19.76.10&quot;,\r\n      },\r\n    }, {\r\n      &quot;uid&quot; : &quot;116f3792-8baa-4e56-888bcbd8194&quot;,\r\n      &quot;name&quot; : &quot;member2&quot;,\r\n      &quot;type&quot; : &quot;host&quot;,\r\n      &quot;ipv4-address&quot; : &quot;84.12.48.10&quot;,\r\n    } ]\r\n  } ]\r\n}\r\n\r\n```\r\n\r\nBut I can&#39;t figure out how to get the member details out.  This is what I have so far:\r\n\r\n```cat groups.txt | jq &#39;.objects[] | { name: .name, uid: .uid, type: .type, members: .members[] | { name: .name, uid: .uid, &quot;ipv4-address&quot;: .&quot;ipv4-address&quot;, type: .type } }&#39;```\r\n\r\nThis repeats everything for each member, so I need an &quot;inner loop&quot; to deal with the members and I can&#39;t see it:\r\n\r\n```\r\n{\r\n  &quot;name&quot;: &quot;group1&quot;,\r\n  &quot;uid&quot;: &quot;fc5d20ad-03d5-4684-8836-feae73d1fe&quot;,\r\n  &quot;type&quot;: &quot;group&quot;,\r\n  &quot;members&quot;: {\r\n    &quot;name&quot;: &quot;member1&quot;,\r\n    &quot;uid&quot;: &quot;7846f4d6-72e0-4cd8-8795-1f5bc2f124&quot;,\r\n    &quot;ipv4-address&quot;: &quot;17.19.49.10&quot;,\r\n    &quot;type&quot;: &quot;host&quot;\r\n  }\r\n}\r\n{\r\n  &quot;name&quot;: &quot;group1&quot;,\r\n  &quot;uid&quot;: &quot;fc5d20ad-03d5-4684-8836-feae73d1fe&quot;,\r\n  &quot;type&quot;: &quot;group&quot;,\r\n  &quot;members&quot;: {\r\n    &quot;name&quot;: &quot;member2&quot;,\r\n    &quot;uid&quot;: &quot;a5b12fed-e32e-4151-8310-4848f16bef&quot;,\r\n    &quot;ipv4-address&quot;: &quot;12.19.50.10&quot;,\r\n    &quot;type&quot;: &quot;host&quot;\r\n  }\r\n}\r\n[snip]\r\n```\r\n\r\nHow do I keep them together, and keep the surrounding array?\r\n",
        "link": "https://stackoverflow.com/questions/73599316/jq-transform-outer-and-inner-array",
        "title": "jq transform outer and inner array"
    },
    {
        "tags": [
            "json",
            "jq",
            "standard-deviation"
        ],
        "answers": [
            {
                "up_vote_count": 7,
                "is_accepted": true,
                "score": 7,
                "last_activity_date": 1662303033,
                "last_edit_date": 1662303033,
                "creation_date": 1662302551,
                "answer_id": 73600291,
                "question_id": 73599978,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "This is how you do it:\r\n```\r\n(add / length) as $mean | (map(. - $mean | . * .) | add) / (length - 1) | sqrt\r\n```\r\n&lt;sup&gt;[Online demo](https://jqplay.org/s/LhK4pixoXxe)&lt;/sup&gt;",
                "title": "Sample Standard Deviation in JQ"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 4,
        "last_activity_date": 1662307293,
        "creation_date": 1662299694,
        "last_edit_date": 1662307293,
        "question_id": 73599978,
        "body_markdown": "I&#39;ve an array of numbers and I need to calculate the __Sample Standard Deviation__ using `jq`.\r\n\r\nSample Standard Deviation formula ([credits](https://www.thoughtco.com/thmb/GVy7U2pn2FP2Tut4MG53ZiCgOCQ=/768x0/filters:no_upscale():max_bytes(150000):strip_icc():format(webp)/calculate-a-sample-standard-deviation-3126345-v4-CS-01-5b76f58f46e0fb0050bb4ab2.png)):\r\n[![Standard Deviation formula][1]][1]\r\n\r\nI&#39;ve tried splitting the code into multiple pieces (length, mean), but none of my attempts worked because I don&#39;t know how to merge all the data into a single `sqrt` and `map` operation:\r\n```console\r\n# Example of data input\r\n_data=&quot;[73,73,76,77,81,100]&quot;\r\n\r\n_length=$(echo &quot;$_data&quot; | jq --raw-output &#39;length&#39;)\r\n_mean=$(echo &quot;$_data&quot; | jq --raw-output &#39;add/length&#39;)\r\n\r\n_standard_deviation=$(echo &quot;$_data&quot; \\\r\n&#160; &#160; &#160; &#160; &#160; &#160; &#160; &#160; &#160; &#160; &#160; | jq --raw-output \\\r\n&#160; &#160; &#160; &#160; &#160; &#160; &#160; &#160; &#160; &#160; &#160; &#160; &#160;  --arg length &quot;$_length&quot; \\\r\n&#160; &#160; &#160; &#160; &#160; &#160; &#160; &#160; &#160; &#160; &#160; &#160; &#160; &#160;--arg mean &quot;$_mean&quot; \\\r\n&#160; &#160; &#160; &#160; &#160; &#160; &#160; &#160; &#160; &#160; &#160; &#160; &#160; &#160;&#39;&#39;) # &lt;- sqrt and map ?\r\n\r\necho &quot;$_standard_deviation&quot; # Should print 10.237187\r\n```\r\n\r\n[1]: https://i.sstatic.net/YbpRx.png",
        "link": "https://stackoverflow.com/questions/73599978/sample-standard-deviation-in-jq",
        "title": "Sample Standard Deviation in JQ"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 4879,
                    "reputation": 248190,
                    "user_id": 7552,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/b60298053f87465641c1b1192338c8cd?s=256&d=identicon&r=PG",
                    "display_name": "glenn jackman",
                    "link": "https://stackoverflow.com/users/7552/glenn-jackman"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1662346341,
                "post_id": 73604109,
                "comment_id": 129976986,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1662347143,
                "last_edit_date": 1662347143,
                "creation_date": 1662346736,
                "answer_id": 73604183,
                "question_id": 73604109,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You could simply `or` the conditions, e.g. using your approach:\r\n\r\n```\r\n.[] \r\n| .end2end.data[0]\r\n| select(.latency&gt;10)\r\n| select(.source | (startswith(&quot;app1&quot;) or startswith(&quot;app2&quot;)) )\r\n```\r\n\r\nOr you could use a regular expression, e.g.\r\n\r\n```\r\nselect( .source | test(&quot;^app[12]&quot;) )\r\n\r\n```\r\nor perhaps\r\n```\r\nselect( .source | test(&quot;^app[12][.]&quot;) )\r\n```",
                "title": "How to use wildcards to filter values using jq based on starting names"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1662347143,
        "creation_date": 1662345804,
        "last_edit_date": 1662346354,
        "question_id": 73604109,
        "body_markdown": "Can someone please help me to filter multiple values based on starting names from below json output. I am able to filter values same type attributes but not others in same query.\r\n\r\n```\r\n{\r\n  &quot;app1.btch_src&quot;: {\r\n    &quot;eventrate&quot;: 0,\r\n    &quot;end2end&quot;: {\r\n      &quot;data&quot;: [\r\n        {\r\n          &quot;at&quot;: 16054343444,\r\n          &quot;source&quot;: &quot;app1.btch_src&quot;,\r\n          &quot;latency&quot;: 0.05,\r\n          &quot;target&quot;: &quot;app1.btch_tgt&quot;\r\n        }\r\n      ]\r\n    }\r\n  },\r\n  &quot;app1.btch1_src&quot;: {\r\n    &quot;eventrate&quot;: 0,\r\n    &quot;end2end&quot;: {\r\n      &quot;data&quot;: [\r\n        {\r\n          &quot;at&quot;: 16054343445,\r\n          &quot;source&quot;: &quot;app1.btch1_src&quot;,\r\n          &quot;latency&quot;: 200.5,\r\n          &quot;target&quot;: &quot;app1.btch1_tgt&quot;\r\n        }\r\n      ]\r\n    }\r\n  },\r\n  &quot;app2.btch_src&quot;: {\r\n    &quot;eventrate&quot;: 0,\r\n    &quot;end2end&quot;: {\r\n      &quot;data&quot;: [\r\n        {\r\n          &quot;at&quot;: 16054341234,\r\n          &quot;source&quot;: &quot;app2.btch_src&quot;,\r\n          &quot;latency&quot;: 50.4,\r\n          &quot;target&quot;: &quot;app2.btch_tgt&quot;\r\n        }\r\n      ]\r\n    }\r\n  },\r\n  &quot;app3.btch_src&quot;: {\r\n    &quot;eventrate&quot;: 0,\r\n    &quot;end2end&quot;: {\r\n      &quot;data&quot;: [\r\n        {\r\n          &quot;at&quot;: 16054343444,\r\n          &quot;source&quot;: &quot;app3.btch_src&quot;,\r\n          &quot;latency&quot;: 10,\r\n          &quot;target&quot;: &quot;app3.btch_tgt&quot;\r\n        }\r\n      ]\r\n    }\r\n  }\r\n}\r\n```\r\n\r\nI&#39;ve written query like below as I want to retrieve both `app1.*` and `app2.*` object values if latency is more than 10 sec.\r\nwhen I select below one attribute and it&#39;s working.\r\n```\r\njq -r &#39;.[] |.end2end.data[0] | select(.latency&gt;10) |select(.source |startswith(&quot;app1&quot;)&#39; all_info.json\r\n```\r\nI need to know now how I can retrieve the `app2` values along with `app1` if above condition satisfied.",
        "link": "https://stackoverflow.com/questions/73604109/how-to-use-wildcards-to-filter-values-using-jq-based-on-starting-names",
        "title": "How to use wildcards to filter values using jq based on starting names"
    },
    {
        "tags": [
            "json",
            "csv",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1662401028,
                "creation_date": 1662401028,
                "answer_id": 73613216,
                "question_id": 73613113,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "It&#39;s easier than you think:\r\n```\r\njq -r &#39;@csv&#39; file.json\r\n```\r\n&lt;sup&gt;[Online demo](https://jqplay.org/s/3PuIsPyLa4a)&lt;/sup&gt;",
                "title": "How to transform a stream of arrays to CSV in JQ?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1662402503,
        "creation_date": 1662400381,
        "last_edit_date": 1662402503,
        "question_id": 73613113,
        "body_markdown": "I&#39;ve got this informations from a json file aplying jq filter, now I need to transform this in a csv file but I don&#39;t know how to do.\r\n\r\nThe file:\r\n\r\n    [\r\n      &quot;https://localhost/rundeck/project/Enterprise/execution/show/228&quot;,\r\n      &quot;succeeded&quot;,\r\n      &quot;Enterprise&quot;,\r\n      &quot;2020-04-19T03:00:01Z&quot;,\r\n      &quot;2020-04-19T03:13:17Z&quot;,\r\n      &quot;job_particion&quot;\r\n    ]\r\n    [\r\n      &quot;https://localhost/rundeck/project/Enterprise/execution/show/824&quot;,\r\n      &quot;succeeded&quot;,\r\n      &quot;Enterprise&quot;,\r\n      &quot;2020-09-01T04:15:00Z&quot;,\r\n      &quot;2020-09-01T04:15:02Z&quot;,\r\n      &quot;job_scheduler&quot;\r\n    ]\r\n    [\r\n      &quot;https://localhost/rundeck/project/Enterprise/execution/show/822&quot;,\r\n      &quot;succeeded&quot;,\r\n      &quot;Enterprise&quot;,\r\n      &quot;2020-09-01T03:45:00Z&quot;,\r\n      &quot;2020-09-01T03:45:06Z&quot;,\r\n      &quot;job_system&quot;\r\n    ]\r\n    [\r\n      &quot;https://localhost/rundeck/project/Enterprise/execution/show/823&quot;,\r\n      &quot;succeeded&quot;,\r\n      &quot;Enterprise&quot;,\r\n      &quot;2020-09-01T04:00:00Z&quot;,\r\n      &quot;2020-09-01T04:00:25Z&quot;,\r\n      &quot;job_operator&quot;\r\n    ]\r\n    [\r\n      &quot;https://localhost/rundeck/project/Enterprise/execution/show/821&quot;,\r\n      &quot;succeeded&quot;,\r\n      &quot;Enterprise&quot;,\r\n      &quot;2020-09-01T03:30:00Z&quot;,\r\n      &quot;2020-09-01T03:30:10Z&quot;,\r\n      &quot;job_aplication&quot;\r\n    ]\r\n\r\nI see this ERROR when I try like this:\r\n\r\n    cat file.json | jq &#39;.[]| join(&quot;,&quot;)&#39;\r\n    jq: error (at &lt;stdin&gt;:8): Cannot iterate over string (&quot;https://lo...)",
        "link": "https://stackoverflow.com/questions/73613113/how-to-transform-a-stream-of-arrays-to-csv-in-jq",
        "title": "How to transform a stream of arrays to CSV in JQ?"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1662455838,
                "creation_date": 1662455838,
                "answer_id": 73619550,
                "question_id": 73616458,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "```\r\n.releases[] | select(.name | index(&quot;release-1&quot;)) | .artifacts[].commitId\r\n```\r\n\r\nWill show each `commitId` where `name` contains ([`index()`][1]) `release-1`.\r\n\r\nResult:\r\n```\r\n&quot;523asdc3&quot;\r\n&quot;523asdc3&quot;\r\n&quot;523asdc3&quot;\r\n```\r\n\r\n[JqPlay demo](https://jqplay.org/s/BxFuRd43Vzt)\r\n\r\n\r\n  [1]: https://stedolan.github.io/jq/manual/#example51",
                "title": "How to filter jq based on the key value?"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1662618490,
                "last_edit_date": 1662618490,
                "creation_date": 1662613936,
                "answer_id": 73644007,
                "question_id": 73616458,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": ".releases[]|select(.name|contains([&quot;release-1&quot;]))|.artifacts[].commitId\r\n\r\nis another way.\r\n\r\n\r\n.releases[]|select(.name[0] ==&quot;release-1&quot;)|.artifacts[].commitId\r\n\r\nis yet another way.",
                "title": "How to filter jq based on the key value?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": -2,
        "last_activity_date": 1662618490,
        "creation_date": 1662435483,
        "last_edit_date": 1662436274,
        "question_id": 73616458,
        "body_markdown": "I am quite new with JQ library, I want to filter the json file using their name(eg. release-1),Then I want to return key value of the all commitId in the same object as the name.\r\n\r\n\r\n\r\nMy json file\r\n```\r\n{\r\n   &quot;releases&quot;:[\r\n      {\r\n         &quot;name&quot;:[\r\n            &quot;release-1&quot;\r\n         ],\r\n         &quot;artifacts&quot;:[\r\n            {\r\n               &quot;name&quot;:&quot;pkg-1&quot;,\r\n               &quot;commitId&quot;:&quot;523asdc3&quot;\r\n            },\r\n            {\r\n               &quot;name&quot;:&quot;pkg-2&quot;,\r\n               &quot;commitId&quot;:&quot;523asdc3&quot;\r\n            },\r\n            {\r\n               &quot;name&quot;:&quot;pkg-3&quot;,\r\n               &quot;commitId&quot;:&quot;523asdc3&quot;\r\n            }\r\n         ]\r\n      },\r\n      {\r\n         &quot;name&quot;:[\r\n            &quot;release-2&quot;\r\n         ],\r\n         &quot;artifacts&quot;:[\r\n            {\r\n               &quot;name&quot;:&quot;pkg-3&quot;,\r\n               &quot;commitId&quot;:&quot;523asdc3&quot;\r\n            },\r\n            {\r\n               &quot;name&quot;:&quot;pkg-4&quot;,\r\n               &quot;commitId&quot;:&quot;523asdc3&quot;\r\n            },\r\n            {\r\n               &quot;name&quot;:&quot;pkg-5&quot;,\r\n               &quot;commitId&quot;:&quot;523asdc3&quot;\r\n            }\r\n         ]\r\n      }\r\n   ]\r\n}\r\n```\r\n\r\nExpected Output\r\n```\r\n523asdc3\r\n523asdc3\r\n523asdc3\r\n```",
        "link": "https://stackoverflow.com/questions/73616458/how-to-filter-jq-based-on-the-key-value",
        "title": "How to filter jq based on the key value?"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 1613587,
                    "reputation": 786618,
                    "user_id": 1491895,
                    "user_type": "registered",
                    "accept_rate": 69,
                    "profile_image": "https://www.gravatar.com/avatar/82f9e178a16364bf561d0ed4da09a35d?s=256&d=identicon&r=PG",
                    "display_name": "Barmar",
                    "link": "https://stackoverflow.com/users/1491895/barmar"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1662437583,
                "post_id": 73616608,
                "comment_id": 129998874,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1613587,
                    "reputation": 786618,
                    "user_id": 1491895,
                    "user_type": "registered",
                    "accept_rate": 69,
                    "profile_image": "https://www.gravatar.com/avatar/82f9e178a16364bf561d0ed4da09a35d?s=256&d=identicon&r=PG",
                    "display_name": "Barmar",
                    "link": "https://stackoverflow.com/users/1491895/barmar"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1662437615,
                "post_id": 73616608,
                "comment_id": 129998878,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 13113751,
                    "reputation": 147428,
                    "user_id": 9473764,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/pqE2g.jpg?s=256",
                    "display_name": "Nick",
                    "link": "https://stackoverflow.com/users/9473764/nick"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1662438727,
                "post_id": 73616608,
                "comment_id": 129999036,
                "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": 1662484182,
                "post_id": 73616608,
                "comment_id": 130014234,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 10320113,
                    "reputation": 293,
                    "user_id": 8952375,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/1d461b96cdbc512a1d0e269b07093821?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Berk7871",
                    "link": "https://stackoverflow.com/users/8952375/berk7871"
                },
                "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": 1662520892,
                "post_id": 73616608,
                "comment_id": 130021818,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 10320113,
                    "reputation": 293,
                    "user_id": 8952375,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/1d461b96cdbc512a1d0e269b07093821?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Berk7871",
                    "link": "https://stackoverflow.com/users/8952375/berk7871"
                },
                "edited": false,
                "score": 3,
                "creation_date": 1662521036,
                "post_id": 73616608,
                "comment_id": 130021843,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1662618815,
                "creation_date": 1662618815,
                "answer_id": 73644612,
                "question_id": 73616608,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "\r\nGiven JSON data and a query, there is no\r\n&gt; option in `jq` that, instead of printing the value itself, prints the location\r\n\r\nof possible matches.\r\n\r\nThis is because JSON parsers providing an interface to developers usually focus on processing the logical structure of a JSON input, not the textual stream conveying it. You would have to instruct it to explicitly treat its input as raw text, while properly parsing it at the same time in order to extract the queried value. In the case of `jq`, the former can be achieved using the `--raw-input` (or `-R`) option, the latter then by parsing the read-in JSON-encoded string using `fromjson`.\r\n\r\nThe `-R` option alone would read the input linewise into an array of strings, which would have to be concatenated (e.g. using `add`) in order to provide the whole input at once to `fromjson`. The other way round, you could also provide the `--slurp` (or `-s`) option which (in combination with `-R`) already concatenates the input to a single string which then, after having parsed it with `fromjson`, would have to be split again into lines (e.g. using `/&quot;\\n&quot;`) in order to provide row numbers. I found the latter to be more convenient.\r\n\r\nThat said, this could give you a starting point (the `--raw-output` (or `-r`) option outputs raw text instead of JSON):\r\n~~~sh\r\njq -Rrs &#39;\r\n  &quot;\\(fromjson.key2.key2_2.key2_2_1)&quot; as $query    # save the query value as string\r\n  | ($query | length) as $length      # save its length by counting its characters\r\n  | ./&quot;\\n&quot; | to_entries[]      # split into lines and provide 0-based line numbers\r\n  | {row: .key, col: .value | indices($query)[]}   # find occurrences of the query\r\n  | &quot;(\\(.row),\\(.col)) (\\(.row),\\(.col + $length))&quot;            # format the output\r\n&#39;\r\n~~~\r\n~~~json\r\n(5,24) (5,34)\r\n~~~\r\n[Demo](https://jqplay.org/s/omxgd95n3op)\r\n\r\nNow, this works for the sample query, how about the general case? Your example queried a number (`1.43123123`) which is an easy target as it has the same textual representation when encoded as JSON. Therefore, a simple string search and length count did a fairly good job (not a perfect one because it would still find any occurrence of that character stream, not just &quot;values&quot;). Thus, for more precision, but especially with more complex JSON datatypes being queried, you would need to develop a more sophisticated searching approach, probably involving more JSON conversions, whitespace stripping and other normalizing shenanigans. So, unless your goal is to rebuild a full JSON parser within another one, you should narrow it down to the kind of queries you expect, and compose an appropriately tailored searching approach. This solution provides you with concepts to simultaneously process the input textually and structurally, and with a simple search and ouput integration.\r\n",
                "title": "Finding the location (line, column) of a field value in a JSON file"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -3,
        "last_activity_date": 1662660798,
        "creation_date": 1662437258,
        "last_edit_date": 1662660798,
        "question_id": 73616608,
        "body_markdown": "Consider the following JSON file *example.json*:\r\n\r\n    {\r\n        &quot;key1&quot;: [&quot;arr value 1&quot;, &quot;arr value 2&quot;, &quot;arr value 3&quot;],\r\n        &quot;key2&quot;: {\r\n            &quot;key2_1&quot;: [&quot;a1&quot;, &quot;a2&quot;],\r\n            &quot;key2_2&quot;: {\r\n                &quot;key2_2_1&quot;: 1.43123123,\r\n                &quot;key2_2_2&quot;: 456.3123,\r\n                &quot;key2_2_3&quot;: &quot;string1&quot;\r\n            }\r\n        }\r\n    }\r\n\r\nThe following `jq` command extracts a value from the above file:\r\n\r\n```lang-none\r\njq &quot;.key2.key2_2.key2_2_1&quot; example.json\r\n```\r\n\r\nOutput:\r\n\r\n```lang-none\r\n1.43123123\r\n```\r\n\r\nIs there an option in `jq` that, instead of printing the value itself, prints the location (line and column, start and end position) of the value within a (valid) JSON file, given an *Object Identifier-Index* (`.key2.key2_2.key2_2_1` in the example)?\r\n\r\nThe output could be something like:\r\n\r\n```lang-none\r\nsome_utility &quot;.key2.key2_2.key2_2_1&quot; example.json\r\n```\r\n\r\nOutput:\r\n\r\n```lang-none\r\n(6,25) (6,35)\r\n```\r\n\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/73616608/finding-the-location-line-column-of-a-field-value-in-a-json-file",
        "title": "Finding the location (line, column) of a field value in a JSON file"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1662447888,
                "last_edit_date": 1662447888,
                "creation_date": 1662439869,
                "answer_id": 73616835,
                "question_id": 73616768,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s one way:\r\n``` none\r\nlast(.values[] | select(has(1))) [1]\r\n```\r\n&lt;sup&gt;[Online demo](https://jqplay.org/s/l8LHozbdgSS)&lt;/sup&gt;\r\n\r\n\r\nIf the second column does not contain false values (`null`, `false`) this will also work:\r\n``` none\r\nlast(.values[][1] // empty)\r\n```",
                "title": "Getting Last Available element of a Particular Column in JQ"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1662475143,
                "last_edit_date": 1662475143,
                "creation_date": 1662443321,
                "answer_id": 73617228,
                "question_id": 73616768,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s a different solution:\r\n\r\n```\r\n.values | map(.[1] | select(.)) | last\r\n```\r\n\r\nprobably less efficient, but quite readable.\r\n\r\nThe difference to the [other answer](https://stackoverflow.com/a/73616835/112968) is that `select(.)` will filter any falsy value, not only non-existent values. So if your second columns were to contain `false` or `null`, these wouldn&#39;t show up in your result.",
                "title": "Getting Last Available element of a Particular Column in JQ"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": -1,
        "last_activity_date": 1662475143,
        "creation_date": 1662439102,
        "last_edit_date": 1662440831,
        "question_id": 73616768,
        "body_markdown": "I have been working on a Bash script. I am having a curl response as follows.\r\n\r\n```\r\n{\r\n  &quot;range&quot;: &quot;&#39;PR-DETAILS&#39;!A1:Z1000&quot;,\r\n  &quot;majorDimension&quot;: &quot;ROWS&quot;,\r\n  &quot;values&quot;: [\r\n    [\r\n      &quot;PR ID&quot;,\r\n      &quot;PR Owner&quot;\r\n    ],\r\n    [\r\n      &quot;1929&quot;,\r\n      &quot;Angel&quot;\r\n    ],\r\n    [\r\n      &quot;73&quot;,    \r\n      &quot;Martin&quot;\r\n    ],\r\n    [\r\n      &quot;142&quot;\r\n    ]\r\n  ]\r\n}\r\n```\r\n\r\n**Here I just want to get the last available element for the second column.**\r\n\r\nExpected Answer:- `Martin`\r\n\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/73616768/getting-last-available-element-of-a-particular-column-in-jq",
        "title": "Getting Last Available element of a Particular Column in JQ"
    },
    {
        "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": 1662490150,
                "post_id": 73626362,
                "comment_id": 130016100,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1662490034,
                "last_edit_date": 1662490034,
                "creation_date": 1662489540,
                "answer_id": 73626483,
                "question_id": 73626362,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You&#39;re looking for [`transpose`](https://stedolan.github.io/jq/manual/#transpose).\r\n```\r\n.[] | .id, .msg, ([.FilePath, .line] | transpose | add), &quot;&quot;\r\n```\r\n&lt;sup&gt;[Online demo](https://jqplay.org/s/udgsUPSndlx)&lt;/sup&gt;",
                "title": "How to combine jq array value into same key in json file in shell script?"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1662490641,
                "last_edit_date": 1662490641,
                "creation_date": 1662490050,
                "answer_id": 73626578,
                "question_id": 73626362,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "```\r\n&lt;stack.json jq -r &#39;.[] | .id, .msg, ([.FilePath, .line]|transpose|add)&#39;\r\n```\r\n\r\ngives the output as required by you.\r\n\r\n`transpose` turns `[[1,2,3],[4,5,6]]` into `[[1,4],[2,5],[3,6]]` and `add` collects all array elements into a single array.\r\n\r\nIf you are looking to have file path and line number in a single line, I suggest formatting them as string, separated by colon:\r\n\r\n```\r\n.[] | .id, .msg, ([.FilePath, .line]|transpose|map(join(&quot;:&quot;)))\r\n```",
                "title": "How to combine jq array value into same key in json file in shell script?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1662490641,
        "creation_date": 1662488827,
        "last_edit_date": 1662489243,
        "question_id": 73626362,
        "body_markdown": "I have a json file with this content: \r\n\r\n    [\r\n      {\r\n        &quot;id&quot;: &quot;one&quot;,\r\n        &quot;msg&quot;: [\r\n          &quot;test&quot;\r\n        ],\r\n        &quot;FilePath&quot;: [\r\n          &quot;JsonSerializer.cs&quot;,\r\n          &quot;ChatClient.cs&quot;,\r\n          &quot;MiniJSON.cs&quot;\r\n        ],\r\n        &quot;line&quot;: [\r\n          358,\r\n          1241,\r\n          382\r\n        ]\r\n      },\r\n      {\r\n        &quot;id&quot;: &quot;two&quot;,\r\n        &quot;msg&quot;: [\r\n          &quot;secondtest&quot;\r\n        ],\r\n        &quot;FilePath&quot;: [\r\n          &quot;Utilities.cs&quot;,\r\n          &quot;PhotonPing.cs&quot;\r\n        ],\r\n        &quot;line&quot;: [\r\n          88,\r\n          36\r\n        ]\r\n      }\r\n    ]\r\nI want the output where as you can see the value combine into one :\r\n\r\n    one\r\n    [\r\n      &quot;test&quot;\r\n    ]\r\n    [\r\n      &quot;JsonSerializer.cs&quot;,358\r\n      &quot;ChatClient.cs&quot;,1241\r\n      &quot;MiniJSON.cs&quot;,382\r\n    ]\r\n    \r\n    two\r\n    [\r\n      &quot;secondtest&quot;\r\n    ]\r\n    [\r\n      &quot;Utilities.cs&quot;,88\r\n      &quot;PhotonPing.cs&quot;,36\r\n    ]\r\n\r\nI have tried this `cat stack.json |jq -r &#39;.[]|.id,.msg,.FilePath,.line&#39;`\r\nwhich gave output as \r\n\r\n  \r\n\r\n      one\r\n        [\r\n          &quot;test&quot;\r\n        ]\r\n        [\r\n          &quot;JsonSerializer.cs&quot;,\r\n          &quot;ChatClient.cs&quot;,\r\n          &quot;MiniJSON.cs&quot;\r\n        ]\r\n        [\r\n          358,\r\n          1241,\r\n          382\r\n        ]\r\n        two\r\n        [\r\n          &quot;secondtest&quot;\r\n        ]\r\n        [\r\n          &quot;Utilities.cs&quot;,\r\n          &quot;PhotonPing.cs&quot;\r\n        ]\r\n        [\r\n          88,\r\n          36\r\n        ]\r\n\r\nKindly help me resolve this, I have tried a lot to debug this but unable to get through. Also, the Filepath and line would always be similar for each . For example if FilePath has 3, line would also have 3 values. ",
        "link": "https://stackoverflow.com/questions/73626362/how-to-combine-jq-array-value-into-same-key-in-json-file-in-shell-script",
        "title": "How to combine jq array value into same key in json file in shell script?"
    },
    {
        "tags": [
            "json",
            "command-line",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1662501589,
                "last_edit_date": 1662501589,
                "creation_date": 1662500971,
                "answer_id": 73628066,
                "question_id": 73628028,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "This will take the json document and put it as a &quot;items&quot; attribute of a dictionary.\r\n```\r\njq &#39;{items: .}&#39;\r\n```\r\n\r\nHere is a good guide for the basics.  https://www.baeldung.com/linux/jq-command-json",
                "title": "How can I transform a JSON array returned by jq into an object with a single attribute with that list&#39;s data?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1662501589,
        "creation_date": 1662500620,
        "question_id": 73628028,
        "body_markdown": "Suppose that the output of a jq command is a list of objects. What would be the command to get this list as the attribute of an object? That is: transforming the output from a list into an object.\r\n\r\nExample JSON list:\r\n\r\n```json\r\n[\r\n  {&quot;name&quot;:&quot;Foo&quot;},\r\n  {&quot;name&quot;:&quot;Bar&quot;}\r\n]\r\n```\r\n\r\nExample desired output object:\r\n\r\n_The attribute &quot;items&quot; has been added, and contains the list that serves as input._\r\n\r\n```json\r\n{\r\n  &quot;items&quot;: [\r\n    {&quot;name&quot;:&quot;Foo&quot;},\r\n    {&quot;name&quot;:&quot;Bar&quot;}\r\n  ]\r\n}\r\n```",
        "link": "https://stackoverflow.com/questions/73628028/how-can-i-transform-a-json-array-returned-by-jq-into-an-object-with-a-single-att",
        "title": "How can I transform a JSON array returned by jq into an object with a single attribute with that list&#39;s data?"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1662544925,
                "creation_date": 1662544925,
                "answer_id": 73633556,
                "question_id": 73632847,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "This should work if your actual data doesn&#39;t contain deeper arrays than in your example:\r\n```\r\ndef f: {\r\n  name: .[0],\r\n  value: .[1]\r\n};\r\n{\r\n  children: [\r\n    _nwise(2) | (.[0] | f) + {\r\n      children: (.[1] | map(f))\r\n    }\r\n  ]\r\n}\r\n```\r\n&lt;sup&gt;[Online demo](https://jqplay.org/s/B28sJ05rLhH)&lt;/sup&gt;",
                "title": "Transforming arrays of varying length into objects based on the parity of their indices in JQ"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1662546364,
        "creation_date": 1662541907,
        "last_edit_date": 1662546364,
        "question_id": 73632847,
        "body_markdown": "Basically i need to transform a set of arrays depending on if the index is odd or even, while the length of each array is different.\r\nWhat i have been unable to do is to transform and add the additional arrays into the right children array, which im guessing should be done based on if the index of the array is odd or even.\r\nI need a universal solution, which would work on a bigger amount of data also.\r\n\r\njson example: \r\n```\r\n[\r\n  [\r\n    [\r\n      &quot;dev&quot;,\r\n      5\r\n    ],\r\n    [\r\n      [\r\n        &quot;RT&quot;,\r\n        1\r\n      ],\r\n      [\r\n        &quot;CP&quot;,\r\n        2\r\n      ]\r\n    ]\r\n  ],\r\n  [\r\n    [\r\n      &quot;jez&quot;,\r\n      2\r\n    ],\r\n    [\r\n      [\r\n        &quot;ME&quot;,\r\n        1\r\n      ],\r\n      [\r\n        &quot;PW&quot;,\r\n        1\r\n      ]\r\n    ],\r\n    [\r\n      &quot;lem&quot;,\r\n      3\r\n    ],\r\n    [\r\n      [\r\n        &quot;AR&quot;,\r\n        1\r\n      ],\r\n      [\r\n        &quot;ME&quot;,\r\n        2\r\n      ]\r\n    ],\r\n    [\r\n      &quot;has&quot;,\r\n      1\r\n    ],\r\n    [\r\n      [\r\n        &quot;MOBILE&quot;,\r\n        1\r\n      ]\r\n    ]\r\n  ]\r\n]\r\n```\r\ntransform into:\r\n```\r\n{\r\n  &quot;children&quot;: [\r\n    {\r\n      &quot;name&quot;: &quot;dev&quot;,\r\n      &quot;value&quot;: 5,\r\n      &quot;children&quot;: [\r\n        {\r\n          &quot;name&quot;: &quot;RT&quot;,\r\n          &quot;value&quot;: 1\r\n        },\r\n        {\r\n          &quot;name&quot;: &quot;CP&quot;,\r\n          &quot;value&quot;: 2\r\n        }\r\n      ]\r\n    }\r\n  ]\r\n}\r\n{\r\n  &quot;children&quot;: [\r\n    {\r\n      &quot;name&quot;: &quot;jez&quot;,\r\n      &quot;value&quot;: 2,\r\n      &quot;children&quot;: [\r\n        {\r\n          &quot;name&quot;: &quot;ME&quot;,\r\n          &quot;value&quot;: 1\r\n        },\r\n        {\r\n          &quot;name&quot;: &quot;PW&quot;,\r\n          &quot;value&quot;: 1\r\n        }\r\n      ]\r\n    },\r\n    {\r\n      &quot;name&quot;: &quot;lem&quot;,\r\n      &quot;value&quot;: 3,\r\n      &quot;children&quot;: [\r\n        {\r\n          &quot;name&quot;: &quot;AR&quot;,\r\n          &quot;value&quot;: 1\r\n        },\r\n        {\r\n          &quot;name&quot;: &quot;ME&quot;,\r\n          &quot;value&quot;: 2\r\n        }\r\n      ]\r\n    },\r\n    {\r\n      &quot;name&quot;: &quot;has&quot;,\r\n      &quot;value&quot;: 1,\r\n      &quot;children&quot;: [\r\n        {\r\n          &quot;name&quot;: &quot;MOBILE&quot;,\r\n          &quot;value&quot;: 1\r\n        }\r\n      ]\r\n    }\r\n  ]\r\n}\r\n```\r\nwhat i have been able to transform it into(jqplay: https://jqplay.org/s/7nZEbfRTKDz)\r\n```\r\n{\r\n  &quot;children&quot;: [\r\n    {\r\n      &quot;name&quot;: &quot;dev&quot;,\r\n      &quot;value&quot;: 5,\r\n      &quot;children&quot;: [\r\n        {\r\n          &quot;name&quot;: &quot;RT&quot;,\r\n          &quot;value&quot;: 1\r\n        },\r\n        {\r\n          &quot;name&quot;: &quot;CP&quot;,\r\n          &quot;value&quot;: 2\r\n        }\r\n      ]\r\n    }\r\n  ]\r\n}\r\n{\r\n  &quot;children&quot;: [\r\n    {\r\n      &quot;name&quot;: &quot;jez&quot;,\r\n      &quot;value&quot;: 2,\r\n      &quot;children&quot;: [\r\n        {\r\n          &quot;name&quot;: &quot;ME&quot;,\r\n          &quot;value&quot;: 1\r\n        },\r\n        {\r\n          &quot;name&quot;: &quot;PW&quot;,\r\n          &quot;value&quot;: 1\r\n        }\r\n      ]\r\n    }\r\n  ]\r\n}\r\n```\r\nthanks in advance for any answers",
        "link": "https://stackoverflow.com/questions/73632847/transforming-arrays-of-varying-length-into-objects-based-on-the-parity-of-their",
        "title": "Transforming arrays of varying length into objects based on the parity of their indices in JQ"
    },
    {
        "tags": [
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1662604984,
                "post_id": 73637407,
                "comment_id": 130045964,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 4271620,
                    "reputation": 219,
                    "user_id": 3493315,
                    "user_type": "registered",
                    "accept_rate": 33,
                    "profile_image": "https://www.gravatar.com/avatar/652dfa0126a15bc9455f80e2e02e5c19?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Madhuprathap",
                    "link": "https://stackoverflow.com/users/3493315/madhuprathap"
                },
                "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": 1662605594,
                "post_id": 73637407,
                "comment_id": 130046056,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 4271620,
                    "reputation": 219,
                    "user_id": 3493315,
                    "user_type": "registered",
                    "accept_rate": 33,
                    "profile_image": "https://www.gravatar.com/avatar/652dfa0126a15bc9455f80e2e02e5c19?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Madhuprathap",
                    "link": "https://stackoverflow.com/users/3493315/madhuprathap"
                },
                "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": 1662605885,
                "post_id": 73637407,
                "comment_id": 130046116,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1662616290,
                "last_edit_date": 1662616290,
                "creation_date": 1662615212,
                "answer_id": 73644131,
                "question_id": 73637407,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Unfortunately there are some aspects of the problem which I do not understand, but the following should help as it addresses the key need:\r\n\r\n&gt; I need to loop items array such that I should continue where I left for an element of vals array.\r\n\r\nThe key to doing this cleanly is to define a helper function which allows us to keep track of where to resume the search:\r\n```\r\n# input: [ $index, $array ] where $index is null or &gt;= -1\r\n# output: the first index, $i, in the array for which\r\n#   $i &gt; $index and $array[$i].amount == $v , or else null\r\ndef value($v): \r\n   . as [ $index, $array ]\r\n   | if $index == null then null\r\n     else first( range($index + 1; $array|length) | select($array[.].amount == $v) ) // null\r\n     end ;\r\n```\r\n\r\nFor computing the number of days between two dates, another helper function will be useful:\r\n```\r\n# Date format: dd-mm-year\r\ndef days($finish; $start):\r\n  [$finish, $start]\r\n  | map(strptime(&quot;%d-%m-%Y&quot;) | mktime) # seconds\r\n  | (.[0] - .[1]) / 86400 + 0.5 | trunc ;\r\n```\r\n\r\nNow we have simply to build up the result by visiting the elements of `.vals`:\r\n```\r\n.items as $items\r\n| reduce .vals[] as $val ({ix: 0, date: .vals[0].date, array: []};\r\n    ([.ix, $items] | value($val.amount)) as $ix\r\n    | .ix = $ix\r\n    | if $ix == null\r\n      then .\r\n      else .date as $date\r\n      | .array += [$val | {month, value: days($items[$ix].date; $date) }] \r\n      | .date = $date\r\n      end )\r\n```\r\n\r\nAs already stated, this is probably not exactly what you want, but should provide a suitable framework for you.\r\n",
                "title": "iterate an array with conditions such that certain elements can be revisited multiple time"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1662616290,
        "creation_date": 1662561618,
        "last_edit_date": 1662605623,
        "question_id": 73637407,
        "body_markdown": "For the input below:\r\n\r\n```\r\n{\r\n\t&quot;vals&quot;: [\r\n      {\r\n        &quot;month&quot;: &quot;Jan 2022&quot;,\r\n        &quot;value&quot;: 0,\r\n        &quot;amount&quot;: -200,\r\n        &quot;date&quot;: &quot;01-02-2022&quot;\r\n      },\r\n      {\r\n        &quot;month&quot;: &quot;Feb 2022&quot;,\r\n        &quot;value&quot;: 0,\r\n        &quot;amount&quot;: -200,\r\n        &quot;date&quot;: &quot;28-02-2022&quot;\r\n      }\r\n    ],\r\n\t&quot;items&quot;: [\r\n\t\t{\r\n\t\t\t&quot;date&quot;: &quot;01-02-2022&quot;,\r\n\t\t\t&quot;amount&quot;: -200\r\n\t\t},\r\n\t\t{\r\n\t\t\t&quot;date&quot;: &quot;04-02-2022&quot;,\r\n\t\t\t&quot;amount&quot;: 100\r\n\t\t},\r\n\t\t{\r\n\t\t\t&quot;date&quot;: &quot;28-02-2022&quot;,\r\n\t\t\t&quot;amount&quot;: -200\r\n\t\t},\r\n\t\t{\r\n\t\t\t&quot;date&quot;: &quot;10-03-2022&quot;\r\n\t\t\t&quot;amount&quot;: 250\r\n\t\t},\r\n\t\t{\r\n\t\t\t&quot;date&quot;: &quot;12-03-2022&quot;\r\n\t\t\t&quot;amount&quot;: 50\r\n\t\t}\r\n\t]\t\r\n}\r\n````\r\n\r\nI want the below output\r\n\r\n````\r\n{\r\n\t&quot;vals&quot;: [\r\n      {\r\n        &quot;month&quot;: &quot;Jan 2022&quot;,\r\n        &quot;value&quot;: 37\r\n      },\r\n      {\r\n        &quot;month&quot;: &quot;Feb 2022&quot;,\r\n        &quot;value&quot;: 12\r\n      }\r\n    ]\r\n}\r\n````\r\n\r\nfor month &quot;Jan 2022&quot; of vals, we have debit amount on 01-02-2022. So need go through the items arrays from 01-02-2022 till the total sum of amount matches with vals &quot;Jan 2022&quot; amount value and we need to the no of days between i.e. 01-02-2022 and 10-03-2022\r\n\r\nfor month &quot;Feb 2022&quot; instead of going through items array again from first we should continue where we left for Jan 2022.\r\n\r\n\t\t{\r\n\t\t\t&quot;date&quot;: &quot;10-03-2022&quot;\r\n\t\t\t&quot;amount&quot;: 250\r\n\t\t}\r\n\r\nof this item 100 is considered for Jan 2022 and 150 is considered for Feb 2022. \r\n\r\nso I need to loop items array such that I should continue where I left for an element of vals array.\r\n\r\n\t\t{\r\n\t\t\t&quot;date&quot;: &quot;10-03-2022&quot;\r\n\t\t\t&quot;amount&quot;: 250\r\n\t\t}\r\nthis element of items array should be considered twice once for Jan 2022 and second for Feb 2022\r\n\r\nBut \r\n\r\n\t\t{\r\n\t\t\t&quot;date&quot;: &quot;04-02-2022&quot;\r\n\t\t\t&quot;amount&quot;: 100\r\n\t\t}\r\nshould considered only once as the 100 will not completely serve Jan 2022 amount i.e. -200\r\n\r\nI hope I made it clear.",
        "link": "https://stackoverflow.com/questions/73637407/iterate-an-array-with-conditions-such-that-certain-elements-can-be-revisited-mul",
        "title": "iterate an array with conditions such that certain elements can be revisited multiple time"
    },
    {
        "tags": [
            "json",
            "bash",
            "logging",
            "sed",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1662573722,
                "post_id": 73639504,
                "comment_id": 130039647,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 7,
                "is_accepted": true,
                "score": 7,
                "last_activity_date": 1662574181,
                "last_edit_date": 1662574181,
                "creation_date": 1662573021,
                "answer_id": 73639722,
                "question_id": 73639504,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If you feed your log sample to:\r\n```\r\njq -rR &#39;index(&quot;{&quot;) as $ix | .[0:$ix], ( .[$ix:]|fromjson)&#39;\r\n```\r\n\r\nyou will get the log stamp followed by a copy of the corresponding valid JSON.  \r\n\r\nYour subject line indicates you want to &quot;prettify&quot; the JSON rather than mangle it, so I&#39;ll assume you didn&#39;t intend the latter.\r\n\r\nIf you really want the initial &#39;{&#39; to appear with the log stamp, then assuming a bash or bash-like shell, you could pipe the above into:\r\n```\r\n    sed $&#39;/^[0-9][0-9][0-9][0-9]-/ {N; s/\\\\n{/{/; }&#39;\r\n```",
                "title": "Prettify json in a streaming log"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1662574469,
        "creation_date": 1662571633,
        "last_edit_date": 1662574469,
        "question_id": 73639504,
        "body_markdown": "I am trying to prettify aws logs stream\r\n\r\nlog format:\r\n```log\r\n2022-09-07T17:14:35.987000+00:00 2022/09/07/[$LATEST]58f517bs4ebcsae033sd953bs734224 {&quot;cold_start&quot;:true,&quot;function_memory_size&quot;:512,&quot;function_request_id&quot;:&quot;a2cfdd5d-4b0b-4cfa-97c2-4af9ba6a1056&quot;,&quot;level&quot;:&quot;ERROR&quot;,&quot;message&quot;:&quot;Unexpected&quot;,&quot;sampling_rate&quot;:1,&quot;timestamp&quot;:&quot;2022-09-07T17:14:35.987Z&quot;,&quot;xray_trace_id&quot;:&quot;1-6318d178-0e96c13a1399a74b4f353edd&quot;,&quot;extra&quot;:&quot;{\\&quot;error\\&quot;:\\&quot;AccessDeniedException: User: arn:aws:sts::\\&quot;,\\&quot;stack\\&quot;:\\&quot;AccessDeniedException: User: arn:aws:sts::\\&quot;}&quot;}\r\n```\r\n\r\nI want to change this to\r\n```\r\n2022-09-07T17:14:35.987000+00:00 2022/09/07/[$LATEST]58f51004277b4ebcae033d953b734224 {\r\n  &quot;cold_start&quot;: true,\r\n  &quot;function_memory_size&quot;: 512,\r\n  &quot;function_request_id&quot;: &quot;a2cfdd5d-4b0b-4cfa-97c2-4af9ba6a1056&quot;,\r\n  &quot;level&quot;: &quot;ERROR&quot;,\r\n  &quot;message&quot;: &quot;Unexpected&quot;,\r\n  &quot;sampling_rate&quot;: 1,\r\n  &quot;timestamp&quot;: &quot;2022-09-07T17:14:35.987Z&quot;,\r\n  &quot;xray_trace_id&quot;: &quot;1-6318d178-0e96c13a1399a74b4f353edd&quot;,\r\n  &quot;extra&quot;: &#39;{&quot;error&quot;:&quot;AccessDeniedException: User: arn:aws:sts::&quot;,&quot;stack&quot;:&quot;AccessDeniedException: User: arn:aws:sts::&quot;}&#39;,\r\n}\r\n```\r\n\r\nI tried this\r\n```\r\naws logs tail /aws/lambda/lambda-name | sed -u -e &quot;s/\\({.*}\\)/$(echo \\&#39;\\\\1\\&#39; | jq)/&quot;\r\n```\r\n\r\nbut I am getting this error\r\n```\r\nparse error: Invalid numeric literal at line 2, column 0\r\n```\r\n\r\nHow do I do this?",
        "link": "https://stackoverflow.com/questions/73639504/prettify-json-in-a-streaming-log",
        "title": "Prettify json in a streaming log"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1662579169,
                "creation_date": 1662579169,
                "answer_id": 73640638,
                "question_id": 73640375,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s one way:\r\n~~~sh\r\nmap(\r\n  select(values)\r\n  | (.type // &quot;UNKN&quot;) as $type\r\n  | ., .changes[]?\r\n  | {id, $type, wanted_key: true}\r\n)\r\n~~~\r\n~~~json\r\n[\r\n  {\r\n    &quot;id&quot;: 1,\r\n    &quot;type&quot;: &quot;A&quot;,\r\n    &quot;wanted_key&quot;: true\r\n  },\r\n  {\r\n    &quot;id&quot;: 12,\r\n    &quot;type&quot;: &quot;A&quot;,\r\n    &quot;wanted_key&quot;: true\r\n  },\r\n  {\r\n    &quot;id&quot;: 13,\r\n    &quot;type&quot;: &quot;A&quot;,\r\n    &quot;wanted_key&quot;: true\r\n  },\r\n  {\r\n    &quot;id&quot;: 2,\r\n    &quot;type&quot;: &quot;A&quot;,\r\n    &quot;wanted_key&quot;: true\r\n  },\r\n  {\r\n    &quot;id&quot;: 3,\r\n    &quot;type&quot;: &quot;B&quot;,\r\n    &quot;wanted_key&quot;: true\r\n  },\r\n  {\r\n    &quot;id&quot;: 31,\r\n    &quot;type&quot;: &quot;B&quot;,\r\n    &quot;wanted_key&quot;: true\r\n  },\r\n  {\r\n    &quot;id&quot;: 32,\r\n    &quot;type&quot;: &quot;B&quot;,\r\n    &quot;wanted_key&quot;: true\r\n  },\r\n  {\r\n    &quot;id&quot;: 4,\r\n    &quot;type&quot;: &quot;B&quot;,\r\n    &quot;wanted_key&quot;: true\r\n  },\r\n  {\r\n    &quot;id&quot;: 7,\r\n    &quot;type&quot;: &quot;UNKN&quot;,\r\n    &quot;wanted_key&quot;: true\r\n  }\r\n]\r\n~~~\r\n[Demo](https://jqplay.org/s/YzLK0AAvQ7q)",
                "title": "how to extract and modify inner array objects with parent object data in jq"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1662579898,
                "last_edit_date": 1662579898,
                "creation_date": 1662579233,
                "answer_id": 73640650,
                "question_id": 73640375,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Something like below should work\r\n\r\n```none\r\nmap( \r\n  select(type == &quot;object&quot;) | \r\n  ( {id}, {id : ( .changes[]? .id )} ) + \r\n  { type: (.type // &quot;UNKN&quot;), wanted_key: true }\r\n)\r\n```\r\n\r\njq play  - [demo][1]\r\n\r\n\r\n  [1]: https://jqplay.org/s/1NCswQyMUI3",
                "title": "how to extract and modify inner array objects with parent object data in jq"
            },
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1662586411,
                "last_edit_date": 1662586411,
                "creation_date": 1662579557,
                "answer_id": 73640705,
                "question_id": 73640375,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The following should work:\r\n\r\n```\r\nmap(select(values))\r\n| map(., .type as $type | (.changes[]? + {$type}))\r\n| map({id, type: (.type // &quot;UNKN&quot;), wanted_key: true})\r\n```\r\n\r\n1. Only select non-null values\r\n2. Return the original items followed by their inner changes array (+ outer type)\r\n3. Extract 3 properties for output\r\n\r\nMultiple `map` calls can usually be combined, so this becomes:\r\n\r\n```\r\nmap(\r\n    select(values)\r\n    | ., (.type as $type | (.changes[]? + {$type}))\r\n    | {id, type: (.type // &quot;UNKN&quot;), wanted_key: true}\r\n)\r\n```\r\n\r\n*****\r\n\r\nAnother option without variables:\r\n\r\n```\r\nmap(\r\n    select(values)\r\n    | ., .changes[]? + {type}\r\n    | {id, type: (.type // &quot;UNKN&quot;), wanted_key: true}\r\n)\r\n# or:\r\nmap(select(values))\r\n| map(., .changes[]? + {type})\r\n| map({id, type: (.type // &quot;UNKN&quot;), wanted_key: true})\r\n```\r\n\r\nor even with a separate normalization step for the unknown type:\r\n\r\n```\r\nmap(select(values))\r\n| map(.type //= &quot;UNKN&quot;)\r\n| map(., .changes[]? + {type})\r\n| map({id, type, wanted_key: true})\r\n# condensed to a single line:\r\nmap(select(values) | .type //= &quot;UNKN&quot; | ., .changes[]? + {type} | {id, type, wanted_key: true})\r\n```\r\n\r\nExplanation:\r\n\r\n1. Select only non-null values from the array\r\n2. If type is not set, create the property with value `&quot;UNKN&quot;`\r\n3. Produce the original array items, followed by their nested changes elements extended with the parent type\r\n4. Reshape objects to only contain properties id, type, and wanted_key.",
                "title": "how to extract and modify inner array objects with parent object data in jq"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 1,
        "last_activity_date": 1662586411,
        "creation_date": 1662577350,
        "question_id": 73640375,
        "body_markdown": "We are tying to format a json similar to this:\r\n\r\n```json\r\n[\r\n{&quot;id&quot;: 1,\r\n    &quot;type&quot;: &quot;A&quot;,\r\n    &quot;changes&quot;: [ \r\n        {&quot;id&quot;: 12},\r\n        {&quot;id&quot;: 13}\r\n    ],\r\n    &quot;wanted_key&quot;: &quot;good&quot;,\r\n    &quot;unwanted_key&quot;: &quot;aaa&quot;\r\n},\r\n{&quot;id&quot;: 2,\r\n    &quot;type&quot;: &quot;A&quot;,\r\n    &quot;unwanted_key&quot;: &quot;aaa&quot;\r\n},\r\n{&quot;id&quot;: 3,\r\n    &quot;type&quot;: &quot;B&quot;,\r\n    &quot;changes&quot;: [\r\n        {&quot;id&quot;: 31},\r\n        {&quot;id&quot;: 32}\r\n    ],\r\n    &quot;unwanted_key&quot;: &quot;aaa&quot;,\r\n    &quot;unwanted_key2&quot;: &quot;aaa&quot;\r\n},\r\n{&quot;id&quot;: 4,\r\n    &quot;type&quot;: &quot;B&quot;,\r\n    &quot;unwanted_key3&quot;: &quot;aaa&quot;\r\n},\r\nnull,\r\nnull,\r\n{&quot;id&quot;: 7}\r\n]\r\n```\r\n\r\ninto something like this:\r\n\r\n```json\r\n[\r\n  {\r\n    &quot;id&quot;: 1,\r\n    &quot;type&quot;: &quot;A&quot;,\r\n    &quot;wanted_key&quot;: true  # every record must have this key/value\r\n  },\r\n  {\r\n    &quot;id&quot;: 12,  # note: this was in the &quot;changes&quot; property of record id 1\r\n    &quot;type&quot;: &quot;A&quot;,  # type should be the same type than record id 1\r\n    &quot;wanted_key&quot;: true\r\n  },\r\n  {\r\n    &quot;id&quot;: 13,  # note: this was in the &quot;changes&quot; property of record id 1\r\n    &quot;type&quot;: &quot;A&quot;,  # type should be the same type than record id 1\r\n    &quot;wanted_key&quot;: true\r\n  },\r\n  {\r\n    &quot;id&quot;: 2,\r\n    &quot;type&quot;: &quot;A&quot;,\r\n    &quot;wanted_key&quot;: true\r\n  },\r\n  {\r\n    &quot;id&quot;: 3,\r\n    &quot;type&quot;: &quot;B&quot;,\r\n    &quot;wanted_key&quot;: true\r\n  },\r\n  {\r\n    &quot;id&quot;: 31,  # note: this was in the &quot;changes&quot; property of record id 3\r\n    &quot;type&quot;: &quot;B&quot;,  # type should be the same type than record id 3\r\n    &quot;wanted_key&quot;: true\r\n  },\r\n  {\r\n    &quot;id&quot;: 32,  # note: this was in the &quot;changes&quot; property of record id 3\r\n    &quot;type&quot;: &quot;B&quot;,  # type should be the same type than record id 3\r\n    &quot;wanted_key&quot;: true\r\n  },\r\n  {\r\n    &quot;id&quot;: 4,\r\n    &quot;type&quot;: &quot;B&quot;,\r\n    &quot;wanted_key&quot;: true\r\n  },\r\n  {\r\n    &quot;id&quot;: 7,\r\n    &quot;type&quot;: &quot;UNKN&quot;,  # records without a type should have this type\r\n    &quot;wanted_key&quot;: true\r\n  }\r\n]\r\n\r\n```\r\n\r\nSo far, I&#39;ve been able to: \r\n- remove null records\r\n- obtain the keys we need with their default\r\n- give records without a type a default type\r\n\r\nWhat we are missing:\r\n- from records having a `changes` key, create new records with the `type` of their parent record\r\n- join all records in a single array\r\n\r\nUnfortunately we are not entirely sure how to proceed... Any help would be appreciated.\r\n\r\nSo far our jq goes like this:\r\n`del(..|nulls) | map({id, type: (.type // &quot;UNKN&quot;), wanted_key: (true)}) | del(..|nulls)`\r\n\r\nHere&#39;s our test code:\r\n\r\nhttps://jqplay.org/s/eLAWwP1ha8P",
        "link": "https://stackoverflow.com/questions/73640375/how-to-extract-and-modify-inner-array-objects-with-parent-object-data-in-jq",
        "title": "how to extract and modify inner array objects with parent object data in jq"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 2433008,
                    "reputation": 40025,
                    "user_id": 2123530,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/37a7fba006184897e8d74f1795e2835b?s=256&d=identicon&r=PG",
                    "display_name": "β.εηοιτ.βε",
                    "link": "https://stackoverflow.com/users/2123530/%ce%b2-%ce%b5%ce%b7%ce%bf%ce%b9%cf%84-%ce%b2%ce%b5"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1662619434,
                "post_id": 73641959,
                "comment_id": 130048464,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1662620662,
                "creation_date": 1662620662,
                "answer_id": 73644941,
                "question_id": 73641959,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You have two issues:\r\n\r\n- Your inner `jq` quotes conflict with the outer shell quotes. Replace the inner ones with double quotes `&quot;`, which is the way to use string literals in `jq`.\r\n- To include a variable&#39;s value inside a string in `jq` you would either add up the parts (e.g. using `+` as in `&quot;..&quot; + $var + &quot;..&quot;`), or use string interpolation `&quot;..\\($var)..&quot;`\r\n\r\nTry\r\n~~~sh\r\njq -r --arg CLUSTER_NAME &quot;$EKS_CLUSTER_NAME&quot; &#39;\r\n  .logGroups[] | select(.logGroupName == &quot;/aws/eks/\\($CLUSTER_NAME)/cluster&quot;)\r\n&#39;",
                "title": "Filtering issues with JSON"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1662620662,
        "creation_date": 1662588990,
        "last_edit_date": 1662619445,
        "question_id": 73641959,
        "body_markdown": "I can&#39;t use environment variables inside a string in jmespath. Using a wildcard could have also worked but it didn&#39;t work in my case either. Any leads on this issue would be appreciated thanks!\r\n\r\n```\r\naws logs describe-log-groups | jq -r --arg CLUSTER_NAME &quot;$EKS_CLUSTER_NAME&quot; &#39;.logGroups[] | select(.logGroupName == &#39;/aws/eks/$CLUSTER_NAME/cluster&#39;)&#39;\r\n```\r\n\r\nOutput:\r\n```\r\njq: error: syntax error, unexpected &#39;/&#39; (Unix shell quoting issues?) at &lt;top-level&gt;, line 1:\r\n.logGroups[] | select(.logGroupName == /aws/eks//cluster)\r\njq: 1 compile error\r\n```",
        "link": "https://stackoverflow.com/questions/73641959/filtering-issues-with-json",
        "title": "Filtering issues with JSON"
    },
    {
        "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": 1662626804,
                "post_id": 73645963,
                "comment_id": 130050704,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 4271620,
                    "reputation": 219,
                    "user_id": 3493315,
                    "user_type": "registered",
                    "accept_rate": 33,
                    "profile_image": "https://www.gravatar.com/avatar/652dfa0126a15bc9455f80e2e02e5c19?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Madhuprathap",
                    "link": "https://stackoverflow.com/users/3493315/madhuprathap"
                },
                "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": 1662627300,
                "post_id": 73645963,
                "comment_id": 130050872,
                "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": 1662627396,
                "post_id": 73645963,
                "comment_id": 130050906,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 4271620,
                    "reputation": 219,
                    "user_id": 3493315,
                    "user_type": "registered",
                    "accept_rate": 33,
                    "profile_image": "https://www.gravatar.com/avatar/652dfa0126a15bc9455f80e2e02e5c19?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Madhuprathap",
                    "link": "https://stackoverflow.com/users/3493315/madhuprathap"
                },
                "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": 1662628410,
                "post_id": 73645963,
                "comment_id": 130051241,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1662630132,
                "creation_date": 1662630132,
                "answer_id": 73646921,
                "question_id": 73645963,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You cannot &quot;update&quot; a variable in the same context, you can only shadow it by setting its value for a new context, based on the previous.\r\n\r\nThat said, `range` already iterates in your sense, no need to `+1` anywhere. Store the value of the iteration itself to the `$runner` variable, and you can use it as envisioned. To filter out certain values, use `select`, no need for `label` and `break`.\r\n\r\n~~~sh\r\n. as $index | range($index; 20) as $runner\r\n| select($runner &lt; 10) | &quot;dx\\($runner)&quot;\r\n~~~\r\n~~~json\r\n&quot;dx1&quot;\r\n&quot;dx2&quot;\r\n&quot;dx3&quot;\r\n&quot;dx4&quot;\r\n&quot;dx5&quot;\r\n&quot;dx6&quot;\r\n&quot;dx7&quot;\r\n&quot;dx8&quot;\r\n&quot;dx9&quot;\r\n~~~\r\n[Demo](https://jqplay.org/s/jzBy_hytVUd)\r\n\r\n---\r\nIf you don&#39;t need the variables elsewhere, you can even iterate without variables. A condensed version ofthe above:\r\n~~~sh\r\nrange(.; 20) | &quot;dx\\(select(. &lt; 10))&quot;\r\n~~~\r\n[Demo](https://jqplay.org/s/8Tit6KEf5ij)",
                "title": "how to update a variable defined out side of range from the range"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -2,
        "last_activity_date": 1662630132,
        "creation_date": 1662625864,
        "question_id": 73645963,
        "body_markdown": "````\r\n. as $index | 1 as $runner | label $out | range($index; 20) \r\n| if (. == 10) then break $out else &quot;dx&quot; + ($runner|tostring) | ($runner+1) as $runner | . end\r\n```` \r\nfor input 1\r\n\r\nI would like to update $runner variable value while looping using range.\r\n\r\n\r\n[demo][1]\r\n\r\n\r\nThanks in advance\r\n\r\n\r\n  [1]: https://jqplay.org/s/r3MYd5lMrrR",
        "link": "https://stackoverflow.com/questions/73645963/how-to-update-a-variable-defined-out-side-of-range-from-the-range",
        "title": "how to update a variable defined out side of range from the range"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 39208,
                    "reputation": 267964,
                    "user_id": 112968,
                    "user_type": "registered",
                    "accept_rate": 68,
                    "profile_image": "https://i.sstatic.net/zHTaT.png?s=256",
                    "display_name": "knittl",
                    "link": "https://stackoverflow.com/users/112968/knittl"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1663014888,
                "post_id": 73648264,
                "comment_id": 130135542,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1066421,
                    "reputation": 109,
                    "user_id": 1066865,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/V8xBA.jpg?s=256",
                    "display_name": "EBAH",
                    "link": "https://stackoverflow.com/users/1066865/ebah"
                },
                "reply_to_user": {
                    "account_id": 39208,
                    "reputation": 267964,
                    "user_id": 112968,
                    "user_type": "registered",
                    "accept_rate": 68,
                    "profile_image": "https://i.sstatic.net/zHTaT.png?s=256",
                    "display_name": "knittl",
                    "link": "https://stackoverflow.com/users/112968/knittl"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1663071994,
                "post_id": 73648264,
                "comment_id": 130148713,
                "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": 1663102479,
                "post_id": 73648264,
                "comment_id": 130159745,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1066421,
                    "reputation": 109,
                    "user_id": 1066865,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/V8xBA.jpg?s=256",
                    "display_name": "EBAH",
                    "link": "https://stackoverflow.com/users/1066865/ebah"
                },
                "reply_to_user": {
                    "account_id": 39208,
                    "reputation": 267964,
                    "user_id": 112968,
                    "user_type": "registered",
                    "accept_rate": 68,
                    "profile_image": "https://i.sstatic.net/zHTaT.png?s=256",
                    "display_name": "knittl",
                    "link": "https://stackoverflow.com/users/112968/knittl"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1663129006,
                "post_id": 73648264,
                "comment_id": 130163768,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1662636469,
                "creation_date": 1662636469,
                "answer_id": 73648355,
                "question_id": 73648264,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Well, you were close. Here&#39;s how you put those together:\r\n```\r\nmap({name, definedRanges: .definedRanges | map({name, beginIPv4Address, endIPv4Address})})\r\n```\r\n&lt;sup&gt;[Online demo](https://jqplay.org/s/tHkRlLUV3K-)&lt;/sup&gt;",
                "title": "How to filter object at multiple levels in JQ?"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1662637212,
                "creation_date": 1662637212,
                "answer_id": 73648496,
                "question_id": 73648264,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The &#39;*or even this*&#39; can be achieved using:\r\n```\r\nmap(.name as $name | .definedRanges[] | { name, beginIPv4Address, endIPv4Address} | with_entries(.key = &quot;definedRanges.&quot; + .key) | .name = $name)\r\n```\r\n\r\nWhich yields:\r\n```json\r\n[\r\n  {\r\n    &quot;definedRanges.name&quot;: &quot;100-200&quot;,\r\n    &quot;definedRanges.beginIPv4Address&quot;: &quot;192.168.090.100&quot;,\r\n    &quot;definedRanges.endIPv4Address&quot;: &quot;192.168.090.200&quot;,\r\n    &quot;name&quot;: &quot;home network configuration&quot;\r\n  },\r\n  {\r\n    &quot;definedRanges.name&quot;: &quot;100-200&quot;,\r\n    &quot;definedRanges.beginIPv4Address&quot;: &quot;192.168.090.100&quot;,\r\n    &quot;definedRanges.endIPv4Address&quot;: &quot;192.168.090.200&quot;,\r\n    &quot;name&quot;: &quot;lab network configuration&quot;\r\n  },\r\n  {\r\n    &quot;definedRanges.name&quot;: &quot;100-200&quot;,\r\n    &quot;definedRanges.beginIPv4Address&quot;: &quot;192.168.090.100&quot;,\r\n    &quot;definedRanges.endIPv4Address&quot;: &quot;192.168.090.200&quot;,\r\n    &quot;name&quot;: &quot;lab network configuration&quot;\r\n  }\r\n]\r\n```\r\n\r\n[Demo](https://jqplay.org/s/m7gEiLLqkE4)",
                "title": "How to filter object at multiple levels in JQ?"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1663855590,
                "last_edit_date": 1663855590,
                "creation_date": 1663014772,
                "answer_id": 73694969,
                "question_id": 73648264,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s my shot at solutions to produce one or the other desired output:\r\n\r\n```\r\nmap(\r\n  { name }\r\n  + (.definedRanges[] | {\r\n      &quot;definedRanges.name&quot;: .name,\r\n      &quot;definedRanges.beginIPv4Address&quot;: .beginIPv4Address,\r\n      &quot;definedRanges.endIPv4Address&quot;: .endIPv4Address\r\n  }))\r\n```\r\n\r\nOutput:\r\n\r\n```json\r\n[\r\n  {\r\n    &quot;name&quot;: &quot;home network configuration&quot;,\r\n    &quot;definedRanges.name&quot;: &quot;100-200&quot;,\r\n    &quot;definedRanges.beginIPv4Address&quot;: &quot;192.168.090.100&quot;,\r\n    &quot;definedRanges.endIPv4Address&quot;: &quot;192.168.090.200&quot;\r\n  },\r\n  {\r\n    &quot;name&quot;: &quot;lab network configuration&quot;,\r\n    &quot;definedRanges.name&quot;: &quot;100-200&quot;,\r\n    &quot;definedRanges.beginIPv4Address&quot;: &quot;192.168.090.100&quot;,\r\n    &quot;definedRanges.endIPv4Address&quot;: &quot;192.168.090.200&quot;\r\n  },\r\n  {\r\n    &quot;name&quot;: &quot;lab network configuration&quot;,\r\n    &quot;definedRanges.name&quot;: &quot;100-200&quot;,\r\n    &quot;definedRanges.beginIPv4Address&quot;: &quot;192.168.090.100&quot;,\r\n    &quot;definedRanges.endIPv4Address&quot;: &quot;192.168.090.200&quot;\r\n  }\r\n]\r\n```\r\n\r\nProducing the first kind of output is even simpler (IMHO it reads a bit more straightforward):\r\n\r\n```\r\nmap({\r\n    name,\r\n    definedRanges: .definedRanges | map({ name, beginIPv4Address, endIPv4Address })\r\n})\r\n```\r\n\r\nOutput:\r\n\r\n```json\r\n[\r\n  {\r\n    &quot;name&quot;: &quot;home network configuration&quot;,\r\n    &quot;definedRanges&quot;: [\r\n      {\r\n        &quot;name&quot;: &quot;100-2001&quot;,\r\n        &quot;beginIPv4Address&quot;: &quot;192.168.090.101&quot;,\r\n        &quot;endIPv4Address&quot;: &quot;192.168.090.201&quot;\r\n      }\r\n    ]\r\n  },\r\n  {\r\n    &quot;name&quot;: &quot;lab network configuration&quot;,\r\n    &quot;definedRanges&quot;: [\r\n      {\r\n        &quot;name&quot;: &quot;100-2002&quot;,\r\n        &quot;beginIPv4Address&quot;: &quot;192.168.090.102&quot;,\r\n        &quot;endIPv4Address&quot;: &quot;192.168.090.202&quot;\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;100-2003&quot;,\r\n        &quot;beginIPv4Address&quot;: &quot;192.168.090.103&quot;,\r\n        &quot;endIPv4Address&quot;: &quot;192.168.090.203&quot;\r\n      }\r\n    ]\r\n  }\r\n]\r\n```",
                "title": "How to filter object at multiple levels in JQ?"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 0,
        "last_activity_date": 1663855590,
        "creation_date": 1662636126,
        "last_edit_date": 1663128905,
        "question_id": 73648264,
        "body_markdown": "I have a json like this but much longer:\r\n\r\n    [\r\n      {\r\n        &quot;id&quot;: &quot;123&quot;,\r\n        &quot;name&quot;: &quot;home network configuration&quot;,\r\n        &quot;description&quot;: &quot;home utilities&quot;,\r\n        &quot;definedRanges&quot;: [\r\n          {\r\n    \t    &quot;id&quot;: &quot;6500b67e&quot;,\r\n            &quot;name&quot;: &quot;100-200&quot;,\r\n            &quot;beginIPv4Address&quot;: &quot;192.168.090.100&quot;,\r\n            &quot;endIPv4Address&quot;: &quot;192.168.090.200&quot;,\r\n            &quot;state&quot;: &quot;UNALLOCATED&quot;\r\n          }\r\n        ]\r\n      },\r\n      {\r\n        &quot;id&quot;: &quot;456&quot;,\r\n        &quot;name&quot;: &quot;lab network configuration&quot;,\r\n        &quot;description&quot;: &quot;lab experiments&quot;,\r\n        &quot;definedRanges&quot;: [\r\n          {\r\n            &quot;id&quot;: &quot;1209b90d&quot;,\r\n            &quot;name&quot;: &quot;100-200&quot;,\r\n            &quot;beginIPv4Address&quot;: &quot;192.168.090.100&quot;,\r\n            &quot;endIPv4Address&quot;: &quot;192.168.090.200&quot;,\r\n            &quot;state&quot;: &quot;ALLOCATED&quot;\r\n          },\r\n          {\r\n            &quot;id&quot;: &quot;99e08ca4&quot;,\r\n            &quot;name&quot;: &quot;100-200&quot;,\r\n            &quot;beginIPv4Address&quot;: &quot;192.168.090.100&quot;,\r\n            &quot;endIPv4Address&quot;: &quot;192.168.090.200&quot;,\r\n            &quot;state&quot;: &quot;UNALLOCATED&quot;\r\n          }\r\n        ]\r\n      }\r\n    ]\r\n\r\nI&#39;d like to query with jq and obtain the following:\r\n\r\n    [\r\n      {\r\n        &quot;name&quot;: &quot;home network configuration&quot;\r\n        &quot;definedRanges&quot;: [\r\n          {\r\n            &quot;name&quot;: &quot;100-200&quot;,\r\n            &quot;beginIPv4Address&quot;: &quot;192.168.090.100&quot;,\r\n            &quot;endIPv4Address&quot;: &quot;192.168.090.200&quot;,\r\n          }\r\n        ]\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;lab network configuration&quot;,\r\n        &quot;definedRanges&quot;: [\r\n          {\r\n            &quot;name&quot;: &quot;100-200&quot;,\r\n            &quot;beginIPv4Address&quot;: &quot;192.168.090.100&quot;,\r\n            &quot;endIPv4Address&quot;: &quot;192.168.090.200&quot;,\r\n          },\r\n          {\r\n            &quot;name&quot;: &quot;100-200&quot;,\r\n            &quot;beginIPv4Address&quot;: &quot;192.168.090.100&quot;,\r\n            &quot;endIPv4Address&quot;: &quot;192.168.090.200&quot;,\r\n          }\r\n        ]\r\n      }\r\n    ]\r\n\r\nor even this:\r\n\r\n    [\r\n      {\r\n        &quot;name&quot;: &quot;home network configuration&quot;,\r\n        &quot;definedRanges.name&quot;: &quot;100-200&quot;,\r\n        &quot;definedRanges.beginIPv4Address&quot;: &quot;192.168.090.100&quot;,\r\n        &quot;definedRanges.endIPv4Address&quot;: &quot;192.168.090.200&quot;,\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;lab network configuration&quot;,\r\n        &quot;definedRanges.name&quot;: &quot;100-200&quot;,\r\n        &quot;definedRanges.beginIPv4Address&quot;: &quot;192.168.090.100&quot;,\r\n        &quot;definedRanges.endIPv4Address&quot;: &quot;192.168.090.200&quot;,\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;lab network configuration&quot;,\r\n        &quot;definedRanges.name&quot;: &quot;100-200&quot;,\r\n        &quot;definedRanges.beginIPv4Address&quot;: &quot;192.168.090.100&quot;,\r\n        &quot;definedRanges.endIPv4Address&quot;: &quot;192.168.090.200&quot;,\r\n      }\r\n    ]\r\n\r\nSo far I was able to extract the network name at the first level with:\r\n\r\n    .[] | {name}\r\n\r\nI could also extract the definedRanges with:\r\n\r\n    .[].definedRanges[] | {name,beginIPv4Address,endIPv4Address}\r\n\r\nBut I can&#39;t figure out how to merge the two with jq.\r\n\r\nI solved the problem with a very simple python script (7 lines of code) but now I&#39;d like to understand how to do the same with jq, out of curiosity.",
        "link": "https://stackoverflow.com/questions/73648264/how-to-filter-object-at-multiple-levels-in-jq",
        "title": "How to filter object at multiple levels in JQ?"
    },
    {
        "tags": [
            "json",
            "linux",
            "bash",
            "parsing",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 39208,
                    "reputation": 267964,
                    "user_id": 112968,
                    "user_type": "registered",
                    "accept_rate": 68,
                    "profile_image": "https://i.sstatic.net/zHTaT.png?s=256",
                    "display_name": "knittl",
                    "link": "https://stackoverflow.com/users/112968/knittl"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1662669393,
                "post_id": 73648521,
                "comment_id": 130065896,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 3584587,
                    "reputation": 27,
                    "user_id": 2992033,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/0497a0b64dad2b2714f2f06631c00f81?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Mr.Simple",
                    "link": "https://stackoverflow.com/users/2992033/mr-simple"
                },
                "reply_to_user": {
                    "account_id": 39208,
                    "reputation": 267964,
                    "user_id": 112968,
                    "user_type": "registered",
                    "accept_rate": 68,
                    "profile_image": "https://i.sstatic.net/zHTaT.png?s=256",
                    "display_name": "knittl",
                    "link": "https://stackoverflow.com/users/112968/knittl"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1662722957,
                "post_id": 73648521,
                "comment_id": 130077424,
                "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": 1662732830,
                "post_id": 73648521,
                "comment_id": 130081143,
                "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": 1662740283,
                "post_id": 73648521,
                "comment_id": 130083720,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": false,
                "score": 4,
                "last_activity_date": 1662641904,
                "last_edit_date": 1662641904,
                "creation_date": 1662638397,
                "answer_id": 73648769,
                "question_id": 73648521,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "```\r\n.categories[].Attributes[] | \r\n    if (.key | IN([&quot;AAA&quot;,&quot;BBB&quot;,&quot;DDD&quot;,&quot;EEE&quot;][])) \r\n        then .value \r\n        else &quot;NOT-EXIST&quot; \r\n    end\r\n```\r\n\r\nGives the following output\r\n```none\r\n&quot;111&quot;\r\n&quot;222&quot;\r\n&quot;NOT-EXIST&quot;\r\n&quot;444&quot;\r\n&quot;555&quot;\r\n```\r\n\r\n\r\n* First we loop over the `Attributes`\r\n* Then we use an `if` to;\r\n    * Check if `key` exist in `[&quot;AAA&quot;,&quot;BBB&quot;,&quot;DDD&quot;,&quot;EEE&quot;]`\r\n    * TRUE: use `.value`\r\n    * FALSE: use `NOT-EXIST` as value\r\n\r\n#### [Demo](https://jqplay.org/s/_A0iCOx17hu)\r\n\r\n\r\n----------\r\n\r\n\r\n----------\r\n\r\nAnother approach, using `with_entries()` to update the `.value` before looping over all the objects to show just the value, gives the same output as above:\r\n```none\r\n.categories[].Attributes[] \r\n    | select(.key | IN([&quot;AAA&quot;,&quot;BBB&quot;,&quot;DDD&quot;,&quot;EEE&quot;][]) | not).value = &quot;NOT-EXIST&quot;\r\n    | .value\r\n```\r\n\r\n#### [Demo](https://jqplay.org/s/ixibsda1JlE)",
                "title": "Check if Json field Exist, giving default value with (select) jq command"
            },
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1663855708,
                "last_edit_date": 1663855708,
                "creation_date": 1662731998,
                "answer_id": 73663306,
                "question_id": 73648521,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I hope I understood your requirements correctly, but here is a solution that looks simple enough to understand and should be somewhat efficient. If you always expect the same 5 keys in your input, you can try:\r\n\r\n```\r\n.categories[].Attributes | from_entries as $attr\r\n  | [&quot;AAA&quot;, &quot;BBB&quot;, &quot;CCC&quot;, &quot;DDD&quot;, &quot;EEE&quot;]\r\n  | map($attr[.] // &quot;NOT-EXIST&quot;)\r\n```\r\n\r\nInput:\r\n\r\n```json\r\n{&quot;categories&quot;: [\r\n{\r\n  &quot;categoryName&quot;: &quot;Device&quot;,\r\n  &quot;Attributes&quot;: [\r\n    {\r\n      &quot;key&quot;: &quot;AAA&quot;,\r\n      &quot;value&quot;: &quot;111&quot;\r\n    },\r\n    {\r\n      &quot;key&quot;: &quot;BBB&quot;,\r\n      &quot;value&quot;: &quot;222&quot;\r\n    },\r\n    {\r\n      &quot;key&quot;: &quot;DDD&quot;,\r\n      &quot;value&quot;: &quot;444&quot;\r\n    },\r\n    {\r\n      &quot;key&quot;: &quot;EEE&quot;,\r\n      &quot;value&quot;: &quot;555&quot;\r\n    }\r\n  ]\r\n}]}\r\n```\r\n\r\nOutput:\r\n\r\n```\r\n[\r\n  &quot;111&quot;,\r\n  &quot;222&quot;,\r\n  &quot;NOT-EXIST&quot;,\r\n  &quot;444&quot;,\r\n  &quot;555&quot;\r\n]\r\n```\r\n\r\nIf you require only the values, add `[]` or `| .[]` at the end of the script or rewrite to:\r\n\r\n```\r\n.categories[].Attributes | from_entries as $attr\r\n  | &quot;AAA&quot;, &quot;BBB&quot;, &quot;CCC&quot;, &quot;DDD&quot;, &quot;EEE&quot;\r\n  | $attr[.] // &quot;NOT-EXIST&quot;\r\n```\r\n\r\n****\r\n\r\nWith the input from updated question, you intend to first merge all `extendedAttributes` array into one big array, convert to an object and then use this complete object to look up your values:\r\n\r\n```\r\n.categories | map(.extendedAttributes[]) | from_entries as $attr\r\n  | &quot;ICCID&quot;, &quot;MDN&quot;, &quot;MSISDN&quot;, &quot;MCC&quot;, &quot;MNC&quot;, &quot;FeatureTypes&quot;, &quot;RatePlanCode&quot;, &quot;RatePlanDescription&quot;, &quot;DeviceState&quot;, &quot;BillingCycleStartDate&quot;, &quot;BillingCycleEndDate&quot;, &quot;CurrentBillCycleDataUnRatedUsage&quot;\r\n  | $attr[.] // &quot;NOT-EXIST&quot;\r\n```\r\n\r\n`.categories | map(.extendedAttributes[])` can be rewritten as `[.categories[].extendedAttributes[]]` or `.categories | map(.extendedAttributes) | add`, which might be easier to grok.\r\n\r\nOutput:\r\n\r\n```\r\n&quot;89148000&quot;\r\n&quot;5514048068&quot;\r\n&quot;NOT-EXIST&quot;\r\n&quot;311&quot;\r\n&quot;480&quot;\r\n&quot;4G Public Dynamic&quot;\r\n&quot;4G5G &quot;\r\n&quot;4G5G&quot;\r\n&quot;active&quot;\r\n&quot;2022-09-02T00:00:00Z&quot;\r\n&quot;2022-10-01T00:00:00Z&quot;\r\n&quot;1698414605&quot;\r\n```\r\n\r\n*****\r\n\r\nA version without an intermediate variable is also possible:\r\n\r\n```\r\n[\r\n  .categories | map(.extendedAttributes[]) | from_entries[\r\n    &quot;ICCID&quot;,\r\n    &quot;MDN&quot;,\r\n    &quot;MSISDN&quot;,\r\n    &quot;MCC&quot;,\r\n    &quot;MNC&quot;,\r\n    &quot;FeatureTypes&quot;,\r\n    &quot;RatePlanCode&quot;,\r\n    &quot;RatePlanDescription&quot;,\r\n    &quot;DeviceState&quot;,\r\n    &quot;BillingCycleStartDate&quot;,\r\n    &quot;BillingCycleEndDate&quot;,\r\n    &quot;CurrentBillCycleDataUnRatedUsage&quot;\r\n  ]\r\n]\r\n| map(. // &quot;NOT-EXIST&quot;)\r\n```\r\n\r\nor\r\n\r\n```\r\n[\r\n  .categories | map(.extendedAttributes[]) | from_entries\r\n  | .[&quot;ICCID&quot;, &quot;MDN&quot;, &quot;MSISDN&quot;, &quot;MCC&quot;, &quot;MNC&quot;, &quot;FeatureTypes&quot;, &quot;RatePlanCode&quot;, &quot;RatePlanDescription&quot;, &quot;DeviceState&quot;, &quot;BillingCycleStartDate&quot;, &quot;BillingCycleEndDate&quot;, &quot;CurrentBillCycleDataUnRatedUsage&quot;]\r\n]\r\n| map(. // &quot;NOT-EXIST&quot;)\r\n```",
                "title": "Check if Json field Exist, giving default value with (select) jq command"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": -2,
        "last_activity_date": 1663855708,
        "creation_date": 1662637344,
        "last_edit_date": 1662739046,
        "question_id": 73648521,
        "body_markdown": "I have some JSON data and i want to push some of them to DB , but sometimes the json values not exists for specific devices:\r\nfrom all of the following data I want just to pull , **&quot;ICCID&quot;,&quot;MDN&quot;,&quot;MSISDN&quot;,&quot;MCC&quot;,&quot;MNC&quot;,&quot;FeatureTypes&quot;,&quot;RatePlanCode&quot;,&quot;RatePlanDescription&quot;,&quot;DeviceState&quot;,&quot;BillingCycleStartDate&quot;,&quot;BillingCycleEndDate&quot;,&quot;CurrentBillCycleDataUnRatedUsage&quot;**\r\n \r\nand if any one not exist print not-exist . \r\n\r\n\r\n    {\r\n\t&quot;categories&quot;: [{\r\n\t\t\t&quot;categoryName&quot;: &quot;DeviceIdentifier&quot;,\r\n\t\t\t&quot;extendedAttributes&quot;: [{\r\n\t\t\t\t\t&quot;key&quot;: &quot;ICCID&quot;,\r\n\t\t\t\t\t&quot;value&quot;: &quot;89148000&quot;\r\n\t\t\t\t},\r\n\t\t\t\t{\r\n\t\t\t\t\t&quot;key&quot;: &quot;IMSI&quot;,\r\n\t\t\t\t\t&quot;value&quot;: &quot;31148094&quot;\r\n\t\t\t\t},\r\n\t\t\t\t{\r\n\t\t\t\t\t&quot;key&quot;: &quot;MDN&quot;,\r\n\t\t\t\t\t&quot;value&quot;: &quot;5514048068&quot;\r\n\t\t\t\t},\r\n\t\t\t\t{\r\n\t\t\t\t\t&quot;key&quot;: &quot;MEID&quot;,\r\n\t\t\t\t\t&quot;value&quot;: &quot;A0000000005006&quot;\r\n\t\t\t\t},\r\n\t\t\t\t{\r\n\t\t\t\t\t&quot;key&quot;: &quot;MIN&quot;,\r\n\t\t\t\t\t&quot;value&quot;: &quot;5514041185&quot;\r\n\t\t\t\t}\r\n\t\t\t]\r\n\t\t},\r\n\t\t{\r\n\t\t\t&quot;categoryName&quot;: &quot;DeviceAttributes&quot;,\r\n\t\t\t&quot;extendedAttributes&quot;: [{\r\n\t\t\t\t\t&quot;key&quot;: &quot;MCC&quot;,\r\n\t\t\t\t\t&quot;value&quot;: &quot;311&quot;\r\n\t\t\t\t},\r\n\t\t\t\t{\r\n\t\t\t\t\t&quot;key&quot;: &quot;MNC&quot;,\r\n\t\t\t\t\t&quot;value&quot;: &quot;480&quot;\r\n\t\t\t\t},\r\n\t\t\t\t{\r\n\t\t\t\t\t&quot;key&quot;: &quot;FeatureCodes&quot;,\r\n\t\t\t\t\t&quot;value&quot;: &quot;75802,84777,54307&quot;\r\n\t\t\t\t},\r\n\t\t\t\t{\r\n\t\t\t\t\t&quot;key&quot;: &quot;FeatureNames&quot;,\r\n\t\t\t\t\t&quot;value&quot;: &quot;75802,84777,54307&quot;\r\n\t\t\t\t},\r\n\t\t\t\t{\r\n\t\t\t\t\t&quot;key&quot;: &quot;FeatureTypes&quot;,\r\n\t\t\t\t\t&quot;value&quot;: &quot;4G Public Dynamic&quot;\r\n\t\t\t\t},\r\n\t\t\t\t{\r\n\t\t\t\t\t&quot;key&quot;: &quot;RatePlanCode&quot;,\r\n\t\t\t\t\t&quot;value&quot;: &quot;4G5G &quot;\r\n\t\t\t\t},\r\n\t\t\t\t{\r\n\t\t\t\t\t&quot;key&quot;: &quot;RatePlanDescription&quot;,\r\n\t\t\t\t\t&quot;value&quot;: &quot;4G5G&quot;\r\n\t\t\t\t},\r\n\t\t\t\t{\r\n\t\t\t\t\t&quot;key&quot;: &quot;Services&quot;,\r\n\t\t\t\t\t&quot;value&quot;: &quot;null&quot;\r\n\t\t\t\t}\r\n\t\t\t]\r\n\t\t},\r\n\t\t{\r\n\t\t\t&quot;categoryName&quot;: &quot;Provisioning&quot;,\r\n\t\t\t&quot;extendedAttributes&quot;: [{\r\n\t\t\t\t\t&quot;key&quot;: &quot;LastActivationDate&quot;,\r\n\t\t\t\t\t&quot;value&quot;: &quot;2022-03-01T19:38:52Z&quot;\r\n\t\t\t\t},\r\n\t\t\t\t{\r\n\t\t\t\t\t&quot;key&quot;: &quot;CreatedAt&quot;,\r\n\t\t\t\t\t&quot;value&quot;: &quot;2021-12-01T21:22:55Z&quot;\r\n\t\t\t\t},\r\n\t\t\t\t{\r\n\t\t\t\t\t&quot;key&quot;: &quot;DeviceState&quot;,\r\n\t\t\t\t\t&quot;value&quot;: &quot;active&quot;\r\n\t\t\t\t},\r\n\t\t\t\t{\r\n\t\t\t\t\t&quot;key&quot;: &quot;LastDeactivationDate&quot;,\r\n\t\t\t\t\t&quot;value&quot;: &quot;2021-12-01T21:22:55Z&quot;\r\n\t\t\t\t}\r\n\t\t\t]\r\n\t\t},\r\n\t\t{\r\n\t\t\t&quot;categoryName&quot;: &quot;Connectivity&quot;,\r\n\t\t\t&quot;extendedAttributes&quot;: [{\r\n\t\t\t\t\t&quot;key&quot;: &quot;Connected&quot;,\r\n\t\t\t\t\t&quot;value&quot;: &quot;true&quot;\r\n\t\t\t\t},\r\n\t\t\t\t{\r\n\t\t\t\t\t&quot;key&quot;: &quot;LastConnectionDate&quot;,\r\n\t\t\t\t\t&quot;value&quot;: &quot;2022-09-08T03:38:55Z&quot;\r\n\t\t\t\t},\r\n\t\t\t\t{\r\n\t\t\t\t\t&quot;key&quot;: &quot;LastDisconnectDate&quot;,\r\n\t\t\t\t\t&quot;value&quot;: &quot;2022-09-08T03:25:15Z&quot;\r\n\t\t\t\t}\r\n\t\t\t]\r\n\t\t},\r\n\t\t{\r\n\t\t\t&quot;categoryName&quot;: &quot;Billing&quot;,\r\n\t\t\t&quot;extendedAttributes&quot;: [{\r\n\t\t\t\t\t&quot;key&quot;: &quot;BillingCycleStartDate&quot;,\r\n\t\t\t\t\t&quot;value&quot;: &quot;2022-09-02T00:00:00Z&quot;\r\n\t\t\t\t},\r\n\t\t\t\t{\r\n\t\t\t\t\t&quot;key&quot;: &quot;BillingCycleEndDate&quot;,\r\n\t\t\t\t\t&quot;value&quot;: &quot;2022-10-01T00:00:00Z&quot;\r\n\t\t\t\t},\r\n\t\t\t\t{\r\n\t\t\t\t\t&quot;key&quot;: &quot;DefaultRatePlan&quot;,\r\n\t\t\t\t\t&quot;value&quot;: &quot;0&quot;\r\n\t\t\t\t}\r\n\t\t\t]\r\n\t\t},\r\n\t\t{\r\n\t\t\t&quot;categoryName&quot;: &quot;Usage&quot;,\r\n\t\t\t&quot;extendedAttributes&quot;: [{\r\n\t\t\t\t\t&quot;key&quot;: &quot;CurrentRatedUsageRecordDate&quot;,\r\n\t\t\t\t\t&quot;value&quot;: &quot;2022-09-04T00:00:00Z&quot;\r\n\t\t\t\t}, {\r\n\t\t\t\t\t&quot;key&quot;: &quot;CurrentUnRatedUsageRecordDate&quot;,\r\n\t\t\t\t\t&quot;value&quot;: &quot;2022-09-08T01:25:15Z&quot;\r\n\t\t\t\t},\r\n\t\t\t\t{\r\n\t\t\t\t\t&quot;key&quot;: &quot;CurrentBillCycleDataUnRatedUsage&quot;,\r\n\t\t\t\t\t&quot;value&quot;: &quot;1698414605&quot;\r\n\t\t\t\t}\r\n\t\t\t]\r\n\t\t}\r\n\r\n\t]\r\n}\r\n\r\n    \r\ni&#39;m not pushing all fields to db so i&#39;m selecting a specific keys from that,\r\n(**what i&#39;am selecting its fixed not changed**) so the select will not change and always will be :\r\n\r\n**Expected output :** \r\n\r\n&gt; &quot;89148000&quot;\r\n&quot;5514048068&quot;\r\n&quot;not-exist&quot;\r\n&quot;4G Public Dynamic&quot;\r\n&quot;4G5G&quot;\r\n&quot;4G5G&quot;\r\n&quot;active&quot;\r\n&quot;2022-09-02T00:00:00Z&quot;\r\n&quot;2022-10-01T00:00:00Z&quot;\r\n&quot;2022-09-08T01:25:15Z&quot;\r\n\r\n\r\n**I would like to check if the value of key is missing for this case &quot;MSISDN&quot; ,if not will print for me not-exist or null**\r\n\r\nany help ?",
        "link": "https://stackoverflow.com/questions/73648521/check-if-json-field-exist-giving-default-value-with-select-jq-command",
        "title": "Check if Json field Exist, giving default value with (select) jq command"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 5,
                "is_accepted": true,
                "score": 5,
                "last_activity_date": 1709215080,
                "last_edit_date": 1709215080,
                "creation_date": 1662645792,
                "answer_id": 73650375,
                "question_id": 73650287,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "```\r\n.[] | select(.state | startswith(&quot;failed-&quot;)).id\r\n```\r\n\r\nWill output:\r\n```none\r\n&quot;RA_kwDOGETrS84EmTf6&quot;\r\n```\r\n\r\nTrick is to pass `state` in the [`select()`][1] to [`startswith()`][2], and then get `.id` of the result\r\n\r\n\r\n----------\r\n\r\n\r\n[Demo](https://jqplay.org/s/XIG4npKJyRu)\r\n\r\n\r\n  [1]: https://jqlang.github.io/jq/manual/#select\r\n  [2]: https://jqlang.github.io/jq/manual/#startswith",
                "title": "jq find value in object where key matches a regex"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1663077795,
                "last_edit_date": 1663077795,
                "creation_date": 1662665498,
                "answer_id": 73654246,
                "question_id": 73650287,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "```\r\n.[] | select(.state | test(&quot;^failed&quot;)).id\r\n```\r\n\r\nis another way",
                "title": "jq find value in object where key matches a regex"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1709215080,
        "creation_date": 1662645405,
        "question_id": 73650287,
        "body_markdown": "In the JSON below, I need to find the value of the `id` key of every object where the value of `state` starts with &quot;failed-&quot;\r\n\r\n```js\r\n[\r\n  {\r\n    &quot;id&quot;: &quot;RA_kwDOGETrS84EmTf2&quot;,\r\n    &quot;state&quot;: &quot;uploaded&quot;\r\n  },\r\n  {\r\n    &quot;id&quot;: &quot;RA_kwDOGETrS84EmTf6&quot;,\r\n    &quot;state&quot;: &quot;failed-4325423&quot;\r\n  },\r\n  {\r\n    &quot;id&quot;: &quot;RA_kwDOGETrS84EmTf7&quot;,\r\n    &quot;state&quot;: &quot;uploaded&quot;\r\n  }\r\n]\r\n```\r\n\r\nI got as far as extracting just the matching values of `state`:\r\n```\r\n.[] | .state | select(startswith(&quot;failed-&quot;))\r\n```\r\n\r\nHow do I find the corresponding values of `id` ?",
        "link": "https://stackoverflow.com/questions/73650287/jq-find-value-in-object-where-key-matches-a-regex",
        "title": "jq find value in object where key matches a regex"
    },
    {
        "tags": [
            "json",
            "bash",
            "if-statement",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 7,
                "is_accepted": false,
                "score": 7,
                "last_activity_date": 1662648915,
                "creation_date": 1662648915,
                "answer_id": 73651144,
                "question_id": 73651039,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "`jq` outputs `&quot;elephant&quot;`, note the `&quot;`\r\n\r\nAdd `-r` to the `jq` command so the quotes are removed (raw-mode)\r\n\r\n\r\n----------\r\n\r\nThen the output will match the string `elephant`\r\n```bash\r\n#!/bin/bash\r\n\r\nVAR=&quot;$(jq -r &#39;.animal&#39; animal.json)&quot;\r\necho &quot;$VAR&quot;\r\n\r\nif [[ &quot;$VAR&quot; == &quot;elephant&quot; ]]; then\r\n      echo &quot;this is an elephant&quot;\r\nelse\r\n      echo &quot;failed&quot;\r\nfi\r\n```",
                "title": "jq: How do I assign a jq output to a variable?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 3,
        "last_activity_date": 1662648967,
        "creation_date": 1662648494,
        "last_edit_date": 1662648967,
        "question_id": 73651039,
        "body_markdown": "I&#39;m new to jq and struggling to obtain a json value and use it in a bash IF statement.\r\n\r\n```json   \r\n{\r\n    &quot;animal&quot;: &quot;elephant&quot;,\r\n    &quot;colour&quot;: &quot;red&quot;\r\n}\r\n```\r\n```bash\r\nVAR=$( jq &#39;.animal&#39; animal.json )\r\necho &quot;$VAR&quot;\r\n\r\nif [[ &quot;$VAR&quot; == &quot;elephant&quot; ]]; then\r\n      echo &quot;this is an elephant&quot;\r\nelse\r\n      echo &quot;failed&quot;\r\nfi\r\n```\r\nWhen I run the script the comparison fails \r\n \r\nWhat can change to make the script work?",
        "link": "https://stackoverflow.com/questions/73651039/jq-how-do-i-assign-a-jq-output-to-a-variable",
        "title": "jq: How do I assign a jq output to a variable?"
    },
    {
        "tags": [
            "json",
            "bash",
            "sh",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1662749793,
                "creation_date": 1662749793,
                "answer_id": 73666463,
                "question_id": 73666430,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Keep the array using `map` instead of decomposing it with `.[]`, then join with a glue string:\r\n~~~sh\r\njq -r &#39;map(select(.run==&quot;True&quot;) | .name) | join(&quot;,&quot;)&#39; svcs.json\r\n~~~\r\n~~~json\r\nsvc-A,svc-C\r\n~~~\r\n[Demo](https://jqplay.org/s/0Jq3akjPEqB)\r\n\r\n---\r\nIf your goal is to create a CSV output, there is a special `@csv` command taking care of quoting, escaping etc.\r\n~~~sh\r\njq -r &#39;map(select(.run==&quot;True&quot;) | .name) | @csv&#39; svcs.json\r\n~~~\r\n~~~json\r\n&quot;svc-A&quot;,&quot;svc-C&quot;\r\n~~~\r\n[Demo](https://jqplay.org/s/GcZn4SSnWXb)",
                "title": "jq - Looping through json and concatenate the output to single string"
            },
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1662749864,
                "creation_date": 1662749864,
                "answer_id": 73666473,
                "question_id": 73666430,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The `.[]` expression explodes the array into a stream of its elements. You&#39;ll need to collect the transformed stream (the names) back into an array. Then you can use the `@csv` filter for the final output\r\n\r\n```sh\r\n$ jq -r &#39;[ .[] | select(.run==&quot;True&quot;) | .name ] | @csv&#39; svcs.json\r\n&quot;svc-A&quot;,&quot;svc-C&quot;\r\n```\r\n\r\nBut here&#39;s where `map` comes in handy to operate on an array&#39;s elements:\r\n```sh\r\n$ jq -r &#39;map(select(.run==&quot;True&quot;) | .name) | @csv&#39; svcs.json\r\n&quot;svc-A&quot;,&quot;svc-C&quot;\r\n```",
                "title": "jq - Looping through json and concatenate the output to single string"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1662749864,
        "creation_date": 1662749603,
        "question_id": 73666430,
        "body_markdown": "I was currently learning the usage of `jq`. I have a json file and I am able to loop through and filter out the values I need from the json. However, I am running into issue when I try to combine the output into single string instead of having the output in multiple lines.\r\n\r\nFile `svcs.json`:\r\n\r\n    [ \r\n     {\r\n       &quot;name&quot;: &quot;svc-A&quot;,\r\n       &quot;run&quot; : &quot;True&quot;\r\n     },\r\n     {\r\n       &quot;name&quot;: &quot;svc-B&quot;,\r\n       &quot;run&quot; : &quot;False&quot;\r\n     },\r\n     {\r\n       &quot;name&quot;: &quot;svc-C&quot;,\r\n       &quot;run&quot; : &quot;True&quot;\r\n     }\r\n    ]\r\n\r\nI was using the jq to filter to output the service names with `run` value as `True`\r\n\r\n`jq -r &#39;.[] | select(.run==&quot;True&quot;) | .name &#39; svcs.json`\r\n\r\nI was getting the output as follows:\r\n\r\n```\r\n svc-A\r\n svc-C\r\n```\r\n\r\nI was looking to get the output as single string separated by commas. \r\n\r\nExpected Output: \r\n\r\n`&quot;svc-A,svc-C&quot;`\r\n\r\nI tried to using join, but was unable to get it to work so far.",
        "link": "https://stackoverflow.com/questions/73666430/jq-looping-through-json-and-concatenate-the-output-to-single-string",
        "title": "jq - Looping through json and concatenate the output to single string"
    },
    {
        "tags": [
            "arrays",
            "json",
            "slice",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 5,
                "is_accepted": true,
                "score": 5,
                "last_activity_date": 1662755818,
                "last_edit_date": 1662755818,
                "creation_date": 1662751186,
                "answer_id": 73666642,
                "question_id": 73666600,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I&#39;d do\r\n```sh\r\njq --arg ix &quot;$ix&quot; &#39;\r\n    ($ix | split(&quot;,&quot;) | map(tonumber)) as [$a, $b] \r\n    | .[$a:$b+1]\r\n&#39;\r\n```\r\nThe `+1` is needed because the array slice operation `.[from;to]` is from (inclusive) and to (exclusive)\r\n\r\n---\r\nThe variable-assignment expression `... | exp as $var | ...` uses the input value in the expression, sets the variable, then passes the original input as its output.\r\n\r\n---\r\nAnother way to do this: split the ix in bash, and pass the values as positional arguments:\r\n```sh\r\nIFS=, read -ra ixs &lt;&lt;&lt; &quot;$ix&quot;\r\necho &#39;[&quot;a&quot;,&quot;b&quot;,&quot;c&quot;]&#39; \\\r\n| jq --jsonargs &#39;.[$ARGS.positional[0]:$ARGS.positional[1]+1]&#39; &quot;${ixs[@]}&quot;\r\n```\r\n\r\n---\r\nSo, you have a huge array and a large list of indices to extract? Then perhaps:\r\n```jq\r\n. as $some_huge_array |\r\nreduce ($ix | split(&quot;,&quot;) | map(tonumber))[] as $i ([]; . + [$some_huge_array[$i]])\r\n```\r\n\r\n---\r\nRolling up some of these ideas:\r\n```sh\r\nix=&quot;0,3,4&quot;\r\njq --argjson ixs &quot;[$ix]&quot; &#39;. as $a | reduce $ixs[] as $i ([]; . + [$a[$i]])&#39; &lt;&lt;END_INPUT\r\n  [1, 2, 3, 4, 5, 6, 7]\r\nEND_INPUT\r\n```\r\n```json\r\n[\r\n  1,\r\n  4,\r\n  5\r\n]\r\n```\r\n\r\nAnd as @oguzismail points out, `reduce` is not needed here\r\n```sh\r\njq --argjson ixs &quot;[$ix]&quot; &#39;[.[$ixs[]]]&#39;\r\n```\r\n\r\n* `$ixs` is an _array_\r\n* `$ixs[]` is a _stream_ of values\r\n* `.[ $ixs[] ]` will output the values of the input array _for each value of $ixs_, as a stream of values\r\n    - this is an **implicit** iteration\r\n* `[ .[$ixs[]] ]` _collects_ the previous stream into an array.",
                "title": "Subset json based on string list of indices using jq"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1662870065,
                "last_edit_date": 1662870065,
                "creation_date": 1662779401,
                "answer_id": 73669018,
                "question_id": 73666600,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "```\r\n$ cat test.json\r\n&gt;&gt; [&quot;a&quot;, &quot;b&quot;, &quot;c&quot;, &quot;d&quot;, &quot;e&quot; ]\r\n\r\n$ ix=&quot;0,2&quot;\r\n\r\n$ jq --arg ix &quot;$ix&quot; &#39;($ix | split(&quot;,&quot;) | map(tonumber)) as [$a, $b] | .[$a:$b+1]&#39; test.json\r\n\r\n&gt;&gt; [\r\n&gt;&gt;   &quot;a&quot;,\r\n&gt;&gt;   &quot;b&quot;,\r\n&gt;&gt;   &quot;c&quot;\r\n&gt;&gt; ]\r\n\r\n\r\n$ jq --arg ix &quot;$ix&quot; &#39;($ix | split(&quot;,&quot;) | map(tonumber)) as [$a, $b] | .[$a,$b+1]&#39; test.json\r\n\r\n&gt;&gt; &quot;a&quot;\r\n\r\n&gt;&gt; &quot;d&quot;\r\n```\r\n\r\n\r\nNote how the output differs between `[$a:$b+1]` and `[$a,$b+1]`. \r\n\r\n`[$a:$b+1]` is array slicing which generates a sub-array \r\nwhereas \r\n`[$a,$b+1]` selects two individual elements of the original array.",
                "title": "Subset json based on string list of indices using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1662870065,
        "creation_date": 1662750796,
        "last_edit_date": 1662776214,
        "question_id": 73666600,
        "body_markdown": "I have a JSON array that looks like:\r\n\r\n```\r\n[&quot;a&quot;,&quot;b&quot;,&quot;c&quot;]\r\n```\r\n\r\nAnd I have a bash variable which is list of array indices that I would like to subset to\r\n\r\n```\r\nix=&quot;0,2&quot;\r\n```\r\n\r\nI would like to use `jq` to subset to those indices, yielding the following array:\r\n\r\n```\r\n[&quot;a&quot;, &quot;c&quot;]\r\n```\r\n\r\nSo far I&#39;ve been able to parse `$ix` into an array:\r\n```\r\necho &#39;[&quot;a&quot;,&quot;b&quot;,&quot;c&quot;]&#39; | jq --arg ix $ix &#39;$ix | split(&quot;,&quot;) | map(tonumber)&#39;\r\n```\r\n\r\nBut when I try to use this array of indices to subset `[&quot;a&quot;,&quot;b&quot;,&quot;c&quot;]`, I have problems (None of the following work):\r\n\r\n```\r\necho &#39;[&quot;a&quot;,&quot;b&quot;,&quot;c&quot;]&#39; | jq --arg ix $ix &#39;. | $ix | split(&quot;,&quot;) | map(tonumber)&#39;\r\n\r\necho &#39;[&quot;a&quot;,&quot;b&quot;,&quot;c&quot;]&#39; | jq --arg ix $ix &#39;. | ($ix | split(&quot;,&quot;) | map(tonumber))&#39;\r\n\r\necho &#39;[&quot;a&quot;,&quot;b&quot;,&quot;c&quot;]&#39; | jq --arg ix $ix &#39;. | [$ix | split(&quot;,&quot;) | map(tonumber)]&#39;\r\n\r\necho &#39;[&quot;a&quot;,&quot;b&quot;,&quot;c&quot;]&#39; | jq --arg ix $ix &#39;. | .[$ix | split(&quot;,&quot;) | map(tonumber)]&#39;\r\n\r\n```",
        "link": "https://stackoverflow.com/questions/73666600/subset-json-based-on-string-list-of-indices-using-jq",
        "title": "Subset json based on string list of indices using jq"
    },
    {
        "tags": [
            "json",
            "key",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1662805212,
                "creation_date": 1662805212,
                "answer_id": 73671029,
                "question_id": 73670883,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can use `to_entries` to access key and value, and `range` to iterate:\r\n~~~sh\r\njq -r &#39;to_entries[] | range(.value.amount) as $_ | .key&#39;\r\n~~~\r\n~~~none\r\n2tMRnry9cMqcMo5JqPWvyFaznoU8ujcf3i9ALpzokFHK\r\n2tMRnry9cMqcMo5JqPWvyFaznoU8ujcf3i9ALpzokFHK\r\n2tMRnry9cMqcMo5JqPWvyFaznoU8ujcf3i9ALpzokFHK\r\nCVjVEB2WBmDACcovpxKAEqXZZKdUGsGAn2v5EsWSjtXX\r\nCndq2Yjt1MVkQPYiZod9eGZcTHFDhuYjJA7N6vAuVw8H\r\nCndq2Yjt1MVkQPYiZod9eGZcTHFDhuYjJA7N6vAuVw8H\r\n~~~\r\n[Demo](https://jqplay.org/s/ozwFXfLTrku)",
                "title": "How to use jq to extract keys and print them a certain amount of times depending on another keys value from a JSON file"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -1,
        "last_activity_date": 1662805212,
        "creation_date": 1662803841,
        "question_id": 73670883,
        "body_markdown": "So I&#39;m trying to get the top-level keys and then multiply each one by the amount under each key then post the key as many times as the amount states.\r\n\r\nHow do I get jq to take json like this:\r\n\r\n    {\r\n\t&quot;2tMRnry9cMqcMo5JqPWvyFaznoU8ujcf3i9ALpzokFHK&quot;: {\r\n\t\t&quot;mints&quot;: [\r\n\t\t\t&quot;Ehmx5dGtUtYSTRYDNptYSPLXs4ZSFmCPHvPd5ProtGPp&quot;,\r\n\t\t\t&quot;DZHynoX1yrwdppnNNZmBHqap89vziSehmhJP3BQESoaN&quot;,\r\n\t\t\t&quot;CVdM8fu474xaVxxuUzLsn7rxTA1mcrkpq8K7YYN4gRoc&quot;\r\n\t\t],\r\n\t\t&quot;amount&quot;: 3\r\n\t},\r\n\t&quot;CVjVEB2WBmDACcovpxKAEqXZZKdUGsGAn2v5EsWSjtXX&quot;: {\r\n\t\t&quot;mints&quot;: [\r\n\t\t\t&quot;CPBsjXBKrG2QfRAkaPDJ282bXr7uD9259Ymb6EC93jjb&quot;\r\n\t\t],\r\n\t\t&quot;amount&quot;: 1\r\n\t},\r\n\t&quot;Cndq2Yjt1MVkQPYiZod9eGZcTHFDhuYjJA7N6vAuVw8H&quot;: {\r\n\t\t&quot;mints&quot;: [\r\n\t\t\t&quot;66T698sRaJiyEXu6RrBw8ApNYsx1spkQQZZM9nZdA9EE&quot;,\r\n\t\t\t&quot;65QEUZVWMg12UvrRNcoV5DwVANKWaarHPd52KemV4pRy&quot;\r\n\t\t],\r\n    \t\t&quot;amount&quot;: 2\r\n    \t}\r\n    }\r\nand generate this output:\r\n\r\n    2tMRnry9cMqcMo5JqPWvyFaznoU8ujcf3i9ALpzokFHK\r\n    2tMRnry9cMqcMo5JqPWvyFaznoU8ujcf3i9ALpzokFHK\r\n    2tMRnry9cMqcMo5JqPWvyFaznoU8ujcf3i9ALpzokFHK\r\n    CVjVEB2WBmDACcovpxKAEqXZZKdUGsGAn2v5EsWSjtXX\r\n    Cndq2Yjt1MVkQPYiZod9eGZcTHFDhuYjJA7N6vAuVw8H\r\n    Cndq2Yjt1MVkQPYiZod9eGZcTHFDhuYjJA7N6vAuVw8H\r\n\r\n",
        "link": "https://stackoverflow.com/questions/73670883/how-to-use-jq-to-extract-keys-and-print-them-a-certain-amount-of-times-depending",
        "title": "How to use jq to extract keys and print them a certain amount of times depending on another keys value from a JSON file"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1662807960,
                "post_id": 73671232,
                "comment_id": 130094650,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 3379153,
                    "reputation": 209476,
                    "user_id": 2836621,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/suHg4.jpg?s=256",
                    "display_name": "Mark Setchell",
                    "link": "https://stackoverflow.com/users/2836621/mark-setchell"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1662808058,
                "post_id": 73671232,
                "comment_id": 130094670,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 18068363,
                    "reputation": 428,
                    "user_id": 18181790,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b6656afb769d61997a794a6a80cb4dd9?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "rowboat",
                    "link": "https://stackoverflow.com/users/18181790/rowboat"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1662814212,
                "post_id": 73671232,
                "comment_id": 130095704,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1662813625,
                "last_edit_date": 1662813625,
                "creation_date": 1662813076,
                "answer_id": 73671834,
                "question_id": 73671232,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Different steps of a pipeline behave like sub shells. Variables are inherited from the parent, but changes do not propagate back to the parent. You have to make your echo statement part of this step in the pipeline:\r\n\r\n```\r\ndomain_count=0\r\n\r\njq -r &#39;.domains[]&#39; variables.json | {\r\n  while read -r domain; do\r\n    host=&quot;0.0.0.0 ${domain}&quot;\r\n    echo &quot;$host&quot;;\r\n\r\n    domain_count+$((domain_count++))\r\n  done\r\n\r\n  echo $domain_count\r\n}\r\n```\r\n\r\nBut if all you want to do is count the number of domains/hosts, that can be done with jq directly:\r\n\r\n```\r\ndomain_count=$(jq &#39;.domains|length&#39; variables.json)\r\n```\r\n\r\nAnd to output all domains formatted as hosts:\r\n\r\n```\r\njq -r &#39;.domains[] | &quot;0.0.0.0 \\(.)&quot;&#39; variables.json\r\n```\r\n\r\nSummarized, without losing functionality, your script can be shortened to:\r\n\r\n```\r\njq -r &#39;.domains[] | &quot;0.0.0.0 \\(.)&quot;&#39; variables.json\r\ndomain_count=$(jq &#39;.domains|length&#39; variables.json)\r\n```",
                "title": "JSON jq execute with Process Substitution"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1662813625,
        "creation_date": 1662807284,
        "question_id": 73671232,
        "body_markdown": "I create bash script to parse json file and generate hosts. For that I use jq but I cannot get it work with variable ```domain_count``` changing.\r\n\r\n```\r\ndomain_count=0\r\n\r\njq -r .domains[] variables.json | while read domain; do\r\n  host=&quot;0.0.0.0 ${domain}&quot;\r\n  echo $host;\r\n\r\n  # ((domain_count++))\r\ndone\r\n\r\necho $domain_count\r\n```\r\n\r\nIt is still 0.\r\n\r\nSo that is because Process Substitution. I tried change it different ways. But non of it works.\r\n\r\n```\r\nwhile read domain\r\ndo\r\n  host=&quot;0.0.0.0         ${domain}&quot;\r\n  echo $host;\r\n  ((domain_count++))\r\ndone &lt; &lt;(jq -r .domains[] variables.json)\r\n\r\necho $domain_count\r\n```\r\n\r\nI got next error\r\n```\r\ngenerate.sh: line 20: syntax error near unexpected token `&lt;&#39;\r\ngenerate.sh: line 20: `done &lt; &lt;(jq -r .domains[] variables.json)&#39;\r\n```",
        "link": "https://stackoverflow.com/questions/73671232/json-jq-execute-with-process-substitution",
        "title": "JSON jq execute with Process Substitution"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1662855577,
                "last_edit_date": 1662855577,
                "creation_date": 1662855254,
                "answer_id": 73675991,
                "question_id": 73675742,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If you know that `contact` and `nextarray` are the sub-objects to merge, then:\r\n```sh\r\njq &#39;. + .contact + .nextarray | del(.contact) | del(.nextarray)&#39; file.json\r\n```\r\n```json\r\n{\r\n  &quot;id&quot;: 1,\r\n  &quot;feed&quot;: &quot;jqQuestion&quot;,\r\n  &quot;organization&quot;: &quot;question.com&quot;,\r\n  &quot;category&quot;: &quot;question&quot;,\r\n  &quot;website&quot;: &quot;https://thankyou.com/&quot;,\r\n  &quot;schedule&quot;: &quot;daily&quot;,\r\n  &quot;stamp_added&quot;: &quot;2017-09-27 00:00:00&quot;,\r\n  &quot;stamp_updated&quot;: &quot;2022-09-10 15:51:09&quot;,\r\n  &quot;stamp_pulled&quot;: &quot;2022-09-10 08:51:03&quot;,\r\n  &quot;stamp_modified&quot;: &quot;2019-08-07 18:29:00&quot;,\r\n  &quot;name&quot;: &quot;&quot;,\r\n  &quot;email&quot;: &quot;&quot;,\r\n  &quot;phone&quot;: &quot;&quot;,\r\n  &quot;value&quot;: 1,\r\n  &quot;value2&quot;: 2\r\n}\r\n```\r\n\r\nThe `+` operator, when given object operands, will merge the objects.\r\n\r\nGenerically:\r\n```sh\r\njq &#39;\r\n    to_entries \r\n    | map(if (.value|type) == &quot;object&quot; then .value else {(.key): .value} end) \r\n    | add\r\n&#39;\r\n```\r\n```json\r\n{\r\n  &quot;id&quot;: 1,\r\n  &quot;feed&quot;: &quot;jqQuestion&quot;,\r\n  &quot;organization&quot;: &quot;question.com&quot;,\r\n  &quot;category&quot;: &quot;question&quot;,\r\n  &quot;name&quot;: &quot;&quot;,\r\n  &quot;email&quot;: &quot;&quot;,\r\n  &quot;phone&quot;: &quot;&quot;,\r\n  &quot;website&quot;: &quot;https://thankyou.com/&quot;,\r\n  &quot;schedule&quot;: &quot;daily&quot;,\r\n  &quot;stamp_added&quot;: &quot;2017-09-27 00:00:00&quot;,\r\n  &quot;stamp_updated&quot;: &quot;2022-09-10 15:51:09&quot;,\r\n  &quot;stamp_pulled&quot;: &quot;2022-09-10 08:51:03&quot;,\r\n  &quot;stamp_modified&quot;: &quot;2019-08-07 18:29:00&quot;,\r\n  &quot;value&quot;: 1,\r\n  &quot;value2&quot;: 2\r\n}\r\n```\r\n",
                "title": "Flatten array and reformat the JSON using jq"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1662972409,
                "creation_date": 1662972409,
                "answer_id": 73686655,
                "question_id": 73675742,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": " &gt;     jq -c &#39;to_entries[]|flatten[]&#39;\r\n\r\nwould already get you to\r\n\r\n    &quot;id&quot;\r\n    1\r\n    &quot;feed&quot;\r\n    &quot;jqQuestion&quot;\r\n    &quot;organization&quot;\r\n    &quot;question.com&quot;\r\n    &quot;category&quot;\r\n    &quot;question&quot;\r\n    &quot;contact&quot;\r\n    {&quot;name&quot;:&quot;&quot;,&quot;email&quot;:&quot;&quot;,&quot;phone&quot;:&quot;&quot;}\r\n    &quot;website&quot;\r\n    &quot;https://thankyou.com/&quot;\r\n    &quot;schedule&quot;\r\n    &quot;daily&quot;\r\n    &quot;stamp_added&quot;\r\n    &quot;2017-09-27 00:00:00&quot;\r\n    &quot;stamp_updated&quot;\r\n    &quot;2022-09-10 15:51:09&quot;\r\n    &quot;stamp_pulled&quot;\r\n    &quot;2022-09-10 08:51:03&quot;\r\n    &quot;stamp_modified&quot;\r\n    &quot;2019-08-07 18:29:00&quot;\r\n    &quot;nextarray&quot;\r\n    {&quot;value&quot;:1,&quot;value2&quot;:2}\r\n\r\nto create ur desired output should be trivial from here",
                "title": "Flatten array and reformat the JSON using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": -1,
        "last_activity_date": 1662972409,
        "creation_date": 1662851030,
        "last_edit_date": 1662908616,
        "question_id": 73675742,
        "body_markdown": "I&#39;m trying to accomplish two things:\r\n\r\n - Flatten the array in this json\r\n - Reformat the json to a simple payload\r\n\r\nHere&#39;s is the json I&#39;m working with:\r\n\r\n    {\r\n      &quot;id&quot;: 1,\r\n      &quot;feed&quot;: &quot;jqQuestion&quot;,\r\n      &quot;organization&quot;: &quot;question.com&quot;,\r\n      &quot;category&quot;: &quot;question&quot;,\r\n      &quot;contact&quot;: {\r\n        &quot;name&quot;: &quot;&quot;,\r\n        &quot;email&quot;: &quot;&quot;,\r\n        &quot;phone&quot;: &quot;&quot;\r\n      },\r\n      &quot;website&quot;: &quot;https://thankyou.com/&quot;,\r\n      &quot;schedule&quot;: &quot;daily&quot;,\r\n      &quot;stamp_added&quot;: &quot;2017-09-27 00:00:00&quot;,\r\n      &quot;stamp_updated&quot;: &quot;2022-09-10 15:51:09&quot;,\r\n      &quot;stamp_pulled&quot;: &quot;2022-09-10 08:51:03&quot;,\r\n      &quot;stamp_modified&quot;: &quot;2019-08-07 18:29:00&quot;,\r\n      &quot;nextarray&quot;: {\r\n        &quot;value&quot;: 1,\r\n        &quot;value2&quot;: 2\r\n      }\r\n    }\r\n\r\n\r\nI&#39;m hoping to remove the &quot;title&quot; of the arrays, just keep the content, and align the contents of the array with the reset of the json:\r\n\r\n    {\r\n      &quot;id&quot;: 1,\r\n      &quot;feed&quot;: &quot;jqQuestion&quot;,\r\n      &quot;organization&quot;: &quot;question.com&quot;,\r\n      &quot;category&quot;: &quot;question&quot;,\r\n      &quot;name&quot;: &quot;&quot;,\r\n      &quot;email&quot;: &quot;&quot;,\r\n      &quot;phone&quot;: &quot;&quot;\r\n      &quot;website&quot;: &quot;https://thankyou.com/&quot;,\r\n      &quot;schedule&quot;: &quot;daily&quot;,\r\n      &quot;stamp_added&quot;: &quot;2017-09-27 00:00:00&quot;,\r\n      &quot;stamp_updated&quot;: &quot;2022-09-10 15:51:09&quot;,\r\n      &quot;stamp_pulled&quot;: &quot;2022-09-10 08:51:03&quot;,\r\n      &quot;stamp_modified&quot;: &quot;2019-08-07 18:29:00&quot;,\r\n      &quot;value&quot;: 1,\r\n      &quot;value2&quot;: 2\r\n    }\r\n\r\n\r\nI&#39;ve tried a few approaches, using sed, awk, and jq. I think using jq would be &quot;optimal&quot;, but haven&#39;t been able to get the format right with the mentioned approaches. Any guidance here would be much appreciated!",
        "link": "https://stackoverflow.com/questions/73675742/flatten-array-and-reformat-the-json-using-jq",
        "title": "Flatten array and reformat the JSON using jq"
    },
    {
        "tags": [
            "json",
            "loops",
            "for-loop",
            "jq",
            "variable-assignment"
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": false,
                "score": 4,
                "last_activity_date": 1662958579,
                "last_edit_date": 1662958579,
                "creation_date": 1662867837,
                "answer_id": 73676660,
                "question_id": 73676257,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You never set the jq var `$i` before using it. You could do so as follows:\r\n\r\n```sh\r\njq --arg i &quot;$i&quot; &#39;.taskArns[ $i | tonumber ]&#39;\r\n```\r\n\r\n---\r\n\r\nYou might want to move the loop into `jq` to avoid calling `aws` twice.\r\n\r\n```sh\r\naws ecs list-tasks --cluster $1 --profile $2 | jq &#39;.taskArns[0:2][]&#39;\r\n```\r\n",
                "title": "jq: error: $i is not defined at &lt;top-level&gt;"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -2,
        "last_activity_date": 1662958579,
        "creation_date": 1662860240,
        "last_edit_date": 1662954441,
        "question_id": 73676257,
        "body_markdown": "Im doing a bash script where I use a for loop in order to get some information using a AWS command, the output of the command is a list in Json so, i&#39;m using jq for filtering the response. As I&#39;m expecting to pass the output of the first command to another i need to send each element of the list individually and here is where I&#39;m in troubles.\r\n\r\n```\r\nfor i in {0..1}\r\ndo\r\naws ecs list-tasks --cluster $1 --profile $2 | jq &#39;.taskArns[$i]&#39;\r\ndone\r\n```\r\n\r\nIt doesn&#39;t matter how I set the for, if I set it as for i in {0..1} or for i in &quot;${tasks[@]}&quot; when I run the script it give back the same error, however if I put the index as taskArns[0] or taskArns[1] the script works.\r\n\r\nThanks in Advice!",
        "link": "https://stackoverflow.com/questions/73676257/jq-error-i-is-not-defined-at-top-level",
        "title": "jq: error: $i is not defined at &lt;top-level&gt;"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1662917786,
                "creation_date": 1662917786,
                "answer_id": 73681374,
                "question_id": 73680764,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "A simple `reduce` with an `if` expression builig up an indexed object may suffice. The final `map` converts the object back to an array.\r\n~~~sh\r\nreduce .[] as $i ({};\r\n  if $i.main_id == &quot;none&quot; then .[$i.id] += $i\r\n  else .[$i.main_id].details += [$i] end\r\n) | map(.)\r\n~~~\r\n~~~json\r\n[\r\n  {\r\n    &quot;id&quot;: &quot;AAKG&quot;,\r\n    &quot;data&quot;: &quot;some data...&quot;,\r\n    &quot;main_id&quot;: &quot;none&quot;\r\n  },\r\n  {\r\n    &quot;id&quot;: &quot;PMBL&quot;,\r\n    &quot;data&quot;: &quot;some data...&quot;,\r\n    &quot;main_id&quot;: &quot;none&quot;,\r\n    &quot;details&quot;: [\r\n      {\r\n        &quot;id&quot;: &quot;ZDFG&quot;,\r\n        &quot;data&quot;: &quot;some data...&quot;,\r\n        &quot;main_id&quot;: &quot;PMBL&quot;\r\n      },\r\n      {\r\n        &quot;id&quot;: &quot;XHGF&quot;,\r\n        &quot;data&quot;: &quot;some data...&quot;,\r\n        &quot;main_id&quot;: &quot;PMBL&quot;\r\n      }\r\n    ]\r\n  },\r\n  {\r\n    &quot;id&quot;: &quot;LOKJ&quot;,\r\n    &quot;data&quot;: &quot;some data...&quot;,\r\n    &quot;main_id&quot;: &quot;none&quot;\r\n  },\r\n  {\r\n    &quot;id&quot;: &quot;JQWC&quot;,\r\n    &quot;data&quot;: &quot;some data...&quot;,\r\n    &quot;main_id&quot;: &quot;none&quot;\r\n  },\r\n  {\r\n    &quot;id&quot;: &quot;QQSZ&quot;,\r\n    &quot;data&quot;: &quot;some data...&quot;,\r\n    &quot;main_id&quot;: &quot;none&quot;,\r\n    &quot;details&quot;: [\r\n      {\r\n        &quot;id&quot;: &quot;JQWC&quot;,\r\n        &quot;data&quot;: &quot;some data...&quot;,\r\n        &quot;main_id&quot;: &quot;QQSZ&quot;\r\n      }\r\n    ]\r\n  },\r\n  {\r\n    &quot;id&quot;: &quot;LLRE&quot;,\r\n    &quot;data&quot;: &quot;some data...&quot;,\r\n    &quot;main_id&quot;: &quot;none&quot;\r\n  }\r\n]\r\n~~~\r\n[Demo](https://jqplay.org/s/B-017OhagKv)",
                "title": "Need help to link several objects to one another (main object) with some specificities"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1662925340,
        "creation_date": 1662912631,
        "last_edit_date": 1662917112,
        "question_id": 73680764,
        "body_markdown": "Need help to link several objects to one another (main object) with some specificities.\r\n\r\nHello, I need help to make this rendering from a JSON file.\r\nI tried several filters, I never managed to make it work the way I wanted.\r\n(This is a simplified example of my JSON file)\r\n\r\nInput JSON:\r\n\r\n    [  \r\n      {\r\n        &quot;id&quot;: &quot;AAKG&quot;,\r\n        &quot;data&quot;: &quot;some data...&quot;,\r\n        &quot;main_id&quot;: &quot;none&quot;\r\n      },\r\n      {\r\n        &quot;id&quot;: &quot;PMBL&quot;,\r\n        &quot;data&quot;: &quot;some data...&quot;,\r\n        &quot;main_id&quot;: &quot;none&quot;\r\n      },\r\n      {\r\n        &quot;id&quot;: &quot;ZDFG&quot;,\r\n        &quot;data&quot;: &quot;some data...&quot;,\r\n        &quot;main_id&quot;: &quot;PMBL&quot;\r\n      },\r\n      {\r\n        &quot;id&quot;: &quot;XHGF&quot;,\r\n        &quot;data&quot;: &quot;some data...&quot;,\r\n        &quot;main_id&quot;: &quot;PMBL&quot;\r\n      },\r\n      {\r\n        &quot;id&quot;: &quot;LOKJ&quot;,\r\n        &quot;data&quot;: &quot;some data...&quot;,\r\n        &quot;main_id&quot;: &quot;none&quot;\r\n      },\r\n      {\r\n        &quot;id&quot;: &quot;JQWC&quot;,\r\n        &quot;data&quot;: &quot;some data...&quot;,\r\n        &quot;main_id&quot;: &quot;none&quot;\r\n      },\r\n      {\r\n        &quot;id&quot;: &quot;QQSZ&quot;,\r\n        &quot;data&quot;: &quot;some data...&quot;,\r\n        &quot;main_id&quot;: &quot;none&quot;\r\n      },\r\n      {\r\n        &quot;id&quot;: &quot;JQWC&quot;,\r\n        &quot;data&quot;: &quot;some data...&quot;,\r\n        &quot;main_id&quot;: &quot;QQSZ&quot;\r\n      },\r\n      {\r\n        &quot;id&quot;: &quot;LLRE&quot;,\r\n        &quot;data&quot;: &quot;some data...&quot;,\r\n        &quot;main_id&quot;: &quot;none&quot;\r\n      }\r\n    ]\r\n\r\nOutput (what i want):\r\n\r\n    [  \r\n      {\r\n        &quot;id&quot;: &quot;AAKG&quot;,\r\n        &quot;data&quot;: &quot;some data...&quot;,\r\n        &quot;main_id&quot;: &quot;none&quot;\r\n      },\r\n      {\r\n        &quot;id&quot;: &quot;PMBL&quot;,\r\n        &quot;data&quot;: &quot;some data...&quot;,\r\n        &quot;main_id&quot;: &quot;none&quot;\r\n        &quot;details&quot;: [\r\n                {\r\n                    &quot;id&quot;: &quot;ZDFG&quot;,\r\n                    &quot;data&quot;: &quot;some data...&quot;,\r\n                    &quot;main_id&quot;: &quot;PMBL&quot;\r\n                },\r\n                {\r\n                    &quot;id&quot;: &quot;XHGF&quot;,\r\n                    &quot;data&quot;: &quot;some data...&quot;,\r\n                    &quot;main_id&quot;: &quot;PMBL&quot;\r\n                }\r\n            ]\r\n      },\r\n      {\r\n        &quot;id&quot;: &quot;LOKJ&quot;,\r\n        &quot;data&quot;: &quot;some data...&quot;,\r\n        &quot;main_id&quot;: &quot;none&quot;\r\n      },\r\n      {\r\n        &quot;id&quot;: &quot;JQWC&quot;,\r\n        &quot;data&quot;: &quot;some data...&quot;,\r\n        &quot;main_id&quot;: &quot;none&quot;\r\n      },\r\n      {\r\n        &quot;id&quot;: &quot;QQSZ&quot;,\r\n        &quot;data&quot;: &quot;some data...&quot;,\r\n        &quot;main_id&quot;: &quot;none&quot;\r\n        &quot;details&quot;: [\r\n                {\r\n                    &quot;id&quot;: &quot;JQWC&quot;,\r\n                    &quot;data&quot;: &quot;some data...&quot;,\r\n                    &quot;main_id&quot;: &quot;QQSZ&quot;\r\n                }\r\n            ]\r\n      },\r\n      {\r\n    \r\n      },\r\n      {\r\n        &quot;id&quot;: &quot;LLRE&quot;,\r\n        &quot;data&quot;: &quot;some data...&quot;,\r\n        &quot;main_id&quot;: &quot;none&quot;\r\n      }\r\n    ]\r\n\r\nExplanations:\r\n\r\nIn my input I have only one array that covers all the objects in my file, I would like to link all the objects in an Array that have in the &quot;main_id&quot; key value a specific value other than &quot;none&quot; (with key &quot;details&quot;), to the object (which I call the parent object) containing that same value in the &quot;id&quot; key of the parent object.\r\n\r\nAs you can see in my output example, which I think is more explicit than my explanations. \r\nOf course my real input file contains many more objects\r\nbut the structure remains the same as in my example.\r\n[object,object,object,....]",
        "link": "https://stackoverflow.com/questions/73680764/need-help-to-link-several-objects-to-one-another-main-object-with-some-specifi",
        "title": "Need help to link several objects to one another (main object) with some specificities"
    },
    {
        "tags": [
            "bash",
            "gitlab-ci",
            "jq",
            "gitlab-api"
        ],
        "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": 1662997796,
                "post_id": 73691651,
                "comment_id": 130130312,
                "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": 1662999809,
                "post_id": 73691651,
                "comment_id": 130131021,
                "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": 1663009818,
                "post_id": 73691651,
                "comment_id": 130134060,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1663143182,
                "last_edit_date": 1663143182,
                "creation_date": 1662999961,
                "answer_id": 73692380,
                "question_id": 73691651,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "[jq](https://stedolan.github.io/jq/) is a _JSON_ processor. A YAML document is not JSON (but a JSON document is a YAML document). YAML is a superset of JSON.\r\n\r\nThere are other tools to process YAML, such as [yq](https://github.com/mikefarah/yq), which uses the familiar syntax from jq, but doesn&#39;t support every feature of jq.\r\n\r\nSo you will probably need run something similar to the following:\r\n\r\n```\r\ncurl … | yq &#39;.merged_yaml&#39; | yq &#39;…&#39;\r\n```\r\n\r\nor perhaps (but that shouldn&#39;t be required, since `yq` can handle JSON files just fine):\r\n\r\n\r\n```\r\ncurl … | jq &#39;.merged_yaml&#39; | yq &#39;…&#39;\r\n```\r\n\r\n*****\r\n\r\nEDIT:\r\n\r\nI think you found a bug in GitLab&#39;s documentation.\r\n\r\n```\r\njq --null-input --arg yaml &quot;$(&lt;example-gitlab-ci.yml)&quot; &#39;.content=$yaml&#39; \\\r\n| curl &quot;https://gitlab.com/api/v4/ci/lint?include_merged_yaml=true&quot; \\\r\n--header &#39;Content-Type: application/json&#39; --data @- \\\r\n| jq --raw-output &#39;.merged_yaml | fromjson&#39;\r\n```\r\n\r\nShould actually not use the `fromjson` filter:\r\n\r\n```\r\njq --null-input --arg yaml &quot;$(&lt;example-gitlab-ci.yml)&quot; &#39;.content=$yaml&#39; \\\r\n| curl &quot;https://gitlab.com/api/v4/ci/lint?include_merged_yaml=true&quot; \\\r\n--header &#39;Content-Type: application/json&#39; --data @- \\\r\n| jq --raw-output &#39;.merged_yaml&#39;\r\n```\r\n\r\nEverything in the first part of this answer still holds: jq cannot process YAML, you need yq for that. (But the GitLab docs never process the YAML document, they only print it)",
                "title": "Gitlab CI Lint Api"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1663143182,
        "creation_date": 1662996512,
        "question_id": 73691651,
        "body_markdown": "Lately, I have been trying to access the Gitlab CI Lint Api via bash using curl.\r\nfor that I have been trying to strictly follow the documentation on [Gitlab](https://docs.gitlab.com/ee/api/lint.html).\r\nAccording to the Gitlab documentation this fragment should return the formatted yml:\r\n```\r\njq --null-input --arg yaml &quot;$(&lt;example-gitlab-ci.yml)&quot; &#39;.content=$yaml&#39; \\\r\n| curl &quot;https://gitlab.com/api/v4/ci/lint?include_merged_yaml=true&quot; \\\r\n--header &#39;Content-Type: application/json&#39; --data @- \\\r\n| jq --raw-output &#39;.merged_yaml | fromjson&#39;\r\n```\r\nI hove modified the Request with my credentials and I get a valid response, when I shorten the jq query to\r\n\r\n `jq --raw-output &#39;.merged_yaml&#39;`\r\n\r\nand I recieve \r\n\r\n```\r\n&quot;---\r\n\\&quot;.api_test\\&quot;:\r\n  rules:\r\n  - if: $CI_PIPELINE_SOURCE==\\&quot;merge_request_event\\&quot;\r\n    changes:\r\n    - src/api/*\r\ndeploy:\r\n  rules:\r\n  - when: manual\r\n    allow_failure: true\r\n  extends:\r\n  - \\&quot;.api_test\\&quot;\r\n  script:\r\n  - echo \\&quot;hello world\\&quot;\r\n&quot;,&quot;includes&quot;:[],&quot;jobs&quot;:[{&quot;name&quot;:&quot;deploy&quot;,&quot;stage&quot;:&quot;test&quot;,&quot;before_script&quot;:[],&quot;script&quot;:[&quot;echo \\&quot;hello world\\&quot;&quot;],&quot;after_script&quot;:[],&quot;tag_list&quot;:[],&quot;only&quot;:null,&quot;except&quot;:null,&quot;environment&quot;:null,&quot;when&quot;:&quot;on_success&quot;,&quot;allow_failure&quot;:false,&quot;needs&quot;:null}],&quot;status&quot;:&quot;valid&quot;}\r\n\r\n```\r\n\r\nWhen i let this code run with the `fromjson` option I get an error:\r\n\r\n```\r\njq: error (at &lt;stdin&gt;:0): Invalid numeric literal at line 2, column 0 (while parsing &#39;---\r\n&quot;.api_test&quot;:\r\n  rules:\r\n[...]\r\n```\r\n\r\nI am at the End of my wits, pls help me!",
        "link": "https://stackoverflow.com/questions/73691651/gitlab-ci-lint-api",
        "title": "Gitlab CI Lint Api"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1663075608,
                "last_edit_date": 1663075608,
                "creation_date": 1663058478,
                "answer_id": 73699960,
                "question_id": 73699232,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can use **`slurp`** option such as\r\n```\r\njq -s &#39;{ List:. }&#39;\r\n```\r\n&lt;kbd&gt;[Demo](https://jqplay.org/s/-7cWmnFo7hA)&lt;/kbd&gt;",
                "title": "How to add a new element using the jq command?"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1663082638,
                "creation_date": 1663082638,
                "answer_id": 73705556,
                "question_id": 73699232,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Using [`inputs`](https://stedolan.github.io/jq/manual/v1.6/#IO) to consume the rest of the input data\r\n\r\n```\r\njq &#39;{List: [., inputs]}&#39;\r\n```",
                "title": "How to add a new element using the jq command?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1663082638,
        "creation_date": 1663055080,
        "last_edit_date": 1663058747,
        "question_id": 73699232,
        "body_markdown": "i have this JSON data\r\n\r\n    {\r\n      &quot;slotNo&quot;: &quot;2&quot;,\r\n      &quot;tracking&quot;: &quot;797aacdf9e40443aba4c818fead0195e&quot;,\r\n      &quot;TEST&quot;: &quot;ASD.mpg&quot;,\r\n      &quot;ZXC&quot;: &quot;555&quot;,\r\n      &quot;TID&quot;: &quot;T15789&quot;,\r\n      &quot;AD&quot;: &quot;123456&quot;\r\n    }\r\n    {\r\n      &quot;slotNo&quot;: &quot;3&quot;,\r\n      &quot;tracking&quot;: &quot;897aacdf9e40443aba4c818fead0195e&quot;,\r\n      &quot;TEST&quot;: &quot;zxc.mpg&quot;,\r\n      &quot;ZXC&quot;: &quot;666&quot;,\r\n      &quot;TID&quot;: &quot;T777&quot;,\r\n      &quot;AD&quot;: &quot;789456&quot;\r\n    }\r\n\r\nAnd I want to append `&quot;{&quot;List&quot;: []}` to the top of the list and save the JSON data to a file.\r\n The result that I want is like this:\r\n```json\r\n{\r\n  &quot;List&quot;: [\r\n    {\r\n      &quot;slotNo&quot;: &quot;2&quot;,\r\n      &quot;tracking&quot;: &quot;797aacdf9e40443aba4c818fead0195e&quot;,\r\n      &quot;TEST&quot;: &quot;ASD.mpg&quot;,\r\n      &quot;ZXC&quot;: &quot;555&quot;,\r\n      &quot;TID&quot;: &quot;T15789&quot;,\r\n      &quot;AD&quot;: &quot;123456&quot;\r\n    },\r\n    {\r\n      &quot;slotNo&quot;: &quot;3&quot;,\r\n      &quot;tracking&quot;: &quot;897aacdf9e40443aba4c818fead0195e&quot;,\r\n      &quot;TEST&quot;: &quot;zxc.mpg&quot;,\r\n      &quot;ZXC&quot;: &quot;666&quot;,\r\n      &quot;TID&quot;: &quot;T777&quot;,\r\n      &quot;AD&quot;: &quot;789456&quot;\r\n    }\r\n  ]\r\n}\r\n```     \r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/73699232/how-to-add-a-new-element-using-the-jq-command",
        "title": "How to add a new element using the jq command?"
    },
    {
        "tags": [
            "json",
            "ubuntu",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1663064555,
                "creation_date": 1663064555,
                "answer_id": 73701327,
                "question_id": 73701211,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "```\r\nmap((.Name | split(&quot;/&quot;) | last) + &quot;=&quot; + .Value) | join(&quot; &quot;)\r\n```\r\n\r\nWill output:\r\n```none\r\n&quot;key_value=foo key_value_2=bar&quot;\r\n```\r\n\r\n\r\n#### [Online demo](https://jqplay.org/s/ry_UIFyln4r)\r\n\r\n\r\nThe &#39;trick&#39; is to wrap the `.Name | split(&quot;/&quot;) | last)` into `()` so that `.value` remains available\r\n\r\n\r\n----------\r\n\r\n\r\n----------\r\n\r\nIf you prefer [string interpolation][1] (`\\()`) over `(key) + .Value`, you can rewrite it as:\r\n```none\r\nmap(&quot;\\(.Name | split(&quot;/&quot;) | last)=\\(.Value)&quot;) | join(&quot; &quot;)\r\n```\r\n#### [Online demo](https://jqplay.org/s/Qmthe5y-wGQ)\r\n\r\n\r\n  [1]: https://stedolan.github.io/jq/manual/#Stringinterpolation-%5C(foo)",
                "title": "Mapping over a JSON array of objects and processing values using JQ"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1663064555,
        "creation_date": 1663064049,
        "question_id": 73701211,
        "body_markdown": "Just started playing around with `jq` and cannot for the life of me come to terms with how I should approach this in a cleaner way. I have some data from AWS SSM Parameter Store that I receive as JSON, that I want to process.\r\n\r\nThe data is structured in the following way\r\n```\r\n[\r\n    {\r\n        &quot;Name&quot;: &quot;/path/to/key_value&quot;,\r\n        &quot;Value&quot;: &quot;foo&quot;\r\n    },\r\n    {\r\n        &quot;Name&quot;: &quot;/path/to/key_value_2&quot;,\r\n        &quot;Value&quot;: &quot;bar&quot;\r\n    },\r\n    ...\r\n]\r\n```\r\n\r\nI want it output in the following way: `key_value=foo key_value_2=bar`. My first thought was to process it as follows: `map([.Name | split(&quot;/&quot;) | last, .Value] | join(&quot;=&quot;)) | join(&quot; &quot;)` but then I get the following error: `jq: error (at &lt;stdin&gt;:9): Cannot index array with string &quot;Value&quot;`. It&#39;s as if the reference to the `Value` value is lost after piping the value for the `Name` parameter.\r\n\r\nOf course I could just solve it like this, but it&#39;s just plain ugly: `map([.Value, .Name | split(&quot;/&quot;) | last] | reverse | join(&quot;=&quot;)) | join(&quot; &quot;)`. How do I process the value for `Name` without losing reference to `Value`?\r\n\r\n**Edit:** [JQ Play link][1]\r\n\r\n\r\n  [1]: https://jqplay.org/s/i1_jN3sB4SI",
        "link": "https://stackoverflow.com/questions/73701211/mapping-over-a-json-array-of-objects-and-processing-values-using-jq",
        "title": "Mapping over a JSON array of objects and processing values using JQ"
    },
    {
        "tags": [
            "json",
            "bash",
            "join",
            "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": 1663109042,
                "post_id": 73709666,
                "comment_id": 130161122,
                "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": 1663119622,
                "post_id": 73709666,
                "comment_id": 130162557,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1663114532,
                "last_edit_date": 1663114532,
                "creation_date": 1663108914,
                "answer_id": 73709788,
                "question_id": 73709666,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Use `JOIN` with an `INDEX` on the `.servers` items:\r\n~~~sh\r\njq &#39;{servers: [JOIN(\r\n  INDEX(.groups[]; .s_Group); .servers[]; .s_Group // empty; add\r\n)]}&#39;\r\n~~~\r\n~~~json\r\n{\r\n  &quot;servers&quot;: [\r\n    {\r\n      &quot;location&quot;: &quot;srv_apc1&quot;,\r\n      &quot;f_Group&quot;: &quot;auc-1&quot;\r\n    },\r\n    {\r\n      &quot;location&quot;: &quot;srv_apc2&quot;,\r\n      &quot;f_Group&quot;: &quot;auc-1&quot;,\r\n      &quot;c_Group&quot;: &quot;c1&quot;\r\n    },\r\n    {\r\n      &quot;location&quot;: &quot;srv_apc3&quot;,\r\n      &quot;f_Group&quot;: &quot;auc-1&quot;,\r\n      &quot;c_Group&quot;: &quot;c2&quot;\r\n    },\r\n    {\r\n      &quot;location&quot;: &quot;srv_apc4&quot;,\r\n      &quot;f_Group&quot;: &quot;auc-1&quot;,\r\n      &quot;c_Group&quot;: &quot;c3&quot;\r\n    },\r\n    {\r\n      &quot;location&quot;: &quot;srv_wc1&quot;,\r\n      &quot;s_Group&quot;: &quot;cb-1&quot;,\r\n      &quot;options&quot;: [\r\n        &quot;opt1&quot;,\r\n        &quot;opt3&quot;,\r\n        &quot;opt5&quot;,\r\n        &quot;home&quot;\r\n      ]\r\n    },\r\n    {\r\n      &quot;location&quot;: &quot;srv_wc2&quot;,\r\n      &quot;s_Group&quot;: &quot;cb-2&quot;,\r\n      &quot;options&quot;: [\r\n        &quot;opt2&quot;,\r\n        &quot;opt4&quot;,\r\n        &quot;opt6&quot;,\r\n        &quot;home&quot;\r\n      ]\r\n    },\r\n    {\r\n      &quot;location&quot;: &quot;srv_wc3&quot;,\r\n      &quot;s_Group&quot;: &quot;cb-3&quot;,\r\n      &quot;options&quot;: [\r\n        &quot;opt7&quot;,\r\n        &quot;opt8&quot;,\r\n        &quot;opt9&quot;,\r\n        &quot;home&quot;,\r\n        &quot;print&quot;\r\n      ]\r\n    },\r\n    {\r\n      &quot;location&quot;: &quot;srv_wc4&quot;,\r\n      &quot;s_Group&quot;: &quot;cb-4&quot;,\r\n      &quot;options&quot;: [\r\n        &quot;emsar&quot;,\r\n        &quot;ereceipt&quot;,\r\n        &quot;expressmtreceive&quot;,\r\n        &quot;home&quot;,\r\n        &quot;mtagentlookup&quot;,\r\n        &quot;mtreceive&quot;,\r\n        &quot;mtstatus&quot;\r\n      ]\r\n    }\r\n  ]\r\n}\r\n~~~\r\n[Demo](https://jqplay.org/s/IY_KWuOPB4P)",
                "title": "Merge two arrays based on common key, keeping unmatched values"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1663119253,
                "last_edit_date": 1663119253,
                "creation_date": 1663108948,
                "answer_id": 73709795,
                "question_id": 73709666,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Everything can be done with one invocation of jq. If I understand the requirements correctly, you could use the following jq program:\r\n```\r\n  INDEX(.groups[] | select(.s_Group); .s_Group) as $dict\r\n  | .servers |= map( . + $dict[.s_Group // &quot;&quot;]) \r\n  | {servers : [.servers] }\r\n\r\n```\r\n\r\nThis returns the desired output as shown except for the obvious discrepancy relative to &quot;s_Group&quot;: &quot;cb-4&quot;.\r\n",
                "title": "Merge two arrays based on common key, keeping unmatched values"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1663119253,
        "creation_date": 1663107574,
        "last_edit_date": 1663112162,
        "question_id": 73709666,
        "body_markdown": "Given this data I am trying to return the `servers` array with any matches from `groups` array based on `s_Group` value.  However `group_by(s_Group)` only returns those common to both arrays (with one extraneous non-match I cannot explain).  It might be worth mentioning this is being done in a bash script so I am game to break the arrays into separate files and/or multiple steps if that makes things easier.\r\n\r\n**EDIT**: I should have specified I want all the attributes from `groups` pulled into the new `servers` elements where a match occurs.  Apologies for not making that clear.  Adding a &quot;desired output&quot;.\r\n\r\ninput data:\r\n```\r\n{\r\n\t&quot;servers&quot;: [\r\n\t\t{\r\n\t\t\t&quot;location&quot;: &quot;srv_apc1&quot;,\r\n\t\t\t&quot;f_Group&quot;: &quot;auc-1&quot;\r\n\t\t},\r\n\t\t{\r\n\t\t\t&quot;location&quot;: &quot;srv_apc2&quot;,\r\n\t\t\t&quot;f_Group&quot;: &quot;auc-1&quot;,\r\n\t\t\t&quot;c_Group&quot;: &quot;c1&quot;\r\n\t\t},\r\n\t\t{\r\n\t\t\t&quot;location&quot;: &quot;srv_apc3&quot;,\r\n\t\t\t&quot;f_Group&quot;: &quot;auc-1&quot;,\r\n\t\t\t&quot;c_Group&quot;: &quot;c2&quot;\r\n\t\t},\r\n\t\t{\r\n\t\t\t&quot;location&quot;: &quot;srv_apc4&quot;,\r\n\t\t\t&quot;f_Group&quot;: &quot;auc-1&quot;,\r\n\t\t\t&quot;c_Group&quot;: &quot;c3&quot;\r\n\t\t},\r\n\t\t{\r\n\t\t\t&quot;location&quot;: &quot;srv_wc1&quot;,\r\n\t\t\t&quot;s_Group&quot;: &quot;cb-1&quot;\r\n\t\t},\r\n\t\t{\r\n\t\t\t&quot;location&quot;: &quot;srv_wc2&quot;,\r\n\t\t\t&quot;s_Group&quot;: &quot;cb-2&quot;\r\n\t\t},\r\n\t\t{\r\n\t\t\t&quot;location&quot;: &quot;srv_wc3&quot;,\r\n\t\t\t&quot;s_Group&quot;: &quot;cb-3&quot;\r\n\t\t},\r\n\t\t{\r\n\t\t\t&quot;location&quot;: &quot;srv_wc4&quot;,\r\n\t\t\t&quot;s_Group&quot;: &quot;cb-4&quot;\r\n\t\t}\r\n\t],\r\n\t&quot;groups&quot;: [\r\n\t\t{\r\n\t\t\t&quot;s_Group&quot;: &quot;cb-1&quot;,\r\n\t\t\t&quot;options&quot;: [\r\n\t\t\t\t&quot;opt1&quot;,\r\n\t\t\t\t&quot;opt3&quot;,\r\n\t\t\t\t&quot;opt5&quot;,\r\n\t\t\t\t&quot;home&quot;\r\n\t\t\t]\r\n\t\t},\r\n\t\t{\r\n\t\t\t&quot;s_Group&quot;: &quot;cb-2&quot;,\r\n\t\t\t&quot;options&quot;: [\r\n\t\t\t\t&quot;opt2&quot;,\r\n\t\t\t\t&quot;opt4&quot;,\r\n\t\t\t\t&quot;opt6&quot;,\r\n\t\t\t\t&quot;home&quot;\r\n\t\t\t]\r\n\t\t},\r\n\t\t{\r\n\t\t\t&quot;s_Group&quot;: &quot;cb-3&quot;,\r\n\t\t\t&quot;options&quot;: [\r\n\t\t\t\t&quot;opt7&quot;,\r\n\t\t\t\t&quot;opt8&quot;,\r\n\t\t\t\t&quot;opt9&quot;,\r\n\t\t\t\t&quot;home&quot;,\r\n\t\t\t\t&quot;print&quot;\r\n\t\t\t]\r\n\t\t},\r\n\t\t{\r\n\t\t\t&quot;s_Group&quot;: &quot;cb-4&quot;,\r\n\t\t\t&quot;options&quot;: [\r\n\t\t\t\t&quot;ems99&quot;,\r\n\t\t\t\t&quot;erec98&quot;,\r\n\t\t\t\t&quot;expr-77&quot;,\r\n\t\t\t\t&quot;home&quot;\r\n\t\t]\r\n\t\t},\r\n\t\t{\r\n\t\t\t&quot;s_Group&quot;: &quot;extra-99&quot;,\r\n\t\t\t&quot;options&quot;: [\r\n\t\t\t\t&quot;conf1&quot;,\r\n\t\t\t\t&quot;ems34&quot;,\r\n\t\t\t\t&quot;erec1&quot;,\r\n\t\t\t\t&quot;home&quot;,\r\n\t\t\t\t&quot;chec99&quot;,\r\n\t\t\t\t&quot;franT&quot;\r\n\t\t\t]\r\n\t\t}\r\n\t]\r\n}\r\n```\r\n\r\njq:\r\n```\r\n.servers + .groups | group_by(.s_Group) | map(add)\r\n```\r\n[Demo][1]\r\n\r\ndesired output:\r\n```\r\n{\r\n\t&quot;servers&quot;: [\r\n\t\t[\r\n\t\t\t{\r\n\t\t\t\t&quot;location&quot;: &quot;srv_apc1&quot;,\r\n\t\t\t\t&quot;f_Group&quot;: &quot;auc-1&quot;\r\n\t\t\t},\r\n\t\t\t{\r\n\t\t\t\t&quot;location&quot;: &quot;srv_apc2&quot;,\r\n\t\t\t\t&quot;f_Group&quot;: &quot;auc-1&quot;,\r\n\t\t\t\t&quot;c_Group&quot;: &quot;c1&quot;\r\n\t\t\t},\r\n\t\t\t{\r\n\t\t\t\t&quot;location&quot;: &quot;srv_apc3&quot;,\r\n\t\t\t\t&quot;f_Group&quot;: &quot;auc-1&quot;,\r\n\t\t\t\t&quot;c_Group&quot;: &quot;c2&quot;\r\n\t\t\t},\r\n\t\t\t{\r\n\t\t\t\t&quot;location&quot;: &quot;srv_apc4&quot;,\r\n\t\t\t\t&quot;f_Group&quot;: &quot;auc-1&quot;,\r\n\t\t\t\t&quot;c_Group&quot;: &quot;c3&quot;\r\n\t\t\t},\r\n\t\t\t{\r\n\t\t\t\t&quot;location&quot;: &quot;srv_wc1&quot;,\r\n\t\t\t\t&quot;s_Group&quot;: &quot;cb-1&quot;,\r\n\t\t\t\t&quot;options&quot;: [\r\n\t\t\t\t\t&quot;opt1&quot;,\r\n\t\t\t\t\t&quot;opt3&quot;,\r\n\t\t\t\t\t&quot;opt5&quot;,\r\n\t\t\t\t\t&quot;home&quot;\r\n\t\t\t\t]\r\n\t\t\t},\r\n\t\t\t{\r\n\t\t\t\t&quot;location&quot;: &quot;srv_wc2&quot;,\r\n\t\t\t\t&quot;s_Group&quot;: &quot;cb-2&quot;,\r\n\t\t\t\t&quot;options&quot;: [\r\n\t\t\t\t\t&quot;opt2&quot;,\r\n\t\t\t\t\t&quot;opt4&quot;,\r\n\t\t\t\t\t&quot;opt6&quot;,\r\n\t\t\t\t\t&quot;home&quot;\r\n\t\t\t\t]\r\n\t\t\t},\r\n\t\t\t{\r\n\t\t\t\t&quot;location&quot;: &quot;srv_wc3&quot;,\r\n\t\t\t\t&quot;s_Group&quot;: &quot;cb-3&quot;,\r\n\t\t\t\t&quot;options&quot;: [\r\n\t\t\t\t\t&quot;opt7&quot;,\r\n\t\t\t\t\t&quot;opt8&quot;,\r\n\t\t\t\t\t&quot;opt9&quot;,\r\n\t\t\t\t\t&quot;home&quot;,\r\n\t\t\t\t\t&quot;print&quot;\r\n\t\t\t\t]\r\n\t\t\t},\r\n\t\t\t{\r\n\t\t\t\t&quot;location&quot;: &quot;srv_wc4&quot;,\r\n\t\t\t\t&quot;s_Group&quot;: &quot;cb-4&quot;,\r\n\t\t\t\t&quot;options&quot;: [\r\n\t\t\t\t\t&quot;ems99&quot;,\r\n\t\t\t\t\t&quot;erec98&quot;,\r\n\t\t\t\t\t&quot;expr-77&quot;,\r\n\t\t\t\t\t&quot;home&quot;\r\n\t\t\t\t]\r\n\t\t\t}\r\n\t\t]\r\n\t]\r\n}\r\n```\r\n\r\n\r\n  [1]: https://jqplay.org/s/VGgahOvwLvG",
        "link": "https://stackoverflow.com/questions/73709666/merge-two-arrays-based-on-common-key-keeping-unmatched-values",
        "title": "Merge two arrays based on common key, keeping unmatched values"
    },
    {
        "tags": [
            "json",
            "path",
            "nested",
            "key",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1663160426,
                "creation_date": 1663160426,
                "answer_id": 73717290,
                "question_id": 73716917,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can get an array representation of the path using `path`, join it using `join` (assuming [simple, identifier-like](https://stedolan.github.io/jq/manual/#ObjectIdentifier-Index:.foo,.foo.bar) field names), and set it using `setpath`:\r\n~~~sh\r\njq &#39;\r\n  reduce path((.. | objects | select(.base))) as $p (.;\r\n    setpath($p + [&quot;path&quot;]; $p | join(&quot;.&quot;))\r\n  )\r\n&#39;\r\n~~~\r\n~~~json\r\n{\r\n  &quot;entity&quot;: {\r\n    &quot;product&quot;: {\r\n      &quot;att&quot;: {\r\n        &quot;number_of_values&quot;: &quot;Number of values&quot;\r\n      },\r\n      &quot;title&quot;: {\r\n        &quot;base&quot;: [\r\n          &quot;product&quot;,\r\n          &quot;products&quot;,\r\n          &quot;pdt&quot;,\r\n          &quot;pdts&quot;\r\n        ],\r\n        &quot;path&quot;: &quot;entity.product.title&quot;\r\n      }\r\n    },\r\n    &quot;rabbit&quot;: {\r\n      &quot;att&quot;: {\r\n        &quot;number_of_values&quot;: &quot;Number of values&quot;\r\n      },\r\n      &quot;title&quot;: {\r\n        &quot;base&quot;: [\r\n          &quot;rabbit&quot;,\r\n          &quot;rabbits&quot;\r\n        ],\r\n        &quot;path&quot;: &quot;entity.rabbit.title&quot;\r\n      }\r\n    }\r\n  }\r\n}\r\n~~~\r\n[Demo](https://jqplay.org/s/2JYw2hboTOn)",
                "title": "Use jq to get all parent keys of specific key"
            },
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1663160526,
                "creation_date": 1663160526,
                "answer_id": 73717316,
                "question_id": 73716917,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here is one way:\r\n``` none\r\nreduce paths(objects | has(&quot;base&quot;)) as $p (.;\r\n  setpath($p + [&quot;path&quot;]; $p | join(&quot;.&quot;))\r\n)\r\n```\r\n&lt;sup&gt;[Online demo](https://jqplay.org/s/T4XssOAG4Qe)&lt;/sup&gt;",
                "title": "Use jq to get all parent keys of specific key"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1663165495,
                "creation_date": 1663165495,
                "answer_id": 73718550,
                "question_id": 73716917,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "This was a real learning experience about `path`, `paths`, `setpath` and `objects`. Before reading the other answers, I apparently re-implemented `setpath`:\r\n```jq\r\ndef add_path(p; val):\r\n    if p|length == 0\r\n    then .path = val\r\n    else .[p[0]] |= add_path(p[1:]; val)\r\n    end;\r\n\r\nreduce ([paths(..) | select(last == &quot;base&quot;)] | unique | map(.[:-1]))[] as $path (.;\r\n    add_path($path; ($path | join(&quot;.&quot;)))\r\n)",
                "title": "Use jq to get all parent keys of specific key"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 5,
        "last_activity_date": 1663166138,
        "creation_date": 1663158782,
        "last_edit_date": 1663166138,
        "question_id": 73716917,
        "body_markdown": "What I want to do is &#39;walk&#39; on my json, and for each key named &#39;base&#39;, add a key which is the full &#39;path&#39; of this key.\r\n\r\n**This is my JSON:**\r\n\r\n    {\r\n      &quot;entity&quot;: {\r\n        &quot;product&quot;: {\r\n          &quot;att&quot;: {\r\n            &quot;number_of_values&quot;: &quot;Number of values&quot;\r\n          },\r\n          &quot;title&quot;: {\r\n            &quot;base&quot;: [&quot;product&quot;, &quot;products&quot;, &quot;pdt&quot;, &quot;pdts&quot;]\r\n          }\r\n        },\r\n        &quot;rabbit&quot;: {\r\n          &quot;att&quot;: {\r\n            &quot;number_of_values&quot;: &quot;Number of values&quot;\r\n          },\r\n          &quot;title&quot;: {\r\n            &quot;base&quot;: [&quot;rabbit&quot;, &quot;rabbits&quot;]\r\n          }\r\n        }\r\n      }\r\n    }\r\n\r\n**And I want a result like this :**\r\n\r\n    {\r\n      &quot;entity&quot;: {\r\n        &quot;product&quot;: {\r\n          &quot;att&quot;: {\r\n            &quot;number_of_values&quot;: &quot;Number of values&quot;\r\n          },\r\n          &quot;title&quot;: {\r\n            &quot;base&quot;: [&quot;product&quot;, &quot;products&quot;, &quot;pdt&quot;, &quot;pdts&quot;],\r\n            &quot;path&quot;: &quot;entity.product.title&quot;\r\n          }\r\n        },\r\n        &quot;rabbit&quot;: {\r\n          &quot;att&quot;: {\r\n            &quot;number_of_values&quot;: &quot;Number of values&quot;\r\n          },\r\n          &quot;title&quot;: {\r\n            &quot;base&quot;: [&quot;rabbit&quot;, &quot;rabbits&quot;]\r\n            &quot;path&quot;: &quot;entity.rabbit.title&quot;\r\n          }\r\n        }\r\n      }\r\n    }\r\n\r\nActually, I achieve this, but I get only one sub key:\r\n\r\n    walk(if type == &quot;object&quot; and .base then  keys[] as $k | .base |= {path: $k} else . end)\r\n\r\nResults: \r\n\r\n    {\r\n      &quot;entity&quot;: {\r\n        &quot;product&quot;: {\r\n          &quot;att&quot;: {\r\n            &quot;number_of_values&quot;: &quot;Number of values&quot;\r\n          },\r\n          &quot;title&quot;: {\r\n            &quot;base&quot;: {\r\n              &quot;path&quot;: &quot;base&quot;\r\n            }\r\n          }\r\n        },\r\n        &quot;rabbit&quot;: {\r\n          &quot;att&quot;: {\r\n            &quot;number_of_values&quot;: &quot;Number of values&quot;\r\n          },\r\n          &quot;title&quot;: {\r\n            &quot;base&quot;: {\r\n              &quot;path&quot;: &quot;base&quot;\r\n            }\r\n          }\r\n        }\r\n      }\r\n    }\r\n\r\nI also tried this:\r\n\r\n    walk(if type == &quot;object&quot; and .base then  paths(..) as $v | .base |= {path: $v} else . end)\r\n\r\nResults:\r\n\r\n    {\r\n      &quot;entity&quot;: {\r\n        &quot;product&quot;: {\r\n          &quot;att&quot;: {\r\n            &quot;number_of_values&quot;: &quot;Number of values&quot;\r\n          },\r\n          &quot;title&quot;: {\r\n            &quot;base&quot;: {\r\n              &quot;path&quot;: [\r\n                &quot;base&quot;,\r\n                3\r\n              ]\r\n            }\r\n          }\r\n        },\r\n        &quot;rabbit&quot;: {\r\n          &quot;att&quot;: {\r\n            &quot;number_of_values&quot;: &quot;Number of values&quot;\r\n          },\r\n          &quot;title&quot;: {\r\n            &quot;base&quot;: {\r\n              &quot;path&quot;: [\r\n                &quot;base&quot;,\r\n                1\r\n              ]\r\n            }\r\n          }\r\n        }\r\n      }\r\n    }\r\n\r\nYour advice and expertise is greatly appreciated!",
        "link": "https://stackoverflow.com/questions/73716917/use-jq-to-get-all-parent-keys-of-specific-key",
        "title": "Use jq to get all parent keys of specific key"
    },
    {
        "tags": [
            "json",
            "merge",
            "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": 1663221505,
                "post_id": 73725891,
                "comment_id": 130188845,
                "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": 1663225515,
                "post_id": 73725891,
                "comment_id": 130189914,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2772665,
                    "reputation": 41,
                    "user_id": 2386944,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/7f56edb0e254804baa45c6630c1a2b77?s=256&d=identicon&r=PG",
                    "display_name": "pizzathehut",
                    "link": "https://stackoverflow.com/users/2386944/pizzathehut"
                },
                "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": 1663233485,
                "post_id": 73725891,
                "comment_id": 130192649,
                "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": 1663235689,
                "post_id": 73725891,
                "comment_id": 130193391,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2772665,
                    "reputation": 41,
                    "user_id": 2386944,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/7f56edb0e254804baa45c6630c1a2b77?s=256&d=identicon&r=PG",
                    "display_name": "pizzathehut",
                    "link": "https://stackoverflow.com/users/2386944/pizzathehut"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1663237379,
                "post_id": 73725891,
                "comment_id": 130193941,
                "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": 1663243017,
                "post_id": 73725891,
                "comment_id": 130195864,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2772665,
                    "reputation": 41,
                    "user_id": 2386944,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/7f56edb0e254804baa45c6630c1a2b77?s=256&d=identicon&r=PG",
                    "display_name": "pizzathehut",
                    "link": "https://stackoverflow.com/users/2386944/pizzathehut"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1663276220,
                "post_id": 73725891,
                "comment_id": 130208010,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1663226803,
                "last_edit_date": 1663226803,
                "creation_date": 1663225344,
                "answer_id": 73726830,
                "question_id": 73725891,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I&#39;m not sure I understand the requirements, especially those regarding recursion, but the following\r\ndoes produce the desired result for the given example (after trivial corrections), and does include a recursive\r\ncall to the &quot;dedup&quot; filter, so if it does not meet your requirements, hopefully\r\nit will provide a suitable framework for a solution.\r\n```\r\n# input: an array\r\ndef coalesce(f):\r\n  (map([f]) | add | unique) as $f\r\n  | add\r\n  | f = $f ;\r\n\r\ndef dedup:\r\n  if type == &quot;array&quot; and length &gt; 1\r\n  then unique\r\n  | if (.[0] | has(&quot;employee.id&quot;))\r\n    then group_by(.[&quot;employee.id&quot;])\r\n    | map( coalesce(.hobbygroup) )\r\n      else .\r\n      end\r\n  else .\r\n  end ;\r\n\r\ndef recursively(f):\r\n  if type == &quot;array&quot; then f | map(recursively(f))\r\n  else .\r\n  end;\r\n\r\nrecursively( dedup )\r\n```\r\n",
                "title": "JQ - Recursive dedupe &amp; concatenate JSON objects based on a uniquely identifying field"
            },
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1663281226,
                "last_edit_date": 1663281226,
                "creation_date": 1663279455,
                "answer_id": 73737887,
                "question_id": 73725891,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Thank you for the clarifications. Still not sure about some edge cases, but this should cover most general cases. It detects parent-child relationships of one level distance if the child object has the same field name with `.id` added to it, and applies the merger recursively onto the first relationship found (except for the hard-coded top level as it is an array-object, not an object-object relationship). It also removes array brackets if only one child object is left.\r\n\r\n~~~sh\r\ndef merge_by(f):\r\n  group_by(f) | map(\r\n    [paths[1:3] | select(&quot;\\(first).id&quot; == last)] as [$p]\r\n    | if $p then first + {($p[0]): (\r\n        map(getpath($p[:1])) | merge_by(getpath($p[1:]))\r\n        | if length == 1 then first else . end\r\n      )} else .[] end // empty\r\n  );\r\n  \r\n.employee |= merge_by(.&quot;employee.id&quot;)\r\n~~~\r\n~~~json\r\n{\r\n  &quot;employee&quot;: [\r\n    {\r\n      &quot;employee.id&quot;: &quot;11&quot;,\r\n      &quot;employee.name&quot;: &quot;bob&quot;,\r\n      &quot;hobbygroup&quot;: [\r\n        {\r\n          &quot;hobbygroup.id&quot;: &quot;1&quot;,\r\n          &quot;hobbygroup.name&quot;: &quot;chess&quot;,\r\n          &quot;groupmeeting&quot;: {\r\n            &quot;groupmeeting.id&quot;: &quot;a&quot;,\r\n            &quot;groupmeeting.name&quot;: &quot;kickoff meeting&quot;\r\n          }\r\n        },\r\n        {\r\n          &quot;hobbygroup.id&quot;: &quot;2&quot;,\r\n          &quot;hobbygroup.name&quot;: &quot;boxing&quot;,\r\n          &quot;groupmeeting&quot;: [\r\n            {\r\n              &quot;groupmeeting.id&quot;: &quot;a&quot;,\r\n              &quot;groupmeeting.name&quot;: &quot;kickoff meeting&quot;\r\n            },\r\n            {\r\n              &quot;groupmeeting.id&quot;: &quot;b&quot;,\r\n              &quot;groupmeeting.name&quot;: &quot;second meeting&quot;\r\n            }\r\n          ]\r\n        }\r\n      ]\r\n    },\r\n    {\r\n      &quot;employee.id&quot;: &quot;12&quot;,\r\n      &quot;employee.name&quot;: &quot;bill&quot;,\r\n      &quot;hobbygroup&quot;: {\r\n        &quot;hobbygroup.id&quot;: &quot;1&quot;,\r\n        &quot;hobbygroup.name&quot;: &quot;chess&quot;,\r\n        &quot;groupmeeting&quot;: {\r\n          &quot;groupmeeting.id&quot;: &quot;a&quot;,\r\n          &quot;groupmeeting.name&quot;: &quot;kickoff meeting&quot;\r\n        }\r\n      }\r\n    }\r\n  ]\r\n}\r\n~~~\r\n[Demo](https://jqplay.org/s/I5CJzpR7G7a)",
                "title": "JQ - Recursive dedupe &amp; concatenate JSON objects based on a uniquely identifying field"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1675452069,
        "creation_date": 1663218629,
        "last_edit_date": 1675452069,
        "question_id": 73725891,
        "body_markdown": "I&#39;m trying to dedupe and merge multiple JSON objects together, based on an id field on every JSON object. \r\n\r\nIn the example below, the values of the &quot;employee.id&quot; and &quot;hobbygroup.id&quot; fields are used to determine whether to dedupe the duplicated value and remove it, or instead concatenate its separate value into another location that preserves the hierarchy.\r\n\r\nFor example:\r\n\r\n```\r\n{\r\n   &quot;employee&quot;:[\r\n      {\r\n         &quot;employee.id&quot;:&quot;11&quot;,\r\n         &quot;employee.name&quot;:&quot;bob&quot;,\r\n         &quot;hobbygroup&quot;:{\r\n            &quot;hobbygroup.id&quot;:&quot;1&quot;,\r\n            &quot;hobbygroup.name&quot;:&quot;chess&quot;,\r\n            &quot;groupmeeting&quot;:{\r\n               &quot;groupmeeting.id&quot;:&quot;a&quot;,\r\n               &quot;groupmeeting.name&quot;:&quot;kickoff meeting&quot;\r\n            }\r\n         }\r\n      },\r\n      { # new hobbygroup.id, so this hobbygroup gets concatenated with the hobbygroup &quot;1&quot; above\r\n         &quot;employee.id&quot;:&quot;11&quot;,\r\n         &quot;employee.name&quot;:&quot;bob&quot;,\r\n         &quot;hobbygroup&quot;:{\r\n            &quot;hobbygroup.id&quot;:&quot;2&quot;,\r\n            &quot;hobbygroup.name&quot;:&quot;boxing&quot;,\r\n            &quot;groupmeeting&quot;:{\r\n               &quot;groupmeeting.id&quot;:&quot;a&quot;,\r\n               &quot;groupmeeting.name&quot;:&quot;kickoff meeting&quot;\r\n            }\r\n         }\r\n      },\r\n      { # same hobbygroup.id and employee.id as before, but new group meeting, gets concat with groupmeeting &quot;a&quot;\r\n         &quot;employee.id&quot;:&quot;11&quot;,\r\n         &quot;employee.name&quot;:&quot;bob&quot;,\r\n         &quot;hobbygroup&quot;:{\r\n            &quot;hobbygroup.id&quot;:&quot;2&quot;,\r\n            &quot;hobbygroup.name&quot;:&quot;boxing&quot;,\r\n            &quot;groupmeeting&quot;:{\r\n               &quot;groupmeeting.id&quot;:&quot;b&quot;,\r\n               &quot;groupmeeting.name&quot;:&quot;second meeting&quot;\r\n            }\r\n         }\r\n      },\r\n      { # duplicate employee.id as well as hobbygroup.id, gets deduped/ignored\r\n         &quot;employee.id&quot;:&quot;11&quot;,\r\n         &quot;employee.name&quot;:&quot;bob&quot;,\r\n         &quot;hobbygroup&quot;:{\r\n            &quot;hobbygroup.id&quot;:&quot;2&quot;,\r\n            &quot;hobbygroup.name&quot;:&quot;boxing&quot;\r\n         }\r\n      },\r\n      { # new employee.id, gets concatenated with employee 11 into an array\r\n         &quot;employee.id&quot;:&quot;12&quot;,\r\n         &quot;employee.name&quot;:&quot;bill&quot;,\r\n         &quot;hobbygroup&quot;:{\r\n            &quot;hobbygroup.id&quot;:&quot;1&quot;,\r\n            &quot;hobbygroup.name&quot;:&quot;chess&quot;,\r\n            &quot;groupmeeting&quot;:{\r\n               &quot;groupmeeting.id&quot;:&quot;a&quot;,\r\n               &quot;groupmeeting.name&quot;:&quot;kickoff meeting&quot;\r\n            }\r\n         }\r\n      }\r\n   ]\r\n}\r\n```\r\n\r\nShould return:\r\n```\r\n{\r\n   &quot;employee&quot;:[\r\n      {\r\n         &quot;employee.id&quot;:&quot;11&quot;,\r\n         &quot;employee.name&quot;:&quot;bob&quot;,\r\n         &quot;hobbygroup&quot;:[\r\n            {\r\n               &quot;hobbygroup.id&quot;:&quot;1&quot;,\r\n               &quot;hobbygroup.name&quot;:&quot;chess&quot;,\r\n               &quot;groupmeeting&quot;:{\r\n                  &quot;groupmeeting.id&quot;:&quot;a&quot;,\r\n                  &quot;groupmeeting.name&quot;:&quot;kickoff meeting&quot;\r\n               }\r\n            },\r\n            {\r\n               &quot;hobbygroup.id&quot;:&quot;2&quot;,\r\n               &quot;hobbygroup.name&quot;:&quot;boxing&quot;,\r\n               &quot;groupmeeting&quot;:[\r\n                  {\r\n                     &quot;groupmeeting.id&quot;:&quot;a&quot;,\r\n                     &quot;groupmeeting.name&quot;:&quot;kickoff meeting&quot;\r\n                  },\r\n                  {\r\n                     &quot;groupmeeting.id&quot;:&quot;b&quot;,\r\n                     &quot;groupmeeting.name&quot;:&quot;second meeting&quot;\r\n                  }\r\n               ]\r\n            }\r\n         ]\r\n      },\r\n      {\r\n         &quot;employee.id&quot;:&quot;12&quot;,\r\n         &quot;employee.name&quot;:&quot;bill&quot;,\r\n         &quot;hobbygroup&quot;:{\r\n            &quot;hobbygroup.id&quot;:&quot;11&quot;,\r\n            &quot;hobbygroup.name&quot;:&quot;chess&quot;,\r\n            &quot;groupmeeting&quot;:{\r\n               &quot;groupmeeting.id&quot;:&quot;a&quot;,\r\n               &quot;groupmeeting.name&quot;:&quot;kickoff meeting&quot;\r\n            }\r\n         }\r\n      }\r\n   ]\r\n}\r\n```\r\n\r\n### Example Explanation\r\nAt the first level, if the value of &quot;employee.id&quot; matches between the objects, then:\r\n1. Any child fields in the object (employee.name) gets deduped/overwritten.\r\n2. Any child objects (hobbygroup) get evaluated to see if its corresponding id field (hobbygroup.id) matches. \r\n\t* If matching, then steps 1 and 2 are reapplied recursively to this object. (ie, merge any fields, and then look at any children objects of hobbygroup)\r\n\t* If not matching, then these 2 hobbygroup objects get concatenated into an array of hobbygroups under the parent object (employee), as &quot;hobbygroups&quot;: [{chess...}, {boxing...}]\r\n\r\n### Potential Inputs\r\n* Input JSON objects can have an arbitrary number of nesting levels.\r\n* Each of these objects have a field representing the dedupe key (employee.id &amp; hobbygroup.id in this case). The input keys can all be preemptively renamed to something consistent to make it easier to access, such as &quot;key.id&quot;.\r\n* The solution needs to be generic since there&#39;s a recursive requirement; it shouldn&#39;t require knowing the names of the fields or how it&#39;s nested.\r\n\r\n### Current approach I&#39;m trying\r\nI&#39;ve found a couple of threads for merging JSON objects such as https://stackoverflow.com/questions/53661930/jq-recursively-merge-objects-and-concatenate-arrays, which creates a function similar to the recursively merging multiply operation (*), except that it instead concatenates whenever it runs across an array. \r\n\r\nI think a similar approach could work here, along with an additional conditional check against the id (only concatenating if the ids don&#39;t match). However, I&#39;m new to JQ and it looks like there may be a few ways to get to the same result, so I might be missing a more simpler declarative solution.\r\n\r\nThanks!",
        "link": "https://stackoverflow.com/questions/73725891/jq-recursive-dedupe-concatenate-json-objects-based-on-a-uniquely-identifying",
        "title": "JQ - Recursive dedupe &amp; concatenate JSON objects based on a uniquely identifying field"
    },
    {
        "tags": [
            "json",
            "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": 1663272962,
                "post_id": 73736577,
                "comment_id": 130207043,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1663272196,
                "creation_date": 1663272196,
                "answer_id": 73736806,
                "question_id": 73736577,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "This will give you the product info, one per line:\r\n```sh\r\njq -c &#39;.product[] | {pid: .productID, pname: .productName, pd: .details}&#39; product.json\r\n```\r\n```none\r\n{&quot;pid&quot;:&quot;PR12343&quot;,&quot;pname&quot;:&quot;iphone13&quot;,&quot;pd&quot;:{&quot;info&quot;:&quot;test info&quot;,&quot;desc&quot;:&quot;test desciption&quot;}}\r\n{&quot;pid&quot;:&quot;PR8493&quot;,&quot;pname&quot;:&quot;iphone14&quot;,&quot;pd&quot;:{&quot;info&quot;:&quot;test info&quot;,&quot;desc&quot;:&quot;test desciption&quot;}}\r\n```\r\n\r\nSo you could read it in a loop:\r\n```sh\r\njq -c &#39;.product[] | {pid: .productID, pname: .productName, pd: .details}&#39; product.json \\\r\n| while IFS= read -r input; do\r\n    # do something with &quot;$input&quot;\r\ndone\r\n```\r\nOr capture the output into an array and iterate over that\r\n```bash\r\nmapfile -t inputs &lt; &lt;(jq -c ...)\r\nfor input in &quot;${inputs[@]}&quot;; do\r\n    # do something with &quot;$input&quot;\r\ndone\r\n```",
                "title": "How to iterate and parse JSON Array dynamically using shell script"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1663272196,
        "creation_date": 1663271004,
        "last_edit_date": 1663271927,
        "question_id": 73736577,
        "body_markdown": "I&#39;m trying to parse and iterate below JSON Array using shell script with jq. I want to get the `product.productID, product.productName, product.details.info and product.details.desc`.\r\n\r\nAnd assign these value dynamically in below **input** variable\r\n\r\n    input=&#39;{&quot;pid&quot;&#39;:$productID&#39;, &quot;pname&quot;&#39;:$productName&#39;, &quot;pd&quot;: { &quot;info&quot;&#39;:$info&#39;, &quot;desc&quot;:&#39;:$desc&#39;}}&#39;\r\n\r\nSame I want to do for `inventory` JSON array also. \r\n\r\n**product.json**\r\n```json\r\n{\r\n  &quot;product&quot;: [\r\n    {\r\n      &quot;productID&quot;: &quot;PR12343&quot;,\r\n      &quot;productName&quot;: &quot;iphone13&quot;,\r\n      &quot;price&quot;: 1000,\r\n      &quot;details&quot;: {\r\n        &quot;info&quot;: &quot;test info&quot;,\r\n        &quot;desc&quot;: &quot;test desciption&quot;\r\n      }\r\n    },\r\n    {\r\n      &quot;productID&quot;: &quot;PR8493&quot;,\r\n      &quot;productName&quot;: &quot;iphone14&quot;,\r\n      &quot;price&quot;: 1200,\r\n      &quot;details&quot;: {\r\n        &quot;info&quot;: &quot;test info&quot;,\r\n        &quot;desc&quot;: &quot;test desciption&quot;\r\n      }\r\n    }\r\n  ],\r\n  &quot;inventory&quot;: [\r\n    {\r\n      &quot;id&quot;: &quot;INV8393&quot;,\r\n      &quot;configuration&quot;: &quot;local&quot;,\r\n      &quot;name&quot;: &quot;Macbook&quot;\r\n    },\r\n    {\r\n      &quot;id&quot;: &quot;INV8322&quot;,\r\n      &quot;configuration&quot;: &quot;local&quot;,\r\n      &quot;name&quot;: &quot;iPad&quot;\r\n    }\r\n  ]\r\n}\r\n```\r\n**product.sh**\r\n\r\n    #!/bin/bash\r\n    #\r\n    inputFile=product.json\r\n    request=$(jq -c . $inputFile)\r\n    #echo &quot;$request&quot; | jq -r &#39;.product[]|&quot;\\(.productID) , \\(.productName)&quot;&#39;\r\n    \r\n    jq -c &#39;.[]&#39; product.json | while read i; do\r\n        # do stuff with $i\r\n        echo $i\r\n        input=&#39;{&quot;pid&quot;&#39;:$productID&#39;, &quot;pname&quot;&#39;:$productName&#39;, &quot;pd&quot;: { &quot;info&quot;&#39;:$info&#39;, &quot;desc&quot;:&#39;:$desc&#39;}}&#39;\r\n        # make rest api call\r\n    done\r\n\r\n\r\n\r\nCan someone please help how can I iterate and parse the value in shell script. \r\nAppreciated your help in advance.\r\n",
        "link": "https://stackoverflow.com/questions/73736577/how-to-iterate-and-parse-json-array-dynamically-using-shell-script",
        "title": "How to iterate and parse JSON Array dynamically using shell script"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 308303,
                    "reputation": 37458,
                    "user_id": 620097,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/820980fd43f2607a815c1f3dbfe152cc?s=256&d=identicon&r=PG",
                    "display_name": "shellter",
                    "link": "https://stackoverflow.com/users/620097/shellter"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1663281030,
                "post_id": 73738001,
                "comment_id": 130208961,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 166270,
                    "reputation": 135171,
                    "user_id": 390278,
                    "user_type": "registered",
                    "accept_rate": 86,
                    "profile_image": "https://www.gravatar.com/avatar/84715fec547362389d02f5be0ed12814?s=256&d=identicon&r=PG",
                    "display_name": "Jeff Mercado",
                    "link": "https://stackoverflow.com/users/390278/jeff-mercado"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1663281507,
                "post_id": 73738001,
                "comment_id": 130209061,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 26349737,
                    "reputation": 21,
                    "user_id": 20007545,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/61c68c48a7a106e28ccbe458be93e6b8?s=256&d=identicon&r=PG",
                    "display_name": "sword_of_omens",
                    "link": "https://stackoverflow.com/users/20007545/sword-of-omens"
                },
                "reply_to_user": {
                    "account_id": 166270,
                    "reputation": 135171,
                    "user_id": 390278,
                    "user_type": "registered",
                    "accept_rate": 86,
                    "profile_image": "https://www.gravatar.com/avatar/84715fec547362389d02f5be0ed12814?s=256&d=identicon&r=PG",
                    "display_name": "Jeff Mercado",
                    "link": "https://stackoverflow.com/users/390278/jeff-mercado"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1663282944,
                "post_id": 73738001,
                "comment_id": 130209294,
                "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": 1663283328,
                "post_id": 73738001,
                "comment_id": 130209355,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 166270,
                    "reputation": 135171,
                    "user_id": 390278,
                    "user_type": "registered",
                    "accept_rate": 86,
                    "profile_image": "https://www.gravatar.com/avatar/84715fec547362389d02f5be0ed12814?s=256&d=identicon&r=PG",
                    "display_name": "Jeff Mercado",
                    "link": "https://stackoverflow.com/users/390278/jeff-mercado"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1663286500,
                "post_id": 73738001,
                "comment_id": 130209798,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1663323812,
                "last_edit_date": 1663323812,
                "creation_date": 1663283379,
                "answer_id": 73738259,
                "question_id": 73738001,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Note: Apart from jq, this is a pure `bash` solution. For an `awk` solution, see @peak&#39;s [answer](https://stackoverflow.com/a/73738779/2158479).\r\n\r\nIn jq, `select` from the stream those parts that belong to the `object_array`, then truncate by `2` (field name and array index).\r\nIn the shell, `read` the lines provided by `jq -c` and redirect them to a file.\r\n\r\n~~~sh\r\n&lt; enormous.json jq -cn --stream &#39;\r\n  fromstream(2|truncate_stream(inputs| select(.[0][0] == &quot;object_array&quot;)))\r\n&#39; | while read -r json;\r\n    do fname=&quot;onif00$((++NR))&quot;; &gt; &quot;$fname.json&quot; cat &lt;&lt;&lt; &quot;$json&quot;;\r\n    done\r\n~~~\r\n\r\nTo also extract data to be used for naming the files, interleavingly output them as well. To allow for any string, including special characters such as newlines (although you shouldn&#39;t use newlines in file names), change the line delimiter to the `NUL` byte (using `-j` and `&quot;\\u0000&quot;` in jq, and `-d &#39;&#39;` with read). For instance, taking the `.name` value from the sample input and appending `.json` results in a file called `another name.json`.\r\n\r\n~~~sh\r\n&lt; enormous.json jq -jn --stream &#39;\r\n  fromstream(2|truncate_stream(inputs| select(.[0][0] == &quot;object_array&quot;)))\r\n  | (.name, @json) + &quot;\\u0000&quot;\r\n&#39; | while read -d &#39;&#39; fname; read -d &#39;&#39; json;\r\n    do &gt; &quot;$fname.json&quot; cat &lt;&lt;&lt; &quot;$json&quot;;\r\n    done\r\n~~~\r\n\r\n---\r\nNote: Apparently, for jq versions prior to 1.6 there was a bug in `truncate_stream/1` that prevented it from taking inputs other than `1`. One remedy would be to redefine `truncate_stream` yourself by prepending your filter with\r\n~~~sh\r\ndef truncate_stream(stream):\r\n  . as $n | null | stream | . as $input\r\n  | if (.[0]|length) &gt; $n then setpath([0];$input[0][$n:]) else empty end;\r\n~~~\r\nThis was taken directly from the [1.6 source code](https://github.com/stedolan/jq/blob/jq-1.6/src/builtin.jq#L217-L218), and it works perfectly with jq 1.5, for example.\r\n",
                "title": "Parse enormous json file, output objects to their own files"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1663289653,
                "creation_date": 1663289653,
                "answer_id": 73738779,
                "question_id": 73738001,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "As in the Q, I&#39;d avoid calling jq more than once.  I also like using awk, so if for example you want .name as part of the file name, I&#39;d go with s.t. like:\r\n```\r\n&lt; my.json jq -cnr --stream &#39;\r\n    fromstream(2|truncate_stream(inputs | select(.[0][0] == &quot;object_array&quot;)) )\r\n    | .name, .\r\n&#39; | awk &#39;fn==&quot;&quot; {fn=$1; next} {print &gt; &quot;onif00_&quot; fn &quot;.json&quot;; fn=&quot;&quot;; }&#39;\r\n```\r\n\r\n--- \r\nThis has also been tested using gojq, the Go implementation of jq.\r\n\r\nSee @Jeff_Mercado&#39;s comment elsewhere on this page re adapting this for versions of jq which support --stream but for which `fromstream` is buggy.",
                "title": "Parse enormous json file, output objects to their own files"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 2,
        "last_activity_date": 1663323812,
        "creation_date": 1663280576,
        "last_edit_date": 1663286378,
        "question_id": 73738001,
        "body_markdown": "I have json files of arbitrary size, some small, some enormous (&gt;40GB).  I&#39;m trying to use `jq` to stream objects from an `object_array` to their own files for later processing.\r\n\r\n`object_array` has `N` objects.\r\n\r\nThe json has the following structure:\r\n\r\n```\r\n{\r\n    &quot;top_level_name&quot;: &quot;Some Name Here&quot;,\r\n    &quot;top_level_type&quot;: &quot;Some Type&quot;,\r\n    &quot;last_updated_on&quot;: &quot;2022-07-09&quot;,\r\n    &quot;version&quot;: &quot;1.0.0&quot;,\r\n    &quot;object_array&quot;: [\r\n        {\r\n            &quot;arrangement&quot;: &quot;abcd&quot;,\r\n            &quot;name&quot;: &quot;another name&quot;,\r\n            &quot;type&quot;: &quot;efgh&quot;,\r\n            &quot;type_ver&quot;: &quot;2021&quot;,\r\n            &quot;code&quot;: &quot;12345&quot;,\r\n            &quot;desc&quot;: &quot;some description&quot;,\r\n            &quot;rate&quot;: [\r\n                {\r\n                    &quot;groups&quot;: [\r\n                        {\r\n                            &quot;IDs&quot;: [\r\n                                &quot;123654890&quot;,\r\n                                &quot;012365485&quot;\r\n                            ],\r\n                            &quot;id_type&quot;: {\r\n                                &quot;type&quot;: &quot;xyz&quot;,\r\n                                &quot;value&quot;: &quot;8527419630&quot;\r\n                            }\r\n                        }\r\n                    ],\r\n                    &quot;prices&quot;: [\r\n                        {\r\n                            &quot;price_type&quot;: &quot;priceType&quot;,\r\n                            &quot;rate&quot;: &quot;00.00&quot;,\r\n                            &quot;date&quot;: &quot;2023-01-01&quot;,\r\n                            &quot;svc_code&quot;: [\r\n                                &quot;89&quot;\r\n                            ],\r\n                            &quot;class&quot;: &quot;some-class&quot;,\r\n                            &quot;modifier&quot;: [\r\n                                &quot;78&quot;\r\n                            ],\r\n                            &quot;additional_information&quot;: &quot;null&quot;\r\n                        }\r\n                    ]\r\n                }\r\n            ]\r\n        }\r\n    ]\r\n}\r\n```\r\n\r\nThe current path I&#39;m on has me trying `jq -cn --stream &#39;fromstream(1|truncate_stream(inputs))&#39; test.json| awk &#39;{print &gt; &quot;onif00&quot; NR &quot;.json&quot;}&#39;` but my results vary from a single file with all the data or a ton of files each with some piece of the data e.g. `[` followed by another file with `{` etc.\r\n\r\nSpecifically, I&#39;d like to capture each object like the one below, from `object_array`, and place it in its own file\r\n\r\n```\r\n{\r\n\t&quot;arrangement&quot;: &quot;abcd&quot;,\r\n\t&quot;name&quot;: &quot;another name&quot;,\r\n\t&quot;type&quot;: &quot;efgh&quot;,\r\n\t&quot;type_ver&quot;: &quot;2021&quot;,\r\n\t&quot;code&quot;: &quot;12345&quot;,\r\n\t&quot;desc&quot;: &quot;some description&quot;,\r\n\t&quot;rate&quot;: [{\r\n\t\t&quot;groups&quot;: [{\r\n\t\t\t&quot;IDs&quot;: [\r\n\t\t\t\t&quot;123654890&quot;,\r\n\t\t\t\t&quot;012365485&quot;\r\n\t\t\t],\r\n\t\t\t&quot;id_type&quot;: {\r\n\t\t\t\t&quot;type&quot;: &quot;xyz&quot;,\r\n\t\t\t\t&quot;value&quot;: &quot;8527419630&quot;\r\n\t\t\t}\r\n\t\t}],\r\n\t\t&quot;prices&quot;: [{\r\n\t\t\t&quot;price_type&quot;: &quot;priceType&quot;,\r\n\t\t\t&quot;rate&quot;: &quot;00.00&quot;,\r\n\t\t\t&quot;date&quot;: &quot;2023-01-01&quot;,\r\n\t\t\t&quot;svc_code&quot;: [\r\n\t\t\t\t&quot;89&quot;\r\n\t\t\t],\r\n\t\t\t&quot;class&quot;: &quot;some-class&quot;,\r\n\t\t\t&quot;modifier&quot;: [\r\n\t\t\t\t&quot;78&quot;\r\n\t\t\t],\r\n\t\t\t&quot;additional_information&quot;: &quot;null&quot;\r\n\t\t}]\r\n\t}]\r\n}\r\n```\r\n\r\n",
        "link": "https://stackoverflow.com/questions/73738001/parse-enormous-json-file-output-objects-to-their-own-files",
        "title": "Parse enormous json file, output objects to their own files"
    },
    {
        "tags": [
            "json",
            "shell",
            "github",
            "jq",
            "pull-request"
        ],
        "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": 1663317110,
                "post_id": 73741991,
                "comment_id": 130215524,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 22532382,
                    "reputation": 19,
                    "user_id": 16724212,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/a21a7c68416d83c9a2948ed9e05299a9?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Ankur",
                    "link": "https://stackoverflow.com/users/16724212/ankur"
                },
                "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": 1663317576,
                "post_id": 73741991,
                "comment_id": 130215674,
                "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": 1663318021,
                "post_id": 73741991,
                "comment_id": 130215833,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1663357499,
                "last_edit_date": 1663357499,
                "creation_date": 1663319986,
                "answer_id": 73742619,
                "question_id": 73741991,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Below query help me to get an output:\r\n```\r\njq -r &#39;INDEX(.name)[&quot;title&quot;, &quot;pr&quot;] | &quot;\\(.name) = \\(.value)&quot;&#39; test.json\r\n\r\n```",
                "title": "I want the value of &quot;title&quot; that should be &quot;pipeline-pr-test&quot; and value of &quot;pr&quot; that should be &quot;2&quot; from below code by using shell and jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -1,
        "last_activity_date": 1663440036,
        "creation_date": 1663316817,
        "last_edit_date": 1663440036,
        "question_id": 73741991,
        "body_markdown": "```json\r\n[\r\n  {\r\n    &quot;name&quot;: &quot;pr&quot;,\r\n    &quot;value&quot;: &quot;2&quot;\r\n  },\r\n  {\r\n    &quot;name&quot;: &quot;title&quot;,\r\n    &quot;value&quot;: &quot;pipeline-pr-test&quot;\r\n  },\r\n  {\r\n    &quot;name&quot;: &quot;headhhf&quot;,\r\n    &quot;value&quot;: &quot;60dd35gt6&quot;\r\n  },\r\n  {\r\n    &quot;name&quot;: &quot;base&quot;,\r\n    &quot;value&quot;: &quot;air&quot;\r\n  },\r\n  {\r\n    &quot;name&quot;: &quot;basha&quot;,\r\n    &quot;value&quot;: &quot;7yhfr7e85a0cc&quot;\r\n  }\r\n]\r\n```",
        "link": "https://stackoverflow.com/questions/73741991/i-want-the-value-of-title-that-should-be-pipeline-pr-test-and-value-of-pr",
        "title": "I want the value of &quot;title&quot; that should be &quot;pipeline-pr-test&quot; and value of &quot;pr&quot; that should be &quot;2&quot; from below code by using shell and jq?"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1663318131,
                "post_id": 73742195,
                "comment_id": 130215870,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1663318112,
                "creation_date": 1663318112,
                "answer_id": 73742264,
                "question_id": 73742195,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Are you sure you want invalid json? You can preserve the key if you enclose it in curly braces, e.g.:\r\n```\r\njq &#39;{ data }&#39;\r\n```\r\nOutput:\r\n```json\r\n{\r\n  &quot;data&quot;: {\r\n    &quot;AWS_ACCESS_KEY_ID&quot;: &quot;topsecret&quot;,\r\n    &quot;AWS_SECRET_ACCESS_KEY&quot;: &quot;s3cr3t&quot;\r\n  }\r\n}\r\n```\r\nNote that the above is a shorthand for `{ &quot;data&quot;: .data }`",
                "title": "jq query not working in expected behaviour"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1663318112,
        "creation_date": 1663317821,
        "question_id": 73742195,
        "body_markdown": "    {\r\n      &quot;data&quot;: {\r\n        &quot;AWS_ACCESS_KEY_ID&quot;: &quot;topsecret&quot;,\r\n        &quot;AWS_SECRET_ACCESS_KEY&quot;: &quot;s3cr3t&quot;\r\n      },\r\n      &quot;metadata&quot;: {\r\n        &quot;created_time&quot;: &quot;2022-09-16T06:49:11.45818Z&quot;,\r\n        &quot;deletion_time&quot;: &quot;&quot;,\r\n        &quot;destroyed&quot;: false,\r\n        &quot;version&quot;: 23\r\n      }\r\n    }\r\nI&#39;ve above data and I want my input as:\r\n\r\n    &quot;data&quot;: {\r\n        &quot;AWS_ACCESS_KEY_ID&quot;: &quot;topsecret&quot;,\r\n        &quot;AWS_SECRET_ACCESS_KEY&quot;: &quot;s3cr3t&quot;\r\n      }\r\njq query like this `jq .data file.json` is only giving me output like this:\r\n\r\n    {\r\n      &quot;AWS_ACCESS_KEY_ID&quot;: &quot;topsecret&quot;,\r\n      &quot;AWS_SECRET_ACCESS_KEY&quot;: &quot;s3cr3t&quot;\r\n     }\r\nPlease help.",
        "link": "https://stackoverflow.com/questions/73742195/jq-query-not-working-in-expected-behaviour",
        "title": "jq query not working in expected behaviour"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 6196394,
                    "reputation": 86601,
                    "user_id": 5291015,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/4tAvO.jpg?s=256",
                    "display_name": "Inian",
                    "link": "https://stackoverflow.com/users/5291015/inian"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1663330486,
                "post_id": 73744529,
                "comment_id": 130219882,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1663330101,
                "creation_date": 1663330101,
                "answer_id": 73744636,
                "question_id": 73744529,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The problem is not with the special character `&quot;cmd [sqldb]&quot;` but with your `onInstall` type, which is a list type, but you are missing the `.[]` indicator\r\n\r\n```none\r\n.jps.onInstall[].&quot;cmd [sqldb]&quot; = [&quot;long line&quot;, &quot;another line&quot;]\r\n```\r\n\r\nor \r\n\r\n```none\r\n.jps.onInstall[][&quot;cmd [sqldb]&quot;] = [&quot;long line&quot;, &quot;another line&quot;]\r\n```",
                "title": "Process JSON with key name containing brackets"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1663330444,
        "creation_date": 1663329593,
        "last_edit_date": 1663330444,
        "question_id": 73744529,
        "body_markdown": "I have the following JSON\r\n\r\n```\r\n{\r\n    &quot;jps&quot;: {\r\n      &quot;onInstall&quot;: [{\r\n        &quot;cmd [sqldb]&quot;: [\r\n            &quot;command&quot;\r\n        ]\r\n      }]\r\n    }\r\n  }\r\n```\r\n\r\nWithout `[sqldb]`, I was doing the query as follows:\r\n\r\n\r\n```\r\njq &#39;.jps.onInstall.cmd=[&quot;long line&quot;, &quot;another line&quot;]&#39; my-app.json\r\n```\r\n\r\nAnd it worked, but with `[sqldb]`, how can I translate it to jq query format?\r\n\r\nI tried\r\n\r\n`jps.onInstall.cmd\\[sqldb\\]` and `jps.onInstall.cmd.sqldb` but no luck\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/73744529/process-json-with-key-name-containing-brackets",
        "title": "Process JSON with key name containing brackets"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 113371,
                    "reputation": 104439,
                    "user_id": 298607,
                    "user_type": "registered",
                    "accept_rate": 88,
                    "profile_image": "https://i.sstatic.net/DVW9g.jpg?s=256",
                    "display_name": "dawg",
                    "link": "https://stackoverflow.com/users/298607/dawg"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1663341553,
                "post_id": 73746960,
                "comment_id": 130224217,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 24484284,
                    "reputation": 3,
                    "user_id": 18402224,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b92b382826845803953a0e5e90974674?s=256&d=identicon&r=PG",
                    "display_name": "larry",
                    "link": "https://stackoverflow.com/users/18402224/larry"
                },
                "reply_to_user": {
                    "account_id": 113371,
                    "reputation": 104439,
                    "user_id": 298607,
                    "user_type": "registered",
                    "accept_rate": 88,
                    "profile_image": "https://i.sstatic.net/DVW9g.jpg?s=256",
                    "display_name": "dawg",
                    "link": "https://stackoverflow.com/users/298607/dawg"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1663342509,
                "post_id": 73746960,
                "comment_id": 130224561,
                "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": 1663342669,
                "post_id": 73746960,
                "comment_id": 130224622,
                "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": 1663342827,
                "post_id": 73746960,
                "comment_id": 130224681,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1663342729,
                "creation_date": 1663342729,
                "answer_id": 73747243,
                "question_id": 73746960,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Your input consists of two JSON documents; both have a `data` field on top level. But while the first one is itself an object which has an `.id` field, the second one is an array with one object item, which also has an `.id` field.\r\n\r\nTo retrieve both, you could use the `--slurp` (or `-s`) option which wraps both top-level objects into an array, then you can address them separately by index:\r\n~~~sh\r\njq --slurp &#39;.[0].data.id, .[1].data[].id&#39; jqTrial.txt\r\n~~~\r\n~~~json\r\n24843\r\n20456\r\n~~~\r\n[Demo](https://jqplay.org/s/AU6wGdAsYKr)\r\n",
                "title": "How to extract a paticular key from the json"
            },
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1663344765,
                "last_edit_date": 1663344765,
                "creation_date": 1663342948,
                "answer_id": 73747295,
                "question_id": 73746960,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Assuming you want the **project** id not the **user** id:\r\n```\r\njq &#39;\r\n    .data\r\n    | if type == &quot;object&quot; then . else .[] end\r\n    | select(.type == &quot;projects&quot;)\r\n    | .id\r\n&#39; file.json\r\n```\r\nThere&#39;s probably a better way to write the 2nd expression\r\n\r\n---\r\nIndeed, thanks to @pmf\r\n```jq\r\n.data | objects // arrays[] | select(.type == &quot;projects&quot;).id\r\n```",
                "title": "How to extract a paticular key from the json"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1663344765,
        "creation_date": 1663341273,
        "last_edit_date": 1663342684,
        "question_id": 73746960,
        "body_markdown": "I am trying to extract values from a json that I obtained using the curl command for api testing. My json looks as below.  I need some help extracting the value &quot;20456&quot; from here?\r\n\r\n     {\r\n      &quot;meta&quot;: {\r\n        &quot;status&quot;: &quot;OK&quot;,\r\n        &quot;timestamp&quot;: &quot;2022-09-16T14:45:55.076+0000&quot;\r\n      },\r\n      &quot;links&quot;: {},\r\n      &quot;data&quot;: {\r\n        &quot;id&quot;: 24843,\r\n        &quot;username&quot;: &quot;abcd&quot;,\r\n        &quot;firstName&quot;: &quot;abc&quot;,\r\n        &quot;lastName&quot;: &quot;xyz&quot;,\r\n        &quot;email&quot;: &quot;abc@abc.com&quot;,\r\n        &quot;phone&quot;: &quot;&quot;,\r\n        &quot;title&quot;: &quot;&quot;,\r\n        &quot;location&quot;: &quot;&quot;,\r\n        &quot;licenseType&quot;: &quot;FLOATING&quot;,\r\n        &quot;active&quot;: true,\r\n        &quot;uid&quot;: &quot;u24843&quot;,\r\n        &quot;type&quot;: &quot;users&quot;\r\n      }\r\n    }\r\n    {\r\n      &quot;meta&quot;: {\r\n        &quot;status&quot;: &quot;OK&quot;,\r\n        &quot;timestamp&quot;: &quot;2022-09-16T14:45:55.282+0000&quot;,\r\n        &quot;pageInfo&quot;: {\r\n          &quot;startIndex&quot;: 0,\r\n          &quot;resultCount&quot;: 1,\r\n          &quot;totalResults&quot;: 1\r\n        }\r\n      },\r\n      &quot;links&quot;: {\r\n        &quot;data.createdBy&quot;: {\r\n          &quot;type&quot;: &quot;users&quot;,\r\n          &quot;href&quot;: &quot;https://abc@abc.com/rest/v1/users/{data.createdBy}&quot;\r\n        },\r\n        &quot;data.fields.user1&quot;: {\r\n          &quot;type&quot;: &quot;users&quot;,\r\n          &quot;href&quot;: &quot;https://abc@abc.com/rest/v1/users/{data.fields.user1}&quot;\r\n        },\r\n        &quot;data.modifiedBy&quot;: {\r\n          &quot;type&quot;: &quot;users&quot;,\r\n          &quot;href&quot;: &quot;https://abc@abc.com/rest/v1/users/{data.modifiedBy}&quot;\r\n        },\r\n        &quot;data.fields.projectManager&quot;: {\r\n          &quot;type&quot;: &quot;users&quot;,\r\n          &quot;href&quot;: &quot;https://abc@abc.com/rest/v1/users/{data.fields.projectManager}&quot;\r\n        },\r\n        &quot;data.parent&quot;: {\r\n          &quot;type&quot;: &quot;projects&quot;,\r\n          &quot;href&quot;: &quot;https://abc@abc.com/rest/v1/projects/{data.parent}&quot;\r\n        }\r\n      },\r\n      &quot;data&quot;: [\r\n        {\r\n          &quot;id&quot;: 20456,\r\n          &quot;projectKey&quot;: &quot;Stratus&quot;,\r\n          &quot;parent&quot;: 20303,\r\n          &quot;isFolder&quot;: false,\r\n          &quot;createdDate&quot;: &quot;2018-03-12T23:46:59.000+0000&quot;,\r\n          &quot;modifiedDate&quot;: &quot;2020-04-28T22:14:35.000+0000&quot;,\r\n          &quot;createdBy&quot;: 18994,\r\n          &quot;modifiedBy&quot;: 18865,\r\n          &quot;fields&quot;: {\r\n            &quot;projectManager&quot;: 18373,\r\n            &quot;user1&quot;: 18628,\r\n            &quot;projectKey&quot;: &quot;Stratus&quot;,\r\n            &quot;text1&quot;: &quot;&quot;,\r\n            &quot;name&quot;: &quot;Stratus&quot;,\r\n            &quot;description&quot;: &quot;&quot;,\r\n            &quot;date2&quot;: &quot;2019-03-12&quot;,\r\n            &quot;date1&quot;: &quot;2018-03-12&quot;\r\n          },\r\n          &quot;type&quot;: &quot;projects&quot;\r\n        }\r\n      ]\r\n    }\r\n\r\nI have tried the following, but end up getting error:\r\n\r\n    ▶ cat jqTrial.txt | jq &#39;.data[].id&#39;\r\n    jq: error (at &lt;stdin&gt;:21): Cannot index number with string &quot;id&quot;\r\n    20456\r\n\r\n Also tried this but I get strings outside the object that I am not sure how to remove:\r\n\r\n    cat jqTrial.txt | jq &#39;.data[]&#39;",
        "link": "https://stackoverflow.com/questions/73746960/how-to-extract-a-paticular-key-from-the-json",
        "title": "How to extract a paticular key from the json"
    },
    {
        "tags": [
            "json",
            "jq",
            "parent"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1663345833,
                "creation_date": 1663345833,
                "answer_id": 73747855,
                "question_id": 73747799,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Use `to_entries` to decompose an object into an array of key-value pairs, then `IN` to search in the value&#39;s array, and finally return the key:\r\n\r\n~~~sh\r\njq -r --arg env &quot;Prod&quot; --arg ksp &quot;prod_db6&quot; &#39;\r\n  .[$env][] | to_entries[] | select(IN(.value[]; $ksp)).key\r\n&#39; env.json\r\n~~~\r\n~~~none\r\nprod2\r\n~~~\r\n[Demo](https://jqplay.org/s/EfTE62WLel5)",
                "title": "jq query to find nested value and return parent values"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -1,
        "last_activity_date": 1663399299,
        "creation_date": 1663345476,
        "last_edit_date": 1663399299,
        "question_id": 73747799,
        "body_markdown": "having trouble finding this, maybe it&#39;s just my search terms or who knows.\r\n\r\nbasically, i have a series of arrays mapping keyspaces to destination DBs for a large noSQL migration, in order for us to more easily script data movement. i&#39;ll include sample JSON below.\r\n\r\nit&#39;s nested basically like: `environment &gt;&gt; { [ target DB ] &gt;&gt; [ list of keyspaces ] }, { [ target DB ] &gt;&gt; [ list of keyspaces ] }`\r\n\r\nmy intent was to update my migration script to more intelligently determine where things go based on which environment is specified, etc and require less user input or &quot;figuring things out&quot;.\r\n\r\nhere&#39;s sample JSON:\r\n```\r\n{\r\n    &quot;Prod&quot;: [\r\n        {\r\n            &quot;prod1&quot;: [\r\n                &quot;prod_db1&quot;,\r\n                &quot;prod_db2&quot;,\r\n                &quot;prod_d31&quot;,\r\n                &quot;prod_db4&quot;\r\n            ]\r\n        },\r\n        {\r\n            &quot;prod2&quot;: [\r\n                &quot;prod_db5&quot;,\r\n                &quot;prod_db6&quot;,\r\n                &quot;prod_db7&quot;,\r\n                &quot;prod_db8&quot;\r\n            ]\r\n        }\r\n    ]\r\n}\r\n```\r\n\r\nassuming i&#39;m able to provide keyspace and environment to the script, and use those as variables in my jq query, is there a way to search for the keyspace and return the value for one level up? IE, i know i can do something like:\r\n```\r\n!#/bin/bash\r\nENV=&quot;Prod&quot;\r\njq &#39;..&quot;${ENV}&quot;[][]&#39; env.json\r\n```\r\n\r\nto just get the DBs in the prod environment. but if i&#39;m searching for `prod_db6&#39; how can i return the value `prod2`?",
        "link": "https://stackoverflow.com/questions/73747799/jq-query-to-find-nested-value-and-return-parent-values",
        "title": "jq query to find nested value and return parent values"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1663449955,
                "post_id": 73758609,
                "comment_id": 130244027,
                "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": 1663450138,
                "post_id": 73758609,
                "comment_id": 130244062,
                "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": 1663450625,
                "post_id": 73758609,
                "comment_id": 130244134,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 23350387,
                    "reputation": 1799,
                    "user_id": 17424027,
                    "user_type": "registered",
                    "profile_image": "https://lh3.googleusercontent.com/a/AATXAJz7dVjKgS3PukWt1oS9ptRX9Lytne1bz8wBY-AP=k-s256",
                    "display_name": "Brady Maf",
                    "link": "https://stackoverflow.com/users/17424027/brady-maf"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1663450765,
                "post_id": 73758609,
                "comment_id": 130244153,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1663450932,
                "creation_date": 1663450932,
                "answer_id": 73758736,
                "question_id": 73758609,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "To produce a listing of the key names:\r\n\r\n    jq -r &#39;keys_unsorted[]&#39;\r\n\r\n\r\nTo produce a comma-separated string with the key names, you could start with:\r\n\r\n    jq &#39;keys_unsorted|join(&quot;,&quot;)&#39;\r\n",
                "title": "How to parse JSON array key name dynamically using shell script jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1663452486,
        "creation_date": 1663449701,
        "last_edit_date": 1663452486,
        "question_id": 73758609,
        "body_markdown": "I&#39;ve below JSON, I want to parse all these key names `product, inventory, rating, review` dynamically and put it in the list and iterate the key name one by one. \r\n\r\n    {\r\n        &quot;product&quot;: [\r\n            {\r\n                &quot;productID&quot;: &quot;123&quot;,\r\n                &quot;productName&quot;: &quot;test1&quot;\r\n            }\r\n        ],\r\n        &quot;inventory&quot;: [\r\n            {\r\n                &quot;id&quot;: &quot;12093&quot;,\r\n                &quot;name&quot;: &quot;adie&quot;\r\n            }\r\n        ],\r\n        &quot;rating&quot;: [\r\n            {\r\n                &quot;value&quot;: &quot;4&quot;,\r\n                &quot;status&quot;: &quot;done&quot;\r\n            }\r\n        ],\r\n        &quot;review&quot;: [\r\n            {\r\n                &quot;desc&quot;: &quot;good&quot;,\r\n                &quot;comments&quot;: &quot;test&quot;\r\n            }\r\n        ]\r\n    }\r\n\r\nAfter parsing the key name dynamically, I want to form all the key name in a comma separated and assigned to `key_list` variable like below:\r\n\r\n    key_list=&quot;product,inventory,rating,review&quot;\r\n    \r\nAfter that I want to iterate `key_list` in a loop and print them or do something with that value. The desired output would be print the key name one by one in a loop:\r\n\r\n    product\r\n    inventory\r\n    rating\r\n    review\r\n\r\n\r\n**How can we achieve this using shell script jq?**",
        "link": "https://stackoverflow.com/questions/73758609/how-to-parse-json-array-key-name-dynamically-using-shell-script-jq",
        "title": "How to parse JSON array key name dynamically using shell script jq"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1663597186,
                "creation_date": 1663597186,
                "answer_id": 73774860,
                "question_id": 73774822,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "`join()` works on an array, but you&#39;re returning single items.\r\n\r\nReplace `[]` with `map()` so we keep the array, then `join` will work just fine:\r\n```\r\nto_entries | map(.key + &quot;=&quot; + .value) | join(&quot;,&quot;)\r\n```\r\n\r\n\r\n----------\r\n\r\n##### [JqPlay Demo](https://jqplay.org/s/qET5nEYatIR)",
                "title": "Convert key=value pair from jq output to comma seperated string"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1663597186,
        "creation_date": 1663597007,
        "question_id": 73774822,
        "body_markdown": "I have this json stored in a variable ```foo```\r\n\r\n```\r\n{\r\n&quot;app&quot;:   &quot;myApp&quot;,\r\n&quot;env&quot;:   &quot;test&quot;,\r\n&quot;tier&quot;:  &quot;frontend&quot;\r\n}\r\n```\r\n\r\nI have converted it into key=value pair using the following jq command:\r\n\r\n```\r\njq -r &#39;to_entries[] | (.key) + &quot;=&quot; + .value&#39; &lt;(echo &quot;$foo&quot;)\r\n```\r\nOutput:\r\n\r\n```\r\napp =  myApp\r\nenv =  test\r\ntier= frontend\r\n```\r\n\r\nI need to transform this to a comma seperated string of following string format and store in a variable:\r\n\r\nExpected Output:\r\n\r\n```\r\napp=myApp,env=test,tier=frontend\r\n```\r\nWhat I tried:\r\n```\r\njq -r &#39;to_entries[] | (.key) + &quot;=&quot; + .value| join(&quot;,&quot;)&#39; &lt;(echo &quot;$foo&quot;)\r\n```\r\nBut got error ``` jq: error (at &lt;stdin&gt;:4): Cannot iterate over string (&quot;app=myApp&quot;)```",
        "link": "https://stackoverflow.com/questions/73774822/convert-key-value-pair-from-jq-output-to-comma-seperated-string",
        "title": "Convert key=value pair from jq output to comma seperated string"
    },
    {
        "tags": [
            "arrays",
            "bash",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1663636267,
                "last_edit_date": 1663636267,
                "creation_date": 1663612994,
                "answer_id": 73777972,
                "question_id": 73776972,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I&#39;m not completely sure what you are trying to achieve, but this might help you on the way there:\r\n\r\nTraverse the input document using `..`, and decompose the `objects` found into an array of key-value pairs using `to_entries`. Then, filter it by iterating `.[]` over its items, and `select`ing only those whose `.value`, if in turn being `strings`, is completely contained `inside` the `$data` string, which was provided as argument using the `--arg` option on invocation). The remaining items can then be formatted to your liking, here using string interpolation `\\(…)` to produce strings, and the `-r` option on invocation to output them in raw format (as opposed to being JSON encoded).\r\n\r\n~~~sh\r\njq -r --arg data &quot;$data&quot; &#39;\r\n  .. | objects | to_entries[]\r\n  | select(.value | strings | inside($data))\r\n  | &quot;Found \\(.value) with id \\(.key)&quot;\r\n&#39; config.json\r\n~~~\r\n~~~\r\nFound JANCOK NJARAN with id CITY\r\nFound WEDHUS with id 1\r\nFound MARKONAH with id 33\r\n~~~\r\n[Demo](https://jqplay.org/s/wY0bY82HRUB)\r\n\r\nIf you want to disregard the top level (eg. `CITY`), prepend `..` with `.[] |`.\r\n\r\nTo just output a comma-separated list consisting only of all the matching IDs, wrap the whole traversal, filtering, and formatting into a pair of brackets `[…]` turning the whole result stream into an array, then use `join` with a glue string to concatenate. Additional formatting such as wrapping the final list within parentheses can also be done here, eg. using again string interpolation.\r\n\r\n~~~sh\r\njq -r --arg data &quot;$data&quot; &#39;\r\n  [ .. | objects | to_entries[]\r\n  | select(.value | strings | inside($data)).key\r\n  ] | &quot;(\\(join(&quot;,&quot;)))&quot;\r\n&#39; config.json\r\n~~~\r\n~~~\r\n(CITY,1,33)\r\n~~~\r\n[Demo](https://jqplay.org/s/DLc8w6vvfmN)\r\n",
                "title": "Parse jq array iterate and search string regex"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -1,
        "last_activity_date": 1663668464,
        "creation_date": 1663607294,
        "last_edit_date": 1663668464,
        "question_id": 73776972,
        "body_markdown": "I am working with a JSON below:\r\n\r\n    {\r\n        &quot;CITY&quot;: &quot;JANCOK NJARAN&quot;,\r\n        &quot;FATHER&quot;: {\r\n            &quot;1&quot;: &quot;WEDHUS&quot;,\r\n            &quot;2&quot;: &quot;ANDRE&quot;\r\n        },\r\n        &quot;MOTHER&quot;: {\r\n            &quot;11&quot;: &quot;SARAH&quot;,\r\n            &quot;22&quot;: &quot;EVELYN&quot;,\r\n            &quot;33&quot;: &quot;MARKONAH&quot;\r\n        }\r\n    }\r\n\r\nI parse it with jq to read json\r\n\r\n    file=$(cat config.json)\r\n    city=$(echo $file | ./jq &#39;.CITY&#39;)\r\n    father=$(echo $base_config | ./jq &#39;.FATHER[]&#39;)\r\n\r\n\r\nI have `$data` :\r\n\r\n    HE IS WEDHUS FROM JANCOK NJARAN, ALSO MARKONAH\r\n\r\n\r\n\r\nFor now i have a lot of problem, i know how to do it with php, but dont know how to do it with bash\r\n\r\nwhat i want is parse the json using `jq` and search string inside `$data` with json provided \r\n\r\nExpected output is like this.\r\n\r\n\r\n    Search in $data with JSON config :\r\n    Found WEDHUS with id 1 , and MARKONAH with id 2\r\n\r\nAny help will be appreciated, thanks",
        "link": "https://stackoverflow.com/questions/73776972/parse-jq-array-iterate-and-search-string-regex",
        "title": "Parse jq array iterate and search string regex"
    },
    {
        "tags": [
            "json",
            "bash",
            "shell",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 5,
                "is_accepted": true,
                "score": 5,
                "last_activity_date": 1663675568,
                "last_edit_date": 1663675568,
                "creation_date": 1663674839,
                "answer_id": 73786286,
                "question_id": 73786147,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "This is so trivial that one might not even think of it: Using the jq filter [contains](https://stedolan.github.io/jq/manual/v1.6/#contains(element)):\r\n\r\n```\r\njq &#39;contains({\r\n  &quot;info&quot;: {\r\n    &quot;values&quot;: [\r\n      {\r\n        &quot;data&quot;: [\r\n          {\r\n            &quot;name&quot;: &quot;name&quot;,\r\n            &quot;value&quot;: &quot;val&quot;\r\n          }\r\n        ]\r\n      }\r\n    ]\r\n  }\r\n})&#39; available.json\r\n```\r\n\r\nOutput will be `true` or `false`. If you run `jq -e` (`--exit-status`), it will set the exit status accordingly, which allows you to use it together with `if` or `&amp;&amp;`/`||` in your shell.\r\n\r\nIf you the `input_json` is also stored in a file:\r\n\r\n```\r\njq --slurpfile input_json input_json &#39;contains($input_json[0])&#39; available.json\r\n```\r\n\r\nIf the JSON document is stored in a variable, then `--argjson` instead of `--slurpfile`:\r\n\r\n```\r\njq --argjson input_json &quot;$input_json&quot; &#39;contains($input_json)&#39; available.json\r\n```\r\n\r\nor simply relying on parameter expansion of your shell:\r\n\r\n```\r\njq &quot;contains($input_json)&quot; available.json\r\n```",
                "title": "How to check if json contains another json using jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1663675568,
        "creation_date": 1663674175,
        "question_id": 73786147,
        "body_markdown": "I have just started using jq and I need to check if a given json is present in another json using jq?\r\n\r\nSuppose this is my ```json_input```:\r\n```\r\n{\r\n  &quot;info&quot;: {\r\n    &quot;values&quot;: [\r\n      {\r\n        &quot;data&quot;: [\r\n          {\r\n            &quot;name&quot;: &quot;name&quot;,\r\n            &quot;value&quot;: &quot;val&quot;\r\n          }\r\n        ]\r\n      }\r\n    ]\r\n  }\r\n}\r\n```\r\n\r\nI need to check if the above json input is present inside the following ```available_json```:\r\n```\r\n{\r\n  &quot;info&quot;: {\r\n    &quot;values&quot;: [\r\n      {\r\n        &quot;data&quot;: [\r\n          {\r\n            &quot;name&quot;: &quot;name&quot;,\r\n            &quot;value&quot;: &quot;val&quot;\r\n          },\r\n          {\r\n            &quot;name&quot;: &quot;name2&quot;,\r\n            &quot;value&quot;: &quot;val2&quot;\r\n          },\r\n          {\r\n            &quot;name&quot;: &quot;name3&quot;,\r\n            &quot;value&quot;: &quot;val3&quot;\r\n          }\r\n        ],\r\n        &quot;key1&quot;:&quot;val1&quot;,\r\n        &quot;key2&quot;:&quot;val2&quot;\r\n      }\r\n    ],\r\n    &quot;priority&quot;:1,\r\n    &quot;objects&quot;:[\r\n      {\r\n        &quot;name&quot;:&quot;a&quot;}\r\n    ]\r\n  }\r\n}\r\n```\r\n\r\nBoth json are stored in variables and should report the presence for any ```json_input``` given as input based on any ```available_json``` (generic). How can this be done using jq?\r\n\r\nOr Is there any other better way like converting both json to string and then comparing?\r\n\r\nPS: The json object key ```info``` is fixed and the ```values``` can change.",
        "link": "https://stackoverflow.com/questions/73786147/how-to-check-if-json-contains-another-json-using-jq",
        "title": "How to check if json contains another json using jq?"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1663677913,
                "last_edit_date": 1663677913,
                "creation_date": 1663677593,
                "answer_id": 73786865,
                "question_id": 73786836,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "[`with_entries`](https://stedolan.github.io/jq/manual/v1.6/#to_entries,from_entries,with_entries) helps:\r\n\r\n```\r\nwith_entries(.value |= .value)\r\n```\r\n\r\nwhich is short for `to_entries | map(.value |= .value) | from_entries`\r\n\r\n`to_entries` transforms an object of form `{a:b}` into an array in the form `[{key:a, value:b}]`, so in your example:\r\n\r\n```\r\n{\r\n  &quot;key&quot;: &quot;A&quot;,\r\n  &quot;value&quot;: {\r\n    &quot;type&quot;: &quot;string&quot;,\r\n    &quot;value&quot;: &quot;value_A&quot;\r\n  }\r\n}\r\n```\r\n\r\n`.value |= .value` then assigns the content of `.value.value` to `.value`, leaving you with:\r\n\r\n```\r\n{\r\n  &quot;key&quot;: &quot;A&quot;,\r\n  &quot;value&quot;: &quot;value_A&quot;\r\n}\r\n```\r\n\r\nwhich is then converted to an object again by `from_entries` (repeated from above: `with_entries(f)` is equivalent to `from_entries|map(f)|from_entries`)",
                "title": "jq: Map from nested JSON"
            },
            {
                "up_vote_count": 5,
                "is_accepted": true,
                "score": 5,
                "last_activity_date": 1663678188,
                "creation_date": 1663678188,
                "answer_id": 73787003,
                "question_id": 73786836,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You don&#39;t need `with_entries`.\r\n```\r\nmap_values(.value)\r\n```\r\n&lt;sup&gt;[Online demo](https://jqplay.org/s/7_AVtUHt1al)&lt;/sup&gt;",
                "title": "jq: Map from nested JSON"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1663678229,
                "creation_date": 1663678229,
                "answer_id": 73787016,
                "question_id": 73786836,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Your attempt\r\n~~~sh\r\n.[] | {value}\r\n~~~\r\njust misses the update assignment.\r\n\r\nThis will work as expected:\r\n~~~sh\r\n.[] |= .value\r\n~~~\r\n~~~json\r\n{\r\n  &quot;A&quot;: &quot;value_A&quot;,\r\n  &quot;B&quot;: &quot;value_B&quot;\r\n}\r\n~~~\r\n[Demo](https://jqplay.org/s/A4pWOGpoKjc)\r\n",
                "title": "jq: Map from nested JSON"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1663678450,
                "creation_date": 1663678450,
                "answer_id": 73787074,
                "question_id": 73786836,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Use the function [`map_values()`](https://stedolan.github.io/jq/manual/#map(x),map_values(x)):\r\n\r\n```jq\r\nmap_values(.value)\r\n```\r\n\r\nIt runs the filter passed as argument to each value of the input object, collects the results and associates them with the keys of the input object and returns an object.\r\n\r\nCheck it [online](https://jqplay.org/s/7_AVtUHt1al).",
                "title": "jq: Map from nested JSON"
            }
        ],
        "is_answered": true,
        "answer_count": 4,
        "score": 2,
        "last_activity_date": 1663678593,
        "creation_date": 1663677469,
        "last_edit_date": 1663678593,
        "question_id": 73786836,
        "body_markdown": "I have the following JSON:\r\n```json\r\n{\r\n  &quot;A&quot;: {\r\n    &quot;type&quot;: &quot;string&quot;,\r\n    &quot;value&quot;: &quot;value_A&quot;\r\n  },\r\n  &quot;B&quot;: {\r\n    &quot;type&quot;: &quot;string&quot;,\r\n    &quot;value&quot;: &quot;value_B&quot;\r\n  }\r\n}\r\n```\r\n...and am trying to use JQ to result in the following:\r\n\r\n**Desired Output**\r\n```json\r\n{\r\n  &quot;A&quot;: &quot;value_A&quot;,\r\n  &quot;B&quot;: &quot;value_B&quot;\r\n}\r\n````\r\n...where the key takes the direct value of `node.value`.\r\n\r\n_________\r\n\r\n\r\nMy current attempt:\r\n\r\n    .[] | {value}\r\n\r\n...returns the following:\r\n\r\n    {\r\n      &quot;value&quot;: &quot;value_A&quot;\r\n    }\r\n    {\r\n      &quot;value&quot;: &quot;value_B&quot;\r\n    }\r\n\r\n__________\r\n\r\nHow can I use JQ to produce the desired JSON?",
        "link": "https://stackoverflow.com/questions/73786836/jq-map-from-nested-json",
        "title": "jq: Map from nested JSON"
    },
    {
        "tags": [
            "linux",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 9629731,
                    "reputation": 51350,
                    "user_id": 10248678,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d8f818402f22d485b135a3b685ef908e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "oguz ismail",
                    "link": "https://stackoverflow.com/users/10248678/oguz-ismail"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1663681841,
                "post_id": 73787711,
                "comment_id": 130293820,
                "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": 1663682575,
                "post_id": 73787711,
                "comment_id": 130294169,
                "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"
                },
                "reply_to_user": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1663682780,
                "post_id": 73787711,
                "comment_id": 130294253,
                "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": 1663682781,
                "post_id": 73787711,
                "comment_id": 130294255,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1663681559,
                "creation_date": 1663681559,
                "answer_id": 73787777,
                "question_id": 73787711,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "With your shown samples please try following `jq` code. Using `-r` option to enable raw-mode option of `jq` then in main block using `select` function to check if component .templateId is `test` if yes then print its related id component value.\r\n\r\n```awk\r\necho &quot;${RESPONSE_TEMPLATES}&quot; | jq -r &#39;select(.templateId==&quot;test&quot;).id&#39;\r\n```",
                "title": "command not found when executing jq for manipulating variable"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 3,
        "last_activity_date": 1663681584,
        "creation_date": 1663681324,
        "last_edit_date": 1663681584,
        "question_id": 73787711,
        "body_markdown": "What I do:\r\n\r\n1. `RESPONSE_TEMPLATES=$(curl  &quot;https://maydomain.com/test)`\r\n2. I get back JSON which looks like this:\r\n```\r\n    {\r\n      &quot;templateId&quot;: &quot;test&quot;,\r\n      &quot;id&quot;: 1621030\r\n    }\r\n    {\r\n      &quot;templateId&quot;: &quot;test1&quot;,\r\n      &quot;id&quot;: 5014\r\n    }\r\n    {\r\n      &quot;templateId&quot;: &quot;test3&quot;,\r\n      &quot;id&quot;: 5015\r\n    }\r\n```\r\n3. ``` echo $(${RESPONSE_TEMPLATES} | jq -r &#39;.[]&#39;| {templateId,id}&#39;)``` \r\n\r\nProblem is that I always get error:  [{&quot;id&quot;:1386084,&quot;templateId&quot;:&quot;test: command not found\r\n\r\n\r\nI do not know how I should write 3 steps so that it will display this as a string and not use after &quot;&quot;test: &quot; as command.",
        "link": "https://stackoverflow.com/questions/73787711/command-not-found-when-executing-jq-for-manipulating-variable",
        "title": "command not found when executing jq for manipulating variable"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 4879,
                    "reputation": 248190,
                    "user_id": 7552,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/b60298053f87465641c1b1192338c8cd?s=256&d=identicon&r=PG",
                    "display_name": "glenn jackman",
                    "link": "https://stackoverflow.com/users/7552/glenn-jackman"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1663708779,
                "post_id": 73792708,
                "comment_id": 130302834,
                "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": 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": 1663709235,
                "post_id": 73792708,
                "comment_id": 130302950,
                "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": 1663709559,
                "post_id": 73792708,
                "comment_id": 130303027,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 39208,
                    "reputation": 267964,
                    "user_id": 112968,
                    "user_type": "registered",
                    "accept_rate": 68,
                    "profile_image": "https://i.sstatic.net/zHTaT.png?s=256",
                    "display_name": "knittl",
                    "link": "https://stackoverflow.com/users/112968/knittl"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1663709793,
                "post_id": 73792708,
                "comment_id": 130303081,
                "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": 1663710237,
                "post_id": 73792708,
                "comment_id": 130303177,
                "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": 1663710357,
                "post_id": 73792708,
                "comment_id": 130303201,
                "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": 1663711136,
                "post_id": 73792708,
                "comment_id": 130303349,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1663711108,
                "last_edit_date": 1663711108,
                "creation_date": 1663709955,
                "answer_id": 73792920,
                "question_id": 73792708,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can define **pick/1** as below,\r\n```\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\n```\r\nand use it like so:\r\n```\r\n.[] | pick(.type)\r\n```\r\n&lt;sup&gt;[Online demo](https://jqplay.org/s/W33GXhDUW64)&lt;/sup&gt;\r\n```\r\ndef count_by(paths; filter):\r\n  group_by(paths | filter) | map(\r\n    (.[0] | pick(paths)) + {count: length}\r\n  );\r\ndef count_by(paths):\r\n  count_by(paths; .);\r\ncount_by(.type)\r\n```\r\n&lt;sup&gt;[Online demo](https://jqplay.org/s/XYCGiQql-rO)&lt;/sup&gt;\r\n\r\nI don&#39;t think there&#39;s a *shorter and more readable way*.",
                "title": "How to construct object in function using key passed as argument"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1663744393,
                "last_edit_date": 1663744393,
                "creation_date": 1663743659,
                "answer_id": 73796560,
                "question_id": 73792708,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "As you say, you can use path/1 to define your `keep_field_only` and `count_by`, but it can be done in a very simple way:\r\n```\r\ndef keep_field_only(field):\r\n  (null | path(field)[0]) as $field\r\n  | {($field): field} ;\r\n\r\ndef count_by(field):\r\n  (null | path(field)[0]) as $field\r\n  | group_by(field)\r\n  | map(\r\n    {\r\n      ($field): .[0][$field],\r\n      count: length\r\n    }\r\n  );\r\n\r\n```\r\nOf course this is only intended to work in examples like yours, e.g. with invocations like `keep_field_only(.type)` or `count_by(.type)`.\r\nHowever, thanks to `setpath`, the same technique can be used in more complex cases.\r\n\r\n\r\n",
                "title": "How to construct object in function using key passed as argument"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1664702613,
        "creation_date": 1663708374,
        "last_edit_date": 1664702613,
        "question_id": 73792708,
        "body_markdown": "I frequently need to create reusable function that performs transformations for a given field of input, for example:\r\n\r\n    def keep_field_only(field):\r\n      {field}\r\n    ;\r\n\r\nor\r\n\r\n    def count_by(field):\r\n      group_by(field) |\r\n      map(\r\n        {\r\n          field: .[0].field,\r\n          count: length\r\n        }\r\n      )\r\n    ;\r\n\r\nWhile `group_by` works fine with key passed as an argument, using it to construct object (eg. to keep only key in the object) doesn&#39;t work.\r\n\r\nI believe it can be always worked around using `path/1`, but in my experience it significantly complicates code.\r\n\r\nOther workaround I used is copying field `+{new_field: field}` at beginning of function, deleting it in the end, but it doesn&#39;t look very efficient or readable either.\r\n\r\nIs there a shorter and more readable way?\r\n\r\n**Update:**\r\n\r\nSample input:\r\n\r\n    [\r\n      {&quot;type&quot;:1, &quot;name&quot;: &quot;foo&quot;},\r\n      {&quot;type&quot;:1, &quot;name&quot;: &quot;bar&quot;},\r\n      {&quot;type&quot;:2, &quot;name&quot;: &quot;joe&quot;}\r\n    ]\r\n\r\n\r\nPreferred function invocation and expected results:\r\n\r\n    .[] | keep_field_only(.type):\r\n\r\n      {&quot;type&quot;: 1}\r\n      {&quot;type&quot;: 1}\r\n      {&quot;type&quot;: 2}\r\n\r\n-----\r\n     count_by(.type):\r\n     \r\n     [\r\n       {&quot;type&quot;:1, &quot;count&quot;: 2},\r\n       {&quot;type&quot;:2, &quot;count&quot;: 1}\r\n     ]",
        "link": "https://stackoverflow.com/questions/73792708/how-to-construct-object-in-function-using-key-passed-as-argument",
        "title": "How to construct object in function using key passed as argument"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1663715470,
                "last_edit_date": 1663715470,
                "creation_date": 1663715223,
                "answer_id": 73793461,
                "question_id": 73793450,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Use the `-s` flag to read the stream into an array, the `add` it up and put it into your object:\r\n~~~sh\r\njq -s &#39;{ref: add}&#39;\r\n~~~\r\n~~~json\r\n{\r\n  &quot;ref&quot;: {\r\n    &quot;id1&quot;: {\r\n      &quot;version&quot;: 4,\r\n      &quot;lastModifier&quot;: &quot;abc&quot;\r\n    },\r\n    &quot;id2&quot;: {\r\n      &quot;version&quot;: 3,\r\n      &quot;lastModifier&quot;: &quot;def&quot;\r\n    },\r\n    &quot;id3&quot;: {\r\n      &quot;version&quot;: 8,\r\n      &quot;lastModifier&quot;: &quot;abc&quot;\r\n    }\r\n  }\r\n}\r\n~~~\r\n[Demo](https://jqplay.org/s/u-s2E4OiEmC)\r\n\r\n---\r\nOf course, there is also a solution using `reduce`:\r\n~~~sh\r\njq -n &#39;reduce inputs as $in ({}; .ref += $in)&#39;\r\n~~~\r\n~~~json\r\n{\r\n  &quot;ref&quot;: {\r\n    &quot;id1&quot;: {\r\n      &quot;version&quot;: 4,\r\n      &quot;lastModifier&quot;: &quot;abc&quot;\r\n    },\r\n    &quot;id2&quot;: {\r\n      &quot;version&quot;: 3,\r\n      &quot;lastModifier&quot;: &quot;def&quot;\r\n    },\r\n    &quot;id3&quot;: {\r\n      &quot;version&quot;: 8,\r\n      &quot;lastModifier&quot;: &quot;abc&quot;\r\n    }\r\n  }\r\n}\r\n~~~\r\n[Demo](https://jqplay.org/s/vtKZg_0Zapz)\r\n",
                "title": "Using jq to put a result list into an enclosing object"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1663715470,
        "creation_date": 1663715097,
        "question_id": 73793450,
        "body_markdown": "**Input**: The output from my current jq filters looks like\r\n```\r\n{\r\n  &quot;id1&quot;: {\r\n    &quot;version&quot;: 4,\r\n    &quot;lastModifier&quot;: &quot;abc&quot;\r\n  }\r\n}\r\n{\r\n  &quot;id2&quot;: {\r\n    &quot;version&quot;: 3,\r\n    &quot;lastModifier&quot;: &quot;def&quot;\r\n  }\r\n}\r\n{\r\n  &quot;id3&quot;: {\r\n    &quot;version&quot;: 8,\r\n    &quot;lastModifier&quot;: &quot;abc&quot;\r\n  }\r\n}\r\n```\r\n**Desired Output**: I just need to wrap this list in a object so I end up with\r\n```\r\n{\r\n  &quot;ref&quot;: {\r\n      &quot;id1&quot;: {\r\n          &quot;version&quot;: 4,\r\n          &quot;lastModifier&quot;: &quot;abc&quot;\r\n      },\r\n      &quot;id2&quot;: {\r\n          &quot;version&quot;: 3,\r\n          &quot;lastModifier&quot;: &quot;def&quot;\r\n      },\r\n      &quot;id3&quot;: {\r\n          &quot;version&quot;: 8,\r\n          &quot;lastModifier&quot;: &quot;abc&quot;\r\n      }\r\n   }\r\n}\r\n```\r\nI don&#39;t want to merge anything from the input list into the output object, all the properties need to remain as-is, so piping to `add` doesn&#39;t work. Also tried wrapping my filters with `{ &quot;ref&quot;: (` *filters* `)}` but that yields the same list with a &quot;ref&quot; wrapper for each object. Possibly `reduce` is what is needed but haven&#39;t been able to construct that appropriately.",
        "link": "https://stackoverflow.com/questions/73793450/using-jq-to-put-a-result-list-into-an-enclosing-object",
        "title": "Using jq to put a result list into an enclosing object"
    },
    {
        "tags": [
            "json",
            "shell",
            "object",
            "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": 1663746215,
                "post_id": 73797014,
                "comment_id": 130309194,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 9901716,
                    "reputation": 2367,
                    "user_id": 7331538,
                    "user_type": "registered",
                    "accept_rate": 70,
                    "profile_image": "https://www.gravatar.com/avatar/603a48331ac6169d86f15d0d1b3a32e6?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "bcsta",
                    "link": "https://stackoverflow.com/users/7331538/bcsta"
                },
                "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": 1663746368,
                "post_id": 73797014,
                "comment_id": 130309254,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1663746929,
                "last_edit_date": 1663746929,
                "creation_date": 1663746601,
                "answer_id": 73797140,
                "question_id": 73797014,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "With [hjson](https://github.com/laktak/hjson-py) (using Python), you could use the `-j` flag\r\n~~~\r\n  -j            Output as formatted JSON.\r\n~~~~\r\nas follows:\r\n~~~sh\r\nhjson -j yourfile.txt\r\n~~~\r\n~~~json\r\n{\r\n  &quot;methods&quot;: {\r\n    &quot;0&quot;: &quot;GET&quot;\r\n  }\r\n}\r\n~~~\r\n\r\n---\r\nAnother way could be using the YAML processor [mikefarah/yq](https://github.com/mikefarah/yq) (written in Go) and its `-o` flag\r\n~~~\r\n  -o, --output-format string          [yaml|y|json|j|props|p|xml|x] output format type. (default &quot;yaml&quot;)\r\n~~~\r\nas follows\r\n~~~sh\r\nyq -o json yourfile.txt\r\n~~~\r\n~~~json\r\n{\r\n  &quot;methods&quot;: {\r\n    &quot;0&quot;: &quot;GET&quot;\r\n  }\r\n}\r\n~~~\r\n\r\nBut yq also has a JSON converter `@json` as built-in function, if you&#39;d want to further adjust the data on the fly:\r\n~~~sh\r\nyq &#39;@json&#39; yourfile.txt\r\n~~~\r\n~~~json\r\n{&quot;methods&quot;:{&quot;0&quot;:&quot;GET&quot;}}\r\n~~~",
                "title": "Shell: Map all keys in a string format (json compatible)"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1663746929,
        "creation_date": 1663745917,
        "last_edit_date": 1663746286,
        "question_id": 73797014,
        "body_markdown": "I have an object in a file like:\r\n\r\n## foo.txt\r\n    {\r\n    &quot;methods&quot; :\r\n          {\r\n            0 : &quot;GET&quot;,\r\n          },\r\n    }\r\n\r\nI would like to convert to json with `jq` or some other shell converter. Specifically I want to turn each key into a string `0` -&gt; `&quot;0&quot;`. Keys can be numerical or alphanumerical.\r\n\r\n## Update\r\nAny other tool is also acceptable. Anything that gets the job done. Preferably a shell tool.",
        "link": "https://stackoverflow.com/questions/73797014/shell-map-all-keys-in-a-string-format-json-compatible",
        "title": "Shell: Map all keys in a string format (json compatible)"
    },
    {
        "tags": [
            "shell",
            "hdfs",
            "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": 1663754765,
                "post_id": 73798871,
                "comment_id": 130312195,
                "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": 1663798855,
                "post_id": 73798871,
                "comment_id": 130327123,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1663755641,
                "creation_date": 1663755641,
                "answer_id": 73799111,
                "question_id": 73798871,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Evidently you need first to `select(.url)`.\r\n\r\nCalling both hdfs and jq twice seems a bit extravagant. If efficiency is a concern at all, you might wish to save the result of hdfs to a file and call jq twice, or perhaps even better to contrive to call hdfs and jq just once in a pipeline that ends with a call to awk to write the two files.",
                "title": "Parse Json file in HDFS and write to output only if key is available"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1663758770,
        "creation_date": 1663754567,
        "last_edit_date": 1663758770,
        "question_id": 73798871,
        "body_markdown": "I have a JSON file with &quot;name&quot; as key and &quot;url&quot; as another key. Not all records in the JSON have the &quot;url&quot; key. So when I am trying to write to text it gets written as null. So, I will have to do a check if url key is present and if present, then it has to be written to 2 output text files. name will goto name.txt and url will goto url.txt\r\n\r\n    { [ {&quot;name&quot;: &quot;a&quot;, url: &quot;url1&quot;}, {&quot;name&quot;: &quot;b&quot;}, {&quot;name&quot;: &quot;C&quot;} ] }\r\n\r\nExpected output:\r\n\r\n    name.txt\r\n    a\r\n    url.txt\r\n    url\r\n\r\nWhat i tried so far:\r\n\r\n    name=`hdfs dfs -cat $path | jq -r &#39;.name&#39;`\r\n    url=`hdfs dfs -cat $path | jq -r &#39;.name&#39;`\r\n    \r\n    echo ${name} &gt;&gt; name.txt\r\n    echo ${url} &gt;&gt; url.txt\r\n\r\nThe problem with above is if url is not found it writes a null to output file and equivalent name is written to name.txt file. \r\n\r\nHow to skip the records from writing to output file when url json tag is not found\r\n",
        "link": "https://stackoverflow.com/questions/73798871/parse-json-file-in-hdfs-and-write-to-output-only-if-key-is-available",
        "title": "Parse Json file in HDFS and write to output only if key is available"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 5,
                "is_accepted": true,
                "score": 5,
                "last_activity_date": 1663763559,
                "creation_date": 1663763559,
                "answer_id": 73800800,
                "question_id": 73800715,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The way you check the ticker number is present in the allowed list, is not quite right, the `map(..)` and `in` are not correctly used. You can do something like\r\n\r\n```none\r\n[&quot;24656&quot;, &quot;33445&quot;] as $valid | select(.record.data.ticketNumber | IN($valid[]))\r\n```\r\n\r\n[jqplay Demo][1]\r\n\r\n\r\n  [1]: https://jqplay.org/s/2mDXlp_RfQf",
                "title": "How do I use JQ to select a handful of objects matching an ID in a large json file?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1663763559,
        "creation_date": 1663763142,
        "question_id": 73800715,
        "body_markdown": "Say I have a large file of JSON lines (more than 10k) like so:\r\n\r\n```\r\n{&quot;type&quot;: &quot;RECORD&quot;, &quot;record&quot;: {&quot;stream&quot;: &quot;...&quot;, &quot;data&quot;: {&quot;ticketNumber&quot;: &quot;12345&quot;}}}\r\n{&quot;type&quot;: &quot;RECORD&quot;, &quot;record&quot;: {&quot;stream&quot;: &quot;...&quot;, &quot;data&quot;: {&quot;ticketNumber&quot;: &quot;23456&quot;}}}\r\n{&quot;type&quot;: &quot;RECORD&quot;, &quot;record&quot;: {&quot;stream&quot;: &quot;...&quot;, &quot;data&quot;: {&quot;ticketNumber&quot;: &quot;33445&quot;}}}\r\n{&quot;type&quot;: &quot;RECORD&quot;, &quot;record&quot;: {&quot;stream&quot;: &quot;...&quot;, &quot;data&quot;: {&quot;ticketNumber&quot;: &quot;24656&quot;}}}\r\n{&quot;type&quot;: &quot;RECORD&quot;, &quot;record&quot;: {&quot;stream&quot;: &quot;...&quot;, &quot;data&quot;: {&quot;ticketNumber&quot;: &quot;15523&quot;}}}\r\n{&quot;type&quot;: &quot;RECORD&quot;, &quot;record&quot;: {&quot;stream&quot;: &quot;...&quot;, &quot;data&quot;: {&quot;ticketNumber&quot;: &quot;30030&quot;}}}\r\n\r\n```\r\n\r\nI am trying to use `jq` to extract only the records whose ticketNumbers are &quot;24656&quot; and &quot;33445&quot;. I&#39;ve tried the following command\r\n\r\n```\r\ncat datafile.json | jq &#39;.record.data | select(.ticketNumber | map(in([&quot;24656&quot;, &quot;33445&quot;])))&#39;\r\n```\r\n\r\nWhat have I done wrong here?\r\n\r\nBut all I get are errors saying &quot;error at .... cannot iterate over string (&#39;...&#39;)&quot;). ",
        "link": "https://stackoverflow.com/questions/73800715/how-do-i-use-jq-to-select-a-handful-of-objects-matching-an-id-in-a-large-json-fi",
        "title": "How do I use JQ to select a handful of objects matching an ID in a large json file?"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": -1,
                "last_activity_date": 1663812485,
                "creation_date": 1663812485,
                "answer_id": 73808597,
                "question_id": 73808312,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I was just playing with this today. If you want `[inputs]` to contain **all** the inputs, even the first one, you either need \r\n```sh\r\njq -n &#39;[inputs] | ...&#39;\r\n```\r\nor \r\n```sh\r\njq &#39;[.] + [inputs] | ...\r\n```\r\nor \r\n```sh\r\njq &#39;[., inputs] | ...\r\n```\r\nor \r\n```sh\r\njq -s &#39;...&#39; # &quot;dot&quot; is an array of all the inputs\r\n```",
                "title": "Surprising side effect of (array_expr) as $var for downstream output on non/empty value of array_expr"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1663825261,
                "last_edit_date": 1663825261,
                "creation_date": 1663813832,
                "answer_id": 73808739,
                "question_id": 73808312,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The key point here is that `first(empty)` yields the empty stream.\r\nSo in your query, `first(.[] | select (.ID==3)) as $match` has the effect of `empty`, and thus your program is equivalent to `empty | .`, which is empty.\r\n\r\nUnfortunately, you have not indicated what you are actually trying to do, but chances are you might want to consider something along the lines of:\r\n```\r\n(first(.[] | select (.ID==3)) // null) as $match` \r\n```\r\n\r\n---\r\nSince @glennjackman&#39;s response has been downvoted, it is perhaps worth emphasizing that the command-line option -n must be specified if `inputs` is to be relied on for the entire input stream.",
                "title": "Surprising side effect of (array_expr) as $var for downstream output on non/empty value of array_expr"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1663823180,
                "creation_date": 1663823180,
                "answer_id": 73809588,
                "question_id": 73808312,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Maybe this example will help to clarify:\r\n~~~sh\r\n0 | (1,2,3) as $x | .\r\n~~~\r\n~~~sh\r\n0\r\n0\r\n0\r\n~~~\r\nGiven a single input followed by an (even unrelated) assignment that unfolds multiple times, you end up having a stream of said multitude of items (for each of which `$x` is set to one of the assigned values).\r\n\r\nNow, replacing `(1,2,3)` with `empty`\r\n~~~sh\r\n0 | empty as $x | .\r\n~~~\r\n~~~sh\r\n\r\n~~~\r\nis no exception to that: The assignment unfolds 0 times, so you end up with a stream of 0 items as there is no value `$x` could have been set to, and in consequence no copy of the input for which `$x` could hold a value.\r\n\r\n---\r\nFollowing your example, you could envelop the filter result in something like an array, a structure that can handle any multitude of result items, including 0. In fact, with `[inputs]` you already had that array but decomposed it with the following `.[]`. Keep it by using `map` instead, so your filter can yield either an empty array or one containing the items found.\r\n~~~sh\r\n[inputs]\r\n| map(select (.ID == 1)) as $match\r\n| .   # yields the whole input array with $match set to [{&quot;ID&quot;: 1}]\r\n\r\n# or\r\n\r\n[inputs]\r\n| map(select (.ID == 3)) as $match\r\n| .   # yields the whole input array with $match set to []\r\n~~~\r\n\r\nNext, when using `$match` you would presumably only extract the first value `$match[0]` which evaluates to either the first object found, or `null` if there was no match (the array was empty). In that case, as there&#39;s no need to hold an array with possibly more than just one item in it, you could tweak the assignment from above and directly set the variable to hold the first item or `null` by moving the array (brackets) outside of the capture:\r\n~~~sh\r\n[inputs]\r\n| map(select (.ID == 1)) as [$match]\r\n| .   # yields the whole input array with $match set to {&quot;ID&quot;: 1}\r\n\r\n# or\r\n\r\n[inputs]\r\n| map(select (.ID == 3)) as [$match]\r\n| .   # yields the whole input array with $match set to null\r\n~~~",
                "title": "Surprising side effect of (array_expr) as $var for downstream output on non/empty value of array_expr"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 1,
        "last_activity_date": 1663825261,
        "creation_date": 1663808723,
        "question_id": 73808312,
        "body_markdown": "I need to extract first object matching my criterium in input stream as a variable (if any), then to process the entire stream.\r\n\r\nTurns out, the stream becomes `empty` if there is no matches:\r\n\r\nInput:\r\n\r\n    {&quot;ID&quot;:1}\r\n    {&quot;ID&quot;:2}\r\n\r\nCode resulting in full stream:\r\n\r\n    [inputs] |\r\n    (\r\n      first(.[] | select (.ID==1))\r\n    ) as $match |\r\n    .\r\n\r\nCode resulting in empty stream:\r\n\r\n    [inputs] |\r\n    (\r\n      first(.[] | select (.ID==3))\r\n    ) as $match |\r\n    .\r\n\r\n(The only difference between snippets is `.ID=={1|3}`)\r\n\r\nHow can I make the whole `inputs` available to downstream filter, whether or not there is a match?",
        "link": "https://stackoverflow.com/questions/73808312/surprising-side-effect-of-array-expr-as-var-for-downstream-output-on-non-empt",
        "title": "Surprising side effect of (array_expr) as $var for downstream output on non/empty value of array_expr"
    },
    {
        "tags": [
            "json",
            "set",
            "transform",
            "jq",
            "strip"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 6196394,
                    "reputation": 86601,
                    "user_id": 5291015,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/4tAvO.jpg?s=256",
                    "display_name": "Inian",
                    "link": "https://stackoverflow.com/users/5291015/inian"
                },
                "edited": false,
                "score": 3,
                "creation_date": 1663856590,
                "post_id": 73816279,
                "comment_id": 130342130,
                "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": 1663863630,
                "post_id": 73816279,
                "comment_id": 130344928,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1663856801,
                "creation_date": 1663856801,
                "answer_id": 73816385,
                "question_id": 73816279,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If you input are just plain objects:  \r\nUse `--slurp` to create a single array, then use `map([ . ])` to wrap each object in his own array\r\n```\r\njq --slurp --compact-output &#39;map([ . ])&#39;\r\n[[{&quot;test&quot;:&quot;index&quot;,&quot;test2&quot;:&quot;fdsdfs&quot;,&quot;test3&quot;:&quot;dfs0D0WOQAA3&quot;}],[{&quot;test&quot;:&quot;index&quot;,&quot;test2&quot;:&quot;fdsdfs&quot;,&quot;test3&quot;:&quot;dfs0D0WOQAA3&quot;}], ...\r\n```\r\n\r\n[JqPlay demo](https://jqplay.org/s/ehGkw8oxBsw)",
                "title": "jq add character before and after every row JSON"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1663858329,
                "creation_date": 1663858329,
                "answer_id": 73816740,
                "question_id": 73816279,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Assuming your file contains a stream of stand-alone JSON objects, the filter is simply `[.]`. The filter will be applied to each input object.\r\n\r\n```\r\njq -c &#39;[.]&#39; file.json\r\n```\r\n\r\nOutput:\r\n\r\n```json\r\n[{&quot;test&quot;:&quot;index&quot;,&quot;test2&quot;:&quot;fdsdfs&quot;,&quot;test3&quot;:&quot;dfs0D0WOQAA3&quot;}]\r\n[{&quot;test&quot;:&quot;index&quot;,&quot;test2&quot;:&quot;fdsdfs&quot;,&quot;test3&quot;:&quot;dfs0D0WOQAA3&quot;}]\r\n[{&quot;test&quot;:&quot;index&quot;,&quot;test2&quot;:&quot;fdsdfs&quot;,&quot;test3&quot;:&quot;dfs0D0WOQAA3&quot;}]\r\n[{&quot;test&quot;:&quot;index&quot;,&quot;test2&quot;:&quot;fdsdfs&quot;,&quot;test3&quot;:&quot;dfs0D0WOQAA3&quot;}]\r\n```\r\n\r\nTo wrap everything in one big array:\r\n\r\n```\r\njq -s . file.json\r\n# or:\r\njq -s &lt;file.json\r\n```\r\n\r\nOutput:\r\n\r\n```json\r\n[\r\n  {\r\n    &quot;test&quot;: &quot;index&quot;,\r\n    &quot;test2&quot;: &quot;fdsdfs&quot;,\r\n    &quot;test3&quot;: &quot;dfs0D0WOQAA3&quot;\r\n  },\r\n  {\r\n    &quot;test&quot;: &quot;index&quot;,\r\n    &quot;test2&quot;: &quot;fdsdfs&quot;,\r\n    &quot;test3&quot;: &quot;dfs0D0WOQAA3&quot;\r\n  },\r\n  {\r\n    &quot;test&quot;: &quot;index&quot;,\r\n    &quot;test2&quot;: &quot;fdsdfs&quot;,\r\n    &quot;test3&quot;: &quot;dfs0D0WOQAA3&quot;\r\n  },\r\n  {\r\n    &quot;test&quot;: &quot;index&quot;,\r\n    &quot;test2&quot;: &quot;fdsdfs&quot;,\r\n    &quot;test3&quot;: &quot;dfs0D0WOQAA3&quot;\r\n  }\r\n]\r\n```\r\n\r\nAnd to wrap each single item in an array and all arrays in a top-level array:\r\n\r\n```\r\njq &#39;map([.])&#39; file.json\r\n```\r\n\r\nOutput:\r\n\r\n```json\r\n[\r\n  [\r\n    {\r\n      &quot;test&quot;: &quot;index&quot;,\r\n      &quot;test2&quot;: &quot;fdsdfs&quot;,\r\n      &quot;test3&quot;: &quot;dfs0D0WOQAA3&quot;\r\n    }\r\n  ],\r\n  [\r\n    {\r\n      &quot;test&quot;: &quot;index&quot;,\r\n      &quot;test2&quot;: &quot;fdsdfs&quot;,\r\n      &quot;test3&quot;: &quot;dfs0D0WOQAA3&quot;\r\n    }\r\n  ],\r\n  [\r\n    {\r\n      &quot;test&quot;: &quot;index&quot;,\r\n      &quot;test2&quot;: &quot;fdsdfs&quot;,\r\n      &quot;test3&quot;: &quot;dfs0D0WOQAA3&quot;\r\n    }\r\n  ],\r\n  [\r\n    {\r\n      &quot;test&quot;: &quot;index&quot;,\r\n      &quot;test2&quot;: &quot;fdsdfs&quot;,\r\n      &quot;test3&quot;: &quot;dfs0D0WOQAA3&quot;\r\n    }\r\n  ]\r\n]\r\n```",
                "title": "jq add character before and after every row JSON"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1663858755,
                "creation_date": 1663858755,
                "answer_id": 73816848,
                "question_id": 73816279,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I assume you just forgot to put the commas in your otherwise valid JSON output, in which case you can find reasonable answers elsewhere on this page.\r\n\r\nIf not, and your desired output is accurate as shown, one way to solve it with jq is to read in the lines as raw text, prepend and append to certain lines as you see fit, and output again as raw text:\r\n~~~sh\r\njq -Rnr &#39;[inputs] | (first, .[]) |= &quot;[&quot; + . | (last, .[]) += &quot;]&quot; | .[]&#39;\r\n~~~\r\n~~~json\r\n[[{&quot;test&quot;:&quot;index&quot;,&quot;test2&quot;:&quot;fdsdfs&quot;,&quot;test3&quot;:&quot;dfs0D0WOQAA3&quot;}]\r\n[{&quot;test&quot;:&quot;index&quot;,&quot;test2&quot;:&quot;fdsdfs&quot;,&quot;test3&quot;:&quot;dfs0D0WOQAA3&quot;}]\r\n[{&quot;test&quot;:&quot;index&quot;,&quot;test2&quot;:&quot;fdsdfs&quot;,&quot;test3&quot;:&quot;dfs0D0WOQAA3&quot;}]\r\n[{&quot;test&quot;:&quot;index&quot;,&quot;test2&quot;:&quot;fdsdfs&quot;,&quot;test3&quot;:&quot;dfs0D0WOQAA3&quot;}]]\r\n~~~\r\n[Demo](https://jqplay.org/s/pqNTQTs8o6-)\r\n\r\nBut, to be fair, you actually don&#39;t need a JSON processor if it is just plain text being manipulated. Using `sed` or `awk` would be more reasonable choices here.",
                "title": "jq add character before and after every row JSON"
            }
        ],
        "is_answered": false,
        "answer_count": 3,
        "score": -2,
        "last_activity_date": 1663858755,
        "creation_date": 1663856406,
        "question_id": 73816279,
        "body_markdown": "I want print &quot;[]&quot; in every row with jq to make a big file json proof\r\n\r\nI have:\r\n\r\n    {&quot;test&quot;:&quot;index&quot;,&quot;test2&quot;:&quot;fdsdfs&quot;,&quot;test3&quot;:&quot;dfs0D0WOQAA3&quot;}\r\n    {&quot;test&quot;:&quot;index&quot;,&quot;test2&quot;:&quot;fdsdfs&quot;,&quot;test3&quot;:&quot;dfs0D0WOQAA3&quot;}\r\n    {&quot;test&quot;:&quot;index&quot;,&quot;test2&quot;:&quot;fdsdfs&quot;,&quot;test3&quot;:&quot;dfs0D0WOQAA3&quot;}\r\n    {&quot;test&quot;:&quot;index&quot;,&quot;test2&quot;:&quot;fdsdfs&quot;,&quot;test3&quot;:&quot;dfs0D0WOQAA3&quot;}\r\n\r\nWhat i want:\r\n\r\n    [[{&quot;test&quot;:&quot;index&quot;,&quot;test2&quot;:&quot;fdsdfs&quot;,&quot;test3&quot;:&quot;dfs0D0WOQAA3&quot;}]\r\n    [{&quot;test&quot;:&quot;index&quot;,&quot;test2&quot;:&quot;fdsdfs&quot;,&quot;test3&quot;:&quot;dfs0D0WOQAA3&quot;}]\r\n    [{&quot;test&quot;:&quot;index&quot;,&quot;test2&quot;:&quot;fdsdfs&quot;,&quot;test3&quot;:&quot;dfs0D0WOQAA3&quot;}]\r\n    [{&quot;test&quot;:&quot;index&quot;,&quot;test2&quot;:&quot;fdsdfs&quot;,&quot;test3&quot;:&quot;dfs0D0WOQAA3&quot;}]]\r\n\r\nNow i can push the json line by line to a program.\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/73816279/jq-add-character-before-and-after-every-row-json",
        "title": "jq add character before and after every row JSON"
    },
    {
        "tags": [
            "python",
            "json",
            "pandas",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 17012255,
                    "reputation": 317,
                    "user_id": 12306993,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/nCBZC.jpg?s=256",
                    "display_name": "Ahmet Burak",
                    "link": "https://stackoverflow.com/users/12306993/ahmet-burak"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1663867021,
                "post_id": 73818482,
                "comment_id": 130346060,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 155085,
                    "reputation": 1064,
                    "user_id": 371494,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d335c4d49a83448d2c9572976b92e153?s=256&d=identicon&r=PG",
                    "display_name": "Sean",
                    "link": "https://stackoverflow.com/users/371494/sean"
                },
                "reply_to_user": {
                    "account_id": 17012255,
                    "reputation": 317,
                    "user_id": 12306993,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/nCBZC.jpg?s=256",
                    "display_name": "Ahmet Burak",
                    "link": "https://stackoverflow.com/users/12306993/ahmet-burak"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1663867176,
                "post_id": 73818482,
                "comment_id": 130346120,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1663867142,
                "creation_date": 1663867142,
                "answer_id": 73818522,
                "question_id": 73818482,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "(not very elegant) Answer\r\n\r\n```Python\r\n&quot;&quot;&quot;\r\nRead a JSON file where the 1st item in array is a set of headers, and the other items are values.\r\nOutputs a JSON file where the other items in array are transposed to use those headers.\r\n&quot;&quot;&quot;\r\nimport json\r\nfrom sys import argv\r\n\r\ninput_json=argv[1]\r\noutput_json=argv[2]\r\n\r\ndata = None\r\nwith open(input_json, &quot;r&quot;) as infile:\r\n    # returns JSON object as a dictionary\r\n    data = json.load(infile)\r\n\r\nheadings = data[&quot;data&quot;][0][&#39;values&#39;]\r\n\r\nnew_rows = []\r\nrows = len(data[&quot;data&quot;])\r\nfor r in range(1, rows):\r\n    row = data[&quot;data&quot;][r][&#39;values&#39;]\r\n    new_row = dict()\r\n    new_rows.append(new_row)\r\n    for h in range(0, len(headings)):\r\n        new_row[headings[h]] = row[h]\r\n\r\nnew_data = dict()\r\nnew_data[&quot;data&quot;] = new_rows\r\n\r\nwith open(output_json, &quot;w&quot;) as outfile:\r\n    json_object = json.dumps(new_data, indent=2)\r\n    outfile.write(json_object)\r\n```\r\n\r\nHoping there is a better way with less code :)",
                "title": "How to transform a JSON file that has 1 &#39;header&#39; row followed by &#39;data&#39; rows? - (use jq?)"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1663867475,
                "creation_date": 1663867475,
                "answer_id": 73818580,
                "question_id": 73818482,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "A one liner:\r\n\r\n```\r\nd = {\r\n   &quot;data&quot; : [\r\n     { &quot;values&quot; : [ &quot;ColumnHeader1&quot;, &quot;ColumnHeader2&quot;, &quot;ColumnHeader3&quot; ]},\r\n     { &quot;values&quot; : [ &quot;Row1Column1&quot;, &quot;Row1Column2&quot;, &quot;Row1Column3&quot; ]},\r\n     { &quot;values&quot; : [ &quot;Row2Column1&quot;, &quot;Row2Column2&quot;, &quot;Row2Column3&quot; ]}\r\n  ]\r\n}\r\n\r\n\r\nd = {&quot;data&quot;: [{k: v for k, v in zip(d[&quot;data&quot;][0][&quot;values&quot;], row[&quot;values&quot;])} for row in d[&quot;data&quot;][1:]]}\r\n```\r\n\r\nOutputs:\r\n\r\n```\r\n{&#39;data&#39;: [{&#39;ColumnHeader1&#39;: &#39;Row1Column1&#39;, &#39;ColumnHeader2&#39;: &#39;Row1Column2&#39;, &#39;ColumnHeader3&#39;: &#39;Row1Column3&#39;}, {&#39;ColumnHeader1&#39;: &#39;Row2Column1&#39;, &#39;ColumnHeader2&#39;: &#39;Row2Column2&#39;, &#39;ColumnHeader3&#39;: &#39;Row2Column3&#39;}]}\r\n```",
                "title": "How to transform a JSON file that has 1 &#39;header&#39; row followed by &#39;data&#39; rows? - (use jq?)"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1663867722,
                "creation_date": 1663867722,
                "answer_id": 73818626,
                "question_id": 73818482,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You don&#39;t need to iterate all headings. I hope it helps.\r\n```python\r\ndata = {\r\n    &quot;data&quot;: [\r\n        {&quot;values&quot;: [&quot;ColumnHeader1&quot;, &quot;ColumnHeader2&quot;, &quot;ColumnHeader3&quot;]},\r\n        {&quot;values&quot;: [&quot;Row1Column1&quot;, &quot;Row1Column2&quot;, &quot;Row1Column3&quot;]},\r\n        {&quot;values&quot;: [&quot;Row2Column1&quot;, &quot;Row2Column2&quot;, &quot;Row2Column3&quot;]},\r\n    ]\r\n}\r\n\r\ndata = data[&quot;data&quot;]\r\nheadings = data[0][&quot;values&quot;]\r\nrows = data[1:]\r\nnew_data = {&quot;data&quot;:[dict(zip(headings, row[&quot;values&quot;])) for row in rows]}\r\n```",
                "title": "How to transform a JSON file that has 1 &#39;header&#39; row followed by &#39;data&#39; rows? - (use jq?)"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1663878064,
                "last_edit_date": 1663878064,
                "creation_date": 1663868294,
                "answer_id": 73818726,
                "question_id": 73818482,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s a solution for `jq` using `transpose` and `map`:\r\n~~~sh\r\n.data |= (map(.values) | transpose\r\n  | map([{(.[0]): .[1:][]}]) | transpose\r\n  | map(add)\r\n)\r\n~~~\r\n~~~json\r\n{\r\n  &quot;data&quot;: [\r\n    {\r\n      &quot;ColumnHeader1&quot;: &quot;Row1Column1&quot;,\r\n      &quot;ColumnHeader2&quot;: &quot;Row1Column2&quot;,\r\n      &quot;ColumnHeader3&quot;: &quot;Row1Column3&quot;\r\n    },\r\n    {\r\n      &quot;ColumnHeader1&quot;: &quot;Row2Column1&quot;,\r\n      &quot;ColumnHeader2&quot;: &quot;Row2Column2&quot;,\r\n      &quot;ColumnHeader3&quot;: &quot;Row2Column3&quot;\r\n    }\r\n  ]\r\n}\r\n~~~\r\n[Demo](https://jqplay.org/s/GLJDLGzDfE4)",
                "title": "How to transform a JSON file that has 1 &#39;header&#39; row followed by &#39;data&#39; rows? - (use jq?)"
            },
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1663870233,
                "last_edit_date": 1663870233,
                "creation_date": 1663868545,
                "answer_id": 73818779,
                "question_id": 73818482,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "A jq-only solution:\r\n```\r\ndef objectify($header): \r\n  . as $in\r\n  | reduce range(0; $header|length) as $i ({}; .[$header[$i]] = $in[$i] );\r\n\r\n.data[0].values as $header\r\n| .data |= (.[1:] | map(.values | objectify($header)) )\r\n```\r\n\r\n---\r\nIf you like nifty:\r\n```\r\ndef objectify($header): with_entries(.key |= $header[.]) ;\r\n```\r\n\r\nSo, if you want a two-liner:\r\n```\r\n.data[0].values as $header\r\n| .data |= (.[1:] | map(.values | with_entries(.key |= $header[.])))\r\n```\r\n\r\n",
                "title": "How to transform a JSON file that has 1 &#39;header&#39; row followed by &#39;data&#39; rows? - (use jq?)"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1663871527,
                "last_edit_date": 1663871527,
                "creation_date": 1663871157,
                "answer_id": 73819190,
                "question_id": 73818482,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here is a different jq solution without `reduce`:\r\n\r\n```\r\n.data |= (\r\n  map(.values)\r\n  | first as $headers | del(first)\r\n  | map(\r\n    [ $headers, .]\r\n    | transpose\r\n    | map({(first): last})\r\n    | add\r\n  )\r\n)\r\n```\r\n\r\nOutput:\r\n\r\n```json\r\n{\r\n  &quot;data&quot;: [\r\n    {\r\n      &quot;ColumnHeader1&quot;: &quot;Row1Column1&quot;,\r\n      &quot;ColumnHeader2&quot;: &quot;Row1Column2&quot;,\r\n      &quot;ColumnHeader3&quot;: &quot;Row1Column3&quot;\r\n    },\r\n    {\r\n      &quot;ColumnHeader1&quot;: &quot;Row2Column1&quot;,\r\n      &quot;ColumnHeader2&quot;: &quot;Row2Column2&quot;,\r\n      &quot;ColumnHeader3&quot;: &quot;Row2Column3&quot;\r\n    }\r\n  ]\r\n}\r\n```\r\n\r\nOr to rebuild the result object from scratch:\r\n\r\n```\r\n{\r\n  data: (\r\n    .data | map(.values)\r\n    | first as $headers | del(first) \r\n    | map(\r\n      [ $headers, .]\r\n      | transpose\r\n      | map({(first): last})\r\n      | add\r\n    )\r\n  )\r\n}\r\n```\r\n\r\n`first as $headers` could be rewritten as `. as [$headers]` or `.[0] as $headers`. `del(first)` could be replaced with `.[1:]`.",
                "title": "How to transform a JSON file that has 1 &#39;header&#39; row followed by &#39;data&#39; rows? - (use jq?)"
            }
        ],
        "is_answered": true,
        "answer_count": 6,
        "score": 0,
        "last_activity_date": 1663878064,
        "creation_date": 1663866928,
        "last_edit_date": 1663867027,
        "question_id": 73818482,
        "body_markdown": "I have a JSON file, like this:\r\n\r\n```JSON\r\n{\r\n   &quot;data&quot; : [\r\n     { &quot;values&quot; : [ &quot;ColumnHeader1&quot;, &quot;ColumnHeader2&quot;, &quot;ColumnHeader3&quot; ]},\r\n     { &quot;values&quot; : [ &quot;Row1Column1&quot;, &quot;Row1Column2&quot;, &quot;Row1Column3&quot; ]},\r\n     { &quot;values&quot; : [ &quot;Row2Column1&quot;, &quot;Row2Column2&quot;, &quot;Row2Column3&quot; ]}\r\n  ]\r\n}\r\n```\r\n\r\nI want to transform it, to be like this:\r\n\r\n```JSON\r\n{\r\n   data: [\r\n     { &quot;ColumnHeader1&quot; : &quot;Row1Value1&quot;, &quot;ColumnHeader2&quot;: &quot;Row1Value2&quot;, &quot;ColumnHeader3&quot; : &quot;Row1Value3&quot; },\r\n     { &quot;ColumnHeader1&quot; : &quot;Row2Value1&quot;, &quot;ColumnHeader2&quot;: &quot;Row2Value2&quot;, &quot;ColumnHeader3&quot; : &quot;Row2Value3&quot; }\r\n  ]\r\n}\r\n```\r\n\r\nI did write a Python script for that - but I wonder could something clever be done via `jq` or `pandas` ? (or some other Unix tool or Python library...)\r\n",
        "link": "https://stackoverflow.com/questions/73818482/how-to-transform-a-json-file-that-has-1-header-row-followed-by-data-rows",
        "title": "How to transform a JSON file that has 1 &#39;header&#39; row followed by &#39;data&#39; rows? - (use jq?)"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1740697242,
                "last_edit_date": 1740697242,
                "creation_date": 1663878525,
                "answer_id": 73820333,
                "question_id": 73820269,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "To remove a single character (or any given number of characters) from the end of a string that somewhere also `contains` the literal string `&quot;test&quot;`, `select` it and replace it with a substring that ends before the (nth to) last character, i.e. at the corresponding negative index, here `|= .[:-1]`:\r\n```sh\r\njq &#39;(.HostedZones[].Name | select(contains(&quot;test&quot;))) |= .[:-1]&#39;\r\n```\r\n[Demo](https://play.jqlang.org/s/18qvF1VqkcIhDRj)\r\n\r\n---\r\n\r\nTo additionally only remove the last character if itself is a dot, or more generally any well-defined substring in final position, either `sub`stitute it with the empty string `&quot;&quot;` by matching against a regex pattern, e.g. `[.]$` for a final dot, or use the dedicated `rtrimstr` function by providing the literal substring, `&quot;.&quot;` in this case:\r\n~~~sh\r\njq &#39;(.HostedZones[].Name | select(contains(&quot;test&quot;))) |= sub(&quot;[.]$&quot;; &quot;&quot;)&#39;\r\n# or\r\njq &#39;(.HostedZones[].Name | select(contains(&quot;test&quot;))) |= rtrimstr(&quot;.&quot;)&#39;\r\n~~~\r\n[Demo](https://play.jqlang.org/s/XDQFXpOZfigRDi6) or [Demo](https://play.jqlang.org/s/XIArcfMKi0fmx5R)\r\n",
                "title": "Remove last character from json output using JQ"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1740697242,
        "creation_date": 1663878128,
        "question_id": 73820269,
        "body_markdown": "I have a json that looks like this:\r\n\r\n    { \r\n      &quot;HostedZones&quot;: [\r\n          {\r\n              &quot;ResourceRecordSetCount&quot;: 2,\r\n              &quot;CallerReference&quot;: &quot;test20150527-2&quot;,\r\n              &quot;Config&quot;: {\r\n                  &quot;Comment&quot;: &quot;test2&quot;,\r\n                  &quot;PrivateZone&quot;: true\r\n              },\r\n              &quot;Id&quot;: &quot;/hostedzone/Z119WBBTVP5WFX&quot;,\r\n              &quot;Name&quot;: &quot;dev.devx.company.services.&quot;\r\n          },\r\n          {\r\n              &quot;ResourceRecordSetCount&quot;: 2,\r\n              &quot;CallerReference&quot;: &quot;test20150527-1&quot;,\r\n              &quot;Config&quot;: {\r\n                  &quot;Comment&quot;: &quot;test&quot;,\r\n                  &quot;PrivateZone&quot;: true\r\n              },\r\n              &quot;Id&quot;: &quot;/hostedzone/Z3P5QSUBK4POTI&quot;,\r\n              &quot;Name&quot;: &quot;test.devx.company.services.&quot;\r\n          }\r\n      ],\r\n      &quot;IsTruncated&quot;: false,\r\n      &quot;MaxItems&quot;: &quot;100&quot;\r\n    }\r\n\r\nAnd my goal is to fetch a specific `Name` (in my case it&#39;s the `test.devx.company.services`), however the `Name` field contains an extra &quot;`.`&quot; at the end that I&#39;d like to remove from the output.\r\n\r\nThis is what I have so far:\r\n\r\n`jq --raw-output &#39;.HostedZones[] | select(.Name | test(&quot;test&quot;)?) | (.Name[:-1] | sub(&quot;.&quot;; &quot;&quot;))&#39;`\r\n\r\nThe problem with that it is removing the first character from the output also.\r\n\r\nSo the output currently is: `est.devx.company.services` ([JQ play snippet][1])\r\n\r\nNot sure what I&#39;m doing wrong :/\r\n\r\n  [1]: https://jqplay.org/s/W3PCQ6C9Z-s",
        "link": "https://stackoverflow.com/questions/73820269/remove-last-character-from-json-output-using-jq",
        "title": "Remove last character from json output using JQ"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1663906973,
                "creation_date": 1663906973,
                "answer_id": 73822958,
                "question_id": 73822884,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Try this:\r\n\r\n    jq -s &#39; [ (.[0] | keys[]) as $k | reduce .[] as $item (null; .[$k] += $item[$k]) ] | add&#39; report1.json report2.json\r\n\r\n[![enter image description here][1]][1]\r\n\r\n\r\n  [1]: https://i.sstatic.net/FX1Ez.png",
                "title": "Join the 2 json report using jq"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1663915202,
                "creation_date": 1663915202,
                "answer_id": 73823845,
                "question_id": 73822884,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Take the first input (automatically in context), and operarte on all subsequent objects using `inputs` (without the `-n` option). Then, simply add up all items you care about:\r\n~~~sh\r\njq &#39;.examples += [inputs.examples[]]&#39; report*.json \r\n~~~\r\n~~~json\r\n{\r\n  &quot;examples&quot;: [\r\n    {\r\n      &quot;description&quot;: &quot;desc 1&quot;,\r\n      &quot;full_description&quot;: &quot;full_description 1&quot;,\r\n      &quot;status&quot;: &quot;status 1&quot;,\r\n      &quot;file_path&quot;: &quot;file_path 1&quot;,\r\n      &quot;run_time&quot;: 0.01\r\n    },\r\n    {\r\n      &quot;description&quot;: &quot;desc 2&quot;,\r\n      &quot;full_description&quot;: &quot;full_description 2&quot;,\r\n      &quot;status&quot;: &quot;status 2&quot;,\r\n      &quot;file_path&quot;: &quot;file_path 2&quot;,\r\n      &quot;run_time&quot;: 0.02\r\n    }\r\n  ]\r\n}\r\n~~~\r\n[Demo](https://jqplay.org/s/Y79KfOMkW0-)\r\n",
                "title": "Join the 2 json report using jq"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1663921586,
                "creation_date": 1663921586,
                "answer_id": 73824963,
                "question_id": 73822884,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If the point of the question is that you don&#39;t know the name of the top-level key, then perhaps the following is close to what you want:\r\n```\r\njq -n &#39;\r\n [inputs | to_entries] | add | {(first.key): (map(.value) | add) }\r\n&#39; report{1,2}.json\r\n```\r\n",
                "title": "Join the 2 json report using jq"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1664173433,
                "creation_date": 1664173433,
                "answer_id": 73850261,
                "question_id": 73822884,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s a very simple and straightforward solution using slurp (reads whole file into memory):\r\n\r\n```\r\njq -s &#39;{examples: map(.examples[])}&#39; report1.json report2.json\r\n```",
                "title": "Join the 2 json report using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 4,
        "score": 0,
        "last_activity_date": 1664173433,
        "creation_date": 1663906024,
        "last_edit_date": 1663908038,
        "question_id": 73822884,
        "body_markdown": "I have 2 report files like the following\r\n\r\nreport1.json\r\n```\r\n{\r\n  &quot;examples&quot;: [\r\n    {\r\n      &quot;description&quot;: &quot;desc 1&quot;,\r\n      &quot;full_description&quot;: &quot;full_description 1&quot;,\r\n      &quot;status&quot;: &quot;status 1&quot;,\r\n      &quot;file_path&quot;: &quot;file_path 1&quot;,\r\n      &quot;run_time&quot;: 0.01\r\n    }\r\n  ]\r\n}\r\n```\r\n\r\nand report2.json\r\n```\r\n{\r\n  &quot;examples&quot;: [\r\n    {\r\n      &quot;description&quot;: &quot;desc 2&quot;,\r\n      &quot;full_description&quot;: &quot;full_description 2&quot;,\r\n      &quot;status&quot;: &quot;status 2&quot;,\r\n      &quot;file_path&quot;: &quot;file_path 2&quot;,\r\n      &quot;run_time&quot;: 0.02\r\n    }\r\n  ]\r\n}\r\n```\r\nI want to combine it using jq command with hope the end result is as follows\r\n```\r\n{\r\n  &quot;examples&quot;: [\r\n    {\r\n      &quot;description&quot;: &quot;desc 1&quot;,\r\n      &quot;full_description&quot;: &quot;full_description 1&quot;,\r\n      &quot;status&quot;: &quot;status 1&quot;,\r\n      &quot;file_path&quot;: &quot;file_path 1&quot;,\r\n      &quot;run_time&quot;: 0.01\r\n    },\r\n    {\r\n      &quot;description&quot;: &quot;desc 2&quot;,\r\n      &quot;full_description&quot;: &quot;full_description 2&quot;,\r\n      &quot;status&quot;: &quot;status 2&quot;,\r\n      &quot;file_path&quot;: &quot;file_path 2&quot;,\r\n      &quot;run_time&quot;: 0.02\r\n    }\r\n  ]\r\n}\r\n```\r\ni have tried using this script jq -s &#39;.[0] * .[1]&#39; report1.json report2.json but it doesn&#39;t work, is there any solution to be able to combine according to my expected result using jq command ?",
        "link": "https://stackoverflow.com/questions/73822884/join-the-2-json-report-using-jq",
        "title": "Join the 2 json report using jq"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1663914295,
                "post_id": 73823479,
                "comment_id": 130355415,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1663913099,
                "creation_date": 1663913099,
                "answer_id": 73823596,
                "question_id": 73823479,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "One way could be using `reduce` on subsequent `inputs`:\r\n~~~sh\r\njq &#39;reduce inputs.attributes as $a (.attributes; . + $a) | keys&#39;\r\n~~~\r\n~~~\r\n[\r\n  &quot;a&quot;,\r\n  &quot;b&quot;,\r\n  &quot;c&quot;,\r\n  &quot;d&quot;\r\n]\r\n~~~\r\n[Demo](https://jqplay.org/s/v-bat97apVr)",
                "title": "Get unique nested JSON keys with JQ"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1663918565,
                "creation_date": 1663918565,
                "answer_id": 73824418,
                "question_id": 73823479,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Along the lines of your second attempt:\r\n```\r\njq -n &#39;[inputs.attributes // empty | keys_unsorted[]] | unique&#39;\r\n```\r\n\r\nThe important point is that we have to take care of the case where there is no &quot;attributes&quot; key.\r\n\r\nNote also that `unique` sorts, so (unless you&#39;re using gojq) we can use `keys_unsorted` to avoid redundant sorting.",
                "title": "Get unique nested JSON keys with JQ"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1664102143,
                "last_edit_date": 1664102143,
                "creation_date": 1664054099,
                "answer_id": 73840620,
                "question_id": 73823479,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "With slurp:\r\n\r\n```\r\njq -s &#39;map(.attributes|keys?)|add|unique&#39; test.json\r\n```\r\n\r\n* `-s` loads the input file as array\r\n* `map(.attributes|keys?)` extracts only the keys (ignoring errors, such as trying to get keys of null)\r\n* `add` merges all nested arrays into a single array (`[[1,2],[2,3]]` becomes `[1,2,2,3]`)\r\n* `unique` sorts and removes duplicates",
                "title": "Get unique nested JSON keys with JQ"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 0,
        "last_activity_date": 1664102143,
        "creation_date": 1663912031,
        "last_edit_date": 1663913395,
        "question_id": 73823479,
        "body_markdown": "How to get the unique keys from attributes key with JQ\r\n\r\n    {&quot;id&quot;:1, &quot;attributes&quot;:{&quot;a&quot;: 1, &quot;b&quot;: 2, &quot;c&quot;: 3}}\r\n    {&quot;id&quot;:2, &quot;attributes&quot;:{&quot;a&quot;: 4, &quot;b&quot;: 5, &quot;d&quot;: 6}}\r\n    {&quot;id&quot;:3, &quot;name&quot;:&quot;ABC&quot;}\r\n   \r\nResult like this\r\n[\r\n  &quot;a&quot;,\r\n  &quot;b&quot;,\r\n  &quot;c&quot;,\r\n  &quot;d&quot;\r\n]\r\n\r\nI&#39;m try like this \r\n\r\n    jq &#39;.attributes&#39; test.json | jq -r &#39;[inputs | keys[]] | unique | sort&#39;\r\nor\r\n\r\n    jq -r &#39;[inputs.attributes | keys[]] | unique | sort&#39; test.json\r\n\r\nbut getting error\r\n\r\n**jq: error (at &lt;stdin&gt;:11): null (null) has no keys**",
        "link": "https://stackoverflow.com/questions/73823479/get-unique-nested-json-keys-with-jq",
        "title": "Get unique nested JSON keys with JQ"
    },
    {
        "tags": [
            "json",
            "linux",
            "csv",
            "command-line",
            "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": 1663926136,
                "post_id": 73825788,
                "comment_id": 130359098,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 6196394,
                    "reputation": 86601,
                    "user_id": 5291015,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/4tAvO.jpg?s=256",
                    "display_name": "Inian",
                    "link": "https://stackoverflow.com/users/5291015/inian"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1663926138,
                "post_id": 73825788,
                "comment_id": 130359099,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 21936534,
                    "reputation": 13,
                    "user_id": 16217680,
                    "user_type": "registered",
                    "profile_image": "https://lh3.googleusercontent.com/a/AATXAJyzXVnOTP6WAIX65RJdu81jGK_MOklFsK9XvT_D=k-s256",
                    "display_name": "Laurent Felix",
                    "link": "https://stackoverflow.com/users/16217680/laurent-felix"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1663928267,
                "post_id": 73825788,
                "comment_id": 130359774,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1663926937,
                "creation_date": 1663926937,
                "answer_id": 73825976,
                "question_id": 73825788,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "There is no cannonical way to read in CSV as the format is not standardized. Existing usages mostly differ in the field separator and the escape sequence (used if either one happens to be part of the data), which you would have to consider explicitly when reading in raw text manually.\r\n\r\nTherefore, I regard it as safer to follow your second approach. Here&#39;s one way for the given input:\r\n~~~json\r\n[\r\n    {\r\n        &quot;id&quot;: &quot;1&quot;,\r\n        &quot;age&quot;: &quot;39&quot;,\r\n        &quot;gender&quot;: &quot;M&quot;\r\n    },\r\n    {\r\n        &quot;id&quot;: &quot;2&quot;,\r\n        &quot;age&quot;: &quot;25&quot;,\r\n        &quot;gender&quot;: &quot;M&quot;\r\n    }\r\n]\r\n~~~\r\n~~~sh\r\njq &#39;map(to_entries) | transpose | map({(first.key): map(.value)}) | add&#39;\r\n~~~\r\n~~~json\r\n{\r\n  &quot;id&quot;: [\r\n    &quot;1&quot;,\r\n    &quot;2&quot;\r\n  ],\r\n  &quot;age&quot;: [\r\n    &quot;39&quot;,\r\n    &quot;25&quot;\r\n  ],\r\n  &quot;gender&quot;: [\r\n    &quot;M&quot;,\r\n    &quot;M&quot;\r\n  ]\r\n}\r\n~~~\r\n[Demo](https://jqplay.org/s/iHYGijtHtXK)",
                "title": "csv to json or json format as column array command line"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1663926937,
        "creation_date": 1663925926,
        "question_id": 73825788,
        "body_markdown": "is it possible to obtain this output ?\r\nWith a command line tool (jq or other)\r\n\r\n\r\n\r\nFrom csv\r\n``` csv\r\nid,age,gender\r\n1,39,M\r\n2,25,M\r\n```\r\nTo json column array\r\n\r\n``` json\r\n[{&quot;id&quot;:[&quot;1&quot;,&quot;2&quot;]},{&quot;age&quot;:[&quot;39&quot;,&quot;25&quot;]},{&quot;gender&quot;:[&quot;M&quot;,&quot;M&quot;]}]\r\n```\r\n\r\nOR from json\r\n\r\n``` json\r\n[\r\n    {\r\n        &quot;id&quot;: &quot;1&quot;,\r\n        &quot;age&quot;: &quot;39&quot;,\r\n        &quot;gender&quot;: &quot;M&quot;\r\n    },\r\n    {\r\n        &quot;id&quot;: &quot;2&quot;,\r\n        &quot;age&quot;: &quot;25&quot;,\r\n        &quot;gender&quot;: &quot;M&quot;\r\n    }\r\n]\r\n```\r\nTo json column array\r\n``` json\r\n[{&quot;id&quot;:[&quot;1&quot;,&quot;2&quot;]},{&quot;age&quot;:[&quot;39&quot;,&quot;25&quot;]},{&quot;gender&quot;:[&quot;M&quot;,&quot;M&quot;]}]\r\n```\r\n\r\nHoping you understood me. Thank you in advance for your answers.",
        "link": "https://stackoverflow.com/questions/73825788/csv-to-json-or-json-format-as-column-array-command-line",
        "title": "csv to json or json format as column array command line"
    },
    {
        "tags": [
            "performance",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1664172259,
                "last_edit_date": 1664172259,
                "creation_date": 1664109356,
                "answer_id": 73844515,
                "question_id": 73843868,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Those first three programs are equivalent, both functionally and in terms of resource utilization, but they obscure the difference between array-oriented and stream-oriented programming. \r\n\r\nIn a nutshell, think `sed` and `awk`. For more details, see e.g. my [A Stream-oriented Introduction to jq][1], and i.p. the section [On the importance of `inputs`][2].\r\n\r\n---\r\n&gt; Bonus points: does the same hold true for the following programs:\r\n\r\nReferring to the last four numbered examples in the Q: (4), (5) and (7) are essentially equivalent; (6) is just silly.\r\n\r\n---\r\nIf you&#39;re looking for a reason why all these variations exist, please bear in mind that `input` and `inputs` were late additions in the development of jq.  Perhaps they were late additions because jq was originally envisioned as a very simple and for the most part &quot;purely functional&quot; language.  \r\n\r\n  [1]: https://github.com/pkoppstein/jq/wiki/A-Stream-oriented-Introduction-to-jq\r\n  [2]: https://github.com/pkoppstein/jq/wiki/A-Stream-oriented-Introduction-to-jq#on-the-importance-of-inputs",
                "title": "Difference between slurp, null input, and inputs filter"
            },
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1664171374,
                "last_edit_date": 1664171374,
                "creation_date": 1664129203,
                "answer_id": 73846754,
                "question_id": 73843868,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "With `jq &#39;-n [inputs] ....&#39;` and `jq &#39;[.,inputs] ....&#39;`, you are loading the whole file into memory.\r\n\r\nA more memory-efficient way to achieve the result as an array is:\r\n\r\n```\r\njq -n &#39;[inputs | to_entries[].value]&#39;\r\n```",
                "title": "Difference between slurp, null input, and inputs filter"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1667037906,
                "creation_date": 1667037906,
                "answer_id": 74244367,
                "question_id": 73843868,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Adding even more cases for the sake of completeness:\r\n\r\nFrom the [manual](https://stedolan.github.io/jq/manual/#Invokingjq):\r\n\r\n&gt; `--raw-input`/`-R`:\r\n&gt;\r\n&gt; Don&#39;t parse the input as JSON. Instead, each line of text is passed to the filter as a string. If combined with `--slurp`,  then  the  entire input is passed to the filter as a single long string.\r\n\r\nThis means that on one hand\r\n\r\n- `jq -R -n &#39;[inputs]&#39;` and\r\n- `jq -R &#39;[., inputs]&#39;`\r\n\r\nboth produce an array of strings, as each item provided by `inputs` (and `.` if it wasn&#39;t silenced by `-n`) corresponds to a line of text from the input document(s), whereas on the other hand\r\n\r\n- `jq -R -s &#39;.&#39;`\r\n\r\nslurps all characters from the input document(s) into exactly one long string, newlines included.",
                "title": "Difference between slurp, null input, and inputs filter"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 4,
        "last_activity_date": 1667037906,
        "creation_date": 1664102655,
        "last_edit_date": 1664172235,
        "question_id": 73843868,
        "body_markdown": "Given the input document:\r\n\r\n```json\r\n{&quot;a&quot;:1}\r\n{&quot;b&quot;:2}\r\n{&quot;c&quot;:3,&quot;d&quot;:4}\r\n```\r\n\r\nWhat is the difference between the following jq programs (if any)? They all seem to produce the same output.\r\n\r\n1. `jq &#39;[., inputs] | map(to_entries[].value)&#39;`\r\n2. `jq -n &#39;[inputs] | map(to_entries[].value)&#39;`\r\n3. `jq -s &#39;map(to_entries[].value)&#39;`\r\n\r\nIn other words, the following (simplified/reduced) invocations seem identical: \r\n\r\n - `jq &#39;[.,inputs]&#39;`\r\n - `jq -n &#39;[inputs]&#39;`\r\n - `jq -s &#39;.&#39;`.\r\n\r\nHow are they different? Are there scenarios where one works, but the others don&#39;t? Did older versions of jq not support all of them? Is it performance related? Or simply a matter of readability and personal preference?\r\n\r\n*****\r\n\r\nBonus points (added later to the question): does the same hold true for the following programs?\r\n\r\n4. `jq &#39;., inputs | to_entries[].value&#39;`\r\n5. `jq -n &#39;inputs | to_entries[].value&#39;`\r\n6. `jq -s &#39;.[] | to_entries[].value&#39;`\r\n7. `jq &#39;to_entries[].value&#39;`",
        "link": "https://stackoverflow.com/questions/73843868/difference-between-slurp-null-input-and-inputs-filter",
        "title": "Difference between slurp, null input, and inputs filter"
    },
    {
        "tags": [
            "bash",
            "shell",
            "yaml",
            "jq",
            "yq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1664132308,
                "creation_date": 1664132308,
                "answer_id": 73847119,
                "question_id": 73847027,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "As you have tagged `jq`, I assume you are looking for a solution using [kislyuk/yq](https://github.com/kislyuk/yq). Here&#39;s one using `input` for the second file:\r\n~~~sh\r\nyq -y &#39;\r\n  .default.app.&quot;service-v1&quot;.country.list = input.app.&quot;list-data&quot;\r\n&#39; file1.yaml file2.yaml\r\n~~~\r\n~~~json\r\ndefault:\r\n  app:\r\n    service-v1:\r\n      country:\r\n        list:\r\n          - key1: value\r\n            key2: value\r\n            key3:\r\n              - list1\r\n              - list2\r\n              - list3\r\n          - key4: value\r\n            key5: value\r\n            key6:\r\n              - list1\r\n              - list2\r\n              - list3\r\n~~~\r\n\r\n---\r\nFor a solution using [mikefarah/yq](https://github.com/mikefarah/yq), you could use `load` to read the second file.\r\n~~~sh\r\nyq &#39;\r\n  .default.app.&quot;service-v1&quot;.country.list = load(&quot;file2.yaml&quot;).app.&quot;list-data&quot;\r\n&#39; file1.yaml\r\n~~~\r\n~~~json\r\ndefault:\r\n  app:\r\n    service-v1:\r\n      country:\r\n        list:\r\n          - key1: value\r\n            key2: value\r\n            key3:\r\n              - list1\r\n              - list2\r\n              - list3\r\n          - key4: value\r\n            key5: value\r\n            key6:\r\n              - list1\r\n              - list2\r\n              - list3\r\n~~~\r\nNote: With this implementation of yq, you can also use the `-i` flag to modify `file1.yaml` in-place.",
                "title": "Replace list of data from one file YAML to another file preserving the format(indentation)"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1664135865,
        "creation_date": 1664131485,
        "last_edit_date": 1664135865,
        "question_id": 73847027,
        "body_markdown": "I have a below `YAML` file called file1.yaml\r\n```  \r\ndefault:\r\n  app:\r\n    service-v1:\r\n      country:\r\n        list: LIST_TO_REPLACE \r\n```\r\n\r\nI am trying to replace **LIST_TO_REPLACE** text with the below `YAML` file list data.\r\n\r\n**file2.yml**\r\n```\r\napp:\r\n  list-data: // Need to extract this node data and replace in the file1.yml\r\n    - key1: value\r\n      key2: value\r\n      key3: \r\n        - list1\r\n        - list2\r\n        - list3\r\n    - key4: value\r\n      key5: value\r\n      key6: \r\n        - list1\r\n        - list2\r\n        - list3\r\n ```\r\n\r\nI am using `YQ` to replace the list of data from **file2** to **file1**. But it is not correctly indented in **file1**.\r\n\r\nIs there any way to replace the entire node and it could follow the indentation of **file1**? \r\n\r\n\r\n\r\n**Expected Output:**\r\n```  \r\ndefault:\r\n  app:\r\n    service-v1:\r\n      country:\r\n        list: //After replace operation\r\n          - key1: value\r\n            key2: value\r\n            key3: \r\n          - list1\r\n          - list2\r\n          - list3\r\n          - key4: value\r\n            key5: value\r\n            key6: \r\n          - list1\r\n          - list2\r\n          - list3 \r\n```\r\n",
        "link": "https://stackoverflow.com/questions/73847027/replace-list-of-data-from-one-file-yaml-to-another-file-preserving-the-formatin",
        "title": "Replace list of data from one file YAML to another file preserving the format(indentation)"
    },
    {
        "tags": [
            "json",
            "ansible",
            "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": 1664273260,
                "post_id": 73865690,
                "comment_id": 130428256,
                "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": 1664273302,
                "post_id": 73865690,
                "comment_id": 130428274,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 10543002,
                    "reputation": 1439,
                    "user_id": 7768287,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/ySIAC.png?s=256",
                    "display_name": "Tiya Jose",
                    "link": "https://stackoverflow.com/users/7768287/tiya-jose"
                },
                "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": 1664273788,
                "post_id": 73865690,
                "comment_id": 130428434,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 39208,
                    "reputation": 267964,
                    "user_id": 112968,
                    "user_type": "registered",
                    "accept_rate": 68,
                    "profile_image": "https://i.sstatic.net/zHTaT.png?s=256",
                    "display_name": "knittl",
                    "link": "https://stackoverflow.com/users/112968/knittl"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1664275680,
                "post_id": 73865690,
                "comment_id": 130429074,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1664335288,
                "last_edit_date": 1664335288,
                "creation_date": 1664284415,
                "answer_id": 73868211,
                "question_id": 73865690,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Error seems to be jq complaining about the JSON passed to it. As mentioned by \r\n@knittl the json printed in error message isn&#39;t valid JSON. \r\nSomehow double quotes were replaced by single quote although debug prints valid JSON. Invalid JSON was passed to jq.\r\n\r\nReplacing the single quote with double quote solved the issue.\r\n\r\n```\r\nshell: echo &quot;{{ data | to_json }}&quot;| jq &#39;to_entries | map((.key) + &quot;=&quot; + .value)|join(&quot;,&quot;)&#39;\r\n```\r\n\r\nor \r\n\r\n```\r\nshell: echo &quot;{{ data }}&quot; | sed &quot;s/&#39;/\\&quot;/g&quot; | jq &#39;to_entries | map((.key) + &quot;=&quot; + .value)|join(&quot;,&quot;)&#39;\r\n```\r\n\r\n\r\nPS: This is just a working solution not the ideal one!",
                "title": "How can I pass a json variable set by set_fact to jq pipeline in ansible shell task?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1664335288,
        "creation_date": 1664272750,
        "last_edit_date": 1664273845,
        "question_id": 73865690,
        "body_markdown": "I have a ansible playbook that has set a json variable using ```set_fact``` module. \r\nI&#39;m trying to use jq command in ansible playbook, to transform that json to a particular format, but got parse error: ```Invalid numeric literal at line , column```\r\n\r\nMy Playbook:\r\n```\r\n- name: get data\r\n  set_fact:\r\n    data: &quot;{{ value.stdout | from_json }}&quot;\r\n\r\n- name: get key value pairs\r\n  shell:  echo &quot;{{ data }}&quot; | jq &#39;to_entries | map((.key) + &quot;=&quot; + .value)|join(&quot;,&quot;)&#39;\r\n  register: key_value\r\n```\r\n\r\nError:\r\n```\r\nTASK [utils : debug] *************************************************************************************\r\nok: [localhost] =&gt; {\r\n    &quot;data&quot;: {\r\n        &quot;key1&quot;: &quot;keyval1&quot;,\r\n        &quot;key2&quot;: &quot;keyval2&quot;\r\n    }\r\n}\r\n\r\nTASK [utils : get key value pairs] ***************************************************************\r\nFAILED! =&gt; {&quot;changed&quot;: true, &quot;cmd&quot;: &quot;echo \\&quot;{&#39;key1&#39;: &#39;keyval1&#39;, &#39;key2&#39;: &#39;keyval2&#39;}\\&quot; | jq &#39;to_entries | map((.key) + \\&quot;=\\&quot; + .value)|join(\\&quot;,\\&quot;)&#39;&quot;, &quot;stderr&quot;: &quot;parse error: Invalid numeric literal at line , column&quot;, &quot;stderr_lines&quot;: [&quot;parse error: Invalid numeric literal at line , column&quot;], &quot;stdout&quot;: &quot;&quot;, &quot;stdout_lines&quot;: []}\r\n```\r\nPS: I had tried using &gt; YAML construct specified in https://stackoverflow.com/questions/64045520/how-to-use-jq-in-ansible-shell-tasks/64057402#64057402 but got same error\r\n\r\n```\r\n- name: get key value pairs\r\n  shell:  &gt;\r\n     echo &quot;{{ data }}&quot; \r\n     | jq &#39;to_entries | map((.key) + &quot;=&quot; + .value)|join(&quot;,&quot;)&#39;\r\n  register: key_value\r\n```\r\n\r\nMy ```data``` variable set using ```set_fact``` module:\r\n```\r\n&quot;data&quot;: {\r\n        &quot;key1&quot;: &quot;keyval1&quot;,\r\n        &quot;key2&quot;: &quot;keyval2&quot;\r\n}\r\n```\r\n\r\nWorking jq command and expected output: [jqPlay][1]\r\n\r\nHow can I pass the fact variable set using ```set_fact``` to jq pipeline in ansible?\r\n\r\n  [1]: https://jqplay.org/s/x6hnhPBQUmf",
        "link": "https://stackoverflow.com/questions/73865690/how-can-i-pass-a-json-variable-set-by-set-fact-to-jq-pipeline-in-ansible-shell-t",
        "title": "How can I pass a json variable set by set_fact to jq pipeline in ansible shell task?"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1664289943,
                "last_edit_date": 1664289943,
                "creation_date": 1664274133,
                "answer_id": 73865990,
                "question_id": 73865840,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Give `max_by` a try.\r\n```sh\r\n.linux.amd64.&quot;jdk@adoptium-jre&quot;\r\n| to_entries\r\n| map(select(.key | startswith(&quot;1.17.&quot;)))\r\n| max_by(.key)\r\n| .value\r\n```",
                "title": "Get the latest version release field from a JSON response"
            },
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1664281632,
                "last_edit_date": 1664281632,
                "creation_date": 1664274174,
                "answer_id": 73866001,
                "question_id": 73865840,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Instead of getting the version fields alone, you could get the key/value pair as part of applying the regex and then do a `sort_by` on the version field. Remember to escape the `.` character to be treated as a literal, or use `startswith(&quot;1.17.&quot;)`\r\n\r\n```sh\r\n.linux.amd64.&quot;jdk@adoptium-jre&quot; \r\n| to_entries \r\n| map(select(.key | test(&quot;1\\\\.17\\\\.[0-9]+\\\\.[0-9]+$&quot;))) \r\n| sort_by(.key | split(&quot;.&quot;) | map(tonumber)) \r\n| last.value\r\n```\r\n\r\nThe key part here is the `sort_by` expression that tells `jq` to split the version field to constituent strings and then convert to numbers, i.e. `map(tonumber)` and then perform sort operation on it. \r\n\r\nWith the operation, the list `[1, 17, 0, 4]` is expected to be the highest among the rest of the records. The `last` builtin picks up the last record in a list of elements.\r\n\r\njqplay [demo][1]\r\n\r\n\r\n  [1]: https://jqplay.org/s/HtdJhy4tnWa",
                "title": "Get the latest version release field from a JSON response"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 2,
        "last_activity_date": 1664702588,
        "creation_date": 1664273384,
        "last_edit_date": 1664702588,
        "question_id": 73865840,
        "body_markdown": "I want to automatically download latest LTS for AdoptiumJDK. So I found [a good list][1] to start with.\r\n\r\nI want to filter only stable Releases for 1.17, so I tried:\r\n```sh\r\ncurl -s https://raw.githubusercontent.com/coursier/jvm-index/master/index.json \r\n| jq -r &#39;.linux.amd64.&quot;jdk@adoptium-jre&quot; \r\n| to_entries[] \r\n| .[] \r\n| select(match(&quot;1.17.[0-9]+.[0-9]+$&quot;))&#39;\r\n```\r\ngives:\r\n\r\n&gt; ```\r\n&gt; 1.17.0.1\r\n&gt; 1.17.0.2\r\n&gt; 1.17.0.3\r\n&gt; 1.17.0.4\r\n&gt; ```\r\n\r\nbut I want the latest (highest number) release, and I want the URL of this release.\r\n```sh\r\ncurl -s https://raw.githubusercontent.com/coursier/jvm-index/master/index.json \r\n| jq -r &#39;.linux.amd64.&quot;jdk@adoptium-jre&quot; \r\n| to_entries[] \r\n| .[] \r\n| select(match(&quot;1.17.[0-9]+.[0-9]+$&quot;))&#39;   \r\n| sort -n \r\n| tail -1\r\n```\r\nbut thats not elegant, I have to parse this output via bash and do a new lookup.\r\n\r\nHow can I get the URL for the current newest release for 1.17 (should give `&quot;tgz+https://github.com/adoptium/temurin17-binaries/releases/download/jdk-17.0.4%2B8/OpenJDK17U-jre_x64_linux_hotspot_17.0.4_8.tar.gz&quot;`)\r\n\r\n  [1]: https://raw.githubusercontent.com/coursier/jvm-index/master/index.json\r\n\r\n",
        "link": "https://stackoverflow.com/questions/73865840/get-the-latest-version-release-field-from-a-json-response",
        "title": "Get the latest version release field from a JSON response"
    },
    {
        "tags": [
            "json",
            "bash",
            "shell",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 53124,
                    "reputation": 1802,
                    "user_id": 158787,
                    "user_type": "registered",
                    "accept_rate": 83,
                    "profile_image": "https://www.gravatar.com/avatar/bfe163077b96d47a0fcbe69c56bf5365?s=256&d=identicon&r=PG",
                    "display_name": "GoinOff",
                    "link": "https://stackoverflow.com/users/158787/goinoff"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1664289361,
                "post_id": 73869332,
                "comment_id": 130434425,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 46839,
                    "reputation": 16227,
                    "user_id": 138541,
                    "user_type": "registered",
                    "accept_rate": 97,
                    "profile_image": "https://www.gravatar.com/avatar/08a32b9ae44851b8984b17620d01b8d7?s=256&d=identicon&r=PG",
                    "display_name": "Mint",
                    "link": "https://stackoverflow.com/users/138541/mint"
                },
                "reply_to_user": {
                    "account_id": 53124,
                    "reputation": 1802,
                    "user_id": 158787,
                    "user_type": "registered",
                    "accept_rate": 83,
                    "profile_image": "https://www.gravatar.com/avatar/bfe163077b96d47a0fcbe69c56bf5365?s=256&d=identicon&r=PG",
                    "display_name": "GoinOff",
                    "link": "https://stackoverflow.com/users/158787/goinoff"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1664289869,
                "post_id": 73869332,
                "comment_id": 130434610,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1664290072,
                "creation_date": 1664290072,
                "answer_id": 73869569,
                "question_id": 73869332,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "This will give you `false` if all `strings` and `arrays` are `&quot;&quot;` or `[]`:\r\n~~~sh\r\njq -e &#39;all(.. | strings, arrays; IN(&quot;&quot;, [])) | not&#39;\r\n~~~\r\n[Demo](https://jqplay.org/s/OiOR4-CCosy)",
                "title": "Detect empty json values"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1664295849,
                "creation_date": 1664295849,
                "answer_id": 73870837,
                "question_id": 73869332,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "This might be a good use for [gron](https://github.com/tomnomnom/gron)\r\n```sh\r\njson=&#39;{\r\n  &quot;data&quot;: [],\r\n  &quot;pagination&quot;: {\r\n    &quot;cursor&quot;: &quot;&quot;,\r\n    &quot;position&quot;:[2,3]\r\n  }\r\n}&#39;\r\n```\r\ngron transforms the input JSON into discrete paths:\r\n```sh\r\n$ gron &lt;&lt;&lt; &quot;$json&quot;\r\njson = {};\r\njson.data = [];\r\njson.pagination = {};\r\njson.pagination.cursor = &quot;&quot;;\r\njson.pagination.position = [];\r\njson.pagination.position[0] = 2;\r\njson.pagination.position[1] = 3;\r\n```\r\nand to test for any non-empty elements\r\n```sh\r\n$ gron &lt;&lt;&lt; &quot;$json&quot; | grep -Evq &#39;(\\{\\}|\\[\\]|&quot;&quot;);$&#39; &amp;&amp; echo &quot;not everything is empty&quot;\r\nnot everything is empty\r\n```",
                "title": "Detect empty json values"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1664312846,
        "creation_date": 1664288994,
        "last_edit_date": 1664312846,
        "question_id": 73869332,
        "body_markdown": "I&#39;m trying to detect when I get all empty json values.\r\n\r\nHere are 2 examples of empty json values.\r\n\r\n    json=&#39;{\r\n      &quot;data&quot;: [],\r\n      &quot;pagination&quot;: {\r\n        &quot;cursor&quot;: &quot;&quot;\r\n      }\r\n    }&#39;\r\n\r\n    json=&#39;{\r\n        &quot;data&quot;: [],\r\n        &quot;error&quot;: &quot;&quot;,\r\n        &quot;message&quot;: &quot;&quot;,\r\n        &quot;status&quot;: &quot;&quot;\r\n    }&#39;\r\n\r\n\r\nThe closest I&#39;ve gotten is this, which seems to work for the first example, but not the 2nd.\r\n\r\n    echo &quot;$json&quot; | jq -e &#39;all( .[] ; . == &quot;&quot; or . == [] or . == {}  )&#39;\r\n\r\nOne, I thought easy way, would be to get the string text from each key pair, then just check if I&#39;m left with an empty string. But I haven&#39;t found a way that works in the pagination example.",
        "link": "https://stackoverflow.com/questions/73869332/detect-empty-json-values",
        "title": "Detect empty json values"
    },
    {
        "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": 1664294799,
                "post_id": 73870153,
                "comment_id": 130436667,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1664293939,
                "last_edit_date": 1664293939,
                "creation_date": 1664293001,
                "answer_id": 73870246,
                "question_id": 73870153,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Slightly more verbose way, without specifying the keys:\r\n```\r\n.dev |= with_entries(select(.value.dependencies | length &gt; 0) | .value = { dependencies: .value.dependencies})\r\n```\r\n\r\nUsing [`with_entires()`][1] to [`select()`][2] those where `.value.dependencies` has `length &gt; 0`, then [set (`|=`)][3] `value` to an object only containing the `dependencies`\r\n\r\n\r\n----------\r\n\r\n\r\nWill output:\r\n```json\r\n{\r\n  &quot;dev&quot;: {\r\n    &quot;Alpha&quot;: {\r\n      &quot;dependencies&quot;: [\r\n        &quot;Gamma&quot;,\r\n        &quot;Delta&quot;\r\n      ]\r\n    },\r\n    &quot;Gamma&quot;: {\r\n      &quot;dependencies&quot;: [\r\n        &quot;Delta&quot;\r\n      ]\r\n    }\r\n  }\r\n}\r\n```\r\n\r\n[Online demo](https://jqplay.org/s/vuHZSfv5eTx)\r\n\r\n\r\n  [1]: https://stedolan.github.io/jq/manual/#to_entries,from_entries,with_entries\r\n  [2]: https://stedolan.github.io/jq/manual/#select(boolean_expression)\r\n  [3]: https://stedolan.github.io/jq/manual/#Update-assignment:%7C=",
                "title": "Using jq to filter children and keep only specific key"
            },
            {
                "up_vote_count": 5,
                "is_accepted": true,
                "score": 5,
                "last_activity_date": 1664296874,
                "last_edit_date": 1664296874,
                "creation_date": 1664293041,
                "answer_id": 73870254,
                "question_id": 73870153,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s one way using the [Object construction](https://stedolan.github.io/jq/manual/#ObjectConstruction%3A%7B%7D) shortcut `{name}`:\r\n~~~sh\r\njq &#39;.dev |= ({Alpha, Gamma} | .[] |= {dependencies})&#39;\r\n~~~\r\n[Demo](https://jqplay.org/s/JzBjJhixUbM)\r\n\r\nIf the keys filtered should be dynamic, selecting on `has(0)` can test for the existence of a first array item, i.e. for a non-empty list:\r\n~~~sh\r\njq &#39;.dev[] |= ({dependencies} | select(.[] | has(0)))&#39;\r\n~~~\r\n[Demo](https://jqplay.org/s/co1nvl_cTc3)\r\n\r\nOutput:\r\n~~~json\r\n{\r\n  &quot;dev&quot;: {\r\n    &quot;Alpha&quot;: {\r\n      &quot;dependencies&quot;: [\r\n        &quot;Gamma&quot;,\r\n        &quot;Delta&quot;\r\n      ]\r\n    },\r\n    &quot;Gamma&quot;: {\r\n      &quot;dependencies&quot;: [\r\n        &quot;Delta&quot;\r\n      ]\r\n    }\r\n  }\r\n}\r\n~~~\r\n\r\n\r\n---\r\n\r\n",
                "title": "Using jq to filter children and keep only specific key"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1664462974,
                "creation_date": 1664462974,
                "answer_id": 73897580,
                "question_id": 73870153,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s another understandable solution, which constructs a new object from scratch:\r\n\r\n```\r\n{\r\n    dev: .dev | map_values({dependencies} | select(.[][0]))\r\n}\r\n```\r\n\r\nIt first builds an object containing only the dependencies per key and then selects only those with at least one item.\r\n\r\nOutput:\r\n\r\n```\r\n{\r\n  &quot;dev&quot;: {\r\n    &quot;Alpha&quot;: {\r\n      &quot;dependencies&quot;: [\r\n        &quot;Gamma&quot;,\r\n        &quot;Delta&quot;\r\n      ]\r\n    },\r\n    &quot;Gamma&quot;: {\r\n      &quot;dependencies&quot;: [\r\n        &quot;Delta&quot;\r\n      ]\r\n    }\r\n  }\r\n}\r\n```",
                "title": "Using jq to filter children and keep only specific key"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 0,
        "last_activity_date": 1664462974,
        "creation_date": 1664292629,
        "last_edit_date": 1664351511,
        "question_id": 73870153,
        "body_markdown": "I&#39;m trying to delete all entries that do not have any dependencies, but as I don&#39;t know jq very well, I&#39;m having a problem with finding the answer.\r\n\r\nI have:\r\n\r\n    {\r\n      &quot;dev&quot;: {\r\n        &quot;Alpha&quot;: {\r\n          &quot;dependencies&quot;: [\r\n            &quot;Gamma&quot;,\r\n            &quot;Delta&quot;\r\n          ],\r\n          &quot;other_value_1&quot;: [\r\n            &quot;aaa&quot;\r\n          ],\r\n          &quot;other_value_n&quot;: [\r\n            &quot;unknown number of other values&quot;\r\n          ]\r\n        },\r\n        &quot;Beta&quot;: {\r\n          &quot;package_name&quot;: &quot;some name&quot;,\r\n          &quot;scm&quot;: {\r\n            &quot;type&quot;: &quot;git&quot;,\r\n            &quot;url&quot;: &quot;git url&quot;\r\n          }\r\n        },\r\n        &quot;Gamma&quot;: {\r\n          &quot;dependencies&quot;: [\r\n            &quot;Delta&quot;\r\n          ]\r\n        },\r\n        &quot;Delta&quot;: {\r\n          &quot;dependencies&quot;: []\r\n        }\r\n      }\r\n    }\r\n\r\nOut of which I want to get only the names of objects with dependencies (in this example: Alpha, Gamma) and the dependencies themself:\r\n\r\n    {\r\n      &quot;dev&quot;: {\r\n        &quot;Alpha&quot;: {\r\n          &quot;dependencies&quot;: [\r\n            &quot;Gamma&quot;,\r\n            &quot;Delta&quot;\r\n          ]\r\n        },\r\n    \t&quot;Gamma&quot;: {\r\n          &quot;dependencies&quot;: [\r\n            &quot;Delta&quot;\r\n          ]\r\n        }\r\n      }\r\n    }\r\n\r\nLet&#39;s assume that there may be many unforeseen values besides dependencies",
        "link": "https://stackoverflow.com/questions/73870153/using-jq-to-filter-children-and-keep-only-specific-key",
        "title": "Using jq to filter children and keep only specific key"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1664316857,
                "creation_date": 1664316857,
                "answer_id": 73874284,
                "question_id": 73874066,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I figured it out, but if there&#39;s a better way let me know and I&#39;ll mark that as the accepted answer. \r\n\r\n```jq\r\ndef b($path):\r\n  [ $path[], &quot;(\\(.title?))&quot; ]\r\n  ;\r\ndef n($path):\r\n  ($path + [.text]) as $path\r\n  | $path, \r\n  if has (&quot;blocks&quot;) then .blocks.block?[]? | b($path) else empty end,\r\n  if has (&quot;children&quot;) then .children.node?[]? | n($path) else empty end\r\n  ;\r\n.sitemap.tree.node[] | n([])\r\n```",
                "title": "Recursive jq with multiple branches"
            },
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1664317866,
                "last_edit_date": 1664317866,
                "creation_date": 1664317564,
                "answer_id": 73874358,
                "question_id": 73874066,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s one way:\r\n~~~\r\ndef nodes:\r\n  .node[] | [.text] + (\r\n    [],\r\n    (.blocks.block[]? | [&quot;(\\(.title))&quot;]),\r\n    (.children | nodes?)\r\n  );\r\n\r\n[.sitemap.tree | nodes]\r\n~~~\r\n~~~json\r\n[\r\n  [&quot;Main&quot;],\r\n  [&quot;Main&quot;,&quot;(Header)&quot;],\r\n  [&quot;Main&quot;,&quot;(General)&quot;],\r\n  [&quot;Main&quot;,&quot;(Message)&quot;],\r\n  [&quot;Main&quot;,&quot;(Daily)&quot;],\r\n  [&quot;Main&quot;,&quot;(Recognition)&quot;],\r\n  [&quot;Main&quot;,&quot;(Policies)&quot;],\r\n  [&quot;Main&quot;,&quot;Hub&quot;],\r\n  [&quot;Main&quot;,&quot;Hub&quot;,&quot;Handbook&quot;],\r\n  [&quot;Main&quot;,&quot;Hub&quot;,&quot;Jobs&quot;],\r\n  [&quot;Main&quot;,&quot;Hub&quot;,&quot;Perks&quot;],\r\n  [&quot;Main&quot;,&quot;Hub&quot;,&quot;Benefits&quot;],\r\n  [&quot;Main&quot;,&quot;Resources&quot;],\r\n  [&quot;Main&quot;,&quot;Resources&quot;,&quot;Forms&quot;],\r\n  [&quot;Main&quot;,&quot;Resources&quot;,&quot;Procedures&quot;],\r\n  [&quot;Main&quot;,&quot;Resources&quot;,&quot;Training&quot;],\r\n  [&quot;Main&quot;,&quot;Resources&quot;,&quot;Scripts&quot;],\r\n  [&quot;Main&quot;,&quot;Resources&quot;,&quot;Marketing&quot;],\r\n  [&quot;Main&quot;,&quot;Resources&quot;,&quot;Marketing&quot;,&quot;Logos&quot;],\r\n  [&quot;Main&quot;,&quot;Resources&quot;,&quot;Marketing&quot;,&quot;Brochures&quot;],\r\n  [&quot;Main&quot;,&quot;Resources&quot;,&quot;Marketing&quot;,&quot;Signage&quot;],\r\n  [&quot;Main&quot;,&quot;Resources&quot;,&quot;Tips &amp; Tricks&quot;],\r\n  [&quot;Main&quot;,&quot;About&quot;],\r\n  [&quot;Main&quot;,&quot;About&quot;,&quot;Strategy&quot;],\r\n  [&quot;Search&quot;],\r\n  [&quot;Logins&quot;],\r\n  [&quot;Logins&quot;,&quot;One&quot;],\r\n  [&quot;Logins&quot;,&quot;Two&quot;]\r\n]\r\n~~~\r\n[Demo](https://jqplay.org/s/0AdB9MX5qGV)",
                "title": "Recursive jq with multiple branches"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1664317866,
        "creation_date": 1664314754,
        "question_id": 73874066,
        "body_markdown": "\r\nI&#39;m stuck. How do I use `jq` to transform the following json:\r\n\r\n```json\r\n{\r\n  &quot;sitemap&quot;: {\r\n    &quot;tree&quot;: {\r\n      &quot;node&quot;: [\r\n        {\r\n          &quot;text&quot;: &quot;Main&quot;,\r\n          &quot;blocks&quot;: {\r\n            &quot;block&quot;: [\r\n              {\r\n                &quot;title&quot;: &quot;Header&quot;\r\n              },\r\n              {\r\n                &quot;title&quot;: &quot;General&quot;\r\n              },\r\n              {\r\n                &quot;title&quot;: &quot;Message&quot;\r\n              },\r\n              {\r\n                &quot;title&quot;: &quot;Daily&quot;\r\n              },\r\n              {\r\n                &quot;title&quot;: &quot;Recognition&quot;\r\n              },\r\n              {\r\n                &quot;title&quot;: &quot;Policies&quot;\r\n              },\r\n            ]\r\n          },\r\n          &quot;children&quot;: {\r\n            &quot;node&quot;: [\r\n              {\r\n                &quot;text&quot;: &quot;Hub&quot;,\r\n                &quot;blocks&quot;: null,\r\n                &quot;children&quot;: {\r\n                  &quot;node&quot;: [\r\n                    {\r\n                      &quot;text&quot;: &quot;Handbook&quot;,\r\n                      &quot;blocks&quot;: null,\r\n                      &quot;children&quot;: null\r\n                    },\r\n                    {\r\n                      &quot;text&quot;: &quot;Jobs&quot;,\r\n                      &quot;blocks&quot;: null,\r\n                      &quot;children&quot;: null\r\n                    },\r\n                    {\r\n                      &quot;text&quot;: &quot;Perks&quot;,\r\n                      &quot;blocks&quot;: null,\r\n                      &quot;children&quot;: null\r\n                    },\r\n                    {\r\n                      &quot;text&quot;: &quot;Benefits&quot;,\r\n                      &quot;blocks&quot;: null,\r\n                      &quot;children&quot;: null\r\n                    }\r\n                  ]\r\n                }\r\n              },\r\n              {\r\n                &quot;text&quot;: &quot;Resources&quot;,\r\n                &quot;blocks&quot;: null,\r\n                &quot;children&quot;: {\r\n                  &quot;node&quot;: [\r\n                    {\r\n                      &quot;text&quot;: &quot;Forms&quot;,\r\n                      &quot;blocks&quot;: null,\r\n                      &quot;children&quot;: null\r\n                    },\r\n                    {\r\n                      &quot;text&quot;: &quot;Procedures&quot;,\r\n                      &quot;blocks&quot;: null,\r\n                      &quot;children&quot;: null\r\n                    },\r\n                    {\r\n                      &quot;text&quot;: &quot;Training&quot;,\r\n                      &quot;blocks&quot;: null,\r\n                      &quot;children&quot;: null\r\n                    },\r\n                    {\r\n                      &quot;text&quot;: &quot;Scripts&quot;,\r\n                      &quot;blocks&quot;: null,\r\n                      &quot;children&quot;: null\r\n                    },\r\n                    {\r\n                      &quot;text&quot;: &quot;Marketing&quot;,\r\n                      &quot;blocks&quot;: null,\r\n                      &quot;children&quot;: {\r\n                        &quot;node&quot;: [\r\n                          {\r\n                            &quot;text&quot;: &quot;Logos&quot;,\r\n                            &quot;blocks&quot;: null,\r\n                            &quot;children&quot;: null\r\n                          },\r\n                          {\r\n                            &quot;text&quot;: &quot;Brochures&quot;,\r\n                            &quot;blocks&quot;: null,\r\n                            &quot;children&quot;: null\r\n                          },\r\n                          {\r\n                            &quot;text&quot;: &quot;Signage&quot;,\r\n                            &quot;blocks&quot;: null,\r\n                            &quot;children&quot;: null\r\n                          }\r\n                        ]\r\n                      }\r\n                    },\r\n                    {\r\n                      &quot;text&quot;: &quot;Tips &amp; Tricks&quot;,\r\n                      &quot;blocks&quot;: null,\r\n                      &quot;children&quot;: null\r\n                    }\r\n                  ]\r\n                }\r\n              },\r\n              {\r\n                &quot;text&quot;: &quot;About&quot;,\r\n                &quot;blocks&quot;: null,\r\n                &quot;children&quot;: {\r\n                  &quot;node&quot;: [\r\n                    {\r\n                      &quot;text&quot;: &quot;Strategy&quot;,\r\n                      &quot;blocks&quot;: null,\r\n                      &quot;children&quot;: null\r\n                    }\r\n                  ]\r\n                }\r\n              }\r\n            ]\r\n          }\r\n        },\r\n        {\r\n          &quot;text&quot;: &quot;Search&quot;,\r\n          &quot;blocks&quot;: null,\r\n          &quot;children&quot;: null\r\n        },\r\n        {\r\n          &quot;text&quot;: &quot;Logins&quot;,\r\n          &quot;blocks&quot;: null,\r\n          &quot;children&quot;: {\r\n            &quot;node&quot;: [\r\n              {\r\n                &quot;text&quot;: &quot;One&quot;,\r\n                &quot;blocks&quot;: null,\r\n                &quot;children&quot;: null\r\n              },\r\n              {\r\n                &quot;text&quot;: &quot;Two&quot;,\r\n                &quot;blocks&quot;: null,\r\n                &quot;children&quot;: null\r\n              }\r\n            ]\r\n          }\r\n        }\r\n      ]\r\n    }\r\n  }\r\n}\r\n```\r\n\r\ninto a list of all pages – and with &quot;blocks&quot; contained in parenthesis.\r\n\r\n```json\r\n[\r\n   [ &quot;Main&quot; ],\r\n   [ &quot;Main&quot;, &quot;(Header)&quot; ],\r\n   [ &quot;Main&quot;, &quot;(General)&quot; ],\r\n   [ &quot;Main&quot;, &quot;(Message)&quot; ],\r\n   [ &quot;Main&quot;, &quot;(Daily)&quot; ],\r\n   [ &quot;Main&quot;, &quot;(Recognition)&quot; ],\r\n   [ &quot;Main&quot;, &quot;(Policies)&quot; ],\r\n   [ &quot;Main&quot;, &quot;Hub&quot; ],\r\n   [ &quot;Main&quot;, &quot;Hub&quot;, &quot;Handbook&quot; ],\r\n   [ &quot;Main&quot;, &quot;Hub&quot;, &quot;Jobs&quot; ],\r\n   [ &quot;Main&quot;, &quot;Hub&quot;, &quot;Perks&quot; ],\r\n   [ &quot;Main&quot;, &quot;Hub&quot;, &quot;Benefits&quot; ],\r\n   [ &quot;Main&quot;, &quot;Resources&quot; ],\r\n   [ &quot;Main&quot;, &quot;Resources&quot;, &quot;Forms&quot; ],\r\n   [ &quot;Main&quot;, &quot;Resources&quot;, &quot;Procedures&quot; ],\r\n   [ &quot;Main&quot;, &quot;Resources&quot;, &quot;Training&quot; ],\r\n   [ &quot;Main&quot;, &quot;Resources&quot;, &quot;Scripts&quot; ],\r\n   [ &quot;Main&quot;, &quot;Resources&quot;, &quot;Marketing&quot; ],\r\n   [ &quot;Main&quot;, &quot;Resources&quot;, &quot;Marketing&quot;, &quot;Logos&quot; ],\r\n   [ &quot;Main&quot;, &quot;Resources&quot;, &quot;Marketing&quot;, &quot;Brochures&quot; ],\r\n   [ &quot;Main&quot;, &quot;Resources&quot;, &quot;Marketing&quot;, &quot;Signage&quot; ],\r\n   [ &quot;Main&quot;, &quot;Resources&quot;, &quot;Tips &amp; Tricks&quot; ],\r\n   [ &quot;Main&quot;, &quot;About&quot; ],\r\n   [ &quot;Main&quot;, &quot;About&quot;, &quot;Strategy&quot; ],\r\n   [ &quot;Search&quot; ],\r\n   [ &quot;Logins&quot; ],\r\n   [ &quot;Logins&quot;, &quot;One&quot; ],\r\n   [ &quot;Logins&quot;, &quot;Two&quot; ]\r\n]\r\n```",
        "link": "https://stackoverflow.com/questions/73874066/recursive-jq-with-multiple-branches",
        "title": "Recursive jq with multiple branches"
    }
]